|
|
C6747和C6748感觉差不多,我想实现McASP发送中断方式控制音频信号,在轮询的例程基础上改的,轮询程序可以实现,但是中断一直实现不了,也找不到错误,求大神帮忙!下边是主要程序:9 [9 l1 a6 ], [7 |5 `9 q W4 ]
main文件:! f% Q/ {* w) E! O6 J: q6 [
interrupt void interrupt4(void) ! y0 D$ ?& x4 W( _5 c
{! V3 f) s8 v7 E y: n' T
Uint32 sample;: C9 @& V. E% o! u) Z/ S6 G s
! }9 G5 G3 h& s0 w/ r
sample = input_sample(); // read L + R samples from ADC0 m9 X: X+ e6 A/ R$ i
output_sample(sample); // write L + R samples to DAC . A' |% b0 @' f) z& }
return;
+ i/ k- O9 I; x' m}
, r9 |1 @$ k: Q
. r3 S3 h, `0 H4 M' B* {3 i8 `int main( void )% B/ Q1 P, r# F% }' O4 V
{
& }8 \* |4 ]- X& I9 o. F
" |7 g& h! L' K+ Q6 f) m8 V /* Initialize BSL */
% s. ]* L5 g1 W% x( Y t EVMC6747_init( );
+ G, y0 w8 s* z1 N4 D- L5 k" e9 x /* Call evmc6747_intr function */% w6 z8 K8 R2 F, I/ [% _, W" q
aic3106_init( );
g( i5 M M. Z9 ?- L, [3 h while(1);
7 B/ n1 }6 |, E/ H; m+ N: {0 N% Z}
! t4 c& V, u. |9 F8 _ n$ ^: J- P. B' D" D' e
' a3 M: \$ g* Y) {% W% B. _; P
aic3106_init文件的一部分,McASP配置部分,采用内部时钟,I2S方式,同步传输。音频芯片的配置应该没问题
4 e: @ [, n: P7 O& W* v/* Initialize MCASP1 */
+ _& w. k" L5 Q" l8 I4 W9 w: S mcasp = &MCASP_MODULE_1;! Z4 D# m, }* `+ o% P
mcasp->regs->GBLCTL = 0; // Reset
9 z& ]! _( F5 D& j mcasp->regs->RGBLCTL = 0; // Reset RX$ q- H9 l+ G! S4 T' @- I
mcasp->regs->XGBLCTL = 0; // Reset TX1 N H! X: Q' C% o1 B
mcasp->regs->PWRDEMU = 1; // Free-running
) F9 e5 W* @ X/ q4 n: H // configure McASP0 receive registers& L2 N# z& Y3 I7 a3 q& _
mcasp->regs->RMASK = 0xFFFFFFFF; // No padding used. N9 z4 n3 @9 f5 m+ U7 j
mcasp->regs->RFMT = 0x00018078; // MSB 16bit, 0-delay, no pad, CFGBus! @3 u- T9 g* Z, x
mcasp->regs->AFSRCTL = 0x00000112; // 2TDM, 1bit Falling, External FS, word
( R2 n- u: q# R' {+ \; r6 q mcasp->regs->ACLKRCTL = 0x000000AF; // Rising INTERNAL CLK,(from tx side) o) O9 ^! C# |5 h' I" y9 Z
mcasp->regs->AHCLKRCTL = 0x00000000; // INT CLK (from tx side): n/ c9 [& J; d* l1 |7 O3 g. t
mcasp->regs->RTDM = 0x00000003; // Slots 0,1
. T! r3 h6 h; x6 g mcasp->regs->RINTCTL = 0x00000000; // Not used6 A+ [; m" s8 s6 P9 `
mcasp->regs->RCLKCHK = 0x00FF0008; // 255-MAX 0-MIN, div-by-256- J, ~+ k" S7 |
$ f9 q1 d+ e ^6 [0 t8 I; W6 f) U
mcasp->regs->XMASK = 0xFFFFFFFF; // No padding used9 x! N* y* ?/ d7 r& b- D' |
mcasp->regs->XFMT = 0x00018078; // MSB 16bit, 0-delay, no pad, CFGBus; x1 E8 z. J/ [9 z& A
mcasp->regs->AFSXCTL = 0x00000112; // 2TDM, 1bit Rising edge INTERNAL FS, word" V) Y. W6 H. j+ x m$ o8 [
mcasp->regs->ACLKXCTL = 0x000000AF; // ASYNC, Rising INTERNAL CLK, div-by-16
# h. F2 i3 |& s. d' t mcasp->regs->AHCLKXCTL = 0x00000000; // EXT CLK
7 Q: A+ }4 X! {: Z3 Y$ a mcasp->regs->XTDM = 0x00000003; // Slots 0,1, c `' L% [7 k' S; ]% k
mcasp->regs->XINTCTL = 0x00000020; // interrupt on transmit0 e7 S; x/ @8 z# x
mcasp->regs->XCLKCHK = 0x00FF0008; // 255-MAX 0-MIN, div-by-256! {( l+ v6 f5 o+ k1 y
/ z$ _- Z+ u2 s0 M
mcasp->regs->SRCTL5 = 0x000D; // MCASP1.AXR1[5] --> DIN. s' i- _& B( \0 c9 a5 H2 X+ `+ q" F
mcasp->regs->SRCTL0 = 0x000E; // MCASP1.AXR1[0] <-- DOUT! T# ]5 W$ H& [
mcasp->regs->PFUNC = 0; // All MCASPs' X. ]; S9 f$ f
mcasp->regs->PDIR = 0x14000020; // All inputs except AXR0[5], ACLKX1, AFSX12 `. \0 w+ i1 H8 C% y( g; n
0 q8 }8 V; h) C3 i$ F
mcasp->regs->DITCTL = 0x00000000; // Not used: \' C. U3 a7 S
mcasp->regs->DLBCTL = 0x00000000; // Not used
) i5 w+ D! {5 G4 T Q- R mcasp->regs->AMUTE = 0x00000000; // Not used0 c" C. I2 C3 `6 x" Z$ Q( l
# O' u1 N5 p/ g( \2 e3 k
/* Starting sections of the McASP*/
- K2 A6 J9 z0 z( K7 P1 G3 d. C: j5 | mcasp->regs->XGBLCTL |= GBLCTL_XHCLKRST_ON; / C- g; j4 `0 I& W3 d0 G, F [
while ( ( mcasp->regs->XGBLCTL & GBLCTL_XHCLKRST_ON ) != GBLCTL_XHCLKRST_ON );
/ w& o# |- [; @+ p mcasp->regs->RGBLCTL |= GBLCTL_RHCLKRST_ON; " U1 c r* {0 O6 ?. e4 ]/ u
while ( ( mcasp->regs->RGBLCTL & GBLCTL_RHCLKRST_ON ) != GBLCTL_RHCLKRST_ON );/ ~ O' X( a' v: e& Z" n: n5 L( c
( t! s/ J0 v9 {1 O; R, c" H
mcasp->regs->XGBLCTL |= GBLCTL_XCLKRST_ON;
8 m( S# |+ Q* b7 w1 C) _1 P% U while ( ( mcasp->regs->XGBLCTL & GBLCTL_XCLKRST_ON ) != GBLCTL_XCLKRST_ON );& y$ c& s4 ^ \8 `! }) A
mcasp->regs->RGBLCTL |= GBLCTL_RCLKRST_ON;
0 ^9 J% Y. \1 r' u# z while ( ( mcasp->regs->RGBLCTL & GBLCTL_RCLKRST_ON ) != GBLCTL_RCLKRST_ON );) I1 s" T2 O+ ^% g$ G
5 r" n- h' e7 h+ Y* F7 _) z mcasp->regs->XSTAT = 0x0000ffff;
/ Y# N2 g- l1 @3 x6 s( }# A mcasp->regs->RSTAT = 0x0000ffff; 6 f: r$ R. i/ a' L0 u* d
0 C s0 ~6 F3 M U2 f. ? mcasp->regs->XGBLCTL |= GBLCTL_XSRCLR_ON;+ _3 r/ O: C) \6 ^
while ( ( mcasp->regs->XGBLCTL & GBLCTL_XSRCLR_ON ) != GBLCTL_XSRCLR_ON );
" T+ ~1 H+ ?) x6 m! ?! j mcasp->regs->RGBLCTL |= GBLCTL_RSRCLR_ON;
! _0 e& m- }! z- P. V2 C! d, k while ( ( mcasp->regs->RGBLCTL & GBLCTL_RSRCLR_ON ) != GBLCTL_RSRCLR_ON );
9 k, O5 R: \. ]. M+ `/ Q% T% ]$ a, A
/* Write a 0, so that no underrun occurs after releasing the state machine */) X1 Z0 E3 }# C* A/ P0 u- ]% k
mcasp->regs->XBUF5 = 0;
m; T, |4 t) @1 w mcasp->regs->RBUF0 = 0;
4 Q9 c {. {9 |
8 R- q. G5 W5 [. F5 X$ d mcasp->regs->XGBLCTL |= GBLCTL_XSMRST_ON;
5 o/ o: j) P: m8 S' y8 N while ( ( mcasp->regs->XGBLCTL & GBLCTL_XSMRST_ON ) != GBLCTL_XSMRST_ON );
& x3 g: C# Z! Z; d) \5 H mcasp->regs->RGBLCTL |= GBLCTL_RSMRST_ON;
) M1 t# p" J; Q/ O, J while ( ( mcasp->regs->RGBLCTL & GBLCTL_RSMRST_ON ) != GBLCTL_RSMRST_ON );
g1 v) X& w! g1 Z. ?! `% h/ _0 m, w- R) x* w: S7 P, {# n- ? S4 a; H
mcasp->regs->XGBLCTL |= GBLCTL_XFRST_ON; $ Q8 o- p- n% P: `9 H, L" p
while ( ( mcasp->regs->XGBLCTL & GBLCTL_XFRST_ON ) != GBLCTL_XFRST_ON );
; n2 ]1 d4 v9 c4 n; L6 m mcasp->regs->RGBLCTL |= GBLCTL_RFRST_ON; + |* a1 n# N0 r* _( s7 W2 k/ q
while ( ( mcasp->regs->RGBLCTL & GBLCTL_RFRST_ON ) != GBLCTL_RFRST_ON );
0 j U' x3 n* H4 U! \
4 Y, U* {9 g4 {) Z CSR = 0x0000;
, L# q+ F: I# M# e, F INTC_INTMUX1 = 0x3d;
% H3 K- U: t$ x! p ISTP = (unsigned int)vectors;; o1 w1 e7 U4 K6 g5 @
ICR = 0xFFF0; ( }4 j3 v5 E4 J+ V
IER |= 0x12;
: o9 p7 R: j! a# N4 k, c9 R2 \ CSR |= 0x01; " o& u( h% B. ]& w7 Z# }3 P1 M" [& F
- [3 t7 h9 I: t
9 a. L- w2 y$ z0 [
0 N) C U0 q& C( ~还有就是两个输入输出函数:
- O$ @9 ~3 E+ qvoid output_sample(Int32 out_data)
" |9 v/ h5 _: @6 o: o{
D( {0 }( k$ J AIC31_data.uint = out_data; : `, P: p0 w( b8 `
MCASP1_XBUF5_32BIT = AIC31_data.uint;
/ `; e) c) Q5 s& O+ f/ m}+ d4 w$ K' {( N3 |' a& A7 U/ k0 b
. `1 x3 u( H3 Y5 i5 a2 _
Int32 input_sample(void)' g" g, S9 X3 Y; C0 v7 C
{
5 v2 q' _1 b. z8 Z1 L; ^! X. G' T( T2 U AIC31_data.uint = MCASP1_RBUF0_32BIT;6 ?- J9 y% L, |
return (AIC31_data.uint);
$ |( l5 O! L( x}2 I* S) F# E! }
0 K0 D5 p" E, g" t& h" U
|
|