|
C6747和C6748感觉差不多,我想实现McASP发送中断方式控制音频信号,在轮询的例程基础上改的,轮询程序可以实现,但是中断一直实现不了,也找不到错误,求大神帮忙!下边是主要程序:
& k& Z7 _2 F# y _/ d3 s rmain文件:
9 I$ a! R+ ?3 ^3 e) ], a7 I vinterrupt void interrupt4(void)
9 D' \$ y( R& m) y6 _7 o) }{
* }7 X) U1 {3 U; f ? Uint32 sample;
1 e0 Q( ~ t& \9 C: Y
: `; p: K5 ^- q2 H1 M sample = input_sample(); // read L + R samples from ADC+ @" t3 z& h1 V! e% u( W. j2 [$ ?
output_sample(sample); // write L + R samples to DAC
& C* O4 {9 b' r; l$ \* c return;# h# q& G5 S0 w8 @2 f. T& j5 A
}. g% P/ P: ^7 E1 x' j
# H/ u u3 `4 e
int main( void )
5 |4 ^( O4 k. x& O8 N# ]2 M{
# c6 x, k4 X X c* d6 ^
0 Y" i+ p" ]" v: T5 x3 J7 t& Y' Z /* Initialize BSL */9 q0 h( J4 \' r5 E# s
EVMC6747_init( );' B$ D7 a$ h4 p3 z5 e- k2 x% Z7 _
/* Call evmc6747_intr function */
$ D: t5 w3 [# a; U% x7 S aic3106_init( );% i7 H ^8 f9 F% ~
while(1);
4 C# } ]$ Z8 a+ E7 ~1 q. E- `}0 T+ E( C0 K' l9 ]: Q8 M9 B8 I
6 s! V# \. c8 p' `
8 q F+ x8 r; \& `aic3106_init文件的一部分,McASP配置部分,采用内部时钟,I2S方式,同步传输。音频芯片的配置应该没问题
d) x L2 n) Q+ f n' r/* Initialize MCASP1 */5 B" O% v% X. }
mcasp = &MCASP_MODULE_1;
; i) W; |' x# [0 c9 c mcasp->regs->GBLCTL = 0; // Reset
B/ `+ }) O# i mcasp->regs->RGBLCTL = 0; // Reset RX9 Z, {' P6 M3 v( ~2 o$ Q
mcasp->regs->XGBLCTL = 0; // Reset TX, H" `8 M; o4 D/ O
mcasp->regs->PWRDEMU = 1; // Free-running
% b. N9 @! v! d; \: o( D# Y // configure McASP0 receive registers
4 ~( D3 ]' R0 K7 x! X8 v- L: z, v5 }0 ^ mcasp->regs->RMASK = 0xFFFFFFFF; // No padding used+ W+ T* x+ ~& H% \8 b
mcasp->regs->RFMT = 0x00018078; // MSB 16bit, 0-delay, no pad, CFGBus
+ X, l6 @, I& t3 ^ mcasp->regs->AFSRCTL = 0x00000112; // 2TDM, 1bit Falling, External FS, word
, p: m/ `5 h1 N+ i. v+ e mcasp->regs->ACLKRCTL = 0x000000AF; // Rising INTERNAL CLK,(from tx side)! S$ M! p2 c9 h! T7 C
mcasp->regs->AHCLKRCTL = 0x00000000; // INT CLK (from tx side)5 _) k0 y9 m3 t9 j
mcasp->regs->RTDM = 0x00000003; // Slots 0,1
/ `: ]) A! q; O/ }2 Y0 m# `! Y! e mcasp->regs->RINTCTL = 0x00000000; // Not used
3 K9 }/ A, R4 x0 S# V2 v mcasp->regs->RCLKCHK = 0x00FF0008; // 255-MAX 0-MIN, div-by-2563 f# D& y" u& Y0 A8 r
: b/ }# a8 j( X; o; o! \& w
mcasp->regs->XMASK = 0xFFFFFFFF; // No padding used
1 A' U# I2 y5 |. k) N5 d8 T mcasp->regs->XFMT = 0x00018078; // MSB 16bit, 0-delay, no pad, CFGBus* x9 G M. o5 u$ K. L+ S
mcasp->regs->AFSXCTL = 0x00000112; // 2TDM, 1bit Rising edge INTERNAL FS, word% @, b, v% _6 |* f
mcasp->regs->ACLKXCTL = 0x000000AF; // ASYNC, Rising INTERNAL CLK, div-by-161 m) v- n& [% d
mcasp->regs->AHCLKXCTL = 0x00000000; // EXT CLK
' q" r' R/ p9 A" D( I$ ]1 A mcasp->regs->XTDM = 0x00000003; // Slots 0,1- L6 V" O1 V. w# E( p
mcasp->regs->XINTCTL = 0x00000020; // interrupt on transmit
/ E- t+ H# M2 [7 K mcasp->regs->XCLKCHK = 0x00FF0008; // 255-MAX 0-MIN, div-by-256: _0 f# _5 ]- E y
" w1 D0 V7 x% x6 y6 O' T7 {# `8 I mcasp->regs->SRCTL5 = 0x000D; // MCASP1.AXR1[5] --> DIN
1 t3 k* l$ e& D* \ mcasp->regs->SRCTL0 = 0x000E; // MCASP1.AXR1[0] <-- DOUT& N: V" q# f' U/ y7 L
mcasp->regs->PFUNC = 0; // All MCASPs3 O% N) s7 Y' b; g: h" v
mcasp->regs->PDIR = 0x14000020; // All inputs except AXR0[5], ACLKX1, AFSX1) P1 b: `$ }' L: l/ N( ?# e% U
$ ^- Y0 H: s" _- D1 e
mcasp->regs->DITCTL = 0x00000000; // Not used: |& H5 O% `) P& S) @" H
mcasp->regs->DLBCTL = 0x00000000; // Not used
% D/ u* b8 i6 z/ Y: Y5 q ? mcasp->regs->AMUTE = 0x00000000; // Not used
# l. H/ q: ^/ V, q
2 t$ _( J& g) t0 E. v# @6 [/* Starting sections of the McASP*/4 q; {1 j- r' s7 l
mcasp->regs->XGBLCTL |= GBLCTL_XHCLKRST_ON; $ ^" N: k9 ], y0 T/ M2 H- d
while ( ( mcasp->regs->XGBLCTL & GBLCTL_XHCLKRST_ON ) != GBLCTL_XHCLKRST_ON ); . e; g6 ?, }4 b( |+ E$ i# y! q
mcasp->regs->RGBLCTL |= GBLCTL_RHCLKRST_ON;
# U F8 p5 B D- |0 |2 u9 C" r7 a- K while ( ( mcasp->regs->RGBLCTL & GBLCTL_RHCLKRST_ON ) != GBLCTL_RHCLKRST_ON );
9 X( ~& D: M3 K" V
: e; ]. Q( i$ G! |7 q3 u3 z mcasp->regs->XGBLCTL |= GBLCTL_XCLKRST_ON; 3 E7 I {& F+ y5 K5 c& V* F
while ( ( mcasp->regs->XGBLCTL & GBLCTL_XCLKRST_ON ) != GBLCTL_XCLKRST_ON );
) b0 J$ s z( e* j, G- e. o mcasp->regs->RGBLCTL |= GBLCTL_RCLKRST_ON; & M6 v2 s2 s( y! b4 x" m9 [2 Z# L
while ( ( mcasp->regs->RGBLCTL & GBLCTL_RCLKRST_ON ) != GBLCTL_RCLKRST_ON );
; \$ X" u; ]( o. E. G
- a/ C4 M) c& G: j" ^+ X9 f# D mcasp->regs->XSTAT = 0x0000ffff; ) z6 b* w4 _! t: r
mcasp->regs->RSTAT = 0x0000ffff; # }* K+ z& z4 ~( _" W/ O" R4 Q% Q
1 S9 E3 s9 H- G X7 T0 z mcasp->regs->XGBLCTL |= GBLCTL_XSRCLR_ON;
$ }+ I9 B8 p/ t0 x' G$ U5 C; | while ( ( mcasp->regs->XGBLCTL & GBLCTL_XSRCLR_ON ) != GBLCTL_XSRCLR_ON );( ?& a; b4 a: S H/ v# i4 P
mcasp->regs->RGBLCTL |= GBLCTL_RSRCLR_ON; " H" R' n5 `6 |) f& ?/ n
while ( ( mcasp->regs->RGBLCTL & GBLCTL_RSRCLR_ON ) != GBLCTL_RSRCLR_ON );
0 V3 ?: k4 P) |9 g9 K$ I
2 d' ]; W" v1 u; g* J# T /* Write a 0, so that no underrun occurs after releasing the state machine */) ]2 m- h# I( n; t
mcasp->regs->XBUF5 = 0;
r6 t/ m; @/ c mcasp->regs->RBUF0 = 0;: `9 G7 {. r# b. a
9 [1 A9 M. T7 _' [4 [- m
mcasp->regs->XGBLCTL |= GBLCTL_XSMRST_ON;
) ?0 I( B; p. J7 l9 W2 i; ~ while ( ( mcasp->regs->XGBLCTL & GBLCTL_XSMRST_ON ) != GBLCTL_XSMRST_ON );
! G4 g& R+ K- X" G/ k; R/ h mcasp->regs->RGBLCTL |= GBLCTL_RSMRST_ON; , l3 v) o, v/ r) D& U$ @) K( B# O
while ( ( mcasp->regs->RGBLCTL & GBLCTL_RSMRST_ON ) != GBLCTL_RSMRST_ON );
K7 c# M- H# A' Z& J7 D( J- o" _$ ]" I# _
mcasp->regs->XGBLCTL |= GBLCTL_XFRST_ON; ! F# f* ~8 [* A
while ( ( mcasp->regs->XGBLCTL & GBLCTL_XFRST_ON ) != GBLCTL_XFRST_ON );
$ O. f9 e/ R# f0 M0 l mcasp->regs->RGBLCTL |= GBLCTL_RFRST_ON;
0 h) K1 S2 _! r7 g while ( ( mcasp->regs->RGBLCTL & GBLCTL_RFRST_ON ) != GBLCTL_RFRST_ON );
) n1 w2 ?- h! {* I
& ^8 b: R, }8 k$ _0 K! l6 r CSR = 0x0000;! k2 l9 y* n! K/ g
INTC_INTMUX1 = 0x3d;) ]+ ~: M$ x+ N5 Q9 q( s
ISTP = (unsigned int)vectors;
) N, A. V! Q) @, y ICR = 0xFFF0; 6 S% b8 u+ {6 H! m% j. C b" B0 D
IER |= 0x12; $ T% h! i$ x3 _/ U( |
CSR |= 0x01; 4 J3 B' L/ M' e5 t9 E8 G
8 g: B# t# I* X9 k% x. [$ c* F0 k) J4 [4 o9 n) I
/ T1 b5 Z7 k) |3 E: K8 A* M
还有就是两个输入输出函数:; E% F$ ?+ b; f; i) D! `: V' D9 h
void output_sample(Int32 out_data)
8 {) t% [ l' t" r* }% o{' R6 z b0 s' h+ y3 H0 {
AIC31_data.uint = out_data; 9 B: ~% x& p, f
MCASP1_XBUF5_32BIT = AIC31_data.uint;
& [0 w1 f* T9 M4 O& ~}4 G" R8 L4 Z7 `( g) [" ^( G. l
. p: m" t( w1 v$ c; x& ?1 UInt32 input_sample(void)
/ \- x. f1 D4 N/ k$ S d* ?! w{ - Y6 n' b+ r9 g. R+ j. n
AIC31_data.uint = MCASP1_RBUF0_32BIT;7 m$ {, s9 H" T7 U2 \& ]4 a2 v
return (AIC31_data.uint);" ?. V, v' G" q3 E6 g9 L2 o; ~
}
: F0 R0 k$ j9 b% R: c) c7 F
. R+ ?6 a9 s/ w% P7 q; ] |
|