|
|
C6747和C6748感觉差不多,我想实现McASP发送中断方式控制音频信号,在轮询的例程基础上改的,轮询程序可以实现,但是中断一直实现不了,也找不到错误,求大神帮忙!下边是主要程序:# d9 B+ f0 h& K, g m
main文件:
, F6 {9 y0 a6 C7 e) ]8 Y6 W& Linterrupt void interrupt4(void) ; F, R4 r7 M7 _9 B" O4 w0 d. I
{' N0 Y! l3 F( n, V# b% T+ ^* o' v
Uint32 sample;4 g0 t# i k6 d. _, U9 t; S
! I+ Z$ W; q' P sample = input_sample(); // read L + R samples from ADC
6 h, E$ K* P8 U$ l/ @6 o output_sample(sample); // write L + R samples to DAC
- Q( J1 Y' T- z. | return;
; h) z' q1 R0 [, W} J* P5 D5 w8 R( p: F3 ^
( U6 y! C$ k c6 {. d; [7 E; P. Bint main( void )" c! ~8 S- R4 z L5 L
{
$ E2 i3 m% H, [$ D% ?# ~
/ B$ [5 g& U/ O' @) @5 K /* Initialize BSL */
$ y# i& S' y* m& s) `" v# X EVMC6747_init( );
1 {7 C0 T6 l6 E5 T. @- O" H /* Call evmc6747_intr function */. {+ |/ q q) Z2 P- \) T' v, u4 w
aic3106_init( );
' X/ e# G" g0 m, d while(1);1 `1 D7 h( r9 ~) R9 V: v
}
( a9 d- i1 x; Q+ X o# w3 c9 y c) j' n! A' r f
. w0 N7 L$ m3 X& O& B+ L
aic3106_init文件的一部分,McASP配置部分,采用内部时钟,I2S方式,同步传输。音频芯片的配置应该没问题
. a% [9 S+ Z3 m9 \ f( D4 E/* Initialize MCASP1 */
8 w! D0 ^) t4 B2 x1 z2 o mcasp = &MCASP_MODULE_1;5 V& S9 ~! m) v) m2 }
mcasp->regs->GBLCTL = 0; // Reset
, r( a* l1 W+ i: K+ x% {: E0 |( l/ I mcasp->regs->RGBLCTL = 0; // Reset RX' [, q# n5 ^, i) \( c( y: X
mcasp->regs->XGBLCTL = 0; // Reset TX2 @0 `' J% `3 ~1 o
mcasp->regs->PWRDEMU = 1; // Free-running
0 y/ p8 v; U% u: v& a4 q // configure McASP0 receive registers% G) Z0 O& H5 G
mcasp->regs->RMASK = 0xFFFFFFFF; // No padding used
5 A0 m) H6 X! K( Z0 p1 l/ t mcasp->regs->RFMT = 0x00018078; // MSB 16bit, 0-delay, no pad, CFGBus
& {6 `; a3 w$ F8 K mcasp->regs->AFSRCTL = 0x00000112; // 2TDM, 1bit Falling, External FS, word
4 G/ @8 t, Y( t. O* `; c mcasp->regs->ACLKRCTL = 0x000000AF; // Rising INTERNAL CLK,(from tx side)
$ t8 n. ]5 x1 ~5 c$ s3 T mcasp->regs->AHCLKRCTL = 0x00000000; // INT CLK (from tx side)
$ f* [: F1 i' J3 b( F2 o" X mcasp->regs->RTDM = 0x00000003; // Slots 0,1* ?4 r# y) _. K9 M# ^3 x$ ?9 c. G, R
mcasp->regs->RINTCTL = 0x00000000; // Not used
- v# R. B9 \- E& E/ j4 f2 } mcasp->regs->RCLKCHK = 0x00FF0008; // 255-MAX 0-MIN, div-by-256- a" q( D, u! Q; J; B! D3 G9 {! q
3 u( w! N5 T/ r9 Q R3 @
mcasp->regs->XMASK = 0xFFFFFFFF; // No padding used
U4 E" T7 R) \4 |& q( f) p1 d mcasp->regs->XFMT = 0x00018078; // MSB 16bit, 0-delay, no pad, CFGBus
) M' k+ i9 \+ R1 s! N m8 [ mcasp->regs->AFSXCTL = 0x00000112; // 2TDM, 1bit Rising edge INTERNAL FS, word# _; i! D0 d$ k2 Z9 N; A( R
mcasp->regs->ACLKXCTL = 0x000000AF; // ASYNC, Rising INTERNAL CLK, div-by-16
* U9 N, j* D* f' w, z mcasp->regs->AHCLKXCTL = 0x00000000; // EXT CLK6 @9 I! F' k1 c2 |5 ~) R
mcasp->regs->XTDM = 0x00000003; // Slots 0,1
- K; i9 d: w, p mcasp->regs->XINTCTL = 0x00000020; // interrupt on transmit
* _" a; W) d8 s; {) \ mcasp->regs->XCLKCHK = 0x00FF0008; // 255-MAX 0-MIN, div-by-256. w7 i) s% J! a- F2 \' z0 X
5 r6 S4 h: g0 M' ]' k8 L% \+ h
mcasp->regs->SRCTL5 = 0x000D; // MCASP1.AXR1[5] --> DIN
( V% m8 X3 Q- F9 O$ V0 H mcasp->regs->SRCTL0 = 0x000E; // MCASP1.AXR1[0] <-- DOUT
) p- o, |) y$ p* w% E+ L3 I mcasp->regs->PFUNC = 0; // All MCASPs
" [/ i2 `, ?$ e, C" L- O mcasp->regs->PDIR = 0x14000020; // All inputs except AXR0[5], ACLKX1, AFSX1
% Z" r! J! B6 _4 X- l6 B/ `2 i. Z
mcasp->regs->DITCTL = 0x00000000; // Not used& T2 A9 ?% u3 u; m8 f
mcasp->regs->DLBCTL = 0x00000000; // Not used6 E& E+ g9 P( z2 `: p: G
mcasp->regs->AMUTE = 0x00000000; // Not used
1 E: T- d& Y* j2 s: v& {/ R, ~8 r9 Z/ g4 g( K* z/ H
/* Starting sections of the McASP*/' N+ y- I3 T: ~/ T1 o0 q2 J
mcasp->regs->XGBLCTL |= GBLCTL_XHCLKRST_ON;
" \: M( R/ T& `5 E! A$ Z7 ^ while ( ( mcasp->regs->XGBLCTL & GBLCTL_XHCLKRST_ON ) != GBLCTL_XHCLKRST_ON );
* i. `' ~: |! T mcasp->regs->RGBLCTL |= GBLCTL_RHCLKRST_ON; 1 C4 D/ E2 u. q2 r! g; j
while ( ( mcasp->regs->RGBLCTL & GBLCTL_RHCLKRST_ON ) != GBLCTL_RHCLKRST_ON );
4 Q6 s8 N" H7 h: U9 T
4 f: w! N' g4 J! e& l6 Y mcasp->regs->XGBLCTL |= GBLCTL_XCLKRST_ON;
7 n+ B$ T1 c% {3 l+ e. O while ( ( mcasp->regs->XGBLCTL & GBLCTL_XCLKRST_ON ) != GBLCTL_XCLKRST_ON );( s5 f+ E# \4 e& @) n6 C2 X
mcasp->regs->RGBLCTL |= GBLCTL_RCLKRST_ON; 6 f9 |) ?# r# r- _/ v' O% i
while ( ( mcasp->regs->RGBLCTL & GBLCTL_RCLKRST_ON ) != GBLCTL_RCLKRST_ON );
5 U0 ]: \% O* i& O4 K- b! i# Q
+ T1 K; f/ i$ X, y" ^- C mcasp->regs->XSTAT = 0x0000ffff;
7 N: \/ c' W) T, x# m% B/ G. T mcasp->regs->RSTAT = 0x0000ffff;
: W0 K. W; A$ X p" b. r+ [. c. c4 ?9 G1 T% C
mcasp->regs->XGBLCTL |= GBLCTL_XSRCLR_ON;
8 I6 C: ?# Y6 W" S( X while ( ( mcasp->regs->XGBLCTL & GBLCTL_XSRCLR_ON ) != GBLCTL_XSRCLR_ON );# H; ~% ~1 r# [: z! F3 p
mcasp->regs->RGBLCTL |= GBLCTL_RSRCLR_ON; + o0 s6 L5 i) [4 }$ n; x6 Q3 C
while ( ( mcasp->regs->RGBLCTL & GBLCTL_RSRCLR_ON ) != GBLCTL_RSRCLR_ON );2 `4 W5 P4 H) ~; w+ ], M
/ ~: Z1 r7 Y) ^3 M
/* Write a 0, so that no underrun occurs after releasing the state machine */ O- e' ]% X7 F3 y( v
mcasp->regs->XBUF5 = 0;7 P/ J. J) d7 j5 _0 s* f- l
mcasp->regs->RBUF0 = 0;1 ~( a2 v2 }+ b6 m* l9 G' I
8 A3 E: e! u7 X6 f; z& _# f5 B0 D
mcasp->regs->XGBLCTL |= GBLCTL_XSMRST_ON; / i3 w4 ~9 H( K0 s
while ( ( mcasp->regs->XGBLCTL & GBLCTL_XSMRST_ON ) != GBLCTL_XSMRST_ON );
4 K7 d9 @0 Q8 W0 b mcasp->regs->RGBLCTL |= GBLCTL_RSMRST_ON;
E+ ]) c' Y3 C* \7 m8 ^% i. C while ( ( mcasp->regs->RGBLCTL & GBLCTL_RSMRST_ON ) != GBLCTL_RSMRST_ON );
" |' ^! h( Y7 f5 ^1 \2 {) i
* @2 m& h0 t4 g6 C% ~, }: g9 l mcasp->regs->XGBLCTL |= GBLCTL_XFRST_ON;
! e6 ~' Z" }+ T2 i' S, H while ( ( mcasp->regs->XGBLCTL & GBLCTL_XFRST_ON ) != GBLCTL_XFRST_ON );
( e2 x: C- t w' N6 k: E; n" I mcasp->regs->RGBLCTL |= GBLCTL_RFRST_ON; 8 R; T' j2 C, {/ {! Q% m. R
while ( ( mcasp->regs->RGBLCTL & GBLCTL_RFRST_ON ) != GBLCTL_RFRST_ON );3 P t$ {1 ]& E+ R
( _# \) [4 d. G0 r! ] CSR = 0x0000;
" p, ]$ ~& N. l( \6 s INTC_INTMUX1 = 0x3d;4 ^9 Q) A e+ T0 l5 D1 |
ISTP = (unsigned int)vectors;
2 |2 k4 t" z( F; A" S# v" U1 v ICR = 0xFFF0;
& u3 y7 r- Q6 }- j: X0 D) ]0 F2 l IER |= 0x12; 5 b+ n0 B) Y3 ]. M$ g2 q
CSR |= 0x01; 0 C2 u; f( y- M
; ]( B7 S2 I [6 y1 L# c
7 q+ J2 s# v7 @3 b- @0 m2 c+ E1 o) U2 U7 z0 h& ^5 l
还有就是两个输入输出函数:. U; s; j. N. i9 b. k4 J) s: \& g
void output_sample(Int32 out_data)
9 b9 z" {( z! C5 `{: ? R, F+ s4 N9 |4 O
AIC31_data.uint = out_data;
6 p% W8 t) p) @* C; R MCASP1_XBUF5_32BIT = AIC31_data.uint;
5 t) e: h+ E& t: \% n& l2 P9 {}
' x; h: a/ D* S& f. S2 ~" e! h* ?1 r# e9 ~
Int32 input_sample(void)
* c, S, s) ]' R/ T# Q2 s! ]{ 9 {( ^. y" [2 J* g
AIC31_data.uint = MCASP1_RBUF0_32BIT;
3 P G' ~. ]: Y' p- ^* y) d) k( J return (AIC31_data.uint);
/ k" T9 Z5 w$ v}
# D) l+ |8 H, w: A, W) ^; T. n
9 T$ }/ ?! G+ y8 o; n |
|