|
|
C6747和C6748感觉差不多,我想实现McASP发送中断方式控制音频信号,在轮询的例程基础上改的,轮询程序可以实现,但是中断一直实现不了,也找不到错误,求大神帮忙!下边是主要程序:! g- E3 P; k3 ]( V. E
main文件:
9 {3 G3 ?8 r1 O, G# h' Einterrupt void interrupt4(void)
& `$ o4 i4 ?: h{
& d$ M/ U- a4 P6 u0 s* U Uint32 sample;# ^5 |: r) {& }- p7 F9 B
( a H" G0 o# m' n: e
sample = input_sample(); // read L + R samples from ADC# C, U& d ~$ V
output_sample(sample); // write L + R samples to DAC
/ ~& ~/ u& D: N return;+ r- o! ^2 P7 f1 _% e1 B
}" d T) Q# j0 z! y" l1 j
- j5 ?% U! v1 c5 J3 ]: c
int main( void ) ~9 I, z0 x. T, H
{
8 n( T- J/ g! c1 q9 p, k) [% h: ]: n5 y1 y# C
/* Initialize BSL */( N0 A# T2 E, d- i' _, ~7 b+ B
EVMC6747_init( );
- q3 Y/ R( V- E" u I3 e /* Call evmc6747_intr function */
# x/ v3 e6 y+ A$ h7 y3 ` aic3106_init( );0 W& r. Z4 |$ w% d. @9 m- R$ Z% K
while(1);6 y7 T# P" O# ~$ { P& D
}9 L. C, T6 [" B
' S( w* Y* x, F6 v
# ~4 p6 O2 x8 {$ q- S0 R5 l* Caic3106_init文件的一部分,McASP配置部分,采用内部时钟,I2S方式,同步传输。音频芯片的配置应该没问题
- L& s7 L/ y' k" `& {2 ?3 Q. S/* Initialize MCASP1 */1 R% b, ?* a$ }$ i& }+ c) U
mcasp = &MCASP_MODULE_1;
9 }: U; k5 N- [$ u9 q/ }! g mcasp->regs->GBLCTL = 0; // Reset3 y p: `, i6 }% w3 Y0 h7 S; u- `
mcasp->regs->RGBLCTL = 0; // Reset RX1 @9 I6 l( n) f
mcasp->regs->XGBLCTL = 0; // Reset TX W+ U J4 e3 L5 n
mcasp->regs->PWRDEMU = 1; // Free-running$ A4 q1 Y( t( f% C* U; a* I
// configure McASP0 receive registers) s* F) b W8 g% ]
mcasp->regs->RMASK = 0xFFFFFFFF; // No padding used/ D+ \, N# a2 o- h
mcasp->regs->RFMT = 0x00018078; // MSB 16bit, 0-delay, no pad, CFGBus- t, G$ r. u0 B% ]# h; B
mcasp->regs->AFSRCTL = 0x00000112; // 2TDM, 1bit Falling, External FS, word" P. D3 x/ q' v0 h
mcasp->regs->ACLKRCTL = 0x000000AF; // Rising INTERNAL CLK,(from tx side)
, H4 ?; b! _0 j( [' H mcasp->regs->AHCLKRCTL = 0x00000000; // INT CLK (from tx side)8 M# A0 H) A C# a8 e
mcasp->regs->RTDM = 0x00000003; // Slots 0,1- R- l) c& h& I
mcasp->regs->RINTCTL = 0x00000000; // Not used4 @+ `: Z/ v8 _" D7 N, W4 F% M4 U
mcasp->regs->RCLKCHK = 0x00FF0008; // 255-MAX 0-MIN, div-by-256
( t$ m+ R' V, k! P+ o8 ~" s& a3 h6 M' u2 Y
mcasp->regs->XMASK = 0xFFFFFFFF; // No padding used& v+ l. t' e% t+ [5 s% U5 M
mcasp->regs->XFMT = 0x00018078; // MSB 16bit, 0-delay, no pad, CFGBus
# K/ w4 U9 ~: A# B mcasp->regs->AFSXCTL = 0x00000112; // 2TDM, 1bit Rising edge INTERNAL FS, word9 z1 \0 L7 O2 Q, g
mcasp->regs->ACLKXCTL = 0x000000AF; // ASYNC, Rising INTERNAL CLK, div-by-163 a: V5 P) b+ U* I, J: l
mcasp->regs->AHCLKXCTL = 0x00000000; // EXT CLK
. T! M/ O1 |, u! u' z2 `. i mcasp->regs->XTDM = 0x00000003; // Slots 0,1
! q; ~$ @0 n# m6 i: w8 l mcasp->regs->XINTCTL = 0x00000020; // interrupt on transmit
- q. o! A |2 _, ^ mcasp->regs->XCLKCHK = 0x00FF0008; // 255-MAX 0-MIN, div-by-256
. J, i8 Q* \1 f/ g9 y3 g8 _
" ]5 X+ h d2 i1 _; s mcasp->regs->SRCTL5 = 0x000D; // MCASP1.AXR1[5] --> DIN
# l9 o* {" U6 ?+ C1 p! f mcasp->regs->SRCTL0 = 0x000E; // MCASP1.AXR1[0] <-- DOUT$ r7 Z; _2 W& L0 l- N' ?" C
mcasp->regs->PFUNC = 0; // All MCASPs: {& H0 Y0 z8 y X
mcasp->regs->PDIR = 0x14000020; // All inputs except AXR0[5], ACLKX1, AFSX1
- a$ H! U6 |/ U9 L' E( A
7 Q# C; E0 ~$ p% T8 ^" e mcasp->regs->DITCTL = 0x00000000; // Not used
$ c# K1 |) q5 k L mcasp->regs->DLBCTL = 0x00000000; // Not used- ~" R. t0 w V& d$ t$ ^
mcasp->regs->AMUTE = 0x00000000; // Not used
4 G1 O0 ]& z. S0 G9 |/ f% q( f2 @7 C1 L D% ?3 U! B& i
/* Starting sections of the McASP*/
" z" h5 y* a+ p o ~+ z) ~ mcasp->regs->XGBLCTL |= GBLCTL_XHCLKRST_ON; 1 D0 c4 v- x6 s- G4 x2 X0 b" d
while ( ( mcasp->regs->XGBLCTL & GBLCTL_XHCLKRST_ON ) != GBLCTL_XHCLKRST_ON );
7 p( Y! S: s( S# v; e8 ^$ C mcasp->regs->RGBLCTL |= GBLCTL_RHCLKRST_ON; 7 @' D }. b3 {, {' A3 }8 b6 w1 z% O
while ( ( mcasp->regs->RGBLCTL & GBLCTL_RHCLKRST_ON ) != GBLCTL_RHCLKRST_ON );
% B. o7 Z0 T! U" i- ^ D' a
. B9 |1 M7 D6 g4 R& K# U mcasp->regs->XGBLCTL |= GBLCTL_XCLKRST_ON; : k2 T, _7 z9 a7 w9 _8 n/ {' x
while ( ( mcasp->regs->XGBLCTL & GBLCTL_XCLKRST_ON ) != GBLCTL_XCLKRST_ON );) O5 ]) E( i' X
mcasp->regs->RGBLCTL |= GBLCTL_RCLKRST_ON;
/ S9 _7 u( {; u7 D2 R+ i while ( ( mcasp->regs->RGBLCTL & GBLCTL_RCLKRST_ON ) != GBLCTL_RCLKRST_ON );" C- L; D9 k- }' S
, A: J ? o5 M* F# q1 z( { mcasp->regs->XSTAT = 0x0000ffff;
, B; ~5 ]" s# z. l6 o* @: X9 I7 m( t mcasp->regs->RSTAT = 0x0000ffff;
0 l' H- d7 i. `! u) x: e4 ^( K; L
8 V( H$ c3 F- `4 q mcasp->regs->XGBLCTL |= GBLCTL_XSRCLR_ON;
% Q6 B& l! L9 G! `! B while ( ( mcasp->regs->XGBLCTL & GBLCTL_XSRCLR_ON ) != GBLCTL_XSRCLR_ON );
4 [& P& a% n. r mcasp->regs->RGBLCTL |= GBLCTL_RSRCLR_ON;
$ R3 q& O/ v: l7 a while ( ( mcasp->regs->RGBLCTL & GBLCTL_RSRCLR_ON ) != GBLCTL_RSRCLR_ON );7 y- S, {6 s9 O9 f
( W! L# A U4 j2 q5 T
/* Write a 0, so that no underrun occurs after releasing the state machine */
9 w0 @, m8 F# T9 i mcasp->regs->XBUF5 = 0;# y; c; K5 F2 I* ~) _
mcasp->regs->RBUF0 = 0;. ? m- e0 {' S A/ J7 |
, C8 H5 ~* c4 ?* t6 p mcasp->regs->XGBLCTL |= GBLCTL_XSMRST_ON; # H7 D0 g7 ^+ P6 j8 Q, I) R
while ( ( mcasp->regs->XGBLCTL & GBLCTL_XSMRST_ON ) != GBLCTL_XSMRST_ON );2 G5 F: \" H5 d- y9 I) f
mcasp->regs->RGBLCTL |= GBLCTL_RSMRST_ON;
/ H: |$ I& S, z9 m while ( ( mcasp->regs->RGBLCTL & GBLCTL_RSMRST_ON ) != GBLCTL_RSMRST_ON );( Y* j2 w1 S3 M5 G0 d# ^/ j: s
! S! C8 F- b2 G$ U4 C& X% ]7 d mcasp->regs->XGBLCTL |= GBLCTL_XFRST_ON;
2 [, T$ U( }3 p9 N4 z# R' f while ( ( mcasp->regs->XGBLCTL & GBLCTL_XFRST_ON ) != GBLCTL_XFRST_ON );5 X/ S9 T8 h7 `8 s
mcasp->regs->RGBLCTL |= GBLCTL_RFRST_ON;
) X" m: u5 O1 _3 P while ( ( mcasp->regs->RGBLCTL & GBLCTL_RFRST_ON ) != GBLCTL_RFRST_ON );
. T" U( o; h) {8 `9 Q& n/ N# r+ J. G* S7 V3 t U
CSR = 0x0000;% Z2 X' g2 b" j0 C( r
INTC_INTMUX1 = 0x3d;
0 u ?& N/ j! r$ | ISTP = (unsigned int)vectors;6 O% p. l' d7 |+ u% y
ICR = 0xFFF0;
& |: ^1 Y- m/ i4 w IER |= 0x12;
6 X: B0 R/ w( e CSR |= 0x01;
$ o4 B" L; A" G% G2 C% s: t& O% e& y$ f/ k& o, P4 s
9 D7 a/ ]& u( v+ J5 r& W5 R& ^: O' V9 S C0 P2 Y
还有就是两个输入输出函数:
3 Z( W$ \. |7 T6 @# n0 {void output_sample(Int32 out_data)
3 [/ @" w/ _5 M% b{
9 z! G$ _/ y+ o# h AIC31_data.uint = out_data;
" }5 N) ]0 Z v& Y" E MCASP1_XBUF5_32BIT = AIC31_data.uint;1 J7 z t3 I D+ \
}: d5 W& e& i& X$ Z4 O
- Q9 x$ x' V% w. L! k C
Int32 input_sample(void)' ^' Y1 Q/ S7 m* k7 w
{
6 B! b" o- v E- `. W& y AIC31_data.uint = MCASP1_RBUF0_32BIT;7 H- W/ v0 s s0 D% Y
return (AIC31_data.uint);0 K' p, P& N2 {4 a8 v8 ~
}4 Y1 L; z, O# Y& t7 Z( ]8 F
6 ~: U" v+ o% D- Q# r$ S6 U |
|