|
|
C6747和C6748感觉差不多,我想实现McASP发送中断方式控制音频信号,在轮询的例程基础上改的,轮询程序可以实现,但是中断一直实现不了,也找不到错误,求大神帮忙!下边是主要程序:6 {+ `( S$ _. r/ Y( V
main文件:
: o& s) P6 \$ e4 w6 Qinterrupt void interrupt4(void)
( y) w3 [# N$ ]$ _ @, A, \{
1 V% p8 l1 R, U1 \" c# i4 }. V2 ]9 H7 } Uint32 sample;
8 r% I* R* B9 H0 d8 D1 {6 w- T) o
9 O) {0 E1 {6 }+ o sample = input_sample(); // read L + R samples from ADC! H7 a# p/ x. ~& @- g- Y! n* N
output_sample(sample); // write L + R samples to DAC
2 @& l9 d. K0 R0 u( x return;
" s. D/ K: R, X! e9 A0 L}. A1 @5 p$ n/ U$ @
7 |# f J2 t# ?: T- Z! Kint main( void )
9 l& P ^; ^- ~% w$ z{( I% s5 p+ F, j5 I0 T# K6 p& X
4 c3 ~/ y" Q* p% E
/* Initialize BSL */
, ^; u) x) ?0 h( i EVMC6747_init( );
3 I: X3 w7 M1 ?, A$ e /* Call evmc6747_intr function */ l u# E1 Z* v3 `( |
aic3106_init( );' \+ w" ^9 [4 \: b& A/ s; ?+ y' A$ n
while(1);% G4 Y' H$ Q# e; A5 \) M5 I: H
}1 @# ^. Q" O5 l/ o% E
4 `) |9 {( j6 t1 V9 I G" k0 e, q
4 C a9 Y9 D2 H- n
aic3106_init文件的一部分,McASP配置部分,采用内部时钟,I2S方式,同步传输。音频芯片的配置应该没问题0 H% e: c i! i9 T' c
/* Initialize MCASP1 */$ @3 P4 C9 r9 H9 h( r" F
mcasp = &MCASP_MODULE_1;! W, X) o u9 T5 T" \! s' X# t
mcasp->regs->GBLCTL = 0; // Reset
: d" N& [. L( [$ Z mcasp->regs->RGBLCTL = 0; // Reset RX. q/ O9 R, @, B
mcasp->regs->XGBLCTL = 0; // Reset TX
1 r1 j# Z0 d1 M6 Y$ d* H mcasp->regs->PWRDEMU = 1; // Free-running
7 a! G2 e# X2 n6 |$ u: F) m // configure McASP0 receive registers
$ R. m+ d0 i0 z) B: E8 p, b mcasp->regs->RMASK = 0xFFFFFFFF; // No padding used1 h b3 \# R# H" b4 }- \- e
mcasp->regs->RFMT = 0x00018078; // MSB 16bit, 0-delay, no pad, CFGBus
' R: p5 ^9 S* c( ^8 i* V mcasp->regs->AFSRCTL = 0x00000112; // 2TDM, 1bit Falling, External FS, word
" F& ?9 g0 C% i; C7 S mcasp->regs->ACLKRCTL = 0x000000AF; // Rising INTERNAL CLK,(from tx side)
, {: I* b' n1 Q& s mcasp->regs->AHCLKRCTL = 0x00000000; // INT CLK (from tx side)9 I$ h x5 `" s, y
mcasp->regs->RTDM = 0x00000003; // Slots 0,1
) p8 s! \+ Y! P' A$ [7 d mcasp->regs->RINTCTL = 0x00000000; // Not used
. p0 }: A1 v; b* Q mcasp->regs->RCLKCHK = 0x00FF0008; // 255-MAX 0-MIN, div-by-256
* o. L8 ?8 ` q( O
B, t) a+ s _2 I7 o x mcasp->regs->XMASK = 0xFFFFFFFF; // No padding used
3 M4 C+ ] S8 o# i# V: q1 k/ V" @ mcasp->regs->XFMT = 0x00018078; // MSB 16bit, 0-delay, no pad, CFGBus
! l$ ]& m: B/ }0 w4 L mcasp->regs->AFSXCTL = 0x00000112; // 2TDM, 1bit Rising edge INTERNAL FS, word
# b+ O$ a5 P7 c1 H mcasp->regs->ACLKXCTL = 0x000000AF; // ASYNC, Rising INTERNAL CLK, div-by-16; o/ `/ p, N% o7 o- X
mcasp->regs->AHCLKXCTL = 0x00000000; // EXT CLK
5 k* p, G8 v4 s: |& n mcasp->regs->XTDM = 0x00000003; // Slots 0,1
4 p1 @, w |+ I8 ~; L mcasp->regs->XINTCTL = 0x00000020; // interrupt on transmit: `2 X$ m; ` c8 C% w& [" ~7 S
mcasp->regs->XCLKCHK = 0x00FF0008; // 255-MAX 0-MIN, div-by-256
m* A7 }$ K) _; J5 q$ o' X, K- C5 h4 ~& W$ O& h' O8 {
mcasp->regs->SRCTL5 = 0x000D; // MCASP1.AXR1[5] --> DIN ?# E. t) O8 s* k
mcasp->regs->SRCTL0 = 0x000E; // MCASP1.AXR1[0] <-- DOUT. l% g$ T( }6 U3 ^1 z0 s: z* q
mcasp->regs->PFUNC = 0; // All MCASPs
! ~( T$ h- O2 U' w3 [5 R mcasp->regs->PDIR = 0x14000020; // All inputs except AXR0[5], ACLKX1, AFSX1. F4 }& C# R8 M. h
& v% G8 o% p- o' k) n
mcasp->regs->DITCTL = 0x00000000; // Not used9 g) t, W [, c O4 a! I
mcasp->regs->DLBCTL = 0x00000000; // Not used8 m! o8 m$ l2 D
mcasp->regs->AMUTE = 0x00000000; // Not used
" E7 Y8 ?' K/ ~2 ]& h( V4 x' m+ I
7 I! |4 j; `7 B/* Starting sections of the McASP*/9 l0 m6 S) ]* _$ g
mcasp->regs->XGBLCTL |= GBLCTL_XHCLKRST_ON; 3 M2 a3 r! S; M6 A( o! l
while ( ( mcasp->regs->XGBLCTL & GBLCTL_XHCLKRST_ON ) != GBLCTL_XHCLKRST_ON ); & W; A2 f- j; k( r
mcasp->regs->RGBLCTL |= GBLCTL_RHCLKRST_ON;
+ ?+ f: m( I9 ^7 \! J+ e B while ( ( mcasp->regs->RGBLCTL & GBLCTL_RHCLKRST_ON ) != GBLCTL_RHCLKRST_ON );
1 `8 c" B" a8 w$ V- ~- r
" M: ?9 Z" a' f& r mcasp->regs->XGBLCTL |= GBLCTL_XCLKRST_ON;
7 D9 C, R; p& i* i1 y while ( ( mcasp->regs->XGBLCTL & GBLCTL_XCLKRST_ON ) != GBLCTL_XCLKRST_ON );
' I- i1 E# e. p" I* y mcasp->regs->RGBLCTL |= GBLCTL_RCLKRST_ON;
2 Y' @1 b. B) p* v while ( ( mcasp->regs->RGBLCTL & GBLCTL_RCLKRST_ON ) != GBLCTL_RCLKRST_ON );
5 p. o& J( |5 x1 }4 ]; ~
) S+ a, ]0 e& }2 h$ _! K mcasp->regs->XSTAT = 0x0000ffff;
' r; c2 p/ e- S# w" z( x. A' I mcasp->regs->RSTAT = 0x0000ffff; . X0 r( _( H. i& t A9 ]& R5 m
$ Q$ `+ M: H' V. ? mcasp->regs->XGBLCTL |= GBLCTL_XSRCLR_ON;
& Q# X5 _; H, l* h8 R4 M while ( ( mcasp->regs->XGBLCTL & GBLCTL_XSRCLR_ON ) != GBLCTL_XSRCLR_ON );
0 g: Q' B+ P: E' C2 C9 A- I mcasp->regs->RGBLCTL |= GBLCTL_RSRCLR_ON; % A E: ~* a* O0 V
while ( ( mcasp->regs->RGBLCTL & GBLCTL_RSRCLR_ON ) != GBLCTL_RSRCLR_ON );. c9 n* g, z! P' n: Y# ]
2 [" p+ T* z. M1 ] /* Write a 0, so that no underrun occurs after releasing the state machine */
+ F+ N6 R+ E( Q4 h7 W+ q3 ~ mcasp->regs->XBUF5 = 0;8 _1 T! H, [& e3 [% b
mcasp->regs->RBUF0 = 0;) z( n+ t8 K. T6 e |! T
* [* o( U" z$ P( P! G( R- b) i! ~8 Y8 ]
mcasp->regs->XGBLCTL |= GBLCTL_XSMRST_ON;
) c0 S% z1 ^4 u" b while ( ( mcasp->regs->XGBLCTL & GBLCTL_XSMRST_ON ) != GBLCTL_XSMRST_ON );
$ l# X. I6 c1 N) ~7 z4 l5 b4 } mcasp->regs->RGBLCTL |= GBLCTL_RSMRST_ON; 4 n9 s: G* e& q; i5 l
while ( ( mcasp->regs->RGBLCTL & GBLCTL_RSMRST_ON ) != GBLCTL_RSMRST_ON );* M# O7 t+ p. I2 ?. x: c
/ k" b! z5 |& U* p mcasp->regs->XGBLCTL |= GBLCTL_XFRST_ON; 3 E0 x( |( n0 ]1 r! ]9 y
while ( ( mcasp->regs->XGBLCTL & GBLCTL_XFRST_ON ) != GBLCTL_XFRST_ON );. E! `7 X; l. M; s! g+ h
mcasp->regs->RGBLCTL |= GBLCTL_RFRST_ON;
4 z5 f4 V+ G6 ~5 K' K' k while ( ( mcasp->regs->RGBLCTL & GBLCTL_RFRST_ON ) != GBLCTL_RFRST_ON );: h s; d) P! e7 q- V: \& }" g6 [
0 X) d I5 H7 x D. R CSR = 0x0000;" Y2 b5 W: `* f7 I
INTC_INTMUX1 = 0x3d;
9 P! O6 O, i% o- o, F) w ISTP = (unsigned int)vectors;' f" y# B6 T. W* A- [4 Q
ICR = 0xFFF0;
9 X) Y% ~8 k" ^) E8 ~0 S d3 a IER |= 0x12; " }7 F& _# _% f, o' y( B' S- v
CSR |= 0x01;
0 \% ^, R0 X5 S( q6 q; v
3 e( z/ i3 b' E5 E' D8 l3 q, e. j, g$ H2 Y/ r$ g# z$ X8 `( a3 U0 ~
$ x$ O0 T+ {' X, D# y还有就是两个输入输出函数:
: g" j4 h8 ^7 }" p/ r$ t$ lvoid output_sample(Int32 out_data)
" b, m! W- Z- B& t{8 n! B" ^* G2 J6 X
AIC31_data.uint = out_data;
) z) V3 F. \8 z% \5 c" E MCASP1_XBUF5_32BIT = AIC31_data.uint;
# H9 l; `! G3 U+ Q- J# E% J9 V) w}
4 F6 K8 J, h: w6 d4 n4 |6 Z' ?) L8 @/ M! \
Int32 input_sample(void)
2 C. P% k) @. Q2 V{ 6 }4 r; Z/ x4 n& e( q
AIC31_data.uint = MCASP1_RBUF0_32BIT;
) D7 m' m1 R9 V0 \$ X1 h( S return (AIC31_data.uint);
n# u$ `. B; m}
. w' t6 f$ i1 [* y/ Z2 k2 O7 H: {" i2 Q0 |8 c
|
|