|
|
C6747和C6748感觉差不多,我想实现McASP发送中断方式控制音频信号,在轮询的例程基础上改的,轮询程序可以实现,但是中断一直实现不了,也找不到错误,求大神帮忙!下边是主要程序:- o- \, F5 z# i0 ~1 Y3 M8 \3 g& l
main文件:
1 _% Q* _ [0 E9 q' ^8 |interrupt void interrupt4(void) / I7 y7 j7 U$ T: C, T$ n& U. }) V1 }
{
. [8 S9 s( a' k/ U Uint32 sample;# l5 B7 R/ [9 b( O8 q* n# D2 O
$ D/ K2 u$ g S! X8 d
sample = input_sample(); // read L + R samples from ADC' T+ w( _" W/ Q; X( Y
output_sample(sample); // write L + R samples to DAC * [4 c2 ^, e3 s; o; j
return;
, `8 p) J; ~8 Z4 l# B# A- {}' C7 d8 E, u+ w$ G) J
: M' s# l8 k8 ~! e! {' S9 Kint main( void )3 t [% @1 i' v( \
{
' w2 b( V3 g; N+ _
! ~# R1 t! M4 M) O9 Q* i2 e /* Initialize BSL */
9 b8 ?6 D6 e0 K EVMC6747_init( );8 e7 g" M1 j) p% v5 O! ?$ Y
/* Call evmc6747_intr function */7 d$ m' t7 K9 C
aic3106_init( );
3 k7 r4 Q# F7 P/ i1 d9 O" c while(1);$ ]. w, Y/ ^+ [' d2 s1 ]
}+ ^' p5 A% U6 G: [% y, k
7 p8 X/ \& b2 J- A6 R: B2 b
0 @) O! U) J7 t" Q& {aic3106_init文件的一部分,McASP配置部分,采用内部时钟,I2S方式,同步传输。音频芯片的配置应该没问题
$ R) Z: c: p% v6 G/* Initialize MCASP1 */
4 v& g/ i0 p9 T( n- ^: F mcasp = &MCASP_MODULE_1;/ E5 |* }2 s( |: ?8 f
mcasp->regs->GBLCTL = 0; // Reset
5 A. ~& X! q- O+ `7 \3 U q mcasp->regs->RGBLCTL = 0; // Reset RX! |3 Z1 m4 [8 N0 Z3 c( k8 Z B
mcasp->regs->XGBLCTL = 0; // Reset TX
2 h* I4 E( J9 f0 ^/ O* n mcasp->regs->PWRDEMU = 1; // Free-running4 E2 y& S6 b, @7 m
// configure McASP0 receive registers
! Y5 [) `3 s# ] i5 z5 C6 a mcasp->regs->RMASK = 0xFFFFFFFF; // No padding used
7 y' J9 }' p, p: E, ]1 X mcasp->regs->RFMT = 0x00018078; // MSB 16bit, 0-delay, no pad, CFGBus
. `7 w: t: e+ Q) p mcasp->regs->AFSRCTL = 0x00000112; // 2TDM, 1bit Falling, External FS, word ]- K1 v: a1 g/ p
mcasp->regs->ACLKRCTL = 0x000000AF; // Rising INTERNAL CLK,(from tx side)
9 g/ w0 n7 a+ i5 R& L: a( R mcasp->regs->AHCLKRCTL = 0x00000000; // INT CLK (from tx side)7 K5 I+ f/ _, e$ W) @0 |( j8 K
mcasp->regs->RTDM = 0x00000003; // Slots 0,1
: g" z. `( W' v& E6 |, n: V' a mcasp->regs->RINTCTL = 0x00000000; // Not used
; k$ }- u9 a c& a0 D6 ^9 T! c U mcasp->regs->RCLKCHK = 0x00FF0008; // 255-MAX 0-MIN, div-by-256
- ^5 O2 H6 `7 i' u: j: |7 d i1 G( S$ {
0 i/ i$ H6 t- w6 | mcasp->regs->XMASK = 0xFFFFFFFF; // No padding used
6 ?7 J; j) ^) g' ? mcasp->regs->XFMT = 0x00018078; // MSB 16bit, 0-delay, no pad, CFGBus2 F5 {. L/ a. p0 v+ F6 D9 h
mcasp->regs->AFSXCTL = 0x00000112; // 2TDM, 1bit Rising edge INTERNAL FS, word' y- k3 O g! B; H0 m
mcasp->regs->ACLKXCTL = 0x000000AF; // ASYNC, Rising INTERNAL CLK, div-by-163 E+ Q: p1 Y% Z; }5 a) N
mcasp->regs->AHCLKXCTL = 0x00000000; // EXT CLK" h: H1 D7 D+ e, r
mcasp->regs->XTDM = 0x00000003; // Slots 0,1
/ X2 h; f9 T- F& H: J6 B% J& Q7 H mcasp->regs->XINTCTL = 0x00000020; // interrupt on transmit, f4 B: C; B9 u0 a+ v; n
mcasp->regs->XCLKCHK = 0x00FF0008; // 255-MAX 0-MIN, div-by-256- j! m) @$ k: i5 q
2 y) \) W, J5 U( t! w- g
mcasp->regs->SRCTL5 = 0x000D; // MCASP1.AXR1[5] --> DIN
0 e9 C' J) F) n* q3 B% P- m mcasp->regs->SRCTL0 = 0x000E; // MCASP1.AXR1[0] <-- DOUT
% }) R# ]. @* h. W( {/ `1 q' e- o mcasp->regs->PFUNC = 0; // All MCASPs: U- ]" g- e' O# }+ ~
mcasp->regs->PDIR = 0x14000020; // All inputs except AXR0[5], ACLKX1, AFSX1- o: v& f7 J' V3 p. E
2 O1 r' g8 p! ? mcasp->regs->DITCTL = 0x00000000; // Not used
( I; c0 N+ G# e) ~1 }* \& b mcasp->regs->DLBCTL = 0x00000000; // Not used' `% f- }7 P+ y) c: }
mcasp->regs->AMUTE = 0x00000000; // Not used
' u2 h6 X4 t3 l3 |4 X6 V2 j8 G- Z* Q
/* Starting sections of the McASP*/8 }+ ]$ R. C v) R2 C, f4 S% e4 Y1 e
mcasp->regs->XGBLCTL |= GBLCTL_XHCLKRST_ON; ) K7 [6 j6 K0 w
while ( ( mcasp->regs->XGBLCTL & GBLCTL_XHCLKRST_ON ) != GBLCTL_XHCLKRST_ON ); % I8 t$ m, a5 N- M* [
mcasp->regs->RGBLCTL |= GBLCTL_RHCLKRST_ON;
1 @( |! e" p! X& a' h& e+ z. V9 ^ while ( ( mcasp->regs->RGBLCTL & GBLCTL_RHCLKRST_ON ) != GBLCTL_RHCLKRST_ON );: @# g I. }( j9 t( Z2 F
* K9 c; \# ]6 m1 ?2 x+ m mcasp->regs->XGBLCTL |= GBLCTL_XCLKRST_ON;
1 S6 }( A% G5 n3 y4 D2 a- z g. }* M while ( ( mcasp->regs->XGBLCTL & GBLCTL_XCLKRST_ON ) != GBLCTL_XCLKRST_ON );! H0 p: J# G# V+ s" U! i: t
mcasp->regs->RGBLCTL |= GBLCTL_RCLKRST_ON; 6 O% b8 b. R, J1 g* g
while ( ( mcasp->regs->RGBLCTL & GBLCTL_RCLKRST_ON ) != GBLCTL_RCLKRST_ON );
$ H4 |1 d0 Y& Q% N. x" k4 ^
. g+ f) O) j4 c# f/ M: m6 [ mcasp->regs->XSTAT = 0x0000ffff; 3 M0 j: f) J% `
mcasp->regs->RSTAT = 0x0000ffff;
: `2 X. ^, C1 o0 E% |3 e8 I' ?1 j! \3 S9 ?
mcasp->regs->XGBLCTL |= GBLCTL_XSRCLR_ON;
* ?! F- F! F$ | while ( ( mcasp->regs->XGBLCTL & GBLCTL_XSRCLR_ON ) != GBLCTL_XSRCLR_ON );
, O" N' P# V% e) \7 @5 G5 c+ ? mcasp->regs->RGBLCTL |= GBLCTL_RSRCLR_ON;
8 \! b3 e* ~ i8 t6 A# D while ( ( mcasp->regs->RGBLCTL & GBLCTL_RSRCLR_ON ) != GBLCTL_RSRCLR_ON );2 J0 C: X1 ~/ v0 F
, A! E( x9 Q0 _. o; ]1 t; z- l$ j- G /* Write a 0, so that no underrun occurs after releasing the state machine */
7 J* d+ G% I {) Q9 B5 d mcasp->regs->XBUF5 = 0;1 ~- h% u0 {/ ?# ]- `: e
mcasp->regs->RBUF0 = 0;
& D3 P7 W& G# q
% U7 }; q' x/ X5 k mcasp->regs->XGBLCTL |= GBLCTL_XSMRST_ON;
+ `- m2 b5 D- X. V5 }8 K; c: H while ( ( mcasp->regs->XGBLCTL & GBLCTL_XSMRST_ON ) != GBLCTL_XSMRST_ON );
; O! d* S2 ~ D+ {& V5 y mcasp->regs->RGBLCTL |= GBLCTL_RSMRST_ON;
6 x" K$ i: B; y9 c$ l while ( ( mcasp->regs->RGBLCTL & GBLCTL_RSMRST_ON ) != GBLCTL_RSMRST_ON );
" y4 Y* e7 d5 ^7 h9 z/ F1 w4 q( G' j, u$ Z6 b
mcasp->regs->XGBLCTL |= GBLCTL_XFRST_ON; 9 ?) T) k5 B. C$ }5 B! C
while ( ( mcasp->regs->XGBLCTL & GBLCTL_XFRST_ON ) != GBLCTL_XFRST_ON );
) R2 I& D4 u$ i- |" R mcasp->regs->RGBLCTL |= GBLCTL_RFRST_ON;
% [1 _0 E {3 l6 S while ( ( mcasp->regs->RGBLCTL & GBLCTL_RFRST_ON ) != GBLCTL_RFRST_ON );- F& Q! p/ [3 e. Q1 @& D7 F
5 y/ g1 N3 p' e% ~% v/ o3 V CSR = 0x0000;: |- }, F/ H/ `1 u! w
INTC_INTMUX1 = 0x3d;
0 s! o; z& g! J) }+ A ISTP = (unsigned int)vectors;
) n8 X% n) |4 _- J# ? ICR = 0xFFF0; . V5 D s, j7 q k. F# J
IER |= 0x12; 8 p* Q# H' B- S8 c' e$ o4 O: \( L( K
CSR |= 0x01; 5 h* G. F- M* `9 X- B/ S/ _& H7 N
. t9 Q4 j# ]3 M/ \
# l: Q4 b5 M. I: P; A( t1 G+ z. ?& p+ a7 p# h( ^- x- ~
还有就是两个输入输出函数:
* E$ V" Q$ H f* P6 xvoid output_sample(Int32 out_data)! f0 ^' |9 y7 G( D& z1 m S) A
{
_# j) ?/ K: r% { AIC31_data.uint = out_data; $ m6 X: C# g5 f! H& H3 W7 x) s
MCASP1_XBUF5_32BIT = AIC31_data.uint;: @2 I* n4 {: f7 M1 ~( h
}1 E2 Y* l# r% C% _. @
6 ?1 P& s# [! C, w6 n! ? F
Int32 input_sample(void)
3 e1 q( q0 l, r8 Q u) v5 ]# p/ w{ + d6 Z z$ j, E1 n0 w3 U! L' p; `
AIC31_data.uint = MCASP1_RBUF0_32BIT;
/ X' k5 ]* x) F: A return (AIC31_data.uint);6 z% R& O& x5 e* @1 K
}; B! e+ g c/ q' m
" c. `+ o2 D# c, e
|
|