|
|
C6747和C6748感觉差不多,我想实现McASP发送中断方式控制音频信号,在轮询的例程基础上改的,轮询程序可以实现,但是中断一直实现不了,也找不到错误,求大神帮忙!下边是主要程序:
9 N# R, P4 d" h6 dmain文件:
$ U/ P2 Z4 G$ \6 @+ D; a3 t0 F6 r2 qinterrupt void interrupt4(void)
4 o3 D6 N7 n2 d5 W( A{. U) P8 r0 V# C, s6 }8 O: K
Uint32 sample;
3 F: [. U+ J- m. J; W2 v
6 Z$ u) o4 f! b0 H7 m1 S sample = input_sample(); // read L + R samples from ADC& E3 n, O$ ^3 c8 U5 V' W& c& j
output_sample(sample); // write L + R samples to DAC
9 x2 q, @: s: ^. s( ] return;/ V+ |8 d, O9 v0 q- |+ n5 V8 f/ L1 A
}
! u& ~4 r6 ~( ?
2 r7 i+ g, v7 C2 u1 Zint main( void )
* b/ {* I2 \! v, `- u+ D6 ]{$ ?4 A" S7 y4 }
# b2 h9 G0 a: y( s1 {
/* Initialize BSL */
( Z! o' i, q3 S6 O' ? EVMC6747_init( );
1 H0 h5 z. I: y' C: B /* Call evmc6747_intr function */
& ~* q4 x) l* M, \8 Q7 h aic3106_init( );
( B$ t3 H$ v2 L% z6 r" m' s4 h while(1);3 z# R% M, {& r, p2 p! K
}
7 p& B' V7 h o' R3 b1 N4 j% J D. N3 j& w9 c6 |% B% {
2 U, O9 L/ |; p. v$ Q
aic3106_init文件的一部分,McASP配置部分,采用内部时钟,I2S方式,同步传输。音频芯片的配置应该没问题
1 }& B. z9 s7 K ?+ J( P/* Initialize MCASP1 */1 q9 z. n, ]6 E2 r# A
mcasp = &MCASP_MODULE_1;' a. A( h6 @8 \7 o2 h( U
mcasp->regs->GBLCTL = 0; // Reset
' ^0 Y+ d2 z" Q( P9 E6 i7 M9 } mcasp->regs->RGBLCTL = 0; // Reset RX% R" `* ?: y+ r& F$ q% T, [- R
mcasp->regs->XGBLCTL = 0; // Reset TX" u l" p9 k. E4 U; j: y. Y
mcasp->regs->PWRDEMU = 1; // Free-running3 f8 I# m- e0 b b
// configure McASP0 receive registers
0 k# _) B9 X0 P2 P; G mcasp->regs->RMASK = 0xFFFFFFFF; // No padding used/ P+ {4 T5 Y" F. J& T5 C
mcasp->regs->RFMT = 0x00018078; // MSB 16bit, 0-delay, no pad, CFGBus
1 n1 J8 W" E! P) S' r mcasp->regs->AFSRCTL = 0x00000112; // 2TDM, 1bit Falling, External FS, word
" Y* K, j) p, ?+ I mcasp->regs->ACLKRCTL = 0x000000AF; // Rising INTERNAL CLK,(from tx side)/ W( u0 z6 }8 \( V/ K) l
mcasp->regs->AHCLKRCTL = 0x00000000; // INT CLK (from tx side)
0 r/ o& P: M2 Y, N% o0 w; u& k mcasp->regs->RTDM = 0x00000003; // Slots 0,1- O' W: k2 x: X5 l3 n: R
mcasp->regs->RINTCTL = 0x00000000; // Not used4 y9 d( L) D9 R
mcasp->regs->RCLKCHK = 0x00FF0008; // 255-MAX 0-MIN, div-by-256
; }- v* O& P- K6 z U: L# s8 e" P" U8 I8 b7 t& V/ g
mcasp->regs->XMASK = 0xFFFFFFFF; // No padding used
) q9 b, v7 X+ { mcasp->regs->XFMT = 0x00018078; // MSB 16bit, 0-delay, no pad, CFGBus2 _, H8 C0 G( z$ y
mcasp->regs->AFSXCTL = 0x00000112; // 2TDM, 1bit Rising edge INTERNAL FS, word4 u# }( ` u* N" `3 a
mcasp->regs->ACLKXCTL = 0x000000AF; // ASYNC, Rising INTERNAL CLK, div-by-16( u+ Q" \& t+ a
mcasp->regs->AHCLKXCTL = 0x00000000; // EXT CLK! G; z6 p1 K/ c# |7 d
mcasp->regs->XTDM = 0x00000003; // Slots 0,1
* ?# h) ~3 P* G$ w6 l mcasp->regs->XINTCTL = 0x00000020; // interrupt on transmit
; `9 X) |+ f' T" X mcasp->regs->XCLKCHK = 0x00FF0008; // 255-MAX 0-MIN, div-by-256 l' d# E/ A( J M9 y; D: b1 [
, L, O C- @1 b+ e4 N9 I
mcasp->regs->SRCTL5 = 0x000D; // MCASP1.AXR1[5] --> DIN% `; [( b( u8 p
mcasp->regs->SRCTL0 = 0x000E; // MCASP1.AXR1[0] <-- DOUT. m* P# A+ y w i: L
mcasp->regs->PFUNC = 0; // All MCASPs4 K c6 S" f0 k1 b
mcasp->regs->PDIR = 0x14000020; // All inputs except AXR0[5], ACLKX1, AFSX1
% W* }) i" ]+ v/ u
8 w- h2 U" k# N6 k5 M4 j mcasp->regs->DITCTL = 0x00000000; // Not used$ c0 o5 Q0 `7 l$ w; Y% V
mcasp->regs->DLBCTL = 0x00000000; // Not used7 {9 \$ ]/ e9 f* T' Z" j3 b
mcasp->regs->AMUTE = 0x00000000; // Not used
. x( R% c- Z% M8 ^. _ u( u ]+ O$ g! S
/* Starting sections of the McASP*/
, `# F4 z% S; O mcasp->regs->XGBLCTL |= GBLCTL_XHCLKRST_ON;
+ ^1 p' V E' \" f7 L! T while ( ( mcasp->regs->XGBLCTL & GBLCTL_XHCLKRST_ON ) != GBLCTL_XHCLKRST_ON ); ! _- M& P; ^* @
mcasp->regs->RGBLCTL |= GBLCTL_RHCLKRST_ON;
) `2 N3 c" t' d+ ` while ( ( mcasp->regs->RGBLCTL & GBLCTL_RHCLKRST_ON ) != GBLCTL_RHCLKRST_ON );
M6 h8 o2 z7 V7 |8 @$ ] O) C' a2 t' j1 B8 u* @
mcasp->regs->XGBLCTL |= GBLCTL_XCLKRST_ON;
; l# W% y; t* x while ( ( mcasp->regs->XGBLCTL & GBLCTL_XCLKRST_ON ) != GBLCTL_XCLKRST_ON );
. A+ M# q* J$ Z: Y mcasp->regs->RGBLCTL |= GBLCTL_RCLKRST_ON;
; W( u% J" I6 m \3 E0 o/ h while ( ( mcasp->regs->RGBLCTL & GBLCTL_RCLKRST_ON ) != GBLCTL_RCLKRST_ON );0 F$ }+ @7 n! W6 e" t! N& L% a, L
- j ] Y h0 T$ j
mcasp->regs->XSTAT = 0x0000ffff;
. N) w- o: p2 W5 I8 g# Z mcasp->regs->RSTAT = 0x0000ffff; ; j; t9 o5 S4 l4 D0 l7 f% Z u' w
6 E8 V$ v2 A1 D mcasp->regs->XGBLCTL |= GBLCTL_XSRCLR_ON;0 y& M+ i% { L& w) W$ C9 {$ C
while ( ( mcasp->regs->XGBLCTL & GBLCTL_XSRCLR_ON ) != GBLCTL_XSRCLR_ON );1 G: Q/ ~& Q" l6 Z2 e/ i9 F$ e8 Y
mcasp->regs->RGBLCTL |= GBLCTL_RSRCLR_ON; ; C- }3 c* F* b5 d. R. u
while ( ( mcasp->regs->RGBLCTL & GBLCTL_RSRCLR_ON ) != GBLCTL_RSRCLR_ON );
2 \* `, x2 t4 w/ C
+ ~+ m+ u) r* u w /* Write a 0, so that no underrun occurs after releasing the state machine */
4 J3 E7 l; v" ~) A$ j mcasp->regs->XBUF5 = 0;$ b" {! I; x* S, B- P
mcasp->regs->RBUF0 = 0;1 Q4 w9 b1 }, i# e7 ?
5 f3 f* p$ m4 ?5 P
mcasp->regs->XGBLCTL |= GBLCTL_XSMRST_ON; 8 _; V+ K. e5 n4 |- h
while ( ( mcasp->regs->XGBLCTL & GBLCTL_XSMRST_ON ) != GBLCTL_XSMRST_ON );
) s/ o5 z1 b8 N mcasp->regs->RGBLCTL |= GBLCTL_RSMRST_ON;
. z; I6 P) Q, \ while ( ( mcasp->regs->RGBLCTL & GBLCTL_RSMRST_ON ) != GBLCTL_RSMRST_ON );
& w! Y9 H9 V5 p
- ^, a8 ^+ \% K# N+ G6 m mcasp->regs->XGBLCTL |= GBLCTL_XFRST_ON; 2 }8 @( n+ K& }1 m: t1 k- r$ D
while ( ( mcasp->regs->XGBLCTL & GBLCTL_XFRST_ON ) != GBLCTL_XFRST_ON );$ C1 h1 _' r Y1 m. _
mcasp->regs->RGBLCTL |= GBLCTL_RFRST_ON;
! L. y& G# K, i- O5 u) I p! z while ( ( mcasp->regs->RGBLCTL & GBLCTL_RFRST_ON ) != GBLCTL_RFRST_ON );
! \# r& r1 g3 Z [2 U/ ], E) W/ ^0 L" f. u
CSR = 0x0000;# S. }; J4 k- b$ C; X7 S
INTC_INTMUX1 = 0x3d;
# E& A. H( N2 E& P ISTP = (unsigned int)vectors;) _, a" e0 ~3 ?8 _9 F$ p& p1 u
ICR = 0xFFF0;
6 u" b: B* j: R- H' Z IER |= 0x12; 2 x5 O* h' u+ z/ J
CSR |= 0x01;
7 I+ h2 m) G- ^4 _1 M% K
: ] _( l3 J1 h3 Q, b' D T2 ]8 v/ D/ P
3 Z3 V% E3 T0 B; t% P# t
还有就是两个输入输出函数:% G0 j7 o7 h) V6 ^: ~
void output_sample(Int32 out_data), R( g3 Q! C4 x4 q' ]; `6 N
{
4 l5 ~1 M+ F. O" R- k% k AIC31_data.uint = out_data; I( t* A1 q. W7 L) ]& J" |$ s
MCASP1_XBUF5_32BIT = AIC31_data.uint;
0 f) @6 }8 x' l. ?; b8 z# t, S/ K: b1 [}
) E- n, | _ e6 A X- w
, M1 t& s. {$ OInt32 input_sample(void)4 P( m! }# ]& x, @
{
" |6 A, f4 } E0 S9 c( N, U AIC31_data.uint = MCASP1_RBUF0_32BIT;7 F; Q4 i3 l# f* b Q+ C
return (AIC31_data.uint);
2 V( l3 @1 {/ o, s}
; h, r, v6 _( a) D, C+ }# g& n* n9 Q! ~
|
|