|
|
C6747和C6748感觉差不多,我想实现McASP发送中断方式控制音频信号,在轮询的例程基础上改的,轮询程序可以实现,但是中断一直实现不了,也找不到错误,求大神帮忙!下边是主要程序:
+ ~7 ]+ C+ a- X: P3 \! x# }main文件:
' ~8 W: p6 v; B0 E1 ninterrupt void interrupt4(void)
5 z$ y% J: d; e( d7 B{; ]7 }# n7 e0 N8 {" I
Uint32 sample;6 [" @: J4 e1 J! z1 `6 \* W
; H! C$ w4 s6 i: J4 h* x- O sample = input_sample(); // read L + R samples from ADC
m7 W6 S6 x% k" s) _ output_sample(sample); // write L + R samples to DAC
`1 z' m+ e$ D& ?8 m return;
: g; c" i; w; G) K}
/ G1 J) ^/ m4 ^ G, k, c$ w# [! y7 i+ c v `/ C% P4 Y
int main( void )
* ^% I, |/ `, n{: z. w6 c3 Q. ]' M: r
4 @1 X( K, n) x /* Initialize BSL */+ Y. P. e% v1 }4 B% D
EVMC6747_init( );0 F: [& o% D! @& V4 Z! U& U' y
/* Call evmc6747_intr function */- l9 R3 d7 _- v0 G/ @
aic3106_init( );- Q4 E& w8 k+ }# {5 P5 g$ O
while(1);
0 } ~1 Q0 d4 h+ O}+ U% e: H, L$ s1 e
4 d' e# E3 r9 d M& ? k; R( x8 n9 T: T9 N
aic3106_init文件的一部分,McASP配置部分,采用内部时钟,I2S方式,同步传输。音频芯片的配置应该没问题6 Q5 r! |, _0 ^1 B9 ~: Z
/* Initialize MCASP1 */2 x% E) @% Q' c( @0 o
mcasp = &MCASP_MODULE_1;
, P- I! {1 X# P# B7 K! z/ E0 }! J mcasp->regs->GBLCTL = 0; // Reset
8 b# g6 W! y) q. Y: a mcasp->regs->RGBLCTL = 0; // Reset RX* W) J8 ?0 R u2 Z7 s& f) D$ H3 K4 ^- a
mcasp->regs->XGBLCTL = 0; // Reset TX0 l2 [8 a8 j( y: m. R, |
mcasp->regs->PWRDEMU = 1; // Free-running( C& u% R+ a1 _* O, m$ {& X
// configure McASP0 receive registers" f$ |( T' n0 _2 R& J& C7 Y' O
mcasp->regs->RMASK = 0xFFFFFFFF; // No padding used. X1 X# o0 N! _8 H! s6 _! A( A" B
mcasp->regs->RFMT = 0x00018078; // MSB 16bit, 0-delay, no pad, CFGBus! I/ N; \2 B# X2 g6 d5 s: I) f3 P
mcasp->regs->AFSRCTL = 0x00000112; // 2TDM, 1bit Falling, External FS, word
9 i( R b7 X' V0 j mcasp->regs->ACLKRCTL = 0x000000AF; // Rising INTERNAL CLK,(from tx side)
+ q/ P$ B# M' z2 ?$ M/ \+ E mcasp->regs->AHCLKRCTL = 0x00000000; // INT CLK (from tx side)' V; S/ A: ^$ }4 w! j
mcasp->regs->RTDM = 0x00000003; // Slots 0,1% g) J7 ]" a' z7 m' _$ i
mcasp->regs->RINTCTL = 0x00000000; // Not used
5 [; S9 m" _9 l( X! { Z8 Q mcasp->regs->RCLKCHK = 0x00FF0008; // 255-MAX 0-MIN, div-by-256" T+ E7 N f6 q- E6 c
3 q: f( S$ _8 ^4 Q
mcasp->regs->XMASK = 0xFFFFFFFF; // No padding used" Q, h4 ]! Y/ Y$ e4 S2 ?* T
mcasp->regs->XFMT = 0x00018078; // MSB 16bit, 0-delay, no pad, CFGBus8 h' i x& F$ a3 D/ [! z
mcasp->regs->AFSXCTL = 0x00000112; // 2TDM, 1bit Rising edge INTERNAL FS, word
0 ~; Q/ F1 G7 S0 W' c mcasp->regs->ACLKXCTL = 0x000000AF; // ASYNC, Rising INTERNAL CLK, div-by-16, Y3 v' L0 ^7 L& i7 B
mcasp->regs->AHCLKXCTL = 0x00000000; // EXT CLK
6 \- Y7 |3 p E. X mcasp->regs->XTDM = 0x00000003; // Slots 0,1
& }3 z- B9 g) n4 y! b# s mcasp->regs->XINTCTL = 0x00000020; // interrupt on transmit
3 D. U0 a! F# M ^: S3 W0 c mcasp->regs->XCLKCHK = 0x00FF0008; // 255-MAX 0-MIN, div-by-256) S# L f4 E$ U2 X8 F, F
) ?+ h" i3 p8 q
mcasp->regs->SRCTL5 = 0x000D; // MCASP1.AXR1[5] --> DIN
) f# E g6 U- U) g& f mcasp->regs->SRCTL0 = 0x000E; // MCASP1.AXR1[0] <-- DOUT/ @5 u* ]& k( y1 X
mcasp->regs->PFUNC = 0; // All MCASPs
+ O. x1 F' w$ S5 ? mcasp->regs->PDIR = 0x14000020; // All inputs except AXR0[5], ACLKX1, AFSX1
/ w9 [. ^. U; R7 G0 C; {. m2 x9 T9 ?( w. ?: G! X: u/ Z* M& ]
mcasp->regs->DITCTL = 0x00000000; // Not used+ @' U1 o& _9 `, j1 g
mcasp->regs->DLBCTL = 0x00000000; // Not used6 y) W' d* Z( v, p& ^
mcasp->regs->AMUTE = 0x00000000; // Not used
* _# L$ c) L6 w( e4 a: U8 g: a
$ {: q8 b% I* J/ F- r/* Starting sections of the McASP*/
* L3 h" Y$ B( ?9 a- m6 r" s3 j9 k mcasp->regs->XGBLCTL |= GBLCTL_XHCLKRST_ON;
. B0 ~& k% e& s$ ~! @4 ? while ( ( mcasp->regs->XGBLCTL & GBLCTL_XHCLKRST_ON ) != GBLCTL_XHCLKRST_ON ); $ R+ P. K6 n5 G. G6 S
mcasp->regs->RGBLCTL |= GBLCTL_RHCLKRST_ON; 0 ~2 R1 E: ~7 @3 u1 p" @' |2 D
while ( ( mcasp->regs->RGBLCTL & GBLCTL_RHCLKRST_ON ) != GBLCTL_RHCLKRST_ON );/ X8 I- q) q$ Z3 U
, H5 j4 \6 W$ M$ ` mcasp->regs->XGBLCTL |= GBLCTL_XCLKRST_ON; 0 W. c7 E/ @: R. Q$ E" M
while ( ( mcasp->regs->XGBLCTL & GBLCTL_XCLKRST_ON ) != GBLCTL_XCLKRST_ON );7 k! N: H7 o3 X# T0 B U
mcasp->regs->RGBLCTL |= GBLCTL_RCLKRST_ON;
- R- Z- N' N6 q9 _9 G0 y; b8 R while ( ( mcasp->regs->RGBLCTL & GBLCTL_RCLKRST_ON ) != GBLCTL_RCLKRST_ON );
4 G7 J! g' L8 \* b" R2 N; ]) n3 c7 C* [1 C
mcasp->regs->XSTAT = 0x0000ffff; / r* c4 [2 Y6 ^% y) b3 |: d
mcasp->regs->RSTAT = 0x0000ffff;
3 p' P* M& e) Y* }$ c# z6 A, ~( r; X. b
mcasp->regs->XGBLCTL |= GBLCTL_XSRCLR_ON;+ j" v8 n4 X0 [, a, h* i. X
while ( ( mcasp->regs->XGBLCTL & GBLCTL_XSRCLR_ON ) != GBLCTL_XSRCLR_ON );* [( d8 t- I5 c; C3 L% Z
mcasp->regs->RGBLCTL |= GBLCTL_RSRCLR_ON;
% L$ J5 {/ g( f" F2 K: E% r while ( ( mcasp->regs->RGBLCTL & GBLCTL_RSRCLR_ON ) != GBLCTL_RSRCLR_ON );
8 G2 i4 e7 V1 k6 T' J# c/ ?2 m. I3 u- W( W1 l3 v& L0 G
/* Write a 0, so that no underrun occurs after releasing the state machine */& V' d; h$ _0 E( i' T5 I2 d
mcasp->regs->XBUF5 = 0;$ Q l) d$ v- f+ w5 G
mcasp->regs->RBUF0 = 0;1 p k4 G1 Y1 S& S
' y4 L% G$ t- j; m) Y8 ]" B5 B2 z' @ mcasp->regs->XGBLCTL |= GBLCTL_XSMRST_ON; ( c' |! j( h% z; ~ C( L! W
while ( ( mcasp->regs->XGBLCTL & GBLCTL_XSMRST_ON ) != GBLCTL_XSMRST_ON );6 l7 e4 a& k7 r0 Z; y
mcasp->regs->RGBLCTL |= GBLCTL_RSMRST_ON; # j& o1 L- [3 f, z1 _0 \
while ( ( mcasp->regs->RGBLCTL & GBLCTL_RSMRST_ON ) != GBLCTL_RSMRST_ON );# q( w; r% c5 U4 _3 w
0 D& }1 E3 b/ ?" o+ [! B4 k
mcasp->regs->XGBLCTL |= GBLCTL_XFRST_ON;
" ?9 ]7 o" c- a+ a while ( ( mcasp->regs->XGBLCTL & GBLCTL_XFRST_ON ) != GBLCTL_XFRST_ON );
0 J4 Z& o3 c( E7 C6 Z! @" q mcasp->regs->RGBLCTL |= GBLCTL_RFRST_ON; 0 s) K% f6 R# I) O3 |/ @2 M
while ( ( mcasp->regs->RGBLCTL & GBLCTL_RFRST_ON ) != GBLCTL_RFRST_ON );
: [1 O0 b" j# C1 X+ C2 b
9 o& E Y. J8 [3 D- T, x& x+ d CSR = 0x0000;' V9 A$ q; O- e- I
INTC_INTMUX1 = 0x3d;
7 E7 E6 b# u& H2 }6 s. \1 g ISTP = (unsigned int)vectors;2 J3 x6 }+ d4 e q
ICR = 0xFFF0; 2 g% s" ]. T) ?# z7 Y/ R/ O% N
IER |= 0x12; . _ G" p; I! f) `& r2 Z
CSR |= 0x01;
+ G9 n) ?5 m) T/ \
+ T: n2 X2 I. |8 _: I. `% T [3 M, J5 m! W6 o5 G! }
1 Y( k& d, o% D; G2 g还有就是两个输入输出函数:
6 X; Y. P& y/ w/ H& J Ivoid output_sample(Int32 out_data)
8 O' i, X2 [) b9 L) H9 ]{
, V2 a0 N2 [, }9 I8 J AIC31_data.uint = out_data; 4 ~ a2 g% W7 x& J2 I8 R' Y1 D
MCASP1_XBUF5_32BIT = AIC31_data.uint;
2 K* `" a& i- [8 `/ a+ J}
, p$ M( b1 Y" H: ]) H# A& E3 ^* w2 Q& y( d
Int32 input_sample(void)! g& p j* I5 j6 @+ a' M+ R+ y: l
{ / Y2 t4 K& K% n2 H7 U- U
AIC31_data.uint = MCASP1_RBUF0_32BIT;( u' y) k) M. m6 Y
return (AIC31_data.uint);
% f* ? G% m$ n% D5 k& |% D}) O$ _) c1 z! i. }5 u/ D8 f, r" P
% {" P5 ^" Q' F$ d, N) ^+ s% h- X+ b |
|