|
|
C6747和C6748感觉差不多,我想实现McASP发送中断方式控制音频信号,在轮询的例程基础上改的,轮询程序可以实现,但是中断一直实现不了,也找不到错误,求大神帮忙!下边是主要程序:
" g: [7 I; H' Kmain文件:
9 Z4 C. \' H |4 e2 L6 ~9 Uinterrupt void interrupt4(void) $ U9 d: J( {0 G. p/ d4 p6 h+ l& r
{9 o! a6 b* ?% R* g4 A4 Z3 O
Uint32 sample;& v9 i4 B6 @ T; q- A) h( O
/ G2 o& |3 B* C/ v6 n
sample = input_sample(); // read L + R samples from ADC
6 K, m4 J8 \1 V9 a a9 D8 p output_sample(sample); // write L + R samples to DAC ) P. B& K$ j- U
return;! S7 q: h3 g1 |$ X# Y
}+ O; B5 a' t% I
# Y f) r; Q5 g0 {, D# ?" w* I Yint main( void )7 n4 h8 L2 \' h2 @
{) Q6 Y/ U2 I4 R2 o, w' K1 r1 g; q! u9 j5 ~
4 f/ Y) W! @* j5 R$ L
/* Initialize BSL */6 k, S2 j' i$ W; I# Y+ t/ W
EVMC6747_init( );4 j/ Z: x2 ~% U8 `. E
/* Call evmc6747_intr function */; C2 ^% G. h L6 @/ Z7 \: w+ r4 o/ c
aic3106_init( );
' _% H( g: i9 P while(1);
& |4 C) P0 U( P: N9 C9 P: Q}
8 u" Q7 j. [7 l) u3 |# D( i P
9 }8 B0 i) ]# y- f
8 f# o: Y$ }8 C1 p! raic3106_init文件的一部分,McASP配置部分,采用内部时钟,I2S方式,同步传输。音频芯片的配置应该没问题 K, ^2 a( F0 ?
/* Initialize MCASP1 */
( u; q1 d# B7 p, k5 F6 w1 @ mcasp = &MCASP_MODULE_1;* `4 N7 M& x: Z* y8 d
mcasp->regs->GBLCTL = 0; // Reset
8 f" d4 R* Q5 z9 s0 ^ mcasp->regs->RGBLCTL = 0; // Reset RX0 Y0 V6 z/ r2 F
mcasp->regs->XGBLCTL = 0; // Reset TX, Y! U4 E7 z. r" s1 \9 r
mcasp->regs->PWRDEMU = 1; // Free-running0 i3 Q$ h: Q6 K. N1 ~
// configure McASP0 receive registers
2 i. a9 o7 C' d$ G# E$ Q mcasp->regs->RMASK = 0xFFFFFFFF; // No padding used
E7 E5 F5 t* N' {+ M5 \" v mcasp->regs->RFMT = 0x00018078; // MSB 16bit, 0-delay, no pad, CFGBus, l. X6 r( ?# ]& }) n& o4 B. U" @
mcasp->regs->AFSRCTL = 0x00000112; // 2TDM, 1bit Falling, External FS, word% i5 u- d$ q" v/ l6 L" w: @
mcasp->regs->ACLKRCTL = 0x000000AF; // Rising INTERNAL CLK,(from tx side) {. z: x- @8 B7 b$ ~* {6 o( w. i
mcasp->regs->AHCLKRCTL = 0x00000000; // INT CLK (from tx side)
- r' Q3 b* M! z8 I! j mcasp->regs->RTDM = 0x00000003; // Slots 0,1+ A( {3 R' Q# U9 o U
mcasp->regs->RINTCTL = 0x00000000; // Not used3 a/ e+ d% x0 x
mcasp->regs->RCLKCHK = 0x00FF0008; // 255-MAX 0-MIN, div-by-256
0 s. U b1 A* ?* d2 |; G) I, k6 j6 k0 S7 w2 v/ |( r3 b. I' Q/ n5 s
mcasp->regs->XMASK = 0xFFFFFFFF; // No padding used( J' T2 W9 i) s6 A: ~
mcasp->regs->XFMT = 0x00018078; // MSB 16bit, 0-delay, no pad, CFGBus$ k' c! N' Y# E5 g4 L4 B$ z% l
mcasp->regs->AFSXCTL = 0x00000112; // 2TDM, 1bit Rising edge INTERNAL FS, word. f K/ h" U. P& A1 h5 g J
mcasp->regs->ACLKXCTL = 0x000000AF; // ASYNC, Rising INTERNAL CLK, div-by-16
j3 f% r3 q1 T/ h" Q mcasp->regs->AHCLKXCTL = 0x00000000; // EXT CLK
' p% `% [/ H- Q' D* a5 J9 D mcasp->regs->XTDM = 0x00000003; // Slots 0,1
' v4 T; k6 E' f- F! r# O: C. E mcasp->regs->XINTCTL = 0x00000020; // interrupt on transmit r. }! I. O: C7 R
mcasp->regs->XCLKCHK = 0x00FF0008; // 255-MAX 0-MIN, div-by-256' z _2 t5 j1 T+ |' f
+ I6 t/ u' ]2 y: @7 m
mcasp->regs->SRCTL5 = 0x000D; // MCASP1.AXR1[5] --> DIN" [: z4 w# r8 \2 U& k& c, X1 K
mcasp->regs->SRCTL0 = 0x000E; // MCASP1.AXR1[0] <-- DOUT
% W! W' M( x; u) ^) X, F8 z mcasp->regs->PFUNC = 0; // All MCASPs
( N, b$ A$ A4 X1 F1 ]' a$ r mcasp->regs->PDIR = 0x14000020; // All inputs except AXR0[5], ACLKX1, AFSX1# p( |# k! B* a- [# P4 I7 ?6 r
% d1 q4 K( t- b+ d4 |5 ~$ d
mcasp->regs->DITCTL = 0x00000000; // Not used& K1 l5 ^. L7 K [) I/ K
mcasp->regs->DLBCTL = 0x00000000; // Not used
. V; z! a' m5 |7 a/ @: H mcasp->regs->AMUTE = 0x00000000; // Not used# F1 M$ K# R2 t# S. g- ~/ n
3 Q4 l0 M" ]) b. K/* Starting sections of the McASP*/ J) }2 H3 Y! Q
mcasp->regs->XGBLCTL |= GBLCTL_XHCLKRST_ON;
2 J# g9 Q" e4 M7 W! U- Q while ( ( mcasp->regs->XGBLCTL & GBLCTL_XHCLKRST_ON ) != GBLCTL_XHCLKRST_ON ); $ S% I* Z [& ~+ x) w8 G
mcasp->regs->RGBLCTL |= GBLCTL_RHCLKRST_ON;
% y" |! O- h7 ~% I while ( ( mcasp->regs->RGBLCTL & GBLCTL_RHCLKRST_ON ) != GBLCTL_RHCLKRST_ON );- I# _' q3 ^1 ^ |7 e' C+ v- T) t4 j
5 X: R2 }" D3 s
mcasp->regs->XGBLCTL |= GBLCTL_XCLKRST_ON;
1 W+ K7 B8 r, w. S1 b" ~3 G ^ while ( ( mcasp->regs->XGBLCTL & GBLCTL_XCLKRST_ON ) != GBLCTL_XCLKRST_ON );' z0 A2 S7 I$ \
mcasp->regs->RGBLCTL |= GBLCTL_RCLKRST_ON;
+ e+ B) ^4 x9 J+ r# C; r7 ^ while ( ( mcasp->regs->RGBLCTL & GBLCTL_RCLKRST_ON ) != GBLCTL_RCLKRST_ON );5 \3 S6 y' L/ o7 q
: f% a7 z$ H& W# @7 r2 Z( F mcasp->regs->XSTAT = 0x0000ffff;
1 z' J0 X0 z+ A mcasp->regs->RSTAT = 0x0000ffff; 1 e. R/ e' C' m- B% [$ B8 t+ l
+ s a$ o2 {5 b" T! `% i3 H
mcasp->regs->XGBLCTL |= GBLCTL_XSRCLR_ON;
' g, Q+ A' M' e0 Y while ( ( mcasp->regs->XGBLCTL & GBLCTL_XSRCLR_ON ) != GBLCTL_XSRCLR_ON );
3 \. P$ P, T: F; ^. _% j% z* X mcasp->regs->RGBLCTL |= GBLCTL_RSRCLR_ON;
. _$ R, l# ]& o( k while ( ( mcasp->regs->RGBLCTL & GBLCTL_RSRCLR_ON ) != GBLCTL_RSRCLR_ON );
. J5 @& M5 {* F
6 k% H" C+ F* w$ o9 E" }% M /* Write a 0, so that no underrun occurs after releasing the state machine */3 W5 T1 A& G8 z- W2 s$ W, e
mcasp->regs->XBUF5 = 0;
- M: s- }6 y7 O3 C mcasp->regs->RBUF0 = 0;: h1 \: `! K3 I3 c
`2 _0 k5 b, G; n mcasp->regs->XGBLCTL |= GBLCTL_XSMRST_ON;
7 H0 f( E; ^! X8 d* n) G S. A e while ( ( mcasp->regs->XGBLCTL & GBLCTL_XSMRST_ON ) != GBLCTL_XSMRST_ON );0 @$ T6 W" Y' ~! l; V3 b
mcasp->regs->RGBLCTL |= GBLCTL_RSMRST_ON;
. @6 U8 F% S+ v5 p% N& G4 ~3 I1 ? while ( ( mcasp->regs->RGBLCTL & GBLCTL_RSMRST_ON ) != GBLCTL_RSMRST_ON );, a' d! _: o8 Q+ d4 s/ l
3 Z9 M' F! @! E7 p
mcasp->regs->XGBLCTL |= GBLCTL_XFRST_ON; # l* `& x* D/ P- u7 H+ V
while ( ( mcasp->regs->XGBLCTL & GBLCTL_XFRST_ON ) != GBLCTL_XFRST_ON );
4 l" s! M9 b1 P( ]: L mcasp->regs->RGBLCTL |= GBLCTL_RFRST_ON; - O3 h; V9 U! V S$ U7 `/ [
while ( ( mcasp->regs->RGBLCTL & GBLCTL_RFRST_ON ) != GBLCTL_RFRST_ON );
/ j% k6 B) E' ?+ U) N: U1 u4 A" X: W* Z& m
CSR = 0x0000;8 }8 [/ L- k' `" l" {3 o
INTC_INTMUX1 = 0x3d;
: r& w* b( l/ e" B ISTP = (unsigned int)vectors;
) f" E' T3 w7 C3 @" K; o ICR = 0xFFF0;
9 t* Z& [+ M2 g7 P IER |= 0x12;
{. ^2 v% Y& k4 C' E CSR |= 0x01; * r+ }9 s" V; m( n6 f$ M
' Z; G& {; ^" P& j9 m
7 C+ ^6 Y( \& P/ Y+ u* v+ n, D% {) b( ?% O9 ]
还有就是两个输入输出函数:# p: o4 e8 {* j/ M- F( M
void output_sample(Int32 out_data)
5 I6 O7 y" ^! ?+ {) E: j{- d+ h1 c: V- F( C, x
AIC31_data.uint = out_data; 5 ]( G/ s/ k; G( k0 l+ v. i: d
MCASP1_XBUF5_32BIT = AIC31_data.uint;
: C8 b z, @& q( f3 [9 E/ ]}
1 X' z1 L+ n( q! V* @: C9 n1 f2 F7 x/ j" p. \
Int32 input_sample(void)
# m9 Z. P+ d) R7 A0 l% y0 L% s{ 2 M9 O% ]" s2 ]9 ?! [$ `
AIC31_data.uint = MCASP1_RBUF0_32BIT;' U# k# G: y# j+ _/ G. A2 `7 _ _
return (AIC31_data.uint);8 Y# O/ W7 ~" ~6 R) M* i# a
}6 O& J. d+ z9 O; Q9 n- e
f' C6 p7 o* [3 f1 R
|
|