|
|
C6747和C6748感觉差不多,我想实现McASP发送中断方式控制音频信号,在轮询的例程基础上改的,轮询程序可以实现,但是中断一直实现不了,也找不到错误,求大神帮忙!下边是主要程序:0 u7 @7 A/ F9 x1 x: E
main文件:: [: t9 J; E" K$ y3 E' s! l
interrupt void interrupt4(void)
/ B1 v( ^& C# D. a% B2 [% ~1 K{
6 S: L4 P v% k: d' c" f5 @ Uint32 sample;
* C7 p1 D" o+ E: V4 i- V. f
* o! ]6 R+ w3 R sample = input_sample(); // read L + R samples from ADC8 H0 g% B! J/ W4 `8 ^
output_sample(sample); // write L + R samples to DAC 9 [+ g) U" I! E# K' m) f/ {
return;
% e8 t2 r3 N5 |' `}
& D' r" W \" I% j f' N+ I' F5 G: W0 l- `
int main( void )( K1 d/ S; R: f0 k# U
{
/ ]+ m5 g1 Q6 ~& B$ Z( v0 |* M3 r' D9 B
/* Initialize BSL */
, k5 L- O- G; h" k) g EVMC6747_init( );4 g+ e% z1 }$ F4 S
/* Call evmc6747_intr function */
- [( H( F+ g$ t0 ]; x aic3106_init( );0 p8 c4 C& q @4 G: F3 Q
while(1);
9 ]0 N* k: D# X2 Z( T3 ~+ W}4 K5 V' a+ ^, a6 G5 b
" L$ {0 e) ]4 c% k; H' k) f
} r1 H9 `: M. J+ O4 Daic3106_init文件的一部分,McASP配置部分,采用内部时钟,I2S方式,同步传输。音频芯片的配置应该没问题* V* P) Z! w: O
/* Initialize MCASP1 *// U$ @0 f" Y' Z W2 v8 n
mcasp = &MCASP_MODULE_1;
0 K0 \5 k7 n1 a! o+ H5 V mcasp->regs->GBLCTL = 0; // Reset
: h' g% v+ p- v1 L1 {9 C mcasp->regs->RGBLCTL = 0; // Reset RX
/ ]2 L( Y: K% b: S0 ]8 g: h& ~6 c mcasp->regs->XGBLCTL = 0; // Reset TX
) c s+ ~6 {/ I' N9 g/ @3 K mcasp->regs->PWRDEMU = 1; // Free-running
" |1 |2 ?" ^6 R3 }( P, o // configure McASP0 receive registers
# I6 D s9 e6 Z7 T1 ^% N: v mcasp->regs->RMASK = 0xFFFFFFFF; // No padding used
; C8 k* e4 G# \* U2 O, `+ c: Z mcasp->regs->RFMT = 0x00018078; // MSB 16bit, 0-delay, no pad, CFGBus3 ]0 y" J' m3 }, O* R3 I7 n4 b
mcasp->regs->AFSRCTL = 0x00000112; // 2TDM, 1bit Falling, External FS, word
; t/ ]$ E% s W B6 b/ [ mcasp->regs->ACLKRCTL = 0x000000AF; // Rising INTERNAL CLK,(from tx side)
# n2 C7 X: Q" b! N7 N mcasp->regs->AHCLKRCTL = 0x00000000; // INT CLK (from tx side)4 L+ Z' D4 i- s+ z' c" o! F! F: [1 [
mcasp->regs->RTDM = 0x00000003; // Slots 0,1+ @1 x3 P) R: M
mcasp->regs->RINTCTL = 0x00000000; // Not used! Z* ?5 y- l; h# G- H
mcasp->regs->RCLKCHK = 0x00FF0008; // 255-MAX 0-MIN, div-by-256
* O* d) Z1 }- U, O# G f7 C$ @
: G: c4 r" o& {7 ^& ] mcasp->regs->XMASK = 0xFFFFFFFF; // No padding used
2 q+ Q. K$ ~! p* W& H- L& b mcasp->regs->XFMT = 0x00018078; // MSB 16bit, 0-delay, no pad, CFGBus- G$ f* ]0 P$ l" G- j% D
mcasp->regs->AFSXCTL = 0x00000112; // 2TDM, 1bit Rising edge INTERNAL FS, word
- @1 n7 E$ p* t$ C6 q mcasp->regs->ACLKXCTL = 0x000000AF; // ASYNC, Rising INTERNAL CLK, div-by-16
$ @: d! \5 ]0 f6 e% x- c mcasp->regs->AHCLKXCTL = 0x00000000; // EXT CLK6 } n8 u; O k! J
mcasp->regs->XTDM = 0x00000003; // Slots 0,1
. N: F' ~) D2 Q0 ?: P" D mcasp->regs->XINTCTL = 0x00000020; // interrupt on transmit
4 u7 O5 e6 Y- U& r mcasp->regs->XCLKCHK = 0x00FF0008; // 255-MAX 0-MIN, div-by-256
6 P4 U) I. F& a/ b; c( ~8 l) u7 H* E: G4 r; \* @
mcasp->regs->SRCTL5 = 0x000D; // MCASP1.AXR1[5] --> DIN
2 f! [' y. s$ P mcasp->regs->SRCTL0 = 0x000E; // MCASP1.AXR1[0] <-- DOUT1 J! }( `- Q. p% y* n
mcasp->regs->PFUNC = 0; // All MCASPs
# I! B* e& g& i4 f! f mcasp->regs->PDIR = 0x14000020; // All inputs except AXR0[5], ACLKX1, AFSX1
! \ l+ T2 d# l( I; v7 o; A. ?
0 n7 A9 v2 l" U" a% f- x: K) z2 ~# L mcasp->regs->DITCTL = 0x00000000; // Not used! u: }% G* n$ S6 B
mcasp->regs->DLBCTL = 0x00000000; // Not used
" H9 X, N/ R) |6 Y2 g( p mcasp->regs->AMUTE = 0x00000000; // Not used, T$ x# P6 I8 h+ j. F
: h3 g: I! m. ]/* Starting sections of the McASP*/, j% A/ y/ A, U$ K# K3 f" o
mcasp->regs->XGBLCTL |= GBLCTL_XHCLKRST_ON; 7 R6 N8 S0 J) n1 ~! q. _
while ( ( mcasp->regs->XGBLCTL & GBLCTL_XHCLKRST_ON ) != GBLCTL_XHCLKRST_ON ); 1 m6 d( n3 _; A
mcasp->regs->RGBLCTL |= GBLCTL_RHCLKRST_ON;
" x9 P" `! }2 `6 |( A while ( ( mcasp->regs->RGBLCTL & GBLCTL_RHCLKRST_ON ) != GBLCTL_RHCLKRST_ON );
' S1 F6 [; r; C$ J. P3 W# n& C) I& i1 O7 K. v7 j" q$ ^% H3 c
mcasp->regs->XGBLCTL |= GBLCTL_XCLKRST_ON;
9 r4 r0 S. a2 Y& y+ G5 w while ( ( mcasp->regs->XGBLCTL & GBLCTL_XCLKRST_ON ) != GBLCTL_XCLKRST_ON );
, u$ r' L V+ p mcasp->regs->RGBLCTL |= GBLCTL_RCLKRST_ON; # q- f' h% i0 ]
while ( ( mcasp->regs->RGBLCTL & GBLCTL_RCLKRST_ON ) != GBLCTL_RCLKRST_ON );
3 j i/ t( ] w9 J. J: Y" T+ w) a: e3 K& E9 G2 O7 U
mcasp->regs->XSTAT = 0x0000ffff;
$ |6 i9 {" y; U7 B0 W. g: M. X mcasp->regs->RSTAT = 0x0000ffff; ' w2 Q; Z; }: r
) n" _* @9 k$ Y I4 M) m
mcasp->regs->XGBLCTL |= GBLCTL_XSRCLR_ON;
, h. }8 d, U& H: W while ( ( mcasp->regs->XGBLCTL & GBLCTL_XSRCLR_ON ) != GBLCTL_XSRCLR_ON );( Z7 z! ~# k0 ~0 G& k
mcasp->regs->RGBLCTL |= GBLCTL_RSRCLR_ON; 5 E0 @( j: a \! [2 N) E7 |( k8 d
while ( ( mcasp->regs->RGBLCTL & GBLCTL_RSRCLR_ON ) != GBLCTL_RSRCLR_ON );1 d+ } H) w' l: Y, h0 |! u
6 c$ J1 j5 r( c! d S /* Write a 0, so that no underrun occurs after releasing the state machine */
3 l# |. I5 t8 D6 Y% i+ q mcasp->regs->XBUF5 = 0;
- G# z2 y( E- r7 C9 V0 C" r mcasp->regs->RBUF0 = 0;
4 q! m3 C- S% v$ v+ W* ^- w" ~' x; G" A* X
mcasp->regs->XGBLCTL |= GBLCTL_XSMRST_ON;
8 e, M% |5 p- u+ {6 U$ d while ( ( mcasp->regs->XGBLCTL & GBLCTL_XSMRST_ON ) != GBLCTL_XSMRST_ON );
8 h+ s( l0 y( |( h# g mcasp->regs->RGBLCTL |= GBLCTL_RSMRST_ON;
6 ^3 I1 b- r; u0 A! D0 Z3 J, D while ( ( mcasp->regs->RGBLCTL & GBLCTL_RSMRST_ON ) != GBLCTL_RSMRST_ON );
+ K% n# U0 B% l4 ^8 F& P; P1 A' z( W- X" Q% Q
mcasp->regs->XGBLCTL |= GBLCTL_XFRST_ON;
6 [7 c, M; E0 g2 S& ?6 S! _7 g while ( ( mcasp->regs->XGBLCTL & GBLCTL_XFRST_ON ) != GBLCTL_XFRST_ON );
- d- u% R; m' Y# o, n% U6 W mcasp->regs->RGBLCTL |= GBLCTL_RFRST_ON; e- P Z2 D9 H: }3 [7 j; d! Y! Q
while ( ( mcasp->regs->RGBLCTL & GBLCTL_RFRST_ON ) != GBLCTL_RFRST_ON );+ b) `# O4 a: m! E3 K, \4 E% n
1 c! w3 O8 F& Q9 q9 |/ G CSR = 0x0000;" z2 _- R* `, L% L/ K2 m1 T4 A
INTC_INTMUX1 = 0x3d;) H6 s! C) m+ X* K+ o0 W& w
ISTP = (unsigned int)vectors;1 j: S" @9 Q9 H9 K# ^
ICR = 0xFFF0; * c ?2 H8 C& L. t& `
IER |= 0x12; T) e) J' R g3 D
CSR |= 0x01; ( V7 ]8 c# p+ b; U5 i. Z
; R- Q. K' ^4 i: x) c, V) k
' I$ q: ] F" t& [5 B/ g8 }$ ?; o& I3 A' J+ l% d5 @
还有就是两个输入输出函数:
4 l4 S. N9 [! f: D4 a! Svoid output_sample(Int32 out_data)4 Y# _1 X( \% ?/ r' y# l
{% {' |0 O* ?# O1 Y: \
AIC31_data.uint = out_data; % A* Q! |6 y& X/ Y9 X
MCASP1_XBUF5_32BIT = AIC31_data.uint;
5 U& \2 X( v8 s0 T5 z, ~8 E; e% L}& F2 R e1 `) Y( O: }
$ w: c. t/ a. ?" fInt32 input_sample(void)
6 n: l3 h: p- a9 x" i- Q{ & E/ ]* Q+ g; }! S/ C1 L
AIC31_data.uint = MCASP1_RBUF0_32BIT;) u9 Z! ^4 W& G6 ^( P
return (AIC31_data.uint);! r; N' x& D3 q
}
6 A7 u6 k& Y8 ?' {% q$ [1 e' U. p3 i! Q, Q
|
|