|
|
C6747和C6748感觉差不多,我想实现McASP发送中断方式控制音频信号,在轮询的例程基础上改的,轮询程序可以实现,但是中断一直实现不了,也找不到错误,求大神帮忙!下边是主要程序:
' l: W; z3 k1 y" ]+ cmain文件:; }/ [4 e3 o& G7 W
interrupt void interrupt4(void)
* O `" L$ E+ P7 h# r{$ ]3 S7 P: \1 K/ w- y
Uint32 sample;% X0 N: t* r' g' Y; _3 c/ E$ R
, g" X" `1 D9 Z0 p7 n
sample = input_sample(); // read L + R samples from ADC
+ W$ d; U! ], M' l& g/ z9 W& L1 g. O output_sample(sample); // write L + R samples to DAC
1 r1 e# z$ V$ j. l! ^4 p return;7 r2 K0 O) C7 G
}, @- ]+ E9 @9 i; a! e
9 W/ M) x& e: U S D) k& hint main( void ), @) @6 }* U3 p: E' n, {) M
{
: @4 r# o# B) @. F: O& ]
- d0 M8 {7 D* {7 v /* Initialize BSL */3 f7 u* ~/ r% @, [, p+ t- Y9 `
EVMC6747_init( );
2 q$ g' d' ^4 Y. c6 D /* Call evmc6747_intr function */, p! V6 W" U% s( }
aic3106_init( );
" F; r# z W7 k0 I while(1);
h. I6 B; s" a5 h4 u; I4 P}' W5 | m3 m* D1 F
* m( y' V/ I% ~* f2 Z
) w% w8 Q& N( k4 L: \9 O, faic3106_init文件的一部分,McASP配置部分,采用内部时钟,I2S方式,同步传输。音频芯片的配置应该没问题, P& F, d0 i$ ] Y
/* Initialize MCASP1 */# @5 c1 l1 L" o7 S9 l
mcasp = &MCASP_MODULE_1;/ E; B2 B0 o$ d- M8 n7 }
mcasp->regs->GBLCTL = 0; // Reset8 O1 F" C5 X2 m, D5 N
mcasp->regs->RGBLCTL = 0; // Reset RX2 W$ J( o! Y# N$ A5 ?; j
mcasp->regs->XGBLCTL = 0; // Reset TX
: K C% `/ p( w" ?7 `& B+ H mcasp->regs->PWRDEMU = 1; // Free-running
% g- ?- Y N+ H9 n' @ // configure McASP0 receive registers
& C7 }: @& j% A, R mcasp->regs->RMASK = 0xFFFFFFFF; // No padding used6 K: I# U5 W: q# |" a% o" D* q3 {
mcasp->regs->RFMT = 0x00018078; // MSB 16bit, 0-delay, no pad, CFGBus
3 E! Y0 W) J4 m, O# K0 q mcasp->regs->AFSRCTL = 0x00000112; // 2TDM, 1bit Falling, External FS, word3 x' ~5 m, G" \% n! E
mcasp->regs->ACLKRCTL = 0x000000AF; // Rising INTERNAL CLK,(from tx side)
, o, l$ @" F- I' L2 n& T) u( _. T mcasp->regs->AHCLKRCTL = 0x00000000; // INT CLK (from tx side)& l% c' e4 ^' U" j& ?
mcasp->regs->RTDM = 0x00000003; // Slots 0,1& h# i% A/ o4 |
mcasp->regs->RINTCTL = 0x00000000; // Not used
8 w. S, A, p' |& Z" S ^ mcasp->regs->RCLKCHK = 0x00FF0008; // 255-MAX 0-MIN, div-by-256& s' m8 n& d- c/ E& Y, e
9 n% J- L' @, ^5 C
mcasp->regs->XMASK = 0xFFFFFFFF; // No padding used6 E9 B. O3 o! o- T0 b6 ] P9 ^' x
mcasp->regs->XFMT = 0x00018078; // MSB 16bit, 0-delay, no pad, CFGBus& ]$ v, T0 V' q) ` e9 W# D
mcasp->regs->AFSXCTL = 0x00000112; // 2TDM, 1bit Rising edge INTERNAL FS, word* @1 Z U+ b+ @' Y+ d4 s3 K
mcasp->regs->ACLKXCTL = 0x000000AF; // ASYNC, Rising INTERNAL CLK, div-by-16$ k8 [. Z: ~2 m) U
mcasp->regs->AHCLKXCTL = 0x00000000; // EXT CLK1 |5 }% L: e# Y
mcasp->regs->XTDM = 0x00000003; // Slots 0,1
) c! O& z! ^! i5 `% x mcasp->regs->XINTCTL = 0x00000020; // interrupt on transmit
, X8 m/ Z5 y% X- N7 ^2 v mcasp->regs->XCLKCHK = 0x00FF0008; // 255-MAX 0-MIN, div-by-256
" V1 a, n1 r" ~; R# z' m$ I
9 t. _0 v! D8 U+ f0 K5 L mcasp->regs->SRCTL5 = 0x000D; // MCASP1.AXR1[5] --> DIN
0 t# x) I0 E/ e2 G/ D mcasp->regs->SRCTL0 = 0x000E; // MCASP1.AXR1[0] <-- DOUT! I. Q0 D9 R* \$ C N' U/ H
mcasp->regs->PFUNC = 0; // All MCASPs. E$ C3 h) M2 ]8 S- Q8 f
mcasp->regs->PDIR = 0x14000020; // All inputs except AXR0[5], ACLKX1, AFSX17 T- y/ T/ O7 U0 {" u( W/ {
+ r) y. ~2 N- t2 Q
mcasp->regs->DITCTL = 0x00000000; // Not used: F9 X, C6 P. ]
mcasp->regs->DLBCTL = 0x00000000; // Not used
% D2 Z4 I1 I M& p mcasp->regs->AMUTE = 0x00000000; // Not used) E8 p, J; G6 M" n( r% Z
, E) `, g7 ?+ D6 Q0 \- n
/* Starting sections of the McASP*/
4 Q/ z9 T/ \2 w$ H- P mcasp->regs->XGBLCTL |= GBLCTL_XHCLKRST_ON;
' B& f+ _; T6 r, @& s; P! a while ( ( mcasp->regs->XGBLCTL & GBLCTL_XHCLKRST_ON ) != GBLCTL_XHCLKRST_ON ); ) M4 ~6 @5 d& F( r# F. k
mcasp->regs->RGBLCTL |= GBLCTL_RHCLKRST_ON; 0 a' E' q, v" [) K9 s( I5 C5 ~5 t
while ( ( mcasp->regs->RGBLCTL & GBLCTL_RHCLKRST_ON ) != GBLCTL_RHCLKRST_ON );
9 w2 @2 q5 u, y6 r: g+ X+ d9 a" e
f2 A0 w0 c; Y. y2 e, q mcasp->regs->XGBLCTL |= GBLCTL_XCLKRST_ON; , Z e; h: O' Q( f: X
while ( ( mcasp->regs->XGBLCTL & GBLCTL_XCLKRST_ON ) != GBLCTL_XCLKRST_ON );/ w' [2 y ^7 y# P( q- w s
mcasp->regs->RGBLCTL |= GBLCTL_RCLKRST_ON; $ |/ P Y& p9 z% \' G) j: T
while ( ( mcasp->regs->RGBLCTL & GBLCTL_RCLKRST_ON ) != GBLCTL_RCLKRST_ON );
$ I0 G; [7 l) q1 S G3 @+ X y ?# C% ?8 g5 n
mcasp->regs->XSTAT = 0x0000ffff;
; P( \3 r1 K5 z+ u& M/ u mcasp->regs->RSTAT = 0x0000ffff; ) @2 g; F5 V) `* U9 Y8 S$ T
5 z+ N, b3 g" [/ \9 h3 F mcasp->regs->XGBLCTL |= GBLCTL_XSRCLR_ON;
& x! C8 {, X: K) J while ( ( mcasp->regs->XGBLCTL & GBLCTL_XSRCLR_ON ) != GBLCTL_XSRCLR_ON );8 f* T M( B( h4 |; s0 E
mcasp->regs->RGBLCTL |= GBLCTL_RSRCLR_ON;
, L' A. s9 T6 h1 s" L/ o while ( ( mcasp->regs->RGBLCTL & GBLCTL_RSRCLR_ON ) != GBLCTL_RSRCLR_ON );
: B2 {' X- C+ o6 P/ _
. g9 A4 C9 \' V8 F /* Write a 0, so that no underrun occurs after releasing the state machine */0 }+ L- y1 R& {
mcasp->regs->XBUF5 = 0;/ _: t+ O3 f6 X; P. d6 d. f
mcasp->regs->RBUF0 = 0;0 r+ D+ X# b. f' C- `
# ]' G( v a; l
mcasp->regs->XGBLCTL |= GBLCTL_XSMRST_ON; / a3 }( ?% f2 [ k0 A! |# U
while ( ( mcasp->regs->XGBLCTL & GBLCTL_XSMRST_ON ) != GBLCTL_XSMRST_ON );) y' L+ V, ^% [( t2 s4 v; x
mcasp->regs->RGBLCTL |= GBLCTL_RSMRST_ON;
" p/ b+ N8 l$ |8 h5 \' {/ i8 a while ( ( mcasp->regs->RGBLCTL & GBLCTL_RSMRST_ON ) != GBLCTL_RSMRST_ON );
/ m6 u/ {! u' V$ t3 y' P9 X4 Z
/ m! k# x" q# [, n0 v/ u mcasp->regs->XGBLCTL |= GBLCTL_XFRST_ON;
! q6 @2 e% l" B8 T while ( ( mcasp->regs->XGBLCTL & GBLCTL_XFRST_ON ) != GBLCTL_XFRST_ON );
! z- {) B( `( p) p mcasp->regs->RGBLCTL |= GBLCTL_RFRST_ON;
* H# G- t3 [+ w/ l0 C1 X while ( ( mcasp->regs->RGBLCTL & GBLCTL_RFRST_ON ) != GBLCTL_RFRST_ON );; ` o8 n' z5 C/ Z% y9 [
h: h# a5 I! {) _# t, [
CSR = 0x0000;
2 h% k7 Z' l% G0 H8 T: O5 n INTC_INTMUX1 = 0x3d;" s& Z7 D& \. M6 \- v$ K+ n
ISTP = (unsigned int)vectors;
# k% n: m; u: O7 P- m; f ICR = 0xFFF0;
r8 l2 ^7 j* M4 i IER |= 0x12; 2 x1 p) d2 A2 W6 Y! D( K* d
CSR |= 0x01;
3 r; x& x) D$ ~, O5 E6 P8 Y p2 s
* Y8 n( ?/ g9 N5 @' `- y2 q
# ~1 ]! m, W" i' f4 p, e
3 l+ G3 \" J" @$ s/ \还有就是两个输入输出函数:
6 `% h- `9 ~# Vvoid output_sample(Int32 out_data)
" d! |: V9 g3 M% A1 z{
, ~0 ^. l, o, [2 T9 v AIC31_data.uint = out_data; ; n I, ?8 B6 d' ^# z# {* ?7 N
MCASP1_XBUF5_32BIT = AIC31_data.uint; s+ ], h" R7 R; T, l7 f
} P5 g: @* z, b
, X3 t2 H4 p+ d( q$ jInt32 input_sample(void)
) @! `! Z" {1 ~' D+ O: z{ : K6 \( K Y& ~4 w2 w/ s
AIC31_data.uint = MCASP1_RBUF0_32BIT;0 I- q. m* ^4 y- d- x p
return (AIC31_data.uint);
7 _% Z$ j+ [3 y9 c+ l4 h}3 t1 W; ^: x" m( S! r: P( Q
/ }. C! Y4 @5 S |
|