|
|
C6747和C6748感觉差不多,我想实现McASP发送中断方式控制音频信号,在轮询的例程基础上改的,轮询程序可以实现,但是中断一直实现不了,也找不到错误,求大神帮忙!下边是主要程序:
4 y8 W: n+ n* _- Z" rmain文件:
* ~& U, {+ [* P! p) y8 ~+ K4 Iinterrupt void interrupt4(void)
& ^- k/ L5 q |4 a# D" J/ I{
# S$ L" ~1 _! R, i Uint32 sample;# W$ _" W' t' p# M; s! H
3 V) E1 y C3 G! t
sample = input_sample(); // read L + R samples from ADC1 `3 t- s; C7 W( E) R
output_sample(sample); // write L + R samples to DAC S7 }( W- g. e- Q* |/ d7 @
return;6 }: [- w) X3 P" X0 [( Q
}6 w( p% j# z% w6 Z
/ u- j* i7 x' Y* @) p1 bint main( void )# b1 K0 F& F2 h
{1 Y! n7 @& i& [0 N7 e( b+ D1 N" e
1 M% C- o* y t4 t% U4 ^1 z% L /* Initialize BSL */6 L( N2 W/ P/ ^, Q. M2 E
EVMC6747_init( );
0 R( V, W& X; w% r /* Call evmc6747_intr function */
0 ~- j8 Q5 N3 S7 W aic3106_init( ); Y# {4 H% r4 O1 r( J' g4 R; Q
while(1);" z: v( C! l9 R1 o6 E1 d
}1 M4 g' L7 o) x
& ^# T1 [3 h0 K9 I3 q; K( p' t/ _$ |* D$ E
aic3106_init文件的一部分,McASP配置部分,采用内部时钟,I2S方式,同步传输。音频芯片的配置应该没问题
& e& E c0 f) R1 k7 @# p5 X1 P/* Initialize MCASP1 */4 F( k9 |$ x6 J. Y
mcasp = &MCASP_MODULE_1;
: O8 V( i/ [( }& P* Z mcasp->regs->GBLCTL = 0; // Reset
Q' }5 j z5 R; x3 |' l1 }3 P/ w mcasp->regs->RGBLCTL = 0; // Reset RX
. r$ q3 ]2 J) M) ^# q mcasp->regs->XGBLCTL = 0; // Reset TX
$ `" ?! U2 q4 Y9 O5 z6 | mcasp->regs->PWRDEMU = 1; // Free-running, _( a% ^- @3 h6 ]+ l/ R* s8 X
// configure McASP0 receive registers
' e0 s4 [ P- P0 ?' p mcasp->regs->RMASK = 0xFFFFFFFF; // No padding used5 ~" M& l2 B, w2 z
mcasp->regs->RFMT = 0x00018078; // MSB 16bit, 0-delay, no pad, CFGBus
+ S% m' Q' B& U( j, x ^ mcasp->regs->AFSRCTL = 0x00000112; // 2TDM, 1bit Falling, External FS, word2 f$ C8 ]/ e; O
mcasp->regs->ACLKRCTL = 0x000000AF; // Rising INTERNAL CLK,(from tx side)
# R! ]: h+ x2 _ mcasp->regs->AHCLKRCTL = 0x00000000; // INT CLK (from tx side)
# e, B* n. Q! e$ e; |! g7 p% R mcasp->regs->RTDM = 0x00000003; // Slots 0,1
6 R5 F* L4 r' V- V8 Y2 e! @ mcasp->regs->RINTCTL = 0x00000000; // Not used* Q0 u$ j$ B. c$ d: \8 \4 c/ w
mcasp->regs->RCLKCHK = 0x00FF0008; // 255-MAX 0-MIN, div-by-256
1 x8 ~6 B, I% o$ q( W9 d2 ?& R$ A. d
mcasp->regs->XMASK = 0xFFFFFFFF; // No padding used
9 z+ ^4 C' }: a+ F' e/ h) S mcasp->regs->XFMT = 0x00018078; // MSB 16bit, 0-delay, no pad, CFGBus
. C+ {, r2 b) C4 } mcasp->regs->AFSXCTL = 0x00000112; // 2TDM, 1bit Rising edge INTERNAL FS, word. \/ Z/ u$ _7 P
mcasp->regs->ACLKXCTL = 0x000000AF; // ASYNC, Rising INTERNAL CLK, div-by-16
! s, K9 z4 }1 P) t+ Z) h mcasp->regs->AHCLKXCTL = 0x00000000; // EXT CLK$ Z s; Z1 O) y9 S8 {
mcasp->regs->XTDM = 0x00000003; // Slots 0,1
4 J0 f. u' n. r0 l mcasp->regs->XINTCTL = 0x00000020; // interrupt on transmit& k# |# v- |, z" L( c2 o3 l' H
mcasp->regs->XCLKCHK = 0x00FF0008; // 255-MAX 0-MIN, div-by-2561 i0 |' |) }. z5 ]
1 f! v9 V& Y+ T$ P* j mcasp->regs->SRCTL5 = 0x000D; // MCASP1.AXR1[5] --> DIN
4 w' k) |( ^) Z* y! u1 P mcasp->regs->SRCTL0 = 0x000E; // MCASP1.AXR1[0] <-- DOUT5 A8 L, \' A* t+ R1 [2 `; `. A- A
mcasp->regs->PFUNC = 0; // All MCASPs4 |) g1 W& u0 y. E) _( `& k
mcasp->regs->PDIR = 0x14000020; // All inputs except AXR0[5], ACLKX1, AFSX16 _2 W$ |7 K9 H. t0 d( ]4 m% v
( U9 ?: K Y) P; y& G, y mcasp->regs->DITCTL = 0x00000000; // Not used
* w4 c: h/ j# u5 ^ mcasp->regs->DLBCTL = 0x00000000; // Not used
5 b1 L n, l4 q1 }, r4 j3 | mcasp->regs->AMUTE = 0x00000000; // Not used; V+ ^8 U) v) T& a! |
0 J8 ?- J. c' I! ~$ s8 A
/* Starting sections of the McASP*/
2 A% u6 q# |3 O) m6 q mcasp->regs->XGBLCTL |= GBLCTL_XHCLKRST_ON; 1 ~2 v+ ]5 L6 _
while ( ( mcasp->regs->XGBLCTL & GBLCTL_XHCLKRST_ON ) != GBLCTL_XHCLKRST_ON );
$ F3 {9 G+ n+ I) ]' L% z mcasp->regs->RGBLCTL |= GBLCTL_RHCLKRST_ON; 5 s+ y) t1 p7 R, {/ C
while ( ( mcasp->regs->RGBLCTL & GBLCTL_RHCLKRST_ON ) != GBLCTL_RHCLKRST_ON );
2 w1 V! ?; t# ^, R- H: H+ `, A/ g+ G- ^" @6 F! n+ S
mcasp->regs->XGBLCTL |= GBLCTL_XCLKRST_ON;
5 t V( {% k6 E- X( `! r5 o while ( ( mcasp->regs->XGBLCTL & GBLCTL_XCLKRST_ON ) != GBLCTL_XCLKRST_ON );
t9 O6 c2 o7 {5 _# c7 Z+ { mcasp->regs->RGBLCTL |= GBLCTL_RCLKRST_ON; # I, f: E; v3 q' S0 P* J
while ( ( mcasp->regs->RGBLCTL & GBLCTL_RCLKRST_ON ) != GBLCTL_RCLKRST_ON );
' g2 p5 r( }3 c, P& P7 m" q& X9 N7 G# I" n7 s
mcasp->regs->XSTAT = 0x0000ffff;
! m \1 \: k& {' m' d: P8 A8 C S mcasp->regs->RSTAT = 0x0000ffff;
, [) e H# F8 W; L1 t% J& E- f3 Y% S0 z v+ B, s
mcasp->regs->XGBLCTL |= GBLCTL_XSRCLR_ON;
+ T. K4 t, J! L. ]4 X# l5 w while ( ( mcasp->regs->XGBLCTL & GBLCTL_XSRCLR_ON ) != GBLCTL_XSRCLR_ON );( r2 B; R+ q! ?2 U. ?
mcasp->regs->RGBLCTL |= GBLCTL_RSRCLR_ON; & `1 |" C. M- y6 h% U! f
while ( ( mcasp->regs->RGBLCTL & GBLCTL_RSRCLR_ON ) != GBLCTL_RSRCLR_ON );) ^6 K7 }* ]% ?2 q: V( M2 M8 {
; \' k G! P3 H; B, }1 y4 u
/* Write a 0, so that no underrun occurs after releasing the state machine */
* _( q/ J' V5 C% S) M8 n, x mcasp->regs->XBUF5 = 0;8 X. O+ p4 q6 r9 C- ~8 C8 F7 y
mcasp->regs->RBUF0 = 0;
2 ~* K; w4 F3 ]9 @5 U, s: g6 X+ h* _8 d! ]
mcasp->regs->XGBLCTL |= GBLCTL_XSMRST_ON;
X3 q3 n+ | K; {/ H6 w: v4 ?- h$ f9 \2 f while ( ( mcasp->regs->XGBLCTL & GBLCTL_XSMRST_ON ) != GBLCTL_XSMRST_ON );2 x/ z1 k- q! v
mcasp->regs->RGBLCTL |= GBLCTL_RSMRST_ON; 0 U G$ X+ g2 T
while ( ( mcasp->regs->RGBLCTL & GBLCTL_RSMRST_ON ) != GBLCTL_RSMRST_ON );% E! E, p, u" V* Y" F
0 G) {. s9 p0 `9 `& f: n
mcasp->regs->XGBLCTL |= GBLCTL_XFRST_ON; 3 t4 Q9 a. ^. t. p. s+ c; D( N
while ( ( mcasp->regs->XGBLCTL & GBLCTL_XFRST_ON ) != GBLCTL_XFRST_ON );
$ v. O: W9 c' x mcasp->regs->RGBLCTL |= GBLCTL_RFRST_ON; . q. @* F3 S. F- I4 p, [
while ( ( mcasp->regs->RGBLCTL & GBLCTL_RFRST_ON ) != GBLCTL_RFRST_ON );8 C* v, |5 f- }* O- A
3 J/ s9 t+ ^2 _3 C- R4 {
CSR = 0x0000;% F) V+ W" _5 x3 G
INTC_INTMUX1 = 0x3d;5 g$ o, K* H; M' Y1 e9 y% m
ISTP = (unsigned int)vectors;" g& l) w7 j% e9 B; {! W* S; P
ICR = 0xFFF0;
r* Y+ T& O* X+ @ IER |= 0x12;
. O8 `0 Y3 d1 ~: z CSR |= 0x01;
7 s; b1 d8 h( X4 J
0 E d' N- A8 R3 e: z" G- c j2 Z3 X- W9 _5 v5 P: | b4 y, f% g- d: G0 A
$ ^. y: l& [8 S/ E& c" m
还有就是两个输入输出函数: m2 {8 m( V$ U9 x3 q5 w
void output_sample(Int32 out_data)3 \* u( |0 B( W9 e6 D3 S4 U$ I9 R
{
1 J- X* b& u7 d" z AIC31_data.uint = out_data;
^' n+ r% Z" u8 L6 ]% d4 i' ? MCASP1_XBUF5_32BIT = AIC31_data.uint;
4 _, Y. V. V1 B3 [; `}9 @6 ?: ?3 A* \9 G5 A' X8 N
' v0 V# a9 }6 v: `
Int32 input_sample(void)6 B! ?6 W7 x& |5 a
{
, W9 C* E j& z! s+ w AIC31_data.uint = MCASP1_RBUF0_32BIT;9 h: `% a7 |4 X
return (AIC31_data.uint);
+ I' t( P0 c: Z, ?& U" r% ^9 K}+ @, C/ b3 C' \% i+ o. i; ?
% I( Z" X; p- ^" L
|
|