|
|
C6747和C6748感觉差不多,我想实现McASP发送中断方式控制音频信号,在轮询的例程基础上改的,轮询程序可以实现,但是中断一直实现不了,也找不到错误,求大神帮忙!下边是主要程序:, x& r% A7 K/ f6 K0 ^& Q; O& x) Z, s
main文件:
1 C- Y. v+ e( u' ?7 s0 F: Uinterrupt void interrupt4(void)
: N% |7 Z y# t; L& i# ~/ D. I1 E( x{. _) q3 P; Q; t/ f I. N
Uint32 sample;
; V- h/ m, J- e1 I' z3 t* V6 _+ M8 t* Y6 v! Z5 G" t2 L' |
sample = input_sample(); // read L + R samples from ADC* k1 o1 G4 b1 x& {! n( u
output_sample(sample); // write L + R samples to DAC
6 }: ^' s, _! k return;
/ k' i$ c8 {6 _( E; U L}
& K% o5 E) R: n) x; P
5 F0 s, a n, ^7 W1 ~, K! R" R: Rint main( void ), f! T$ u0 M. D
{
7 Z5 ?# e- K) U: B$ T; Z9 ~! F' D3 ^& e& C9 a1 j/ E
/* Initialize BSL */2 O2 p# c# O# `; O5 r; H' S
EVMC6747_init( );
% |( B$ a) R* k2 _+ {2 W5 C /* Call evmc6747_intr function */6 j8 O' H4 w% w7 a w' p" F
aic3106_init( );) n& L' L9 v* R
while(1);1 r) ^6 {3 }8 d; O7 o0 d
}
! J, f% w2 a; i2 q6 K3 C% u
) o2 ~ x1 h! u; s$ E) `
: C2 ]2 C/ x: S. Y, Daic3106_init文件的一部分,McASP配置部分,采用内部时钟,I2S方式,同步传输。音频芯片的配置应该没问题
6 G. L, A7 d! R8 D2 s/* Initialize MCASP1 */
/ f8 X( O& p8 J' {9 T mcasp = &MCASP_MODULE_1;
' N; Q. X. s+ w4 p8 h( } mcasp->regs->GBLCTL = 0; // Reset1 u" k2 Q9 h/ ~: n5 b4 n [* k
mcasp->regs->RGBLCTL = 0; // Reset RX
s# `/ C) r4 @. R* W, r mcasp->regs->XGBLCTL = 0; // Reset TX
% f, |1 W' J+ k& r& B$ [ mcasp->regs->PWRDEMU = 1; // Free-running0 v& X1 G9 p1 d* o* J8 q7 _
// configure McASP0 receive registers) N" D! p ` _
mcasp->regs->RMASK = 0xFFFFFFFF; // No padding used
( _6 t7 |; U2 i" @+ H6 R% V' ~ mcasp->regs->RFMT = 0x00018078; // MSB 16bit, 0-delay, no pad, CFGBus4 Z7 j$ b. o Z/ B
mcasp->regs->AFSRCTL = 0x00000112; // 2TDM, 1bit Falling, External FS, word# v F& Y7 m2 L: c( y% s2 K
mcasp->regs->ACLKRCTL = 0x000000AF; // Rising INTERNAL CLK,(from tx side)
. Z) R* w$ p0 ]7 i. E5 t! C mcasp->regs->AHCLKRCTL = 0x00000000; // INT CLK (from tx side)3 N& b6 T- M$ q; y) I
mcasp->regs->RTDM = 0x00000003; // Slots 0,1
0 F- [# X2 m3 |% r4 }3 F) j mcasp->regs->RINTCTL = 0x00000000; // Not used3 h% u1 z0 l1 t
mcasp->regs->RCLKCHK = 0x00FF0008; // 255-MAX 0-MIN, div-by-256& l; U/ t6 ?3 d" c6 e% }, Q
" J" G4 r; W0 Y* P1 x
mcasp->regs->XMASK = 0xFFFFFFFF; // No padding used0 E& w% E. t. P6 w8 d ~
mcasp->regs->XFMT = 0x00018078; // MSB 16bit, 0-delay, no pad, CFGBus
, Z. v& }/ e, U6 E$ \) a1 r! { mcasp->regs->AFSXCTL = 0x00000112; // 2TDM, 1bit Rising edge INTERNAL FS, word
2 G/ u6 e' ~1 p9 `2 A- S2 A) l! T mcasp->regs->ACLKXCTL = 0x000000AF; // ASYNC, Rising INTERNAL CLK, div-by-16: T0 s4 ]) Z: u- h9 \6 | d
mcasp->regs->AHCLKXCTL = 0x00000000; // EXT CLK) T e8 {% W3 B1 V4 Y
mcasp->regs->XTDM = 0x00000003; // Slots 0,1
2 e3 Y; ?' Y7 X& R' s/ z6 } mcasp->regs->XINTCTL = 0x00000020; // interrupt on transmit
1 F. v3 x! V( c& ?6 M$ H' O$ C: \8 t mcasp->regs->XCLKCHK = 0x00FF0008; // 255-MAX 0-MIN, div-by-2563 K9 I, b( f a; p
4 G# |, n: |6 |/ J) m mcasp->regs->SRCTL5 = 0x000D; // MCASP1.AXR1[5] --> DIN' o" \% i' ~( i3 v# T9 `8 K
mcasp->regs->SRCTL0 = 0x000E; // MCASP1.AXR1[0] <-- DOUT- R% v) n6 L$ I m
mcasp->regs->PFUNC = 0; // All MCASPs+ n( p" l8 ^' a: h2 R. E' @* |& ]/ m
mcasp->regs->PDIR = 0x14000020; // All inputs except AXR0[5], ACLKX1, AFSX1* b" [+ p0 @( J8 m* q- [
% T1 K( j& C/ U mcasp->regs->DITCTL = 0x00000000; // Not used' i( B1 u( e! _
mcasp->regs->DLBCTL = 0x00000000; // Not used
; h- P. ^) J8 D% h2 S mcasp->regs->AMUTE = 0x00000000; // Not used( J9 f# `( S* X! ?+ m2 d
, }' W$ r& r' c: h4 y8 d/* Starting sections of the McASP*/3 F- w4 ^* K2 s8 `) _# P8 I( m
mcasp->regs->XGBLCTL |= GBLCTL_XHCLKRST_ON; 8 q& Q$ h! }" E) x3 H
while ( ( mcasp->regs->XGBLCTL & GBLCTL_XHCLKRST_ON ) != GBLCTL_XHCLKRST_ON );
* q3 K1 w) W0 j+ i; C mcasp->regs->RGBLCTL |= GBLCTL_RHCLKRST_ON;
4 V. G2 I$ R+ W while ( ( mcasp->regs->RGBLCTL & GBLCTL_RHCLKRST_ON ) != GBLCTL_RHCLKRST_ON );
( h! x* P, d4 {! r5 a) P4 z9 v; q7 |$ Q( L& r
mcasp->regs->XGBLCTL |= GBLCTL_XCLKRST_ON;
* p0 q4 F# j9 H2 T while ( ( mcasp->regs->XGBLCTL & GBLCTL_XCLKRST_ON ) != GBLCTL_XCLKRST_ON );$ w. q( m2 D& n! @
mcasp->regs->RGBLCTL |= GBLCTL_RCLKRST_ON; + k9 x# l' b% \4 @; ]# I( D
while ( ( mcasp->regs->RGBLCTL & GBLCTL_RCLKRST_ON ) != GBLCTL_RCLKRST_ON );
* \$ W8 p/ I- @ L9 H: ]
% _" o' r9 [5 T% ?' |( t' L/ p- e( I mcasp->regs->XSTAT = 0x0000ffff;
5 E8 G2 \! Q) X3 W* r mcasp->regs->RSTAT = 0x0000ffff;
5 {6 D( v' \; t, d* V7 z( c* X S2 R, M6 Q5 m
mcasp->regs->XGBLCTL |= GBLCTL_XSRCLR_ON;
1 u! E1 a' [0 o }, j while ( ( mcasp->regs->XGBLCTL & GBLCTL_XSRCLR_ON ) != GBLCTL_XSRCLR_ON );
5 {2 Q9 |- q# Z# v- j- j mcasp->regs->RGBLCTL |= GBLCTL_RSRCLR_ON; * u9 P" G6 F; O. L
while ( ( mcasp->regs->RGBLCTL & GBLCTL_RSRCLR_ON ) != GBLCTL_RSRCLR_ON );
7 d. h8 |( N! @& Y; ~* ~8 v9 m! B
1 i. F6 S. _/ k l9 ] /* Write a 0, so that no underrun occurs after releasing the state machine */
. Q, X) X' Y0 m- \ mcasp->regs->XBUF5 = 0;
) Q5 J3 j5 b, a2 l. ^$ T mcasp->regs->RBUF0 = 0;
$ P2 W& Q+ `# f( b7 a3 N
. V: H" d; `* j- ~% G mcasp->regs->XGBLCTL |= GBLCTL_XSMRST_ON;
2 Y: @% g. c# x! X( K% i$ q while ( ( mcasp->regs->XGBLCTL & GBLCTL_XSMRST_ON ) != GBLCTL_XSMRST_ON );
% r& N3 @$ _$ l9 D2 H mcasp->regs->RGBLCTL |= GBLCTL_RSMRST_ON; , o t& n/ M* r2 B4 I5 j
while ( ( mcasp->regs->RGBLCTL & GBLCTL_RSMRST_ON ) != GBLCTL_RSMRST_ON );
: D! X3 ^; W9 \) c. Z" d
) P2 G& y a( |4 k# O mcasp->regs->XGBLCTL |= GBLCTL_XFRST_ON;
0 U0 n' c- m- n4 D1 h while ( ( mcasp->regs->XGBLCTL & GBLCTL_XFRST_ON ) != GBLCTL_XFRST_ON );
( i" A c# g7 G2 r5 x# c mcasp->regs->RGBLCTL |= GBLCTL_RFRST_ON;
. _- w5 ]: `0 G# s9 b" X2 q) D while ( ( mcasp->regs->RGBLCTL & GBLCTL_RFRST_ON ) != GBLCTL_RFRST_ON );7 M) k! J1 X0 O- a- a2 U
, x$ `7 G1 |4 [4 X7 j Z
CSR = 0x0000;, l0 i) a2 P' m3 ~
INTC_INTMUX1 = 0x3d;
- p' F. t7 n( O) e ISTP = (unsigned int)vectors;
# r, w' L, ]) H ICR = 0xFFF0;
; i9 ?- E8 m; S4 P u IER |= 0x12; 3 U% H# z) N) B
CSR |= 0x01;
$ ~$ V5 V7 U+ d- T; N. a7 {( `: X% y5 f2 Q
7 y p8 |0 u: [0 _8 J5 Y5 d
2 k- T5 R6 `2 u( `还有就是两个输入输出函数:! U+ v) R4 L7 E" n8 T
void output_sample(Int32 out_data)( X+ A1 u' y6 U2 ?# ^7 v Q2 |; ?0 a2 b, z
{
M& G; p* r6 I AIC31_data.uint = out_data;
6 I# x) O4 w( P1 O* b; M" _ MCASP1_XBUF5_32BIT = AIC31_data.uint;
+ _' W1 i2 Y* o$ T: }' K6 V}
( J! j; n w' o9 i1 A% Z' ]4 c% O8 R* Y
Int32 input_sample(void)
' Q+ e T$ }% N# o. m) S' S1 U) ^{ ) I7 Y" g6 F2 [- J! f; s5 N& T
AIC31_data.uint = MCASP1_RBUF0_32BIT;
6 n! }& L5 L* L! F return (AIC31_data.uint);1 j( R$ w6 P4 w" r8 I
}
% T& q1 P; ?; b& E
, l5 g- r) c% `! p+ V- s1 c |
|