|
|
C6747和C6748感觉差不多,我想实现McASP发送中断方式控制音频信号,在轮询的例程基础上改的,轮询程序可以实现,但是中断一直实现不了,也找不到错误,求大神帮忙!下边是主要程序:
5 c& t5 |5 N+ l# V( omain文件:. I% x/ b! Y1 q' b* y* B
interrupt void interrupt4(void) ' @) e' Y: o6 B" M3 M; q" S
{
: r- r% R; G5 Z3 l: e z% n: F Uint32 sample;( R4 j) K) ^/ d$ t
~# N/ F } f
sample = input_sample(); // read L + R samples from ADC
; c1 A& r+ b) x w output_sample(sample); // write L + R samples to DAC
( [* O9 z# h. l% G5 Y" R# M" p. B return;
k4 C: D+ u/ r}
& Z: H0 U1 R8 T( [) i9 g* R
" f; S, I# V$ oint main( void )+ A) g+ m1 ~) b2 l! R1 F, T
{6 M" C' v5 Q6 W" M% a1 O
3 u$ i/ _) {) S# { /* Initialize BSL */' S% D+ ~0 A+ J) h4 |; Z- K& r
EVMC6747_init( );
7 M0 |7 U" c# ^* H /* Call evmc6747_intr function */
' Q5 [" Z/ Y( h. N- B) \) s aic3106_init( );
6 G p: k ?% g0 T2 ^& N while(1);+ p5 g0 p0 N4 }- g0 o4 |
}4 e0 |9 X2 `% v
8 a0 Q3 L( b' L3 m) A4 a8 u( I
1 Y% X9 k, B$ Q2 Q( taic3106_init文件的一部分,McASP配置部分,采用内部时钟,I2S方式,同步传输。音频芯片的配置应该没问题( c. C9 `" V. W' i( W$ x2 l* Y
/* Initialize MCASP1 */% t" ]$ B: _$ J E6 @% m
mcasp = &MCASP_MODULE_1;5 B" I' v1 ?& G( c5 J5 D% q
mcasp->regs->GBLCTL = 0; // Reset
) o6 _, N% _ l( y: ]$ {- [) W mcasp->regs->RGBLCTL = 0; // Reset RX
( h- z2 B6 k9 t+ o mcasp->regs->XGBLCTL = 0; // Reset TX
& e/ A$ O8 h: i mcasp->regs->PWRDEMU = 1; // Free-running
2 |0 I: A& J. R$ B W9 A // configure McASP0 receive registers/ n# |7 I6 W% a! e
mcasp->regs->RMASK = 0xFFFFFFFF; // No padding used& a' r+ h: J" f1 Y' E
mcasp->regs->RFMT = 0x00018078; // MSB 16bit, 0-delay, no pad, CFGBus
' `; Q" _; @( ?0 V% K mcasp->regs->AFSRCTL = 0x00000112; // 2TDM, 1bit Falling, External FS, word' Y1 e" g+ g3 e2 @
mcasp->regs->ACLKRCTL = 0x000000AF; // Rising INTERNAL CLK,(from tx side)
/ c9 p3 j) ~- d/ g" f3 o8 U% G4 s, @3 h mcasp->regs->AHCLKRCTL = 0x00000000; // INT CLK (from tx side)2 H8 A$ m' R& F! a; E
mcasp->regs->RTDM = 0x00000003; // Slots 0,1
0 X2 R3 @; ]+ B1 E! r mcasp->regs->RINTCTL = 0x00000000; // Not used0 i* U( k' M5 x0 O$ e
mcasp->regs->RCLKCHK = 0x00FF0008; // 255-MAX 0-MIN, div-by-256
. I$ ~" q8 q3 W
9 G" K/ n1 J; s, \/ a! x1 E mcasp->regs->XMASK = 0xFFFFFFFF; // No padding used& ^/ o/ _/ k/ E% y3 @0 V
mcasp->regs->XFMT = 0x00018078; // MSB 16bit, 0-delay, no pad, CFGBus
, Y5 Z4 o( F; A7 W mcasp->regs->AFSXCTL = 0x00000112; // 2TDM, 1bit Rising edge INTERNAL FS, word
, w Z2 E C Q# \ Z1 K% t mcasp->regs->ACLKXCTL = 0x000000AF; // ASYNC, Rising INTERNAL CLK, div-by-16& I: T+ {+ R# [+ v
mcasp->regs->AHCLKXCTL = 0x00000000; // EXT CLK/ `' q! V7 X; q, c( ?9 ?! u( z
mcasp->regs->XTDM = 0x00000003; // Slots 0,1
( I O) f f, x, j; ]6 ^. S mcasp->regs->XINTCTL = 0x00000020; // interrupt on transmit
+ `) ~. t/ q9 B$ z0 F# ? mcasp->regs->XCLKCHK = 0x00FF0008; // 255-MAX 0-MIN, div-by-2561 c3 Y, c! X# t- j+ }
5 [1 [7 o8 y! P4 Z2 m' t mcasp->regs->SRCTL5 = 0x000D; // MCASP1.AXR1[5] --> DIN
1 n$ t- b! @" N# d0 l9 Z7 ^ mcasp->regs->SRCTL0 = 0x000E; // MCASP1.AXR1[0] <-- DOUT1 C$ R* L& i% D! V, R) ?; s
mcasp->regs->PFUNC = 0; // All MCASPs$ k3 J {+ B( c1 N7 Q2 d: ]
mcasp->regs->PDIR = 0x14000020; // All inputs except AXR0[5], ACLKX1, AFSX1
* q- _0 r4 y% \. O6 t) B/ M) v0 c% z& d# @4 b
mcasp->regs->DITCTL = 0x00000000; // Not used
2 |+ v* j% l' A6 Q& p mcasp->regs->DLBCTL = 0x00000000; // Not used
0 L, W0 e* K8 V3 h. G* ` ]+ @8 O mcasp->regs->AMUTE = 0x00000000; // Not used
6 s% x: b' l8 F" J$ E4 y/ d6 X0 S( a0 [9 [( s; {3 ?
/* Starting sections of the McASP*/( w3 H! r! s3 x. s* U
mcasp->regs->XGBLCTL |= GBLCTL_XHCLKRST_ON; + X* v2 O* N+ a
while ( ( mcasp->regs->XGBLCTL & GBLCTL_XHCLKRST_ON ) != GBLCTL_XHCLKRST_ON );
5 |7 y" Y8 Z. b U' K4 D0 z: v mcasp->regs->RGBLCTL |= GBLCTL_RHCLKRST_ON; , v2 _, A1 L; H" C: Y
while ( ( mcasp->regs->RGBLCTL & GBLCTL_RHCLKRST_ON ) != GBLCTL_RHCLKRST_ON );0 T# X7 }. \! e
2 @2 p0 q. G9 g- }
mcasp->regs->XGBLCTL |= GBLCTL_XCLKRST_ON; : K5 R7 r U3 q) q2 X ~: b
while ( ( mcasp->regs->XGBLCTL & GBLCTL_XCLKRST_ON ) != GBLCTL_XCLKRST_ON );- G8 k1 p/ ?& p
mcasp->regs->RGBLCTL |= GBLCTL_RCLKRST_ON; 8 p3 v! V) K. |) L# c/ Y
while ( ( mcasp->regs->RGBLCTL & GBLCTL_RCLKRST_ON ) != GBLCTL_RCLKRST_ON );) W5 A* [0 J! u/ m
d" Z& o/ v4 @6 O4 a0 ] n; F mcasp->regs->XSTAT = 0x0000ffff;
1 ^7 p7 @2 @/ s' O mcasp->regs->RSTAT = 0x0000ffff; 7 `8 K3 d7 T3 r& D0 |
) e1 h' x+ s/ H* ]! w. z( C mcasp->regs->XGBLCTL |= GBLCTL_XSRCLR_ON;
, |% i+ O( c: ^8 i! v2 `# k while ( ( mcasp->regs->XGBLCTL & GBLCTL_XSRCLR_ON ) != GBLCTL_XSRCLR_ON );9 ^& \9 b9 J0 D, u0 z0 q
mcasp->regs->RGBLCTL |= GBLCTL_RSRCLR_ON; / ?, n: ]9 |6 \( @& l
while ( ( mcasp->regs->RGBLCTL & GBLCTL_RSRCLR_ON ) != GBLCTL_RSRCLR_ON );6 d) `5 _+ ]+ }5 H
+ S7 v; ?" N6 G* X0 j8 g( P; b9 f. e5 m /* Write a 0, so that no underrun occurs after releasing the state machine */
# A5 X0 M* l$ K. ] mcasp->regs->XBUF5 = 0;
5 g3 X p6 N' p ?5 n mcasp->regs->RBUF0 = 0;
3 Z: Z; A+ P4 \. K' Y4 a) o! I$ W, ?# ^, A
mcasp->regs->XGBLCTL |= GBLCTL_XSMRST_ON;
- W; T& R* B$ `# Z while ( ( mcasp->regs->XGBLCTL & GBLCTL_XSMRST_ON ) != GBLCTL_XSMRST_ON );! }# c5 S5 Y; N' E
mcasp->regs->RGBLCTL |= GBLCTL_RSMRST_ON;
% [1 ~: T2 }: g while ( ( mcasp->regs->RGBLCTL & GBLCTL_RSMRST_ON ) != GBLCTL_RSMRST_ON );
& j3 I& `4 Y, p' Z5 }- X. C3 Z. n* a/ S
mcasp->regs->XGBLCTL |= GBLCTL_XFRST_ON; % H( j8 `) H0 h
while ( ( mcasp->regs->XGBLCTL & GBLCTL_XFRST_ON ) != GBLCTL_XFRST_ON );" n2 C* S8 n6 s6 D9 G7 u: S2 Q& v% ^
mcasp->regs->RGBLCTL |= GBLCTL_RFRST_ON; + R2 \, _" M( ~1 ^
while ( ( mcasp->regs->RGBLCTL & GBLCTL_RFRST_ON ) != GBLCTL_RFRST_ON );
( W+ J- [: c% e$ k/ G7 ?* Y2 k+ I' A- X. Q8 n K1 Q
CSR = 0x0000;0 G) G& {. {7 j2 A' W4 f% P% J
INTC_INTMUX1 = 0x3d;
p! y: U% i P7 a. ~1 G" } ISTP = (unsigned int)vectors;
# G! O i) l5 V ICR = 0xFFF0;
: n2 p& X; M9 ?/ P IER |= 0x12; 1 f9 U! O4 _7 {( K2 B; i! K4 Y& X
CSR |= 0x01;
: q: n8 A: I2 A! b! @4 j0 M6 S& X2 C" V2 i: G5 A# P' l
# L/ E0 m, E5 F5 }) Y6 A
5 J0 }$ K T2 l; z还有就是两个输入输出函数:
5 s: T: [$ a. Q- kvoid output_sample(Int32 out_data)4 E( t$ V" @' T0 u" i
{! z' a( x7 H0 P1 T' c
AIC31_data.uint = out_data;
e4 {% \8 E! T6 P* C. F1 u- V MCASP1_XBUF5_32BIT = AIC31_data.uint;$ c$ d' t8 ~) ]1 A. c- Y
}
5 L% n: w2 W9 P0 I( @0 ^
3 h' T# C) F. V& B6 O+ S+ BInt32 input_sample(void)
6 t2 K: A+ ^* `1 v+ S9 W{
2 u: d4 C: k+ ?$ ]/ k0 V1 W$ o AIC31_data.uint = MCASP1_RBUF0_32BIT;+ i9 g5 p$ B& I$ b
return (AIC31_data.uint);5 {: x- z3 E4 I0 U: ^# y7 H: W
}6 m1 P4 `. Y% ]: `
; ]! l- c* w, j( T |
|