|
|
C6747和C6748感觉差不多,我想实现McASP发送中断方式控制音频信号,在轮询的例程基础上改的,轮询程序可以实现,但是中断一直实现不了,也找不到错误,求大神帮忙!下边是主要程序:
: ^# Z& d* s+ K/ wmain文件:
$ J! @5 B, G' s$ D$ J. c' M( Q& Kinterrupt void interrupt4(void)
4 }6 ]$ z& d: I) y N0 o4 o{
. h9 |; E; A7 `- b Uint32 sample;! w8 W6 y% t* t
7 F( f$ i% E; N
sample = input_sample(); // read L + R samples from ADC& W$ n9 ?, h2 b: X1 \( d! Z
output_sample(sample); // write L + R samples to DAC
* @) P6 X) U s3 F" n* v( K) X) l return;% _; L! B. S N- p
}* G% n( W! }& e# n" c( N' I
8 u( z5 P. m, G9 T9 R) _2 Y
int main( void )9 Y8 d+ E( I6 i
{1 T. r' s+ ^( A6 `
' _1 K2 s x* v0 f7 y8 G
/* Initialize BSL */5 n, W' G% x! Y6 o$ s
EVMC6747_init( );
v+ n5 o) Q, G /* Call evmc6747_intr function */9 p! d# }& `! l; }8 p( a2 F4 w
aic3106_init( );# \' c3 ~, c: F: E0 m( b- v5 r
while(1);! {+ B( e. e9 K: x8 s
}& E7 e) c% R' e5 ^$ U+ Y
' L: @1 c( b3 s0 p/ ?% ]
2 }% [1 r b4 z9 u+ ~0 O% J2 _
aic3106_init文件的一部分,McASP配置部分,采用内部时钟,I2S方式,同步传输。音频芯片的配置应该没问题1 Y6 b- T6 o& D z7 h2 d- Z% i
/* Initialize MCASP1 */! G$ N B5 ?- p) u
mcasp = &MCASP_MODULE_1;
) h" G7 I7 y0 z5 d# a6 Z9 T, V# J mcasp->regs->GBLCTL = 0; // Reset5 A9 u1 Z% o, `' z+ x. U1 D8 C0 {# Q7 E: `
mcasp->regs->RGBLCTL = 0; // Reset RX- ]1 w, F. c& u, }6 p* Q
mcasp->regs->XGBLCTL = 0; // Reset TX) F" U+ w8 R, }. M; t* v, X
mcasp->regs->PWRDEMU = 1; // Free-running
( _9 k/ q$ |! E: y4 S* W // configure McASP0 receive registers) A. l3 n/ `) m2 M
mcasp->regs->RMASK = 0xFFFFFFFF; // No padding used, T( e$ y- g& V) [; n, x
mcasp->regs->RFMT = 0x00018078; // MSB 16bit, 0-delay, no pad, CFGBus
/ X/ h& F. ^" `2 j mcasp->regs->AFSRCTL = 0x00000112; // 2TDM, 1bit Falling, External FS, word
5 X; L2 p8 ]; Y& x6 C( z( P mcasp->regs->ACLKRCTL = 0x000000AF; // Rising INTERNAL CLK,(from tx side)5 q. @5 g) g) y+ ^
mcasp->regs->AHCLKRCTL = 0x00000000; // INT CLK (from tx side)
# i* A# Q' D: n9 h9 I, T# @8 r mcasp->regs->RTDM = 0x00000003; // Slots 0,15 x! |, f7 Z j5 v' A8 ]
mcasp->regs->RINTCTL = 0x00000000; // Not used2 G4 s& P- j$ g* Q3 r9 v- Y' W
mcasp->regs->RCLKCHK = 0x00FF0008; // 255-MAX 0-MIN, div-by-2568 @0 I) X! x, z% {/ p9 D
* v; @% q% @8 j; |4 ~ mcasp->regs->XMASK = 0xFFFFFFFF; // No padding used u/ W: g: P) D! y' n
mcasp->regs->XFMT = 0x00018078; // MSB 16bit, 0-delay, no pad, CFGBus9 W. h' {* d( ?+ s4 Y
mcasp->regs->AFSXCTL = 0x00000112; // 2TDM, 1bit Rising edge INTERNAL FS, word
* [: B# W! V) d' p/ [$ p# T mcasp->regs->ACLKXCTL = 0x000000AF; // ASYNC, Rising INTERNAL CLK, div-by-163 O5 O. N% B2 B' O
mcasp->regs->AHCLKXCTL = 0x00000000; // EXT CLK
& G. ^9 h' D2 K2 s$ s) I8 U mcasp->regs->XTDM = 0x00000003; // Slots 0,11 O/ h+ _$ ~0 D. Y* |- r
mcasp->regs->XINTCTL = 0x00000020; // interrupt on transmit5 y9 s. ~- P: }. G! U) O8 @0 T4 M, h
mcasp->regs->XCLKCHK = 0x00FF0008; // 255-MAX 0-MIN, div-by-256
9 g, Z& Q' k! D) _( f: N8 f. u! {+ R. f$ q2 X, s
mcasp->regs->SRCTL5 = 0x000D; // MCASP1.AXR1[5] --> DIN
. f2 M7 k6 i% t8 G$ a+ L mcasp->regs->SRCTL0 = 0x000E; // MCASP1.AXR1[0] <-- DOUT
3 j8 t: e6 g- G1 d6 b mcasp->regs->PFUNC = 0; // All MCASPs
; l% S w; S8 h7 ` mcasp->regs->PDIR = 0x14000020; // All inputs except AXR0[5], ACLKX1, AFSX14 K \1 n3 j3 _, u: W
7 h4 d3 Q% P! k1 d8 }$ ? mcasp->regs->DITCTL = 0x00000000; // Not used8 A: {: M9 h5 P0 P
mcasp->regs->DLBCTL = 0x00000000; // Not used" b3 h9 A# K; Q/ S) T
mcasp->regs->AMUTE = 0x00000000; // Not used
3 D, R" z/ J5 `4 M3 ~4 o7 f0 b8 F1 _8 n" W
/* Starting sections of the McASP*/
& c! v, B! ~9 p# H2 }6 x" k mcasp->regs->XGBLCTL |= GBLCTL_XHCLKRST_ON; E! i: I, E3 t' b0 k0 r: m7 H
while ( ( mcasp->regs->XGBLCTL & GBLCTL_XHCLKRST_ON ) != GBLCTL_XHCLKRST_ON ); ) I& c- k7 V3 z5 X
mcasp->regs->RGBLCTL |= GBLCTL_RHCLKRST_ON;
8 Z6 i5 y4 J$ Y% k, M5 r while ( ( mcasp->regs->RGBLCTL & GBLCTL_RHCLKRST_ON ) != GBLCTL_RHCLKRST_ON );" R& g6 r# i! E# K
0 B$ N$ Y( Z- r2 B- {- `& @ ] mcasp->regs->XGBLCTL |= GBLCTL_XCLKRST_ON;
; f; M( K- v( U, Q5 r* g while ( ( mcasp->regs->XGBLCTL & GBLCTL_XCLKRST_ON ) != GBLCTL_XCLKRST_ON );
& a& E& Z3 ]( z: W mcasp->regs->RGBLCTL |= GBLCTL_RCLKRST_ON;
9 z" k* k, @# t) D8 C while ( ( mcasp->regs->RGBLCTL & GBLCTL_RCLKRST_ON ) != GBLCTL_RCLKRST_ON );
2 w) C9 b- R2 k! T/ W2 \$ f
( S8 w0 [4 O* r+ j mcasp->regs->XSTAT = 0x0000ffff; ! p- F$ c- }0 L, g- w
mcasp->regs->RSTAT = 0x0000ffff; ' f5 w, R9 A6 k- ]: |
1 f4 x8 f1 Z( `7 X T2 C mcasp->regs->XGBLCTL |= GBLCTL_XSRCLR_ON;
4 U& g h# w% I' O6 p W. T% x. M) y while ( ( mcasp->regs->XGBLCTL & GBLCTL_XSRCLR_ON ) != GBLCTL_XSRCLR_ON );7 @* H6 V2 {; g
mcasp->regs->RGBLCTL |= GBLCTL_RSRCLR_ON; ! t; W' V2 P- `. E: H0 ~! Y$ F
while ( ( mcasp->regs->RGBLCTL & GBLCTL_RSRCLR_ON ) != GBLCTL_RSRCLR_ON );
# f; R: `0 q' {2 R" O" l
( w2 b- M5 N6 V) F* b0 c7 M /* Write a 0, so that no underrun occurs after releasing the state machine */" @1 s8 d0 e& u8 H
mcasp->regs->XBUF5 = 0;
. f# ^- n& ?8 G mcasp->regs->RBUF0 = 0;/ s; y( A+ \$ p, F" g) u
1 S% [% A% t, a6 m7 e) h; ^- M
mcasp->regs->XGBLCTL |= GBLCTL_XSMRST_ON; ) Q0 z8 |% P) m0 r: p/ e* D1 v
while ( ( mcasp->regs->XGBLCTL & GBLCTL_XSMRST_ON ) != GBLCTL_XSMRST_ON );
. G% e9 }/ I0 u( K) K: E mcasp->regs->RGBLCTL |= GBLCTL_RSMRST_ON;
1 ~: N% ~) y4 I9 T: T while ( ( mcasp->regs->RGBLCTL & GBLCTL_RSMRST_ON ) != GBLCTL_RSMRST_ON );2 C/ U' u* f% `& ~9 }7 ]0 U, `
& V/ b& d9 s' @) B# S2 Y mcasp->regs->XGBLCTL |= GBLCTL_XFRST_ON;
0 H5 D3 c6 a. S while ( ( mcasp->regs->XGBLCTL & GBLCTL_XFRST_ON ) != GBLCTL_XFRST_ON );; ?+ \; H4 E2 F3 r" E, a
mcasp->regs->RGBLCTL |= GBLCTL_RFRST_ON;
8 F9 q1 |: @8 `- `6 h1 W while ( ( mcasp->regs->RGBLCTL & GBLCTL_RFRST_ON ) != GBLCTL_RFRST_ON );
$ Y( ~* h7 ^6 P$ z' W
2 r/ n" Q! J- q- m3 i+ j. Z. E& [ CSR = 0x0000;
0 {% Y( a) c$ g. G. U/ v INTC_INTMUX1 = 0x3d;4 T- V" Q3 A& |) r" O* G A7 C( H5 C
ISTP = (unsigned int)vectors;
3 ^1 T* [5 [, j0 s! r. A3 o ICR = 0xFFF0; 9 {( u( W& _2 @" T
IER |= 0x12;
- R/ B/ @# _2 t0 e/ f6 e' ~( s CSR |= 0x01; 3 z+ j1 h" S9 a4 d8 n$ h" l& H- o' A
0 Q) v3 G- g) p% [; ]7 ?
& M1 z; a7 q1 G* o" @9 l6 i0 x% t* c/ I! U3 N3 g
还有就是两个输入输出函数:5 a' J [+ k$ o5 @, E
void output_sample(Int32 out_data)
1 E% u7 Z& T( ~% E7 C{
c# E6 L% _7 L& E7 ~' J$ ] AIC31_data.uint = out_data; # `8 u& u! J. r0 v$ f
MCASP1_XBUF5_32BIT = AIC31_data.uint;
/ s' _2 G* q3 B}$ ?' I K& D4 T J
" D2 d; Y/ x/ X& d: H
Int32 input_sample(void)
5 P/ k0 u' z; C7 W1 l" C{ . d# D% h2 A2 o! R
AIC31_data.uint = MCASP1_RBUF0_32BIT;5 |/ c# ~2 O- j( c% U& {! O$ F
return (AIC31_data.uint);
) x( P _% }4 @$ c4 c/ a7 Z% Y}
( R' ?# \& a1 _5 d$ ~! ` R3 V% a8 e A8 y: V4 B$ t4 }; v/ {/ y
|
|