|
|
C6747和C6748感觉差不多,我想实现McASP发送中断方式控制音频信号,在轮询的例程基础上改的,轮询程序可以实现,但是中断一直实现不了,也找不到错误,求大神帮忙!下边是主要程序:
/ @0 w) `2 G( _1 P' ~( e( Rmain文件:
0 \& e( @" E& a& X& n& Z" [interrupt void interrupt4(void)
' Z/ ]0 f" u" O8 b! s5 D' _5 g% |5 |. @{' F- L* v3 N( R: i2 J' O' ]
Uint32 sample;
6 M, C! S @8 y5 q
. T8 x4 D$ I. E$ I+ ~8 [) r sample = input_sample(); // read L + R samples from ADC* ]* Q! l* r5 H9 t" U# G* v' Z& m
output_sample(sample); // write L + R samples to DAC % R& I& V, @2 I" D
return;* f8 W8 i2 `4 U! R6 O3 n# U
}
3 `# N2 A& v# q9 ^# d
0 S1 v2 ~: `7 D, e* |int main( void )9 q( {9 q6 e& I
{( ?3 ~9 q2 W( `% G# R$ z) X
: T" w& s' J" o/ L' w3 P0 d
/* Initialize BSL */
* A- ^' u6 a& Z% n EVMC6747_init( );; V0 h+ c" y* B& l
/* Call evmc6747_intr function */( D& }3 V0 `$ S! H/ g3 V* s
aic3106_init( );
$ d3 F4 K% o& B1 ]" b6 I while(1);# W- w6 y% F/ V, X& x4 D# P
} V- v0 p. z/ Z5 ]
+ O7 O9 u4 A& E2 R4 F
7 c/ j( g+ f" H, a7 u$ xaic3106_init文件的一部分,McASP配置部分,采用内部时钟,I2S方式,同步传输。音频芯片的配置应该没问题
; `* x) n2 B1 D0 V" H/* Initialize MCASP1 */
' @5 g3 z3 |! r mcasp = &MCASP_MODULE_1;
' k" u9 }; m2 y' d mcasp->regs->GBLCTL = 0; // Reset
5 R6 C. J0 W( q) V2 S mcasp->regs->RGBLCTL = 0; // Reset RX; \! P0 O4 t# y. Y" X# i
mcasp->regs->XGBLCTL = 0; // Reset TX; [# e% _3 L; P( h
mcasp->regs->PWRDEMU = 1; // Free-running, Y& f8 |7 e O4 S0 z( D' }
// configure McASP0 receive registers c0 x3 }7 A8 F s6 {8 I
mcasp->regs->RMASK = 0xFFFFFFFF; // No padding used6 j; ~/ n4 H' }6 _
mcasp->regs->RFMT = 0x00018078; // MSB 16bit, 0-delay, no pad, CFGBus; M' D$ P* k& N6 I2 T
mcasp->regs->AFSRCTL = 0x00000112; // 2TDM, 1bit Falling, External FS, word9 C3 u: h0 q1 P
mcasp->regs->ACLKRCTL = 0x000000AF; // Rising INTERNAL CLK,(from tx side)
* J- ]: {8 x5 l( i R" u) k mcasp->regs->AHCLKRCTL = 0x00000000; // INT CLK (from tx side)
5 L- C6 Z' r5 b1 O% w0 E( \. d mcasp->regs->RTDM = 0x00000003; // Slots 0,19 C# k" h, N& T- p
mcasp->regs->RINTCTL = 0x00000000; // Not used2 z L* ? a0 H% Q+ p
mcasp->regs->RCLKCHK = 0x00FF0008; // 255-MAX 0-MIN, div-by-256$ W& b; {4 P3 Y: a( P. P
! A% u0 i! m7 |* R0 V- q* X& e1 q
mcasp->regs->XMASK = 0xFFFFFFFF; // No padding used
( d) S. n" k+ l, b. B: I$ x mcasp->regs->XFMT = 0x00018078; // MSB 16bit, 0-delay, no pad, CFGBus1 j5 t3 [( B! i7 U/ x5 b+ n
mcasp->regs->AFSXCTL = 0x00000112; // 2TDM, 1bit Rising edge INTERNAL FS, word, f8 m* J* L/ X) A6 p' j9 T. |5 Q
mcasp->regs->ACLKXCTL = 0x000000AF; // ASYNC, Rising INTERNAL CLK, div-by-16! W. T: y! L/ b) a. n/ x: O/ i# l
mcasp->regs->AHCLKXCTL = 0x00000000; // EXT CLK
8 N: N2 Z z, u4 X3 N# s mcasp->regs->XTDM = 0x00000003; // Slots 0,1" z9 p5 m' |/ {* U6 h3 h+ t
mcasp->regs->XINTCTL = 0x00000020; // interrupt on transmit
: ~& C8 F+ X% [9 \ mcasp->regs->XCLKCHK = 0x00FF0008; // 255-MAX 0-MIN, div-by-256
4 C' O5 a, K& B: m( \
% c1 G7 w. E- t' f2 v0 X mcasp->regs->SRCTL5 = 0x000D; // MCASP1.AXR1[5] --> DIN0 u- ~% X/ |. s& D
mcasp->regs->SRCTL0 = 0x000E; // MCASP1.AXR1[0] <-- DOUT
! j+ x3 |! b$ l mcasp->regs->PFUNC = 0; // All MCASPs
) Y& F* Z, A# l' d mcasp->regs->PDIR = 0x14000020; // All inputs except AXR0[5], ACLKX1, AFSX17 a0 N; V9 R$ F1 b" ]
1 _4 x$ r) c$ }6 x mcasp->regs->DITCTL = 0x00000000; // Not used
' Y, X. j& k1 r0 P mcasp->regs->DLBCTL = 0x00000000; // Not used2 w7 b+ O3 \6 d# L# d
mcasp->regs->AMUTE = 0x00000000; // Not used
# e r% {5 O" p& a+ c3 R
# K! E8 X+ s2 C$ r/* Starting sections of the McASP*/! P0 L" v Z. n+ O
mcasp->regs->XGBLCTL |= GBLCTL_XHCLKRST_ON; ; H1 f7 ?- E( e1 P
while ( ( mcasp->regs->XGBLCTL & GBLCTL_XHCLKRST_ON ) != GBLCTL_XHCLKRST_ON ); ; R/ S* y9 k8 D. w% N+ Q2 n+ Z: b
mcasp->regs->RGBLCTL |= GBLCTL_RHCLKRST_ON; 2 l# d' c. |* r4 e! B
while ( ( mcasp->regs->RGBLCTL & GBLCTL_RHCLKRST_ON ) != GBLCTL_RHCLKRST_ON );3 s5 u i* @: l N% B5 p8 ^5 G
8 \5 W: g. c+ W* X, K k# P0 ?
mcasp->regs->XGBLCTL |= GBLCTL_XCLKRST_ON;
! |# r' u- ?: ~ n" J/ F while ( ( mcasp->regs->XGBLCTL & GBLCTL_XCLKRST_ON ) != GBLCTL_XCLKRST_ON );" T- z! O+ f( x1 ]7 t- _' X. s
mcasp->regs->RGBLCTL |= GBLCTL_RCLKRST_ON;
' k% c y; I4 k5 N3 C3 n1 T. X while ( ( mcasp->regs->RGBLCTL & GBLCTL_RCLKRST_ON ) != GBLCTL_RCLKRST_ON );
2 m# r% U" \$ v. a4 i. Y
; o) f- O4 n8 O. ?7 @( d+ o! T mcasp->regs->XSTAT = 0x0000ffff;
* k: c( ^2 {, b* H, Z6 N$ z mcasp->regs->RSTAT = 0x0000ffff; 6 v2 U' d, X3 P( Y
: X E0 [' [$ S1 u0 c
mcasp->regs->XGBLCTL |= GBLCTL_XSRCLR_ON;( g7 y. B7 |; P$ t$ f
while ( ( mcasp->regs->XGBLCTL & GBLCTL_XSRCLR_ON ) != GBLCTL_XSRCLR_ON );* N9 R5 J( M( |' q
mcasp->regs->RGBLCTL |= GBLCTL_RSRCLR_ON; 8 [- }7 n4 {( ]1 }3 z* y1 K
while ( ( mcasp->regs->RGBLCTL & GBLCTL_RSRCLR_ON ) != GBLCTL_RSRCLR_ON );
+ T8 o- p2 v" K' g6 |
0 O: G; S5 L5 t, q# ]) R+ K /* Write a 0, so that no underrun occurs after releasing the state machine */% N- A9 h, ?4 z
mcasp->regs->XBUF5 = 0;
3 F! }! j, w' U. {- w mcasp->regs->RBUF0 = 0;
: M; c# X D. D
. @6 R, Y E# b2 l/ u0 T mcasp->regs->XGBLCTL |= GBLCTL_XSMRST_ON;
& C. E8 l* Q x- f0 f. T while ( ( mcasp->regs->XGBLCTL & GBLCTL_XSMRST_ON ) != GBLCTL_XSMRST_ON );
1 ]; W! I9 c- }1 c/ h- A1 B3 A- P mcasp->regs->RGBLCTL |= GBLCTL_RSMRST_ON;
2 y5 I" e/ l1 X$ { while ( ( mcasp->regs->RGBLCTL & GBLCTL_RSMRST_ON ) != GBLCTL_RSMRST_ON );) k# U) b7 ^4 @9 `6 O: P8 x1 m0 ~# |
: O( P3 c* F: `5 O' \" S mcasp->regs->XGBLCTL |= GBLCTL_XFRST_ON;
4 p; `9 m9 T1 T8 X, d while ( ( mcasp->regs->XGBLCTL & GBLCTL_XFRST_ON ) != GBLCTL_XFRST_ON );
$ E" u, J% z0 | w/ [) @+ ^ mcasp->regs->RGBLCTL |= GBLCTL_RFRST_ON;
! T* B; `3 n9 ]$ d I9 h" ]2 C while ( ( mcasp->regs->RGBLCTL & GBLCTL_RFRST_ON ) != GBLCTL_RFRST_ON );
5 X: } s* i" n' n: d0 L! |
" Q( ?6 y3 P7 Q: A1 t2 J* _, n CSR = 0x0000;: g$ F3 s7 Q6 {" g i. J% l9 `
INTC_INTMUX1 = 0x3d;. C+ c/ n* ?) z: d5 _2 \
ISTP = (unsigned int)vectors;4 w) V+ `8 R8 ?: \* b* M7 F4 I
ICR = 0xFFF0; 0 ^% e% i1 d/ V4 o8 i7 ~
IER |= 0x12;
7 I' \4 d; W- a6 B CSR |= 0x01;
: P6 F% }2 \% ~# P8 P% O5 z! `) v
% u) G- c$ j# [( e* r# r
; a( I7 G/ E. w; z5 I- A1 p5 t
! U7 Q. s( |2 H0 `/ p& j% t3 h还有就是两个输入输出函数:0 Y0 F+ u7 v4 @$ f; G0 l
void output_sample(Int32 out_data)* A" R8 p9 H4 Y+ @5 a) T
{% o: m( e& G# N2 O B' t& H4 ^
AIC31_data.uint = out_data;
; W3 c5 n2 `% p, c$ W! T, @# Z& B MCASP1_XBUF5_32BIT = AIC31_data.uint;
{2 d! D% k! k4 p, } O}& B0 O/ f: _. o
# x2 n2 D4 V! I: O1 T1 k4 ?Int32 input_sample(void)& ~+ \( B& `, q( \& E$ c# J
{ & Q c( ^+ x9 B& \, M
AIC31_data.uint = MCASP1_RBUF0_32BIT;
) e$ U6 `' y. v return (AIC31_data.uint);" M: H5 z4 U, V
}
- D3 `' J6 ~8 o8 S4 H: l3 e0 w$ m* P- R/ |1 O; A
|
|