|
|
C6747和C6748感觉差不多,我想实现McASP发送中断方式控制音频信号,在轮询的例程基础上改的,轮询程序可以实现,但是中断一直实现不了,也找不到错误,求大神帮忙!下边是主要程序:
7 y) k/ F( O2 dmain文件:
, n/ N" }9 V* D+ {" B+ `. sinterrupt void interrupt4(void) * A7 `' w' y O8 l, \3 h
{
$ ?/ Z$ Z- T5 E$ x# V Uint32 sample;9 Q7 Y: y! J$ K5 _% I9 X2 u( R
% h7 o x$ F1 d5 Z: u3 m; h. { sample = input_sample(); // read L + R samples from ADC
% }. j# d: W7 v$ N' j output_sample(sample); // write L + R samples to DAC
7 F* r+ D( ^$ {( a8 x _) v8 o% Z return;+ o, a9 e& J7 `+ @( F8 D
}
8 w/ k K2 |+ O1 W
+ ?& _$ F* a( g: u# D' S6 Vint main( void )* {3 V, N1 X3 H" Y
{7 Z- |2 @9 Q0 t( V3 U* `
, d7 n, O8 k# u \: Z
/* Initialize BSL *// ^3 w' [3 r6 R* a* A
EVMC6747_init( );# L. h, }, C5 T1 U( O# X5 q2 O: m
/* Call evmc6747_intr function */9 u' D% p5 v4 S+ `# g
aic3106_init( );, {% `) z/ }6 g) ~
while(1);/ D$ F! U7 ~& l' I' |6 h
}# r. ?, s% t$ a, b1 v/ y$ E
: h o, n( l G3 k5 J: Q% F
4 Z" ^, U) }( g. D6 M9 T" aaic3106_init文件的一部分,McASP配置部分,采用内部时钟,I2S方式,同步传输。音频芯片的配置应该没问题
+ u' i2 d, Q$ ~7 L+ Q' ?3 c* a/* Initialize MCASP1 */
* L; F9 m. s5 t mcasp = &MCASP_MODULE_1;
y! m+ D% ]4 g, [* V3 l* U$ A mcasp->regs->GBLCTL = 0; // Reset+ B8 o* }# j0 p5 A" y3 U' l
mcasp->regs->RGBLCTL = 0; // Reset RX3 [8 W# p) U# q& u. @
mcasp->regs->XGBLCTL = 0; // Reset TX
: Q! \! g# ?8 K7 K/ ^. f2 G mcasp->regs->PWRDEMU = 1; // Free-running
/ Q& S7 ]7 G# [ [ // configure McASP0 receive registers
4 s' b4 J9 ]4 E d9 `7 ? t6 [ mcasp->regs->RMASK = 0xFFFFFFFF; // No padding used
9 d( L B K7 B# t2 l, r4 s2 W mcasp->regs->RFMT = 0x00018078; // MSB 16bit, 0-delay, no pad, CFGBus- _% ^7 z$ v5 }2 U! k5 ?6 e+ T
mcasp->regs->AFSRCTL = 0x00000112; // 2TDM, 1bit Falling, External FS, word5 P7 W( ~, i2 S, e5 w2 U
mcasp->regs->ACLKRCTL = 0x000000AF; // Rising INTERNAL CLK,(from tx side)6 l0 \" w0 _- @+ c7 i" @
mcasp->regs->AHCLKRCTL = 0x00000000; // INT CLK (from tx side)' c, ~. ^; y M4 G7 j
mcasp->regs->RTDM = 0x00000003; // Slots 0,1
7 }+ U6 q, _9 T5 \ mcasp->regs->RINTCTL = 0x00000000; // Not used: S' s- D9 B6 ]% e. o$ x
mcasp->regs->RCLKCHK = 0x00FF0008; // 255-MAX 0-MIN, div-by-256
$ `% c) J' x5 x6 W
) }: J' w; i6 ~2 p' j mcasp->regs->XMASK = 0xFFFFFFFF; // No padding used; ?' r% ]$ @7 c" O0 n0 K
mcasp->regs->XFMT = 0x00018078; // MSB 16bit, 0-delay, no pad, CFGBus
+ r+ Q; ]/ p% X mcasp->regs->AFSXCTL = 0x00000112; // 2TDM, 1bit Rising edge INTERNAL FS, word
5 K7 C5 R+ V; a* \' W mcasp->regs->ACLKXCTL = 0x000000AF; // ASYNC, Rising INTERNAL CLK, div-by-16
) H. j" z i% ?5 U1 O mcasp->regs->AHCLKXCTL = 0x00000000; // EXT CLK
) }* D! p% E* p! } mcasp->regs->XTDM = 0x00000003; // Slots 0,19 ^+ R" P2 N6 E6 h5 F' ]4 `
mcasp->regs->XINTCTL = 0x00000020; // interrupt on transmit
4 C& L& m$ U7 H1 v, f mcasp->regs->XCLKCHK = 0x00FF0008; // 255-MAX 0-MIN, div-by-256 F( v0 n( C( X' P% p* O8 d
# _3 R, E! R' q! ]: S" ^* z/ I mcasp->regs->SRCTL5 = 0x000D; // MCASP1.AXR1[5] --> DIN
0 `0 M0 F* j( H. }; I X+ x mcasp->regs->SRCTL0 = 0x000E; // MCASP1.AXR1[0] <-- DOUT
+ B4 D' J! B4 O7 Q4 B% t mcasp->regs->PFUNC = 0; // All MCASPs
: G2 J: J, @- p; z# |) L mcasp->regs->PDIR = 0x14000020; // All inputs except AXR0[5], ACLKX1, AFSX1/ m: q( R5 d5 A1 i! K; l! G5 [
6 `6 G/ J; Q4 w
mcasp->regs->DITCTL = 0x00000000; // Not used0 `7 ~- X& U6 ^, U5 x2 t
mcasp->regs->DLBCTL = 0x00000000; // Not used
. D' o5 M9 o) f; l4 I) m mcasp->regs->AMUTE = 0x00000000; // Not used
: x& H0 [4 x0 M% b0 m1 R+ o9 G. t# Y" O, S# a
/* Starting sections of the McASP*/) _2 L2 `. y& Q: W. Q2 Y, E
mcasp->regs->XGBLCTL |= GBLCTL_XHCLKRST_ON;
1 g; S% i+ N Q1 U' h% e* e while ( ( mcasp->regs->XGBLCTL & GBLCTL_XHCLKRST_ON ) != GBLCTL_XHCLKRST_ON );
4 b$ M4 `9 J9 Y6 L mcasp->regs->RGBLCTL |= GBLCTL_RHCLKRST_ON;
8 q+ g% i9 P0 x1 \4 F- c while ( ( mcasp->regs->RGBLCTL & GBLCTL_RHCLKRST_ON ) != GBLCTL_RHCLKRST_ON );
+ b1 T* u {1 z2 \* |" p
$ o2 U3 _ ~4 N q mcasp->regs->XGBLCTL |= GBLCTL_XCLKRST_ON; 7 Y- x! Y/ @ V3 U9 {
while ( ( mcasp->regs->XGBLCTL & GBLCTL_XCLKRST_ON ) != GBLCTL_XCLKRST_ON );
$ \* x+ b6 w' U+ S mcasp->regs->RGBLCTL |= GBLCTL_RCLKRST_ON;
$ [4 o9 ]$ F; ~+ t" Z1 N while ( ( mcasp->regs->RGBLCTL & GBLCTL_RCLKRST_ON ) != GBLCTL_RCLKRST_ON );
b7 ~6 _5 d$ C8 d6 e1 J) b" ]3 B9 ]" u' y+ v; G! i
mcasp->regs->XSTAT = 0x0000ffff;
+ b+ o) Z; g5 h* Q% I! U# E: K mcasp->regs->RSTAT = 0x0000ffff;
! l; r' o: i' j/ I
5 R0 m2 d% a, S1 Q% y8 P/ }8 O7 g mcasp->regs->XGBLCTL |= GBLCTL_XSRCLR_ON;1 z( E2 X6 r( J; L4 |
while ( ( mcasp->regs->XGBLCTL & GBLCTL_XSRCLR_ON ) != GBLCTL_XSRCLR_ON );! C/ a/ z% i# e; ]0 R" }/ @
mcasp->regs->RGBLCTL |= GBLCTL_RSRCLR_ON;
' R8 W! J; l7 h C3 } while ( ( mcasp->regs->RGBLCTL & GBLCTL_RSRCLR_ON ) != GBLCTL_RSRCLR_ON );9 O0 z) Y6 E& O7 H( y
, d4 ]* H/ s* q* U3 A H% h1 f' }' k
/* Write a 0, so that no underrun occurs after releasing the state machine */
0 ]1 X; y1 j5 i O" O) u- h: z, p# g mcasp->regs->XBUF5 = 0;- {8 h1 o" `& r' O+ ]2 T: M
mcasp->regs->RBUF0 = 0;8 N: x' F" d) g! d8 g
' _& l# ]# L/ O& I/ ?% m: k
mcasp->regs->XGBLCTL |= GBLCTL_XSMRST_ON;
4 k& c# {9 F) W: a: \. s while ( ( mcasp->regs->XGBLCTL & GBLCTL_XSMRST_ON ) != GBLCTL_XSMRST_ON );: d, g2 \$ h3 H6 K0 A
mcasp->regs->RGBLCTL |= GBLCTL_RSMRST_ON;
$ |7 Y* h) {0 N3 {6 e$ Q: u while ( ( mcasp->regs->RGBLCTL & GBLCTL_RSMRST_ON ) != GBLCTL_RSMRST_ON );
5 x3 K) a6 B. ]. c7 @% }: ]9 Q% o$ Z7 \( [7 \5 L
mcasp->regs->XGBLCTL |= GBLCTL_XFRST_ON;
5 ?8 T6 F; d. k) K; _ while ( ( mcasp->regs->XGBLCTL & GBLCTL_XFRST_ON ) != GBLCTL_XFRST_ON );- N6 d* O( {( N3 M
mcasp->regs->RGBLCTL |= GBLCTL_RFRST_ON; , S Y/ b, [1 c& ^, \0 Z
while ( ( mcasp->regs->RGBLCTL & GBLCTL_RFRST_ON ) != GBLCTL_RFRST_ON );# k* w6 t( R( W( W
3 }+ y% a" D0 w, W# A CSR = 0x0000;% W0 u$ V S1 o$ N
INTC_INTMUX1 = 0x3d;
. n8 U+ k3 \/ z' m- Y. G2 h6 p ISTP = (unsigned int)vectors;
2 \1 W8 E/ q Q1 O ICR = 0xFFF0;
! S0 w8 Y6 K& i# n6 p+ |6 j9 q IER |= 0x12; 5 H) W1 }8 i* r! u) I
CSR |= 0x01;
2 x: m0 D- t' e0 J6 M. h8 M/ ]* Q8 G2 @. M6 h
0 ^5 T P @& O9 A4 b& R) h: }. U$ F0 ]$ X, y$ D! U
还有就是两个输入输出函数:- i* a# B5 T% `, I
void output_sample(Int32 out_data)/ p9 \* V2 v& ?" t) i& k
{
' l9 Q1 f' p) u; E' K6 ? AIC31_data.uint = out_data;
5 U8 T$ m6 G1 U1 O4 E; }' E: U MCASP1_XBUF5_32BIT = AIC31_data.uint;, i% i. r% t' y' O
}
9 Z L: X& E; V/ p8 B/ J3 }" ^4 o0 w3 A3 M4 ]7 n
Int32 input_sample(void)9 n- R- _" K) a4 k1 l
{ - _! g2 q4 l1 s/ }6 T- _
AIC31_data.uint = MCASP1_RBUF0_32BIT;6 ]. I/ ~* d3 r+ ^ i
return (AIC31_data.uint);- E; Q9 q9 q h% Z" y# h6 g% A
}# ^% X" i9 C* E$ T- u: P
) R% C% }5 u: a% ?* Y4 T0 | |
|