|
|
C6747和C6748感觉差不多,我想实现McASP发送中断方式控制音频信号,在轮询的例程基础上改的,轮询程序可以实现,但是中断一直实现不了,也找不到错误,求大神帮忙!下边是主要程序:
% p+ s% ]! j5 n# e: wmain文件:. n$ ]* \9 t8 C' a
interrupt void interrupt4(void)
; ^- Q0 `1 p( O" F4 ?) R6 W- Y6 W{
) Q, t% Z* Z( { Uint32 sample;, }4 E5 @! S o( r& i/ ~( L
) a4 O0 \5 Y- i7 n4 M" H
sample = input_sample(); // read L + R samples from ADC
4 D2 O) e3 Z1 O0 r6 j output_sample(sample); // write L + R samples to DAC & v6 z1 w7 D# J: |, a! y
return;
0 h" o5 d' q; k}2 O5 v7 P8 s0 L1 P7 V$ ?$ ]
$ d6 w* d' v* A* U- Vint main( void )
& d; W& E2 \6 \; l. m1 W+ E{
7 H0 t- w& L/ u" H( Y9 J# d, ~* ^& |( ^: |0 y) l3 I" |. K
/* Initialize BSL */
+ c; k" G" e, Y& {. H8 k( q' h EVMC6747_init( );
2 ]! a" P1 E/ `- G( | /* Call evmc6747_intr function */
5 @3 {+ G5 o& C1 n% M# _ aic3106_init( );+ J7 I' I& E) W/ n
while(1);+ l6 J# s" f# |/ s$ ^
}
% [- @2 e7 Y7 \: q2 j- {/ Y, l9 W7 C0 |/ ^$ M9 }
! |- t+ j4 x7 O3 n: ^$ B: ]$ ]! oaic3106_init文件的一部分,McASP配置部分,采用内部时钟,I2S方式,同步传输。音频芯片的配置应该没问题
! Z" J, {" g4 f( V# F0 i7 W/* Initialize MCASP1 */
" w0 ~8 y% ^, m( c mcasp = &MCASP_MODULE_1;6 F" p. G* u z% [% r3 H! g% j
mcasp->regs->GBLCTL = 0; // Reset
- F& R9 ^3 Q0 t# ~ mcasp->regs->RGBLCTL = 0; // Reset RX
, _" ? \) I% h3 g$ i7 @- O mcasp->regs->XGBLCTL = 0; // Reset TX
- Z1 ~! @5 i V6 j8 S5 O7 a8 { mcasp->regs->PWRDEMU = 1; // Free-running# o# [: F- y- T1 u' ]' H1 H
// configure McASP0 receive registers A8 J0 q3 O( `% i% |2 i0 ]+ ~# h
mcasp->regs->RMASK = 0xFFFFFFFF; // No padding used9 W3 F" Y& z g
mcasp->regs->RFMT = 0x00018078; // MSB 16bit, 0-delay, no pad, CFGBus
0 `+ q# I7 J9 y# ] mcasp->regs->AFSRCTL = 0x00000112; // 2TDM, 1bit Falling, External FS, word: F4 {0 O9 o% {/ H
mcasp->regs->ACLKRCTL = 0x000000AF; // Rising INTERNAL CLK,(from tx side)- U2 P+ X B# x5 d8 s( n
mcasp->regs->AHCLKRCTL = 0x00000000; // INT CLK (from tx side)4 U. f/ T' W9 a Y9 }0 |9 d
mcasp->regs->RTDM = 0x00000003; // Slots 0,1
$ m! N9 ?- t9 i3 @" E+ E, y mcasp->regs->RINTCTL = 0x00000000; // Not used
5 r* m3 d" d) O* p. a/ h mcasp->regs->RCLKCHK = 0x00FF0008; // 255-MAX 0-MIN, div-by-2564 {: I7 G) W: S/ N) A/ K# L
5 B0 Y6 Q6 n2 M4 X5 z
mcasp->regs->XMASK = 0xFFFFFFFF; // No padding used1 |" q" e/ N2 ^' _& X6 j4 z0 z8 N
mcasp->regs->XFMT = 0x00018078; // MSB 16bit, 0-delay, no pad, CFGBus
# {; C' ~! [: j2 C* X; z: h mcasp->regs->AFSXCTL = 0x00000112; // 2TDM, 1bit Rising edge INTERNAL FS, word; G$ U3 Z5 A# _$ H3 e9 f
mcasp->regs->ACLKXCTL = 0x000000AF; // ASYNC, Rising INTERNAL CLK, div-by-16+ z9 w4 @# @4 C
mcasp->regs->AHCLKXCTL = 0x00000000; // EXT CLK
7 x" l6 G! K, o. z7 i X. w0 B mcasp->regs->XTDM = 0x00000003; // Slots 0,1: a- g! [' f- V: u9 q0 w5 ]! a$ ^& i
mcasp->regs->XINTCTL = 0x00000020; // interrupt on transmit# C8 _ l9 Q( R; c* c# [- H
mcasp->regs->XCLKCHK = 0x00FF0008; // 255-MAX 0-MIN, div-by-256
3 Y# S% f* d# J8 p. u
) D) W* _- L* U mcasp->regs->SRCTL5 = 0x000D; // MCASP1.AXR1[5] --> DIN
8 O( [ D2 X( r; W mcasp->regs->SRCTL0 = 0x000E; // MCASP1.AXR1[0] <-- DOUT3 |) j9 e2 |. W8 n; Q: y
mcasp->regs->PFUNC = 0; // All MCASPs
/ K: [ I8 f/ H) f mcasp->regs->PDIR = 0x14000020; // All inputs except AXR0[5], ACLKX1, AFSX1+ v2 D1 B9 B( ~' P3 |2 S: l
0 y* Y2 Q1 e' @: Q8 h) E$ m4 E mcasp->regs->DITCTL = 0x00000000; // Not used
$ W" T9 Y; I8 m& `$ o" P$ X. L' |% ] mcasp->regs->DLBCTL = 0x00000000; // Not used
: o- c& Q# _9 }8 K- N mcasp->regs->AMUTE = 0x00000000; // Not used
& n/ Z3 Z x8 p3 \$ v; p: m
9 P5 c) B. V2 z/* Starting sections of the McASP*/
6 M( q. X6 X8 m3 [0 @7 l3 b mcasp->regs->XGBLCTL |= GBLCTL_XHCLKRST_ON; W0 Y. j$ u; \9 B6 K. S
while ( ( mcasp->regs->XGBLCTL & GBLCTL_XHCLKRST_ON ) != GBLCTL_XHCLKRST_ON ); " f* y- Z- |8 U0 Z3 L9 ^! X
mcasp->regs->RGBLCTL |= GBLCTL_RHCLKRST_ON;
9 S% _4 o5 n; l6 ^ while ( ( mcasp->regs->RGBLCTL & GBLCTL_RHCLKRST_ON ) != GBLCTL_RHCLKRST_ON );, r' o4 X# L' B3 r6 l; H! ^- }
2 V8 P1 W: e* ]2 ?; |% o% H* V mcasp->regs->XGBLCTL |= GBLCTL_XCLKRST_ON;
0 n5 B% d; E7 d4 b2 a9 { while ( ( mcasp->regs->XGBLCTL & GBLCTL_XCLKRST_ON ) != GBLCTL_XCLKRST_ON );3 y r4 X* M7 Y, d! ^
mcasp->regs->RGBLCTL |= GBLCTL_RCLKRST_ON; % a% c' r5 k5 r1 s* `
while ( ( mcasp->regs->RGBLCTL & GBLCTL_RCLKRST_ON ) != GBLCTL_RCLKRST_ON );
9 C* K; ~" _6 @0 {9 J" W. ^9 o; c" Y
mcasp->regs->XSTAT = 0x0000ffff;
# l0 r' ^! M: w9 n. `& _ mcasp->regs->RSTAT = 0x0000ffff; & J& }+ E( _1 K1 J$ _3 J0 Y6 t
+ b- w) a) b* v
mcasp->regs->XGBLCTL |= GBLCTL_XSRCLR_ON;
9 @9 v, w' T4 h% X! P8 }2 N# W while ( ( mcasp->regs->XGBLCTL & GBLCTL_XSRCLR_ON ) != GBLCTL_XSRCLR_ON );# k* E& r% L& ~6 G1 A5 C$ D+ b8 d
mcasp->regs->RGBLCTL |= GBLCTL_RSRCLR_ON; - V/ w9 {2 g& S5 K& f' T/ T/ z' i
while ( ( mcasp->regs->RGBLCTL & GBLCTL_RSRCLR_ON ) != GBLCTL_RSRCLR_ON );
9 v4 t, H& T9 u9 ~5 {, ^) |5 W2 `2 a) l+ H, i9 C% t
/* Write a 0, so that no underrun occurs after releasing the state machine */$ c( e+ Z& O3 q# E* f& J; U1 x
mcasp->regs->XBUF5 = 0;
% \$ q; |2 f- i4 @' `5 T' n: H mcasp->regs->RBUF0 = 0;
, h+ H8 _' D4 v) i( K( K: ` T3 e
! R s8 t W5 ]! C: {+ z# e mcasp->regs->XGBLCTL |= GBLCTL_XSMRST_ON; / r% c# U, Y9 F% m# z
while ( ( mcasp->regs->XGBLCTL & GBLCTL_XSMRST_ON ) != GBLCTL_XSMRST_ON );, V" C! Q+ l/ Q) q; z2 [; w- e& Q+ U! s
mcasp->regs->RGBLCTL |= GBLCTL_RSMRST_ON; 8 Z5 U" k3 j7 [
while ( ( mcasp->regs->RGBLCTL & GBLCTL_RSMRST_ON ) != GBLCTL_RSMRST_ON );: ?& g* ]: |) p# x6 a3 A% W
/ r5 A: l; y% p9 }% A! I7 l+ g) O mcasp->regs->XGBLCTL |= GBLCTL_XFRST_ON;
- p! e/ n& ]4 C8 O while ( ( mcasp->regs->XGBLCTL & GBLCTL_XFRST_ON ) != GBLCTL_XFRST_ON );5 ?; `0 @4 G2 D$ s8 G+ t
mcasp->regs->RGBLCTL |= GBLCTL_RFRST_ON; / Z/ c' }0 s" B
while ( ( mcasp->regs->RGBLCTL & GBLCTL_RFRST_ON ) != GBLCTL_RFRST_ON );
9 p8 L0 w4 ?5 `9 N+ F$ M
8 s% i. x7 s/ f4 ^2 P& C CSR = 0x0000;
3 c/ e" l+ I6 F, ~! \/ M' ` INTC_INTMUX1 = 0x3d;
, n% O4 z- I+ [- G! K& Q. t- q( n" s ISTP = (unsigned int)vectors;
% l7 B7 R7 z9 n- k& N Y. w ICR = 0xFFF0; ! p+ c" I. E6 ~2 x. _7 v1 @' w
IER |= 0x12; 6 ~( m' x; l; X5 N1 `6 |
CSR |= 0x01;
# f( p9 H) Y. b) t) B5 o5 J9 Q# m, I% D$ `7 j0 s( U9 ]& L
1 m7 m1 G$ Z+ @; p; s' Q3 H8 J
, Y: Z4 c% U- O8 E
还有就是两个输入输出函数: B' C3 z% \3 m6 X
void output_sample(Int32 out_data)
& A+ l7 e; s- X& `2 `% Z' ~1 d{* n; G5 Y1 F! z" V. N- U; r
AIC31_data.uint = out_data;
; E& N( {; p$ V5 P6 w. u0 O MCASP1_XBUF5_32BIT = AIC31_data.uint;
% J" @9 u3 H) N; |$ r) G}6 F5 W0 p( w3 @+ G/ n
+ \& ~& B8 y6 n& t/ u7 G0 AInt32 input_sample(void)
% N3 q3 [% D0 b- }8 r{ 7 A- f; [" l3 p- s1 C7 Z
AIC31_data.uint = MCASP1_RBUF0_32BIT;
5 K- n* [* S; h) f7 ? return (AIC31_data.uint);
1 o% }3 u H7 a) x1 r- c% R}
) }9 O( ]& X' x, a; [' i! ^ d* b g( O$ Y% }
|
|