|
|
C6747和C6748感觉差不多,我想实现McASP发送中断方式控制音频信号,在轮询的例程基础上改的,轮询程序可以实现,但是中断一直实现不了,也找不到错误,求大神帮忙!下边是主要程序:
# M0 B" O/ j4 ]: K Ymain文件:: f2 ]3 U! \0 m5 y. v
interrupt void interrupt4(void) ; k3 |- s+ ?. E% I
{
' C8 B. G E, F Uint32 sample;: @6 @& X- E# X$ O* }' y5 X
. q! o J* }) K& R) N R# t% g
sample = input_sample(); // read L + R samples from ADC2 O! [" Z% b* x
output_sample(sample); // write L + R samples to DAC
2 q. I2 I1 n9 D$ q/ z( W0 ~7 N6 K! V return;
& [8 b) J# R' l# S `$ b0 T}
9 h& A+ y+ V1 p1 v% }$ Z$ ^. X# F- Y& y% H
int main( void )
( K3 ]5 C* ~" J8 p& p{/ s7 G8 g1 e" w+ ~$ L- e
# x/ M. H- ~4 O! ~
/* Initialize BSL */
: G' n- b+ N) h7 C: N1 p5 E EVMC6747_init( );
% m) W0 C6 T& Z* [( x8 G3 A/ J; H) h /* Call evmc6747_intr function */ C" c) L% e, H, {2 J1 g8 V( ~8 F
aic3106_init( );
9 \& V$ t! X% g3 L) s, @ while(1);
- w: P2 u* a# g4 _}- X$ P, U& v# c4 {3 ?2 Z) d' i
/ \ Y" Z% C" R+ p1 |- w
* Q- h0 Q/ G2 t# }aic3106_init文件的一部分,McASP配置部分,采用内部时钟,I2S方式,同步传输。音频芯片的配置应该没问题 R2 z& I& W# `+ Q5 a) F
/* Initialize MCASP1 */
& J# D& T1 \* W4 M% o: D1 R, \/ L2 C mcasp = &MCASP_MODULE_1;7 g8 J# N# ?- o2 P
mcasp->regs->GBLCTL = 0; // Reset3 \6 F( U1 \7 g9 `' m! J* o: y
mcasp->regs->RGBLCTL = 0; // Reset RX
( z; D) d9 D9 [ mcasp->regs->XGBLCTL = 0; // Reset TX, z# s: S3 n2 n
mcasp->regs->PWRDEMU = 1; // Free-running- h# I! {% b. r. \# a
// configure McASP0 receive registers0 r, z# H, Y" Y! t/ k$ X
mcasp->regs->RMASK = 0xFFFFFFFF; // No padding used
6 Y+ y3 }& H. V& t0 z: y# y! v mcasp->regs->RFMT = 0x00018078; // MSB 16bit, 0-delay, no pad, CFGBus
, U2 g& ]. w9 w mcasp->regs->AFSRCTL = 0x00000112; // 2TDM, 1bit Falling, External FS, word
% L5 t0 a& C: z" f/ k& u mcasp->regs->ACLKRCTL = 0x000000AF; // Rising INTERNAL CLK,(from tx side)* W7 {: X) D; a0 k9 l" d9 N1 W
mcasp->regs->AHCLKRCTL = 0x00000000; // INT CLK (from tx side)
" @6 z2 c% x2 C; \' H& [ mcasp->regs->RTDM = 0x00000003; // Slots 0,1& h7 `" U; E0 A
mcasp->regs->RINTCTL = 0x00000000; // Not used
% F9 v+ S8 S, v9 P) a$ p mcasp->regs->RCLKCHK = 0x00FF0008; // 255-MAX 0-MIN, div-by-2568 p5 O8 o) `+ h* }$ u/ v
4 }7 ^$ q7 o+ j, A! K mcasp->regs->XMASK = 0xFFFFFFFF; // No padding used% |# n1 a1 F; U) G& V! Y
mcasp->regs->XFMT = 0x00018078; // MSB 16bit, 0-delay, no pad, CFGBus
/ B' Y% G% R/ l- p$ z mcasp->regs->AFSXCTL = 0x00000112; // 2TDM, 1bit Rising edge INTERNAL FS, word
+ [5 O/ C9 L b" e: W% k' a1 \. S mcasp->regs->ACLKXCTL = 0x000000AF; // ASYNC, Rising INTERNAL CLK, div-by-167 g$ q4 C( p: O, [6 O j
mcasp->regs->AHCLKXCTL = 0x00000000; // EXT CLK
8 J: |; }4 h) J' V mcasp->regs->XTDM = 0x00000003; // Slots 0,1
7 G$ O/ d8 Y# o) P mcasp->regs->XINTCTL = 0x00000020; // interrupt on transmit
/ e: ^/ p2 L5 d/ f+ Z5 c) j) m1 |: T mcasp->regs->XCLKCHK = 0x00FF0008; // 255-MAX 0-MIN, div-by-256
( E0 x* `0 D* v- ?( _; u3 B7 A% S7 W( |$ J5 s
mcasp->regs->SRCTL5 = 0x000D; // MCASP1.AXR1[5] --> DIN
# `4 M5 M% A. r6 T( ]: z mcasp->regs->SRCTL0 = 0x000E; // MCASP1.AXR1[0] <-- DOUT
& Z' t: H( O; s" O2 ]0 |0 i/ f5 b& ?% Z' ` mcasp->regs->PFUNC = 0; // All MCASPs) L; @. N x/ w
mcasp->regs->PDIR = 0x14000020; // All inputs except AXR0[5], ACLKX1, AFSX1+ U! _% |. P' r( v+ F
8 x5 h$ g3 D, j& U) ]2 v mcasp->regs->DITCTL = 0x00000000; // Not used
! t, S$ d: A9 V* ~3 _1 J mcasp->regs->DLBCTL = 0x00000000; // Not used2 g( f7 C2 Y6 [# r5 b5 u- c9 u
mcasp->regs->AMUTE = 0x00000000; // Not used
2 S3 r$ @" N2 H' l' g: B' x! |) X6 `/ |' E" h
/* Starting sections of the McASP*/
* o) p: O! j1 R9 F mcasp->regs->XGBLCTL |= GBLCTL_XHCLKRST_ON; 6 H" `6 {/ R* y/ Z3 r0 y: p4 C$ c
while ( ( mcasp->regs->XGBLCTL & GBLCTL_XHCLKRST_ON ) != GBLCTL_XHCLKRST_ON );
* d- m" J! t; @& g mcasp->regs->RGBLCTL |= GBLCTL_RHCLKRST_ON;
0 ~, {* B: x. j while ( ( mcasp->regs->RGBLCTL & GBLCTL_RHCLKRST_ON ) != GBLCTL_RHCLKRST_ON );7 H2 O g$ v& C9 T6 O. n9 k
: y. v. L5 r& o* J7 ~6 I7 ~
mcasp->regs->XGBLCTL |= GBLCTL_XCLKRST_ON; ) ]+ Q! C* B6 v* r
while ( ( mcasp->regs->XGBLCTL & GBLCTL_XCLKRST_ON ) != GBLCTL_XCLKRST_ON );
5 I c' }# G% x$ a- { mcasp->regs->RGBLCTL |= GBLCTL_RCLKRST_ON;
1 F6 d) F0 L# M# H while ( ( mcasp->regs->RGBLCTL & GBLCTL_RCLKRST_ON ) != GBLCTL_RCLKRST_ON );5 K. {7 q& G9 m* F- x* M
. F7 T& [' i& b" ? m9 a
mcasp->regs->XSTAT = 0x0000ffff; 9 o5 J ~. ?- w. q
mcasp->regs->RSTAT = 0x0000ffff;
7 X7 {& R" T! Z' N$ _
0 P* L5 q1 Z Y: \0 u mcasp->regs->XGBLCTL |= GBLCTL_XSRCLR_ON;2 j' L" n6 r- B1 y" |8 q
while ( ( mcasp->regs->XGBLCTL & GBLCTL_XSRCLR_ON ) != GBLCTL_XSRCLR_ON );
1 G3 X5 F! x W( m mcasp->regs->RGBLCTL |= GBLCTL_RSRCLR_ON; 4 d' l( ]# `0 h$ V: I
while ( ( mcasp->regs->RGBLCTL & GBLCTL_RSRCLR_ON ) != GBLCTL_RSRCLR_ON );
3 A3 C% g* @+ ~( w% G- P- A. e/ g/ x: Q8 \5 @) t
/* Write a 0, so that no underrun occurs after releasing the state machine */
2 g+ b) m. [& c( s# J" { mcasp->regs->XBUF5 = 0;7 n. @" a9 o- J5 W4 [: n
mcasp->regs->RBUF0 = 0;+ C* t m/ w6 Q9 S1 T
% d- k: d' K& i4 p$ f( }! g
mcasp->regs->XGBLCTL |= GBLCTL_XSMRST_ON; " S8 U. [, ?2 V; c
while ( ( mcasp->regs->XGBLCTL & GBLCTL_XSMRST_ON ) != GBLCTL_XSMRST_ON );
: M) @+ R" G4 R7 u+ ~; O0 A6 y! v mcasp->regs->RGBLCTL |= GBLCTL_RSMRST_ON; 5 u. d1 ^7 d# {: p' ] O$ X
while ( ( mcasp->regs->RGBLCTL & GBLCTL_RSMRST_ON ) != GBLCTL_RSMRST_ON );
$ m7 {; ]' l1 d8 h& v4 i% j* g& l( A" d+ y6 L8 _
mcasp->regs->XGBLCTL |= GBLCTL_XFRST_ON; 7 Z$ i6 O) o6 a" p
while ( ( mcasp->regs->XGBLCTL & GBLCTL_XFRST_ON ) != GBLCTL_XFRST_ON );
* ]: w$ k, l/ L mcasp->regs->RGBLCTL |= GBLCTL_RFRST_ON; - W: E, I* F( f7 f
while ( ( mcasp->regs->RGBLCTL & GBLCTL_RFRST_ON ) != GBLCTL_RFRST_ON );9 Z* Q7 C9 a4 \$ X" H d. [3 A. ~( N; Z
' W3 o; k3 W% U, g0 m; i g
CSR = 0x0000;
0 g" S! k5 N% P2 a INTC_INTMUX1 = 0x3d;
+ W( g2 G5 j/ T- i; |0 q% i9 s+ E ISTP = (unsigned int)vectors;
7 X) W5 [9 F2 M$ A/ G; W i2 r1 f$ C ICR = 0xFFF0; & y% y6 L% o3 ?6 Z/ v7 ^5 d1 _6 o
IER |= 0x12;
4 s- O6 y6 v" l- Q6 Q/ _3 q CSR |= 0x01;
) I+ n' H9 B5 z/ H7 a O% n: d |+ Z& Q" h" ^5 M; A# }
( P, N) Z" e9 d3 s* n1 `% h, i2 A3 B9 l F! P3 l
还有就是两个输入输出函数:
' e% h% z! }- c7 w) I* qvoid output_sample(Int32 out_data)/ T+ _3 Q x1 L' N9 d
{, e2 P$ }, }$ n* C! Q+ T- B
AIC31_data.uint = out_data; ( W' |6 P/ p* p: F1 A# h8 r
MCASP1_XBUF5_32BIT = AIC31_data.uint;+ ?& N* e' ]" n& w$ |& j
}3 Z! j, X6 v ~, o3 r6 X) b
l) s+ x7 K. I& g* N RInt32 input_sample(void)- v1 c M7 C3 M J" d
{ 2 f @# a& n# N/ }. r
AIC31_data.uint = MCASP1_RBUF0_32BIT; i) a1 c" T6 B1 w6 a w A* X; L$ i" N
return (AIC31_data.uint);
; S# C% F. u$ Q+ I( {}& V- m9 K% M0 w
W: {6 F* {8 j. P6 E& V
|
|