|
|
C6747和C6748感觉差不多,我想实现McASP发送中断方式控制音频信号,在轮询的例程基础上改的,轮询程序可以实现,但是中断一直实现不了,也找不到错误,求大神帮忙!下边是主要程序:
6 ]8 t( A9 U9 F/ o3 h0 imain文件:
0 l8 ]3 f9 l* P7 rinterrupt void interrupt4(void) / _# C! L) R; w5 z6 T
{8 A2 E7 }) Y e% W6 U9 S! I
Uint32 sample;
0 ^- M0 o( H% V Q# F+ t% F' |$ v% x4 I y, `" O
sample = input_sample(); // read L + R samples from ADC
) e" r9 }2 M* {5 L$ B2 v output_sample(sample); // write L + R samples to DAC
6 b0 y' Q: E5 R# r' U, A5 V; ~# v return;; T: J) j- A( o& i: ~
}3 o. N' n2 }4 w% V
Q6 T" U4 D2 M5 U5 j* e2 K) V5 L
int main( void )
% b+ W1 ^2 N/ X; T1 c2 c( X{
3 y5 Z1 D3 B, k; R
' `# B( u( y7 [3 H2 X' ` /* Initialize BSL */9 }) `! Z$ _ q7 N
EVMC6747_init( );
1 a/ G$ d9 E- i' \ /* Call evmc6747_intr function */
( S$ @/ _" v" A aic3106_init( );4 m) Z1 A$ r, B* a6 g
while(1);9 d$ t$ G/ U0 V3 I( I8 c
}
4 t% `8 g& B* ~" K" _( N- s
$ E0 J6 t; ?1 _# K
7 k! h4 F7 r8 o. Vaic3106_init文件的一部分,McASP配置部分,采用内部时钟,I2S方式,同步传输。音频芯片的配置应该没问题* A) q( D% ]* X/ r/ d l
/* Initialize MCASP1 */
9 |6 m: A8 |7 J1 Q' D mcasp = &MCASP_MODULE_1;
) s: P, `8 r+ W% D* ]# V! @ mcasp->regs->GBLCTL = 0; // Reset
2 |" U& }% ]- ~% N, x mcasp->regs->RGBLCTL = 0; // Reset RX3 @( `# B3 @0 O1 Y
mcasp->regs->XGBLCTL = 0; // Reset TX
; @/ s$ n; l% R4 K mcasp->regs->PWRDEMU = 1; // Free-running8 R c/ j5 p5 ~* ]0 p( ~
// configure McASP0 receive registers
! k( C; M5 D- P1 g( H mcasp->regs->RMASK = 0xFFFFFFFF; // No padding used
' q) k* M, k6 l- n mcasp->regs->RFMT = 0x00018078; // MSB 16bit, 0-delay, no pad, CFGBus) @& B2 t# r; f% P, | m+ B
mcasp->regs->AFSRCTL = 0x00000112; // 2TDM, 1bit Falling, External FS, word
& K% w9 n( _/ m0 g" L+ s: V mcasp->regs->ACLKRCTL = 0x000000AF; // Rising INTERNAL CLK,(from tx side)
3 R' @% B. T4 ^" f" ^8 K9 F1 j mcasp->regs->AHCLKRCTL = 0x00000000; // INT CLK (from tx side)
$ d" u0 t) P& ]4 ?( Y: b( K mcasp->regs->RTDM = 0x00000003; // Slots 0,16 C6 @% u* i( J2 k$ d( G
mcasp->regs->RINTCTL = 0x00000000; // Not used
# g* g0 B8 c/ O mcasp->regs->RCLKCHK = 0x00FF0008; // 255-MAX 0-MIN, div-by-2561 E/ f2 ?3 U$ k+ T( G
9 u8 G( \( l' X) H, S1 k4 ^ mcasp->regs->XMASK = 0xFFFFFFFF; // No padding used
7 E1 D9 o+ B1 S$ r mcasp->regs->XFMT = 0x00018078; // MSB 16bit, 0-delay, no pad, CFGBus( z% m% `/ p7 e
mcasp->regs->AFSXCTL = 0x00000112; // 2TDM, 1bit Rising edge INTERNAL FS, word
1 H$ }' G, {& u( R mcasp->regs->ACLKXCTL = 0x000000AF; // ASYNC, Rising INTERNAL CLK, div-by-16! W9 ^0 u5 f0 G$ T: c6 ]
mcasp->regs->AHCLKXCTL = 0x00000000; // EXT CLK2 E) @" Y8 f: f4 s& ?
mcasp->regs->XTDM = 0x00000003; // Slots 0,1- |3 w+ M* M5 w; G) O. t) }
mcasp->regs->XINTCTL = 0x00000020; // interrupt on transmit, {& _0 U! L" H2 |3 U- f5 T* w
mcasp->regs->XCLKCHK = 0x00FF0008; // 255-MAX 0-MIN, div-by-256
2 W: V( t4 {7 s* k0 {3 i4 g, x% g3 H R+ X* Z
mcasp->regs->SRCTL5 = 0x000D; // MCASP1.AXR1[5] --> DIN
4 o- S S0 t8 W' e/ O! d" c7 Q1 { mcasp->regs->SRCTL0 = 0x000E; // MCASP1.AXR1[0] <-- DOUT
9 w U# p# I: W0 Y9 ] mcasp->regs->PFUNC = 0; // All MCASPs/ h5 u- T2 |* ?- y/ v! s
mcasp->regs->PDIR = 0x14000020; // All inputs except AXR0[5], ACLKX1, AFSX1
1 m" [- _2 s6 ~$ j, H# S S
- `. y! _* o6 @7 Q' I# } mcasp->regs->DITCTL = 0x00000000; // Not used6 h! M$ T, r( w" o7 @7 h
mcasp->regs->DLBCTL = 0x00000000; // Not used2 i+ C+ W1 W! c T
mcasp->regs->AMUTE = 0x00000000; // Not used$ [: i, {( _2 A. S9 ?' u2 |
% |6 X6 W, |1 V h% t
/* Starting sections of the McASP*/
) ]( v6 n1 n8 m: w! Q mcasp->regs->XGBLCTL |= GBLCTL_XHCLKRST_ON; ( j% x& c% @0 Q L( n9 C( ~0 W
while ( ( mcasp->regs->XGBLCTL & GBLCTL_XHCLKRST_ON ) != GBLCTL_XHCLKRST_ON ); 1 ?5 l3 n: Z, V* x
mcasp->regs->RGBLCTL |= GBLCTL_RHCLKRST_ON; / u( a: \5 O! N. U9 }; B
while ( ( mcasp->regs->RGBLCTL & GBLCTL_RHCLKRST_ON ) != GBLCTL_RHCLKRST_ON );
+ g+ j& f# U" U% w b" W9 ~9 [: g- E. C7 m' P0 _
mcasp->regs->XGBLCTL |= GBLCTL_XCLKRST_ON;
% s8 |) W$ { A" c- U! [ while ( ( mcasp->regs->XGBLCTL & GBLCTL_XCLKRST_ON ) != GBLCTL_XCLKRST_ON );, F5 b" p) r5 j9 L' x' T, q$ ]
mcasp->regs->RGBLCTL |= GBLCTL_RCLKRST_ON;
" |' m( \ x) |. T4 G$ `* w while ( ( mcasp->regs->RGBLCTL & GBLCTL_RCLKRST_ON ) != GBLCTL_RCLKRST_ON );; U: F2 t! c; |( Q) [- k
$ v9 B# E I G7 D! v
mcasp->regs->XSTAT = 0x0000ffff; . P* N5 q- A: G
mcasp->regs->RSTAT = 0x0000ffff; , P7 F/ d( Q9 o% f K
- o% Z0 E# z4 ^- M mcasp->regs->XGBLCTL |= GBLCTL_XSRCLR_ON;% u" c3 I' O( t* C/ ?) H
while ( ( mcasp->regs->XGBLCTL & GBLCTL_XSRCLR_ON ) != GBLCTL_XSRCLR_ON );
. N$ S3 C1 ^; A: T! {) D! ` mcasp->regs->RGBLCTL |= GBLCTL_RSRCLR_ON; 4 j! `& T. S6 G8 o
while ( ( mcasp->regs->RGBLCTL & GBLCTL_RSRCLR_ON ) != GBLCTL_RSRCLR_ON );+ {2 b; I+ q+ X7 m
$ s2 d, p1 A& r5 D( E5 z: N /* Write a 0, so that no underrun occurs after releasing the state machine */
7 ~6 Z. [& m# b+ {8 _ mcasp->regs->XBUF5 = 0;
/ ~! f. L/ S' C2 u8 J mcasp->regs->RBUF0 = 0;
! _1 Q. d& a8 x" Q& h5 q2 e7 M+ _5 ]7 s, l$ {/ G6 T2 f L
mcasp->regs->XGBLCTL |= GBLCTL_XSMRST_ON; 8 V* F5 O7 \1 Y- _$ R, y8 u8 \
while ( ( mcasp->regs->XGBLCTL & GBLCTL_XSMRST_ON ) != GBLCTL_XSMRST_ON );
% G5 B' v, F) T8 I mcasp->regs->RGBLCTL |= GBLCTL_RSMRST_ON; 0 ~0 w5 U4 g4 P9 K. ~( v7 a
while ( ( mcasp->regs->RGBLCTL & GBLCTL_RSMRST_ON ) != GBLCTL_RSMRST_ON );
. o% m" }4 q0 J7 P
8 ] H0 A% x, R; ?, X1 w2 X5 N0 s mcasp->regs->XGBLCTL |= GBLCTL_XFRST_ON; / j) q3 T8 X, D, x3 |+ m
while ( ( mcasp->regs->XGBLCTL & GBLCTL_XFRST_ON ) != GBLCTL_XFRST_ON );
7 e. h4 o+ P1 t& S mcasp->regs->RGBLCTL |= GBLCTL_RFRST_ON;
5 X. [: |- e( X: @* H/ R while ( ( mcasp->regs->RGBLCTL & GBLCTL_RFRST_ON ) != GBLCTL_RFRST_ON );
7 r) x% l0 N/ f6 `
3 f: l) p- J7 r, J6 Q) o) B8 P CSR = 0x0000;! }7 [0 \/ ?4 X8 W8 v, G2 k
INTC_INTMUX1 = 0x3d;8 L* t( {8 b3 @0 F% A7 A( K
ISTP = (unsigned int)vectors;
# ]* {+ C+ I8 O( S( Y/ c ICR = 0xFFF0; ' s' L1 C, G% E: _# d& j4 S8 ]- i
IER |= 0x12;
% N+ d7 U' w, B4 x2 \+ l CSR |= 0x01;
7 Y) Z1 e$ H. [& b
8 Y# U3 F8 L: X0 K9 U2 Y- C8 T% Y% x/ b7 r* k2 ^
3 U6 K g. F! Z2 i0 A: J8 O
还有就是两个输入输出函数:
5 Q/ d4 m! k3 W) ]7 T9 H- tvoid output_sample(Int32 out_data)& f( J/ f+ u' u0 k4 O: i
{$ D6 \9 v% w: N& U% \$ ^
AIC31_data.uint = out_data; ) w6 ]. k( u$ t! |" i- |( [6 o
MCASP1_XBUF5_32BIT = AIC31_data.uint;
+ @, v! \$ ?/ a3 r# ~} J Z+ f2 R( d- H5 m7 t
7 V% y) e5 [+ kInt32 input_sample(void)- [" _, L7 o4 N9 b
{ ' [9 y% x+ n; u7 ` g5 q
AIC31_data.uint = MCASP1_RBUF0_32BIT;
5 h2 x% l) o( A return (AIC31_data.uint);
: q m, T: A7 Y _}
& t6 x+ u1 ?; N4 T: L! L. u5 S* N5 l( t( K1 u
|
|