|
|
C6747和C6748感觉差不多,我想实现McASP发送中断方式控制音频信号,在轮询的例程基础上改的,轮询程序可以实现,但是中断一直实现不了,也找不到错误,求大神帮忙!下边是主要程序:0 F" Q( o! j* N
main文件:9 z' J1 F* c) r) `
interrupt void interrupt4(void)
" j% r( `# z2 a$ m% P{
% w+ T _1 g+ p r% Q0 C t Uint32 sample;
5 }- _% T2 J5 K0 `# U/ \
& m# Z- f+ [- ~' T+ S8 j: k% ]3 Q: A sample = input_sample(); // read L + R samples from ADC
. f5 M( H" O ~/ A output_sample(sample); // write L + R samples to DAC
% j+ Q0 V. d X2 t return;
" }! `3 }/ ^5 @ }}
* s7 K! d8 p* {: s+ G5 B0 d& E* @
" a, I/ @. |) R2 C2 _int main( void )
9 c) X. G2 J. V2 P2 a9 D3 W3 _{
' m- z0 H, u: w f; I5 J0 s* n
5 q4 r4 `8 G7 }+ V2 R /* Initialize BSL */6 n5 k( U+ |) W6 t6 j* u# r6 m
EVMC6747_init( );
+ g+ ~6 i2 Y% q /* Call evmc6747_intr function */
8 ?1 h# g/ A6 f' U6 p aic3106_init( );, h' C3 F/ f+ m q: m
while(1);* Z7 r$ r( z8 o
}
0 u7 Q+ S. _7 {& s7 \
$ F4 a+ f6 D5 ]0 g% Y% r" Z; W' S, O1 Z
aic3106_init文件的一部分,McASP配置部分,采用内部时钟,I2S方式,同步传输。音频芯片的配置应该没问题5 }6 Y6 B4 w( q! l
/* Initialize MCASP1 *// ^9 ]( V4 Z c. b; v/ D' o
mcasp = &MCASP_MODULE_1;
6 e, R- x5 j2 q# H# Y: C3 D0 n" \ mcasp->regs->GBLCTL = 0; // Reset
. {# c% \9 ?( { mcasp->regs->RGBLCTL = 0; // Reset RX- E3 t) g* M$ P% ]
mcasp->regs->XGBLCTL = 0; // Reset TX
b+ u; j! t5 P. f/ K mcasp->regs->PWRDEMU = 1; // Free-running
( ~0 l8 E0 E1 x W // configure McASP0 receive registers
( Y3 C0 V. {- T" f/ M6 ~! m0 C mcasp->regs->RMASK = 0xFFFFFFFF; // No padding used! K2 R8 O: }3 B2 p
mcasp->regs->RFMT = 0x00018078; // MSB 16bit, 0-delay, no pad, CFGBus& d1 ^% N/ a+ _; U. O2 u1 r5 `
mcasp->regs->AFSRCTL = 0x00000112; // 2TDM, 1bit Falling, External FS, word* t7 o9 j5 Y, f; R+ D, r- o7 D5 z w1 \
mcasp->regs->ACLKRCTL = 0x000000AF; // Rising INTERNAL CLK,(from tx side)5 {' g0 W- [3 @/ n! u
mcasp->regs->AHCLKRCTL = 0x00000000; // INT CLK (from tx side)
[" l0 U) W! A- _0 X$ O9 I mcasp->regs->RTDM = 0x00000003; // Slots 0,1/ r: a* p& m `! h4 Q4 \+ v
mcasp->regs->RINTCTL = 0x00000000; // Not used
- p7 [" {" d" W mcasp->regs->RCLKCHK = 0x00FF0008; // 255-MAX 0-MIN, div-by-256) @/ B- ]9 K3 V- s5 ` k
& h* Y: Z2 {& [3 t# @, i' l& E mcasp->regs->XMASK = 0xFFFFFFFF; // No padding used& n# Z j2 N! E# k& {2 p
mcasp->regs->XFMT = 0x00018078; // MSB 16bit, 0-delay, no pad, CFGBus% i: F5 E* M- s4 T0 }6 k
mcasp->regs->AFSXCTL = 0x00000112; // 2TDM, 1bit Rising edge INTERNAL FS, word
/ E+ i4 l. z" _9 |+ @$ m mcasp->regs->ACLKXCTL = 0x000000AF; // ASYNC, Rising INTERNAL CLK, div-by-16% U5 q1 G' c5 j$ B, Z
mcasp->regs->AHCLKXCTL = 0x00000000; // EXT CLK
- L! w4 `- [( `4 ~/ p mcasp->regs->XTDM = 0x00000003; // Slots 0,1
; n2 O( Y4 v/ g$ y( H mcasp->regs->XINTCTL = 0x00000020; // interrupt on transmit; h& h& a! P4 ^- r
mcasp->regs->XCLKCHK = 0x00FF0008; // 255-MAX 0-MIN, div-by-256& D& y6 D/ m/ D3 s5 R! v
! u$ M- w8 a. }1 y6 W) N mcasp->regs->SRCTL5 = 0x000D; // MCASP1.AXR1[5] --> DIN5 J7 ~$ F, [3 K2 |
mcasp->regs->SRCTL0 = 0x000E; // MCASP1.AXR1[0] <-- DOUT
6 b, Q/ ]* ]" \& f# T; n mcasp->regs->PFUNC = 0; // All MCASPs, s7 i; G5 [: ~( v+ z
mcasp->regs->PDIR = 0x14000020; // All inputs except AXR0[5], ACLKX1, AFSX1, U! h7 z# U! D7 V
; B- p, `0 c+ u; L4 S; B
mcasp->regs->DITCTL = 0x00000000; // Not used
; V8 w3 y7 x R5 M" t B mcasp->regs->DLBCTL = 0x00000000; // Not used
5 }: i4 T* F/ G" r5 c4 h mcasp->regs->AMUTE = 0x00000000; // Not used
/ T2 s& Q8 s: [+ D" F
2 N6 b% e9 y# C! ]1 ~! I/* Starting sections of the McASP*/
' F8 y, m7 Y+ [# C1 H mcasp->regs->XGBLCTL |= GBLCTL_XHCLKRST_ON;
) u Z8 G" `8 C* m while ( ( mcasp->regs->XGBLCTL & GBLCTL_XHCLKRST_ON ) != GBLCTL_XHCLKRST_ON );
8 N5 G& V% f6 {- m; u mcasp->regs->RGBLCTL |= GBLCTL_RHCLKRST_ON; 0 o6 h! ~8 \0 n a8 R6 J5 h
while ( ( mcasp->regs->RGBLCTL & GBLCTL_RHCLKRST_ON ) != GBLCTL_RHCLKRST_ON );6 I& ^& `/ {# t% p3 ?
& ~4 r' q$ s( X* s mcasp->regs->XGBLCTL |= GBLCTL_XCLKRST_ON; # s+ ]" Y0 M- J2 a; G2 T: w) v
while ( ( mcasp->regs->XGBLCTL & GBLCTL_XCLKRST_ON ) != GBLCTL_XCLKRST_ON );7 Y6 m4 b' B: G) [$ Y# I5 h
mcasp->regs->RGBLCTL |= GBLCTL_RCLKRST_ON; 0 L8 s# Z# ]& b+ K: E
while ( ( mcasp->regs->RGBLCTL & GBLCTL_RCLKRST_ON ) != GBLCTL_RCLKRST_ON );
Z( K% ^* R8 F$ [* \! U0 d3 ^: q7 C: g6 ^, G/ }
mcasp->regs->XSTAT = 0x0000ffff; & p4 N9 V$ x* M3 G) d: n4 [
mcasp->regs->RSTAT = 0x0000ffff; ! {" H+ ]# U2 z/ P$ G- H
& d, Q6 z1 K8 A, U9 B0 G$ C# i0 p+ ~4 O mcasp->regs->XGBLCTL |= GBLCTL_XSRCLR_ON;
/ R9 o8 ]5 [* R' w2 r" W; Y. Z while ( ( mcasp->regs->XGBLCTL & GBLCTL_XSRCLR_ON ) != GBLCTL_XSRCLR_ON );
7 {4 {5 D9 p) I0 B: S3 O mcasp->regs->RGBLCTL |= GBLCTL_RSRCLR_ON;
$ I7 T0 ?, h) l* x while ( ( mcasp->regs->RGBLCTL & GBLCTL_RSRCLR_ON ) != GBLCTL_RSRCLR_ON );/ j, M/ v% F& z/ {/ X. ?# [$ q
1 c8 A, O, q6 ^- J /* Write a 0, so that no underrun occurs after releasing the state machine */8 a9 h; L9 ^ c$ C
mcasp->regs->XBUF5 = 0;
- s1 T. c* P9 J- T3 B mcasp->regs->RBUF0 = 0;
1 o! v9 v% C5 s7 m! R/ x
9 j. o$ x' M% A! l$ z9 r! B mcasp->regs->XGBLCTL |= GBLCTL_XSMRST_ON;
* j9 M9 f. _* X6 I+ e6 s5 L while ( ( mcasp->regs->XGBLCTL & GBLCTL_XSMRST_ON ) != GBLCTL_XSMRST_ON );
4 b- _: i: I0 t' Z mcasp->regs->RGBLCTL |= GBLCTL_RSMRST_ON; , ]- r) a- O* l& Z- }8 v
while ( ( mcasp->regs->RGBLCTL & GBLCTL_RSMRST_ON ) != GBLCTL_RSMRST_ON );# p7 L2 O. S9 B: R. _
1 S1 o. O5 p, {
mcasp->regs->XGBLCTL |= GBLCTL_XFRST_ON; 4 f+ {/ l5 D+ y
while ( ( mcasp->regs->XGBLCTL & GBLCTL_XFRST_ON ) != GBLCTL_XFRST_ON );
; J0 P5 f' Y- l& n" a mcasp->regs->RGBLCTL |= GBLCTL_RFRST_ON; # ]# `: L' ]! n- B i
while ( ( mcasp->regs->RGBLCTL & GBLCTL_RFRST_ON ) != GBLCTL_RFRST_ON );8 Z; X K5 E' P1 O
7 u6 a# c: l8 ]5 J CSR = 0x0000;- e* F. j+ {8 N& I3 v% R8 i
INTC_INTMUX1 = 0x3d;
l5 I+ [/ q6 E- j8 Y* E# ? ISTP = (unsigned int)vectors;& P$ G* W" M9 T- V3 G7 E) \3 {
ICR = 0xFFF0; ' W/ \0 c( O# D- Y
IER |= 0x12; 5 G9 K+ G4 h. R$ @
CSR |= 0x01;
; r0 R c) Z# z) e3 e1 `: A$ G: m5 F2 y8 _
) m" `9 @; b: k/ o) ]) j( {9 V G8 [; h8 P/ U
还有就是两个输入输出函数:$ _2 S0 a8 ]( `) w* n. q- E5 \1 i1 I
void output_sample(Int32 out_data)8 c# n2 w/ {$ p+ o
{
5 f) i. C+ U+ X) j AIC31_data.uint = out_data;
' d0 ~/ U% O5 q MCASP1_XBUF5_32BIT = AIC31_data.uint;
( L& W/ D/ \! _}) v! ? v, v- ]3 D, p# P
: @' ?* A; g; t3 \, e+ CInt32 input_sample(void)
; r5 A7 J# H1 S4 p{
& g0 l6 H( F- L6 {3 {% d* h AIC31_data.uint = MCASP1_RBUF0_32BIT;
2 s# @. p3 m* N# E( w9 p" e return (AIC31_data.uint);
t9 ?. m$ Z% b/ P/ l; T& I}
2 }# |( c1 V+ D8 t' R5 Z6 v; O: V' t$ ?+ Q; X" o
|
|