|
|
C6747和C6748感觉差不多,我想实现McASP发送中断方式控制音频信号,在轮询的例程基础上改的,轮询程序可以实现,但是中断一直实现不了,也找不到错误,求大神帮忙!下边是主要程序:$ V. V$ i; S% q& a
main文件:
6 j, Z. V& H- x* a9 dinterrupt void interrupt4(void) 3 S% X; l6 m" \: ~4 }& r
{
7 }3 K) l) ~, Z) f; y7 | Uint32 sample;9 {6 ~3 Q3 H( g" f
! L- h/ c" k# B% k3 z. Q0 d) R
sample = input_sample(); // read L + R samples from ADC
2 i: j& O+ w* Z7 _3 J; a output_sample(sample); // write L + R samples to DAC 2 ^4 W' v7 s8 I
return;* Y' v' v7 ]1 C! }
}
/ ~8 u: C- J7 ]' i A8 V0 `
' G ]3 k8 | i- f4 Hint main( void )
0 f' G3 K2 i4 r0 i4 {6 P{; Q6 X: b, V! B, s7 z
; [2 j& I! z( O3 r /* Initialize BSL */' I% ]( Q5 s9 n
EVMC6747_init( );
- N- `" D/ P: n8 q /* Call evmc6747_intr function */: {! L% I. E; ]* w2 m/ V% g# j
aic3106_init( );! k+ k3 l: u: E2 o; e
while(1);* J; T% H; P5 P6 O/ B g! K
}
( F# n* q' l! `4 v l$ R8 V" @" U I. D, n
/ e! W1 x+ A! ~: _
aic3106_init文件的一部分,McASP配置部分,采用内部时钟,I2S方式,同步传输。音频芯片的配置应该没问题9 j" P. M0 e+ {, D) i
/* Initialize MCASP1 */
9 u+ ~$ o( q- i- z. [ mcasp = &MCASP_MODULE_1;( }" `4 l% C4 ^4 d
mcasp->regs->GBLCTL = 0; // Reset
8 S5 Z3 Q# K1 { mcasp->regs->RGBLCTL = 0; // Reset RX
" S8 g. D5 k- W mcasp->regs->XGBLCTL = 0; // Reset TX& w, a5 G- b, X u, }" ] e: \/ X; V4 r
mcasp->regs->PWRDEMU = 1; // Free-running9 A' g9 [6 ]: F4 F9 L* M! ]7 r
// configure McASP0 receive registers
G7 ~3 m* v1 d3 ^$ @. {7 I. I mcasp->regs->RMASK = 0xFFFFFFFF; // No padding used
2 a' w* E9 L$ s; y. `) u( p& W mcasp->regs->RFMT = 0x00018078; // MSB 16bit, 0-delay, no pad, CFGBus& g% U, h9 U! q a- ^& }6 }5 j$ Y, L
mcasp->regs->AFSRCTL = 0x00000112; // 2TDM, 1bit Falling, External FS, word6 x# K. H x `6 p) x
mcasp->regs->ACLKRCTL = 0x000000AF; // Rising INTERNAL CLK,(from tx side)
% j9 p/ @5 u' k9 w ~+ W( |1 |, G mcasp->regs->AHCLKRCTL = 0x00000000; // INT CLK (from tx side)6 g0 G. G8 n: w( p2 E
mcasp->regs->RTDM = 0x00000003; // Slots 0,17 }- f* x3 S( t# f- N% U1 D1 n
mcasp->regs->RINTCTL = 0x00000000; // Not used
3 b$ h1 C% I/ a3 B( p2 ?5 i+ i. R mcasp->regs->RCLKCHK = 0x00FF0008; // 255-MAX 0-MIN, div-by-256
1 x- G: L4 x% w3 q& Z5 x
4 }8 i0 P; ~! W) }% n mcasp->regs->XMASK = 0xFFFFFFFF; // No padding used
: S* q4 k+ e& c. U4 H. Y% L5 W- d mcasp->regs->XFMT = 0x00018078; // MSB 16bit, 0-delay, no pad, CFGBus/ b# D$ J, ~- _
mcasp->regs->AFSXCTL = 0x00000112; // 2TDM, 1bit Rising edge INTERNAL FS, word! I# @) V2 X2 L" E
mcasp->regs->ACLKXCTL = 0x000000AF; // ASYNC, Rising INTERNAL CLK, div-by-16
/ j" ~* p5 g5 u, e9 Z- o mcasp->regs->AHCLKXCTL = 0x00000000; // EXT CLK; U8 R1 I) b" l [3 [+ |9 C. W5 [
mcasp->regs->XTDM = 0x00000003; // Slots 0,1
/ \; O" b* O! w& T7 f, }9 c0 w5 t" ` mcasp->regs->XINTCTL = 0x00000020; // interrupt on transmit4 I4 h' y* \1 r' C: F; \2 R8 y
mcasp->regs->XCLKCHK = 0x00FF0008; // 255-MAX 0-MIN, div-by-256
2 `/ b/ [+ e- P4 g: N
3 K7 m0 G' Y8 @5 h# L& @! R mcasp->regs->SRCTL5 = 0x000D; // MCASP1.AXR1[5] --> DIN
8 i! g. `) ^2 J. R. p* i+ [ mcasp->regs->SRCTL0 = 0x000E; // MCASP1.AXR1[0] <-- DOUT
$ D, n/ w' r8 z {3 J- L mcasp->regs->PFUNC = 0; // All MCASPs) S5 U$ Z) P3 p5 Z- u
mcasp->regs->PDIR = 0x14000020; // All inputs except AXR0[5], ACLKX1, AFSX19 }9 c2 u" U: I1 k3 O
3 q( \7 {6 w" N) l; N' l: }; _
mcasp->regs->DITCTL = 0x00000000; // Not used
9 A: d" C7 x' E# ~- S+ w3 Z mcasp->regs->DLBCTL = 0x00000000; // Not used- _; U/ p# p' J; k
mcasp->regs->AMUTE = 0x00000000; // Not used
6 k ~9 |' f% \% Q: m9 q1 r
* T- f& Q/ p8 |, `/* Starting sections of the McASP*/
4 Y" l4 e2 I9 l0 r% F4 T. Y6 m mcasp->regs->XGBLCTL |= GBLCTL_XHCLKRST_ON; ( q+ @/ x' ~" ?0 \8 s; R$ e
while ( ( mcasp->regs->XGBLCTL & GBLCTL_XHCLKRST_ON ) != GBLCTL_XHCLKRST_ON ); , V2 D) w% p0 c9 t2 R W# b K) l, B
mcasp->regs->RGBLCTL |= GBLCTL_RHCLKRST_ON;
1 \$ W7 V7 t; y9 k+ n while ( ( mcasp->regs->RGBLCTL & GBLCTL_RHCLKRST_ON ) != GBLCTL_RHCLKRST_ON );
/ L7 S6 K" e3 `* A$ h& Z3 t7 [5 E# y7 r P- B( n
mcasp->regs->XGBLCTL |= GBLCTL_XCLKRST_ON; 0 V n% M2 ?8 s- _8 S' K
while ( ( mcasp->regs->XGBLCTL & GBLCTL_XCLKRST_ON ) != GBLCTL_XCLKRST_ON );
* X8 z/ u6 h% n- M mcasp->regs->RGBLCTL |= GBLCTL_RCLKRST_ON; # f, |, P) ]6 D w' k% r. U
while ( ( mcasp->regs->RGBLCTL & GBLCTL_RCLKRST_ON ) != GBLCTL_RCLKRST_ON );
5 w% k* ]/ o) Q; N) K. b* c) f- F5 l2 |7 j9 u3 a
mcasp->regs->XSTAT = 0x0000ffff; + }' c4 N6 B. Z$ B8 h0 }* t4 P
mcasp->regs->RSTAT = 0x0000ffff;
, W4 c8 j8 r5 f" Z; {6 f6 i8 a% m- o' A2 r# N) R
mcasp->regs->XGBLCTL |= GBLCTL_XSRCLR_ON;
) H+ c; [) @& e while ( ( mcasp->regs->XGBLCTL & GBLCTL_XSRCLR_ON ) != GBLCTL_XSRCLR_ON );
, u* } ^5 V: k1 g2 E% Q! o7 c mcasp->regs->RGBLCTL |= GBLCTL_RSRCLR_ON;
. }2 B7 i7 X! M8 |& u while ( ( mcasp->regs->RGBLCTL & GBLCTL_RSRCLR_ON ) != GBLCTL_RSRCLR_ON );( L2 d; }5 ~% }- P( |9 L5 \ a8 ~
2 Y- ]6 N) X' K2 h7 u$ u
/* Write a 0, so that no underrun occurs after releasing the state machine */
* S! p2 A7 P6 S: X mcasp->regs->XBUF5 = 0;
7 ?# z7 B8 P% R mcasp->regs->RBUF0 = 0;
! k: K9 }# j& ?9 y5 ^: x' W
" g7 l$ V& Q; T; _+ U mcasp->regs->XGBLCTL |= GBLCTL_XSMRST_ON; 1 m9 q( y7 N8 V0 U7 S% I+ a* B1 i
while ( ( mcasp->regs->XGBLCTL & GBLCTL_XSMRST_ON ) != GBLCTL_XSMRST_ON );
# }- L- p, T8 Y+ M7 s G& z mcasp->regs->RGBLCTL |= GBLCTL_RSMRST_ON;
; ~" q T9 }( y) G. |6 z! o& Z while ( ( mcasp->regs->RGBLCTL & GBLCTL_RSMRST_ON ) != GBLCTL_RSMRST_ON );( ~3 h0 n/ W$ `4 W( f
8 B7 p( T6 m7 @3 p3 e4 X, Z mcasp->regs->XGBLCTL |= GBLCTL_XFRST_ON;
) V( D$ f& |4 e: Q; K while ( ( mcasp->regs->XGBLCTL & GBLCTL_XFRST_ON ) != GBLCTL_XFRST_ON );
( S' c+ W% I; ] i mcasp->regs->RGBLCTL |= GBLCTL_RFRST_ON;
; q# a) }: Y7 `2 O while ( ( mcasp->regs->RGBLCTL & GBLCTL_RFRST_ON ) != GBLCTL_RFRST_ON );3 D$ c! x9 B& K7 d
( Q& V4 f# z5 C- ? CSR = 0x0000;3 |: C3 P8 Y; F4 Z0 ?0 U
INTC_INTMUX1 = 0x3d;* X. Z, C/ \% F O4 o; ^: L: v, ^0 K
ISTP = (unsigned int)vectors;
% |& R( f2 U4 k. N6 @: k ICR = 0xFFF0;
" q; ^( S/ w* l" a4 W IER |= 0x12; $ j8 b2 W; |" p3 T- ^
CSR |= 0x01; 9 N. |+ L' H' l7 W6 H
6 `# {5 `3 S. Z( @5 i K8 K; o: ?$ v$ I+ Q) T5 f4 l
5 o: Z! o( A6 C x, @' q
还有就是两个输入输出函数:& O# x8 F8 Y3 e! x- v9 @. ?
void output_sample(Int32 out_data)) N/ t( U, F( ~& `& i- i
{
8 e4 o4 X' Q) Q o5 I AIC31_data.uint = out_data;
I- r/ b5 N9 c MCASP1_XBUF5_32BIT = AIC31_data.uint;; }$ |, ^& b+ X& J( p
}0 B! l7 V7 c3 N% L5 \4 V Y H
: }% b' l3 J! z- SInt32 input_sample(void)
4 O' f) g/ M: U- Z: y3 N$ g{
3 H4 m6 L0 H! Z AIC31_data.uint = MCASP1_RBUF0_32BIT;6 j, w Y# H" }6 [
return (AIC31_data.uint);/ a- |% Q1 D+ c: P
}3 l) n6 Q/ f0 ~) o1 s; |' Z
% N& S: q e+ S1 l# M |
|