|
|
C6747和C6748感觉差不多,我想实现McASP发送中断方式控制音频信号,在轮询的例程基础上改的,轮询程序可以实现,但是中断一直实现不了,也找不到错误,求大神帮忙!下边是主要程序:5 k4 J4 {' ~& ]& k' t$ T
main文件:0 p% V# U: h; _1 t- F9 S" G1 D
interrupt void interrupt4(void)
: P6 P% u |; f: X* Z$ D- I{
/ x2 M; D& y, o9 ~" P Uint32 sample;' q5 I+ H4 {' N" b% L
7 N4 S# C7 p4 Z( V( c
sample = input_sample(); // read L + R samples from ADC4 ]/ L0 a" J; W: F
output_sample(sample); // write L + R samples to DAC
8 `' X7 g, \. w% J return;; {8 X. E2 T0 u5 t/ r: }6 M
}
: Z( r' B8 z" k3 _
$ t4 _# f- P3 r7 B3 d8 A/ Fint main( void )6 M8 r1 b- }. X( |* @9 P
{
/ j6 l/ [, W6 u: @# U2 ?: r& d# A' D7 y$ A
/* Initialize BSL */6 z! V/ m! }$ q* ?
EVMC6747_init( );
. K/ k) s/ z2 X( D /* Call evmc6747_intr function */
7 z. c" K' a2 ?6 u$ G& d aic3106_init( );
; `4 |8 K2 Q9 Z8 c s; U% n& l while(1);# }. V9 o1 Z1 j4 `+ X
}8 M& N" H6 C y+ Z- H$ b
* S, t) Z6 P" E* d
$ J: z3 K7 l Daic3106_init文件的一部分,McASP配置部分,采用内部时钟,I2S方式,同步传输。音频芯片的配置应该没问题
) \+ K7 _* l: r/* Initialize MCASP1 */# ^0 N2 e5 A0 [" T- e; Z5 }
mcasp = &MCASP_MODULE_1;/ P( U1 q& ~$ x D7 z' r [5 V
mcasp->regs->GBLCTL = 0; // Reset
5 U& ^# v/ R3 T1 }" h0 P1 a mcasp->regs->RGBLCTL = 0; // Reset RX5 H: M, }* P/ G( [ q
mcasp->regs->XGBLCTL = 0; // Reset TX
* b* M2 z1 ^* n! k mcasp->regs->PWRDEMU = 1; // Free-running
6 u" N! Q2 T( h+ R // configure McASP0 receive registers
$ f+ l8 x6 D$ Y7 c3 r mcasp->regs->RMASK = 0xFFFFFFFF; // No padding used
0 e, K% D* l8 H! K: P+ A mcasp->regs->RFMT = 0x00018078; // MSB 16bit, 0-delay, no pad, CFGBus. Z G1 G& F$ F: [$ W# C
mcasp->regs->AFSRCTL = 0x00000112; // 2TDM, 1bit Falling, External FS, word
: P8 K, n5 a6 q2 _4 S& M. M3 _) g mcasp->regs->ACLKRCTL = 0x000000AF; // Rising INTERNAL CLK,(from tx side)! _! X' a8 C/ p* w$ i) S! R' o$ A5 j
mcasp->regs->AHCLKRCTL = 0x00000000; // INT CLK (from tx side) m- }8 \5 F) f
mcasp->regs->RTDM = 0x00000003; // Slots 0,13 X( C7 J3 i5 r* }/ A0 W
mcasp->regs->RINTCTL = 0x00000000; // Not used1 U' }: K7 Z! b- l1 v! j& V* a
mcasp->regs->RCLKCHK = 0x00FF0008; // 255-MAX 0-MIN, div-by-256/ v2 O0 T! `+ Y5 {6 P4 U/ N3 F
8 B) { J% m! V* j) {8 S
mcasp->regs->XMASK = 0xFFFFFFFF; // No padding used# v/ a1 n$ o- j& w3 [
mcasp->regs->XFMT = 0x00018078; // MSB 16bit, 0-delay, no pad, CFGBus
. e% J( a( Y, c" N1 I" L mcasp->regs->AFSXCTL = 0x00000112; // 2TDM, 1bit Rising edge INTERNAL FS, word
. ?' }% G" r1 E* _/ t mcasp->regs->ACLKXCTL = 0x000000AF; // ASYNC, Rising INTERNAL CLK, div-by-167 x2 p9 t# ?0 H$ M
mcasp->regs->AHCLKXCTL = 0x00000000; // EXT CLK
( N. |5 f3 W) V# N$ v# N1 c mcasp->regs->XTDM = 0x00000003; // Slots 0,1- E6 P: x) W5 p4 B& F2 M8 {
mcasp->regs->XINTCTL = 0x00000020; // interrupt on transmit
2 g [$ z9 n% _0 } mcasp->regs->XCLKCHK = 0x00FF0008; // 255-MAX 0-MIN, div-by-256
" H, B' m' G( D- o, S! d0 }( W q# B0 s! f/ ~! n- n
mcasp->regs->SRCTL5 = 0x000D; // MCASP1.AXR1[5] --> DIN) H" V5 u& c% O6 G% b' p
mcasp->regs->SRCTL0 = 0x000E; // MCASP1.AXR1[0] <-- DOUT
0 L& d* \7 ]7 ?" i3 s8 v7 N mcasp->regs->PFUNC = 0; // All MCASPs( d( H1 j5 B2 H% T! M! h [# _' P
mcasp->regs->PDIR = 0x14000020; // All inputs except AXR0[5], ACLKX1, AFSX17 E4 v- [5 H; o- g
2 `) X, x/ |% Y6 {. x2 E! Z
mcasp->regs->DITCTL = 0x00000000; // Not used% J0 A0 j- B) `1 y+ n( M/ `
mcasp->regs->DLBCTL = 0x00000000; // Not used/ S3 H, e# k" A% H! ]3 N8 b ~
mcasp->regs->AMUTE = 0x00000000; // Not used
9 j8 ^3 ^. v" |8 D6 C. A- s( [& }3 w
/* Starting sections of the McASP*/, G& q# f# K. k( v
mcasp->regs->XGBLCTL |= GBLCTL_XHCLKRST_ON; + \' c8 ]- Y8 W# l, Z/ W
while ( ( mcasp->regs->XGBLCTL & GBLCTL_XHCLKRST_ON ) != GBLCTL_XHCLKRST_ON ); 1 @( H1 l9 ?7 W% }+ k: I/ E
mcasp->regs->RGBLCTL |= GBLCTL_RHCLKRST_ON;
, m2 x+ H0 \& X while ( ( mcasp->regs->RGBLCTL & GBLCTL_RHCLKRST_ON ) != GBLCTL_RHCLKRST_ON );3 F, Y6 ]7 `& S7 r _+ p
7 N( T! C A4 E6 k
mcasp->regs->XGBLCTL |= GBLCTL_XCLKRST_ON; 0 J% }3 i+ j7 z: h$ w; g4 \
while ( ( mcasp->regs->XGBLCTL & GBLCTL_XCLKRST_ON ) != GBLCTL_XCLKRST_ON );
* b F- z: Y& ~# g% }# o; J' V mcasp->regs->RGBLCTL |= GBLCTL_RCLKRST_ON; 1 ?2 h* _7 G+ P0 c/ J, `
while ( ( mcasp->regs->RGBLCTL & GBLCTL_RCLKRST_ON ) != GBLCTL_RCLKRST_ON );9 \1 [. D3 j; I- }9 t" I A. e
1 z( |2 @# k: Q" {7 L6 y/ F& K0 { mcasp->regs->XSTAT = 0x0000ffff;
+ t& Z$ m* R6 c; t& m0 } mcasp->regs->RSTAT = 0x0000ffff;
2 P# I- } ?8 X$ _+ R7 a
; b/ `- L& z9 i; B( x% R6 k2 H mcasp->regs->XGBLCTL |= GBLCTL_XSRCLR_ON;% B1 ~ ?9 w/ w1 I( p3 w) e1 `
while ( ( mcasp->regs->XGBLCTL & GBLCTL_XSRCLR_ON ) != GBLCTL_XSRCLR_ON );
( d) C" k) _7 l- B4 {* M; ~ mcasp->regs->RGBLCTL |= GBLCTL_RSRCLR_ON;
1 ]. X5 l$ F, } while ( ( mcasp->regs->RGBLCTL & GBLCTL_RSRCLR_ON ) != GBLCTL_RSRCLR_ON );
, E) h, v* y5 w$ T3 B) U0 J Y; e
; s" S1 V% R, |0 P o /* Write a 0, so that no underrun occurs after releasing the state machine */! n$ E! O0 Z+ e- L( X* ]
mcasp->regs->XBUF5 = 0;+ U: M b. w" X" ~/ m
mcasp->regs->RBUF0 = 0;) X6 y) i" M: P* H/ Q
+ v, [1 f ]( r0 |5 z
mcasp->regs->XGBLCTL |= GBLCTL_XSMRST_ON; . i1 {2 `5 S( ?6 W
while ( ( mcasp->regs->XGBLCTL & GBLCTL_XSMRST_ON ) != GBLCTL_XSMRST_ON );
: n5 P( t* k, I( {; j- q" C! O6 T mcasp->regs->RGBLCTL |= GBLCTL_RSMRST_ON;
, p+ k6 @0 `# O% `" i5 G while ( ( mcasp->regs->RGBLCTL & GBLCTL_RSMRST_ON ) != GBLCTL_RSMRST_ON );) d' \8 W6 }$ @! T5 Z
" [9 v4 c& z/ A& ^, _) V6 L mcasp->regs->XGBLCTL |= GBLCTL_XFRST_ON;
; z7 j! @3 m3 F% K while ( ( mcasp->regs->XGBLCTL & GBLCTL_XFRST_ON ) != GBLCTL_XFRST_ON );$ q' ]" v! \+ L& N( n; }$ ~
mcasp->regs->RGBLCTL |= GBLCTL_RFRST_ON;
/ m Z( d) I8 o" v$ r; Q, d/ }4 x- F while ( ( mcasp->regs->RGBLCTL & GBLCTL_RFRST_ON ) != GBLCTL_RFRST_ON );0 z8 C; k& P) l* Z9 S+ b1 ^
/ }& ?4 q( x6 n+ W$ |' ] CSR = 0x0000;
7 z( }! p+ I7 l+ T; g9 c INTC_INTMUX1 = 0x3d;0 n' Z5 c) H+ W: H
ISTP = (unsigned int)vectors;& m% F' W9 u' U
ICR = 0xFFF0;
* {$ C' H! d8 D* Q) y7 O IER |= 0x12; ' U) u: e: Q8 J: [
CSR |= 0x01; ! V I) P- I5 f* |" u1 T; f; K
8 ?8 X; ^+ G+ P' j5 T, \6 {7 A
) W6 l" N, @. d% f' E
/ F8 ~+ J. _: o0 u6 B
还有就是两个输入输出函数:
0 Q5 a$ f5 s6 p0 H7 P6 [6 Avoid output_sample(Int32 out_data)8 a, l. O% q9 W
{) i- x9 ?- @! l9 \" F
AIC31_data.uint = out_data;
o x( t1 P1 L h4 R7 D MCASP1_XBUF5_32BIT = AIC31_data.uint;
( ?9 f* K8 i2 h1 U" }1 Y}
. }0 b/ R+ |5 ]5 F; `, G; R% f" d
2 e' }5 A5 E/ r# C! mInt32 input_sample(void)
4 r) D8 C( R+ r e( e{ 6 M# G, b) J% P) J+ h o
AIC31_data.uint = MCASP1_RBUF0_32BIT;' u/ {/ ~7 D* Y# j' Z5 P( M
return (AIC31_data.uint);
$ j4 x1 p& d$ J( ] e j}% K, Y. S3 R: \
1 s0 [% K, v) ?$ P
|
|