|
|
C6747和C6748感觉差不多,我想实现McASP发送中断方式控制音频信号,在轮询的例程基础上改的,轮询程序可以实现,但是中断一直实现不了,也找不到错误,求大神帮忙!下边是主要程序:6 ?; B! i+ S3 g
main文件:
0 o& X* X+ n& o! {! u2 C8 m$ Jinterrupt void interrupt4(void) & g8 C6 k/ D; O) O! I4 Y0 g- q
{$ y/ Y' C! J, b. j* ? v8 `
Uint32 sample;
# U6 Q! N* @" B" s5 c; x E( `$ m {8 h4 }
sample = input_sample(); // read L + R samples from ADC. s- D( Y) Z& u. w8 h, x- P
output_sample(sample); // write L + R samples to DAC
) ~: H+ ^6 \3 e" N9 u: k7 q return;$ J$ O2 u& o) k" H4 H2 r
}
p) a, C: {! F! G+ j% o" c& M/ D h1 T* N# V8 @
int main( void )) R& @; L0 O! B C- A- A
{7 z7 M' o) Y& w. ?" w0 m6 E4 c E
- Z- a9 r& ?" V /* Initialize BSL */
( |$ G3 Q9 s$ g5 l; d" T EVMC6747_init( );' s! C+ \: L1 a: l" P6 [
/* Call evmc6747_intr function */* u! h' d& }/ Q! _+ y
aic3106_init( );( L+ a& s7 |; d! E' T( v
while(1);) {8 n( T% C, Y" d3 y
}: ~( T$ g8 H* ~; l7 a
/ }) |& y" P! K
) c. I4 T7 T" \# qaic3106_init文件的一部分,McASP配置部分,采用内部时钟,I2S方式,同步传输。音频芯片的配置应该没问题% w6 s/ k' p7 M+ G! C W4 g( N
/* Initialize MCASP1 */6 W; v {' E) O3 [( Y% A' n& n0 ~
mcasp = &MCASP_MODULE_1;
2 z/ b' `) J X6 u* V mcasp->regs->GBLCTL = 0; // Reset
) M) w+ @' c5 F9 C, x8 D3 S7 M mcasp->regs->RGBLCTL = 0; // Reset RX
+ | I' E$ Y3 V' w/ | mcasp->regs->XGBLCTL = 0; // Reset TX1 b: c$ }/ v% T$ d& N
mcasp->regs->PWRDEMU = 1; // Free-running6 d; }, o8 @) m4 W
// configure McASP0 receive registers
' m2 m1 G. B1 W( c% A5 B, [ mcasp->regs->RMASK = 0xFFFFFFFF; // No padding used
8 r' k3 Z- N( r+ g mcasp->regs->RFMT = 0x00018078; // MSB 16bit, 0-delay, no pad, CFGBus
& N4 b x2 R2 X; q$ Y; U1 X% F+ a9 l mcasp->regs->AFSRCTL = 0x00000112; // 2TDM, 1bit Falling, External FS, word# i. r, ~& ^& l5 i! M
mcasp->regs->ACLKRCTL = 0x000000AF; // Rising INTERNAL CLK,(from tx side)$ b' m' |9 P5 _5 a3 O* Z
mcasp->regs->AHCLKRCTL = 0x00000000; // INT CLK (from tx side). e) W6 d& |/ o* j/ O! }3 O
mcasp->regs->RTDM = 0x00000003; // Slots 0,1
- N* F7 x. ^! C& n mcasp->regs->RINTCTL = 0x00000000; // Not used
( g! t7 c( [' E5 |- o7 Q mcasp->regs->RCLKCHK = 0x00FF0008; // 255-MAX 0-MIN, div-by-2561 I+ x a! J3 h# t" K: T3 ?
( {& ]; q* _9 e$ e3 d0 \/ U3 x mcasp->regs->XMASK = 0xFFFFFFFF; // No padding used
7 h* m6 n( K0 U t- j! h, g; I5 j mcasp->regs->XFMT = 0x00018078; // MSB 16bit, 0-delay, no pad, CFGBus
* X% I: @+ f) Z3 S1 b/ C3 p3 X& } mcasp->regs->AFSXCTL = 0x00000112; // 2TDM, 1bit Rising edge INTERNAL FS, word9 d. C9 \6 _; ^! k5 z5 l; [
mcasp->regs->ACLKXCTL = 0x000000AF; // ASYNC, Rising INTERNAL CLK, div-by-16) l! `# F( K* W1 x1 Z- n3 T
mcasp->regs->AHCLKXCTL = 0x00000000; // EXT CLK( t% Z' m& q& b6 V2 N- z
mcasp->regs->XTDM = 0x00000003; // Slots 0,14 e/ p# C1 a2 n; l- ^
mcasp->regs->XINTCTL = 0x00000020; // interrupt on transmit
0 d1 v$ y( H) V, d, ]/ c. O; B4 e( ]7 I mcasp->regs->XCLKCHK = 0x00FF0008; // 255-MAX 0-MIN, div-by-256( H. d6 t/ c0 `% Y- Q
1 Z/ S% D; K$ R# g5 B3 j3 J
mcasp->regs->SRCTL5 = 0x000D; // MCASP1.AXR1[5] --> DIN8 F% F- {/ {: X( D3 A0 x
mcasp->regs->SRCTL0 = 0x000E; // MCASP1.AXR1[0] <-- DOUT
& O( @4 e' }. `+ O mcasp->regs->PFUNC = 0; // All MCASPs* R0 n# E3 Y* B% @+ m3 I
mcasp->regs->PDIR = 0x14000020; // All inputs except AXR0[5], ACLKX1, AFSX13 c" h4 e1 W# R; K$ c
2 K7 W; c+ |. x- J( t2 M* k6 M mcasp->regs->DITCTL = 0x00000000; // Not used
I" ^+ R9 J" x5 `" z' H* l2 d" G mcasp->regs->DLBCTL = 0x00000000; // Not used
/ f% `: P- ^# G7 b. \: Y mcasp->regs->AMUTE = 0x00000000; // Not used, r5 D- f1 o6 Q1 Q: _
2 ]7 a, D, e" _! w# ~) L
/* Starting sections of the McASP*/
. K2 G+ L$ ~$ [ e* g, \+ H mcasp->regs->XGBLCTL |= GBLCTL_XHCLKRST_ON; 3 N" m) Q0 o. \0 F/ M6 H
while ( ( mcasp->regs->XGBLCTL & GBLCTL_XHCLKRST_ON ) != GBLCTL_XHCLKRST_ON );
& m+ K) N1 ^. R mcasp->regs->RGBLCTL |= GBLCTL_RHCLKRST_ON;
: S2 ~6 }5 @1 E while ( ( mcasp->regs->RGBLCTL & GBLCTL_RHCLKRST_ON ) != GBLCTL_RHCLKRST_ON );
' m" @5 P; d6 y3 x) n( T! @ ~ d; \# L" t& Y6 H& P( R" M
mcasp->regs->XGBLCTL |= GBLCTL_XCLKRST_ON; ?8 r# g9 S/ i) [$ Z
while ( ( mcasp->regs->XGBLCTL & GBLCTL_XCLKRST_ON ) != GBLCTL_XCLKRST_ON );# L- e5 x; R' q
mcasp->regs->RGBLCTL |= GBLCTL_RCLKRST_ON; * e/ }. Z2 g: D2 B! X0 P3 ~
while ( ( mcasp->regs->RGBLCTL & GBLCTL_RCLKRST_ON ) != GBLCTL_RCLKRST_ON );8 p, i5 ~' h( B7 D5 h
/ _8 I5 ~+ q5 U8 @7 D7 }" n6 S mcasp->regs->XSTAT = 0x0000ffff; / ^- D" i/ W8 d1 }* ?
mcasp->regs->RSTAT = 0x0000ffff;
1 k, y+ c9 ?6 |5 N/ D! H, x* g) M% [& \/ j5 P
mcasp->regs->XGBLCTL |= GBLCTL_XSRCLR_ON;
- x7 F( e; _% d5 p2 \$ w% d0 I while ( ( mcasp->regs->XGBLCTL & GBLCTL_XSRCLR_ON ) != GBLCTL_XSRCLR_ON );7 x! _ j; x! S7 L" N
mcasp->regs->RGBLCTL |= GBLCTL_RSRCLR_ON;
& ]# j* Y$ v8 a) L while ( ( mcasp->regs->RGBLCTL & GBLCTL_RSRCLR_ON ) != GBLCTL_RSRCLR_ON );
& c& x8 i+ o+ Q* }$ s3 o0 i4 g$ t# W( t* e* U. {, z
/* Write a 0, so that no underrun occurs after releasing the state machine */
# w# v$ R2 O& c; w mcasp->regs->XBUF5 = 0;
4 s, h7 p, o- Q+ X9 z mcasp->regs->RBUF0 = 0;/ Y- q7 Z0 U$ V& J) P# K1 l5 g
( K4 ?) s0 L$ P& E1 E+ E mcasp->regs->XGBLCTL |= GBLCTL_XSMRST_ON; 4 O( U% M6 v) A
while ( ( mcasp->regs->XGBLCTL & GBLCTL_XSMRST_ON ) != GBLCTL_XSMRST_ON );0 G1 o/ h, J, x& y
mcasp->regs->RGBLCTL |= GBLCTL_RSMRST_ON; 2 c( }" M3 X0 s% ?( c% p, L, V) S
while ( ( mcasp->regs->RGBLCTL & GBLCTL_RSMRST_ON ) != GBLCTL_RSMRST_ON );
7 [, W' n/ w* {" o( r4 `% r; Y/ p1 v- q* D5 L* s1 ~
mcasp->regs->XGBLCTL |= GBLCTL_XFRST_ON;
) a; Q1 q( y4 R( U1 K; G6 C% T3 C while ( ( mcasp->regs->XGBLCTL & GBLCTL_XFRST_ON ) != GBLCTL_XFRST_ON );9 _ Z3 M8 t: s6 k
mcasp->regs->RGBLCTL |= GBLCTL_RFRST_ON; 6 D m* P5 h+ y$ h
while ( ( mcasp->regs->RGBLCTL & GBLCTL_RFRST_ON ) != GBLCTL_RFRST_ON );' \+ D$ K. g1 |7 S
' r' V* T3 R4 o. N% n4 R
CSR = 0x0000;! r8 I. Z& f% f& m7 A) G$ X0 J
INTC_INTMUX1 = 0x3d;; M3 v, Z' l R) m+ b5 g! f, F
ISTP = (unsigned int)vectors;
7 |& |. p$ v' `- C ICR = 0xFFF0; * j" s- n6 W% v
IER |= 0x12; ! C/ a) N. |* B9 x- \5 U) t- r& m
CSR |= 0x01; * c! A' ~4 [3 h/ m+ g) u
3 F/ f1 f B" ?3 F
- B5 s/ O+ a- {: e; I" b/ Y- Y/ |( d
2 o$ N) B1 l1 d还有就是两个输入输出函数:
! R; F6 T" B) e) @void output_sample(Int32 out_data)
& @- s2 i/ q7 A7 f/ R{
) A$ w" ~9 r" R/ C+ B( i3 x5 ]) y AIC31_data.uint = out_data;
# o# v- y7 W- ^9 j6 A0 i# w MCASP1_XBUF5_32BIT = AIC31_data.uint;7 ?0 w6 U3 o1 x' _
}
# A( a% o) @6 R5 }' R- F7 `9 K' y
Int32 input_sample(void)
" r% E# ~& s$ u5 H# D& [. n: q0 o{
) a& l' m! j- [ AIC31_data.uint = MCASP1_RBUF0_32BIT;/ l1 e' }! j X5 C2 R
return (AIC31_data.uint);! u5 [; ?2 ^' |: P
}
0 x# m: ^: w! H4 i
3 Y; C& W6 S0 v! k$ j7 t |
|