|
|
C6747和C6748感觉差不多,我想实现McASP发送中断方式控制音频信号,在轮询的例程基础上改的,轮询程序可以实现,但是中断一直实现不了,也找不到错误,求大神帮忙!下边是主要程序:
- D" {5 |* P+ I6 K* L# ~- i. A7 [main文件:: i/ W- o7 R5 r9 d7 R3 w0 N
interrupt void interrupt4(void)
* Q u9 X( e7 g! Q. i8 v. i. l, a{9 T0 C2 ~- v7 Q7 u f! k g+ \- R
Uint32 sample;* e* Z4 \- I) X" M2 o9 d [5 M
& x9 w! }, N% H" L! A" c sample = input_sample(); // read L + R samples from ADC2 Q2 C, Z3 c5 K) C% ^4 B$ |
output_sample(sample); // write L + R samples to DAC 6 I1 X' T5 p, n
return;
1 k: v( c V/ S) l& m4 q- S) G1 ^}# m% s" I/ _' m, `* C
( U) R; K: b! \; j: G+ P) H
int main( void )/ a8 y1 x# K' ~% \$ ?4 H- h0 T, f7 G
{7 h' M. l1 x0 |3 ^& f& b- h
/ |- P3 H. q! ?1 D
/* Initialize BSL */
- Y1 s8 o( b& ^2 s4 [' H$ ]0 s EVMC6747_init( );
# g* D' i4 S$ F; Z5 L( B /* Call evmc6747_intr function */: L+ d/ ^* g0 @2 \; ^* J
aic3106_init( );
& t/ W% K1 p8 w; }) b0 u while(1);
' U/ P$ Y; ?: I7 T}, j* f. o7 ]6 V% [* E* t2 ]
9 l; E# v5 E: r" E9 c, n5 @- z( P( Y7 A N( Y( n% b
aic3106_init文件的一部分,McASP配置部分,采用内部时钟,I2S方式,同步传输。音频芯片的配置应该没问题) D: N( U3 u9 I$ v8 N2 K g3 L
/* Initialize MCASP1 *// q; ]' [8 B1 R$ ^
mcasp = &MCASP_MODULE_1;
5 c9 u1 G' }& J4 ]5 ^$ ?; b, K mcasp->regs->GBLCTL = 0; // Reset
: N. u3 C/ z, I' {$ [% o mcasp->regs->RGBLCTL = 0; // Reset RX. c2 E2 w3 |# B% C
mcasp->regs->XGBLCTL = 0; // Reset TX
! m- O5 w4 s: t6 @: c3 w7 r6 A mcasp->regs->PWRDEMU = 1; // Free-running
z8 K$ i( z! T' Y ^3 k4 b9 D // configure McASP0 receive registers8 T6 E4 } y% L! ?! Q
mcasp->regs->RMASK = 0xFFFFFFFF; // No padding used" L! Z6 L/ z- a+ S# z
mcasp->regs->RFMT = 0x00018078; // MSB 16bit, 0-delay, no pad, CFGBus: \' z J2 t/ `# O" K; [6 e
mcasp->regs->AFSRCTL = 0x00000112; // 2TDM, 1bit Falling, External FS, word
; _5 i. \; o- b& Z3 w! T mcasp->regs->ACLKRCTL = 0x000000AF; // Rising INTERNAL CLK,(from tx side)" H, @' V" T5 U( @) U
mcasp->regs->AHCLKRCTL = 0x00000000; // INT CLK (from tx side)% |! t1 R* s; B) W5 m/ o
mcasp->regs->RTDM = 0x00000003; // Slots 0,1
! v6 [: v" v. R$ d mcasp->regs->RINTCTL = 0x00000000; // Not used/ H/ O) j! s# D3 [+ U
mcasp->regs->RCLKCHK = 0x00FF0008; // 255-MAX 0-MIN, div-by-256
) ?' n! X1 C! @. ^/ r/ f' ~; V1 M* X1 C6 _" f* s) Q1 C
mcasp->regs->XMASK = 0xFFFFFFFF; // No padding used
$ o' N. `8 T& l6 H$ C1 _ mcasp->regs->XFMT = 0x00018078; // MSB 16bit, 0-delay, no pad, CFGBus
1 y3 [* I, v2 K% {6 m% t mcasp->regs->AFSXCTL = 0x00000112; // 2TDM, 1bit Rising edge INTERNAL FS, word" Z: Q5 _7 A0 D' E
mcasp->regs->ACLKXCTL = 0x000000AF; // ASYNC, Rising INTERNAL CLK, div-by-16
* b; A( ?0 ~0 a$ U( z0 m/ h4 ? mcasp->regs->AHCLKXCTL = 0x00000000; // EXT CLK
2 G* e% J; x( S, w3 j" x) ]- P mcasp->regs->XTDM = 0x00000003; // Slots 0,1
. i" d' J' B; C$ @" n2 i! e* W mcasp->regs->XINTCTL = 0x00000020; // interrupt on transmit. v3 r v2 [& Y: \8 B
mcasp->regs->XCLKCHK = 0x00FF0008; // 255-MAX 0-MIN, div-by-2568 {( ?% O; N u: D8 d% C" V. t
5 e l3 l4 w6 G5 v% d3 \ mcasp->regs->SRCTL5 = 0x000D; // MCASP1.AXR1[5] --> DIN9 G8 W2 t. s5 V4 I
mcasp->regs->SRCTL0 = 0x000E; // MCASP1.AXR1[0] <-- DOUT5 \6 _0 ~+ |) ~; p
mcasp->regs->PFUNC = 0; // All MCASPs) o) g8 ?+ l7 @4 z/ _
mcasp->regs->PDIR = 0x14000020; // All inputs except AXR0[5], ACLKX1, AFSX1
$ e$ R4 L7 X- G( t
8 t0 \% `$ {% N1 ?% t mcasp->regs->DITCTL = 0x00000000; // Not used
' ~/ F6 R! t* r7 R mcasp->regs->DLBCTL = 0x00000000; // Not used/ A4 c0 ?- V3 v4 g0 l0 a6 Z5 _1 t1 R" B
mcasp->regs->AMUTE = 0x00000000; // Not used. n1 r( s: A5 L4 f) D
0 r6 q; L: Z$ \$ v/* Starting sections of the McASP*/5 w- _4 m* m' N! Z
mcasp->regs->XGBLCTL |= GBLCTL_XHCLKRST_ON; " n, ~' j3 s+ `- H" @, c
while ( ( mcasp->regs->XGBLCTL & GBLCTL_XHCLKRST_ON ) != GBLCTL_XHCLKRST_ON ); 0 K7 N1 W$ B# S3 v
mcasp->regs->RGBLCTL |= GBLCTL_RHCLKRST_ON; ( `% I( q( J6 w
while ( ( mcasp->regs->RGBLCTL & GBLCTL_RHCLKRST_ON ) != GBLCTL_RHCLKRST_ON );; V8 `( D" C+ z5 T+ M* i; H' `" \
: Z4 ` c v4 \
mcasp->regs->XGBLCTL |= GBLCTL_XCLKRST_ON;
) t2 v# t# {6 X0 l$ V$ I while ( ( mcasp->regs->XGBLCTL & GBLCTL_XCLKRST_ON ) != GBLCTL_XCLKRST_ON );
# S2 B0 ?# ^. [' P( H: K mcasp->regs->RGBLCTL |= GBLCTL_RCLKRST_ON;
2 g$ m q; G$ y9 H6 b while ( ( mcasp->regs->RGBLCTL & GBLCTL_RCLKRST_ON ) != GBLCTL_RCLKRST_ON );
. N+ O! o' w1 E- Z( f/ z3 K. j+ Z/ [6 X
mcasp->regs->XSTAT = 0x0000ffff;
! d6 }' q4 K6 ~4 c$ o mcasp->regs->RSTAT = 0x0000ffff; 6 {# P. N) k$ v& S* `3 L
/ x8 v" X2 ?# c3 O
mcasp->regs->XGBLCTL |= GBLCTL_XSRCLR_ON;8 }1 h% Q# w3 R! o M
while ( ( mcasp->regs->XGBLCTL & GBLCTL_XSRCLR_ON ) != GBLCTL_XSRCLR_ON );
0 O1 W% [, N+ t. p& x mcasp->regs->RGBLCTL |= GBLCTL_RSRCLR_ON;
5 v* U7 s n$ y9 t6 a( g' |$ _ while ( ( mcasp->regs->RGBLCTL & GBLCTL_RSRCLR_ON ) != GBLCTL_RSRCLR_ON );6 ]& P% B/ |" |8 ^3 ?* H4 c) z1 k3 \
8 _0 Q. j) E3 T: X1 R' V F /* Write a 0, so that no underrun occurs after releasing the state machine */
8 n- D5 y) ?6 w9 ]3 J mcasp->regs->XBUF5 = 0;2 S$ r) Q: T$ ]$ P% H- Q
mcasp->regs->RBUF0 = 0;* w/ X( i) k# d4 g7 [) X! H
- R5 p4 \5 W" O8 C4 s mcasp->regs->XGBLCTL |= GBLCTL_XSMRST_ON;
0 f" l7 z/ H0 j* Z- i0 g while ( ( mcasp->regs->XGBLCTL & GBLCTL_XSMRST_ON ) != GBLCTL_XSMRST_ON );( P: `# S* p! f) M' Z* Q
mcasp->regs->RGBLCTL |= GBLCTL_RSMRST_ON;
* S7 C) @1 ~1 ~. g while ( ( mcasp->regs->RGBLCTL & GBLCTL_RSMRST_ON ) != GBLCTL_RSMRST_ON );, ?# ]& E; }" _( D: q
n$ g4 }: C/ f mcasp->regs->XGBLCTL |= GBLCTL_XFRST_ON;
4 o8 _$ s0 k" y while ( ( mcasp->regs->XGBLCTL & GBLCTL_XFRST_ON ) != GBLCTL_XFRST_ON );" N. ^" y( y: U9 g: i" ~+ E
mcasp->regs->RGBLCTL |= GBLCTL_RFRST_ON; & g: }; q' e# V0 W; _0 P: w
while ( ( mcasp->regs->RGBLCTL & GBLCTL_RFRST_ON ) != GBLCTL_RFRST_ON );
- h/ G8 g5 C! L- f c* P" k0 K r7 v$ K5 n* t2 O0 Y5 O
CSR = 0x0000;% q# H) I/ c' F3 K1 v2 B
INTC_INTMUX1 = 0x3d;( v5 A. T( h2 N+ J" ]! }4 I
ISTP = (unsigned int)vectors;8 H) r& p# c* b7 M
ICR = 0xFFF0; 3 [3 P. d( }" F6 _/ g3 P
IER |= 0x12;
' z6 b% Y; s( ]' |' n& f( C CSR |= 0x01;
* m- _3 j. _2 V2 ?. B2 ?1 E2 W1 ?; ^0 U" o
+ k) D$ U; j7 d& E$ _. n
; T9 P, ] k% I( y还有就是两个输入输出函数:
& f& ~1 a* x& }; r l) rvoid output_sample(Int32 out_data)- {" [" g7 h1 Q) ^
{! R1 m% _: l: O9 S
AIC31_data.uint = out_data; ; G4 e5 p, N0 s6 u+ @4 U/ j' A
MCASP1_XBUF5_32BIT = AIC31_data.uint;
) a7 f& m: B5 U}
6 M: F; d8 O- w, s. L) n- y2 E; m; \5 k+ J( @- ^5 r
Int32 input_sample(void)
" Y8 Q2 y; ~0 F4 H/ R: e9 a{
6 |/ h1 R7 Q3 O5 J6 Q3 ~1 [4 i, s AIC31_data.uint = MCASP1_RBUF0_32BIT;
; X# d3 p! M8 \. c return (AIC31_data.uint);- G" G6 ]. Q- Z: B8 u! s. h1 a
}
* {7 ~1 w9 b `5 S4 f& {; e2 U: c* G3 V
|
|