|
|
C6747和C6748感觉差不多,我想实现McASP发送中断方式控制音频信号,在轮询的例程基础上改的,轮询程序可以实现,但是中断一直实现不了,也找不到错误,求大神帮忙!下边是主要程序:
: M- O) b, W; Hmain文件:& G& \5 i E: _! e2 `8 ]2 K6 y
interrupt void interrupt4(void) + ~1 D2 w; M* A5 V: n# r0 M0 [# d
{
7 Y" R$ ? B7 V/ ^+ {2 f6 d Uint32 sample;6 o, v* F: K# V! b5 _
5 o$ s, I# R6 a9 d
sample = input_sample(); // read L + R samples from ADC4 A) {- z4 r; E b3 B/ R( H
output_sample(sample); // write L + R samples to DAC
! G7 X2 }( @' d ?0 [" T1 h D0 I return;
$ L7 s: o: [- R1 X2 f}1 |- F! p l+ ?) y- t( y- e2 N
4 D6 J% P: H! J* A9 v% l7 aint main( void )' x# }* e1 H2 N) _' D. C1 X# V7 g# U
{
6 G" G: @8 E7 l+ I% \" G6 M% s5 I& ?% [2 q
/* Initialize BSL */( R9 W- M; R' ` f+ V) E' _
EVMC6747_init( );: F3 r1 w( e* d: \! q8 \( i2 m
/* Call evmc6747_intr function */
; n" U, j4 p: L* x8 C3 C aic3106_init( );
" b. b! ?! i S5 G/ W O4 H G& C3 p- q/ p while(1);
3 P5 Z! w! Y3 I2 g}
5 k$ _# Q# w1 C q0 m, t" L' m. K9 I/ J3 P- l7 U
* e- A$ t P% s1 Y, uaic3106_init文件的一部分,McASP配置部分,采用内部时钟,I2S方式,同步传输。音频芯片的配置应该没问题; k# D# A5 G' t3 D( i T7 L
/* Initialize MCASP1 */
6 r1 A' @8 {% z) [6 v7 {& { mcasp = &MCASP_MODULE_1;% h3 j: c% R# p# d3 D
mcasp->regs->GBLCTL = 0; // Reset% \) j0 h9 r! e# U
mcasp->regs->RGBLCTL = 0; // Reset RX
1 m; ?# N, x6 E$ C% p mcasp->regs->XGBLCTL = 0; // Reset TX: {) z( K% y( b
mcasp->regs->PWRDEMU = 1; // Free-running
$ u: q; a1 z( e9 u, n S // configure McASP0 receive registers% Y; j o0 C) A
mcasp->regs->RMASK = 0xFFFFFFFF; // No padding used+ |4 w/ ~" V: L7 k
mcasp->regs->RFMT = 0x00018078; // MSB 16bit, 0-delay, no pad, CFGBus+ r3 `( c0 m: o) l1 O$ y/ r3 y
mcasp->regs->AFSRCTL = 0x00000112; // 2TDM, 1bit Falling, External FS, word
# @- E6 d2 l; b+ U: } mcasp->regs->ACLKRCTL = 0x000000AF; // Rising INTERNAL CLK,(from tx side): \/ w2 I' m7 ^5 x
mcasp->regs->AHCLKRCTL = 0x00000000; // INT CLK (from tx side); W& C) o% N5 o, l. d* V3 i/ e
mcasp->regs->RTDM = 0x00000003; // Slots 0,1
@: l9 ]( c) u7 L4 v! ?4 q mcasp->regs->RINTCTL = 0x00000000; // Not used) n8 Q3 ~# C( D8 W
mcasp->regs->RCLKCHK = 0x00FF0008; // 255-MAX 0-MIN, div-by-256
/ T* T8 F" v, p' t
) c1 u/ c" G: U! q. M$ A+ | W! w/ z mcasp->regs->XMASK = 0xFFFFFFFF; // No padding used5 I* k/ e2 e& K. h0 O& k4 f5 A
mcasp->regs->XFMT = 0x00018078; // MSB 16bit, 0-delay, no pad, CFGBus( G+ c* A P5 ?9 ~; X% @' h
mcasp->regs->AFSXCTL = 0x00000112; // 2TDM, 1bit Rising edge INTERNAL FS, word
9 E1 v+ f1 H* v" c mcasp->regs->ACLKXCTL = 0x000000AF; // ASYNC, Rising INTERNAL CLK, div-by-16' J: Y: L( u9 @+ t2 V8 b& A6 ?, }
mcasp->regs->AHCLKXCTL = 0x00000000; // EXT CLK+ d. R9 `7 V4 A: B% d
mcasp->regs->XTDM = 0x00000003; // Slots 0,1
- V8 ]7 N9 _3 K P8 R* B mcasp->regs->XINTCTL = 0x00000020; // interrupt on transmit
2 [5 Z `* [* D+ U, Z4 U& L* R0 O mcasp->regs->XCLKCHK = 0x00FF0008; // 255-MAX 0-MIN, div-by-256 G" D8 L1 C4 X, V4 v
5 M+ k# ~1 p! j) s
mcasp->regs->SRCTL5 = 0x000D; // MCASP1.AXR1[5] --> DIN+ \1 k* j$ j- A) M" T
mcasp->regs->SRCTL0 = 0x000E; // MCASP1.AXR1[0] <-- DOUT
" l5 ]/ f7 P# z3 r( J mcasp->regs->PFUNC = 0; // All MCASPs
/ z$ p, H. [0 C$ j mcasp->regs->PDIR = 0x14000020; // All inputs except AXR0[5], ACLKX1, AFSX1
3 j6 J4 K. ]8 {7 [ F H e- V/ _8 w+ J
mcasp->regs->DITCTL = 0x00000000; // Not used G5 X9 J) m" k* m% ]1 b5 Y! I8 k
mcasp->regs->DLBCTL = 0x00000000; // Not used3 `2 ?! P9 a* R, G7 H
mcasp->regs->AMUTE = 0x00000000; // Not used. w- v D/ T0 j, m- n1 L- Z) I
: y8 q' _& k4 m2 l3 E+ l' ~6 F
/* Starting sections of the McASP*/
( w; M J u' I! x+ r mcasp->regs->XGBLCTL |= GBLCTL_XHCLKRST_ON; - n( j9 a/ E4 u# R6 L) ~
while ( ( mcasp->regs->XGBLCTL & GBLCTL_XHCLKRST_ON ) != GBLCTL_XHCLKRST_ON ); 3 I R+ J4 E# J9 Q" [8 P! N, Z
mcasp->regs->RGBLCTL |= GBLCTL_RHCLKRST_ON; , G4 P$ r! a }: k+ t4 j
while ( ( mcasp->regs->RGBLCTL & GBLCTL_RHCLKRST_ON ) != GBLCTL_RHCLKRST_ON );9 }3 g% e+ E' ^; o5 a% T
2 d4 c3 @. x% |9 L6 R
mcasp->regs->XGBLCTL |= GBLCTL_XCLKRST_ON;
. b( F" f% a. u while ( ( mcasp->regs->XGBLCTL & GBLCTL_XCLKRST_ON ) != GBLCTL_XCLKRST_ON );* R: c5 @6 G* [! G# V% j
mcasp->regs->RGBLCTL |= GBLCTL_RCLKRST_ON; # ?1 `. ?3 o; V6 V8 A. D* I
while ( ( mcasp->regs->RGBLCTL & GBLCTL_RCLKRST_ON ) != GBLCTL_RCLKRST_ON );
u; D9 _, p2 t
( \1 t$ A/ S, v. Z8 m* c, H2 E/ r" e mcasp->regs->XSTAT = 0x0000ffff;
0 r8 c) U/ M8 ~8 `. n mcasp->regs->RSTAT = 0x0000ffff; * y8 N, s- C+ {) C
5 T- N8 d. W0 z- k# t9 { mcasp->regs->XGBLCTL |= GBLCTL_XSRCLR_ON;
, t: K: s) e7 o$ C$ G while ( ( mcasp->regs->XGBLCTL & GBLCTL_XSRCLR_ON ) != GBLCTL_XSRCLR_ON );3 _8 }& }* D B0 W% n: l
mcasp->regs->RGBLCTL |= GBLCTL_RSRCLR_ON;
r2 J0 T4 z, x" e4 Q+ c while ( ( mcasp->regs->RGBLCTL & GBLCTL_RSRCLR_ON ) != GBLCTL_RSRCLR_ON );
6 d+ [- C+ I+ i& d8 j: X' I; c$ C# A8 L9 k3 c0 j. g: V
/* Write a 0, so that no underrun occurs after releasing the state machine */& j w2 V$ J. r: Q
mcasp->regs->XBUF5 = 0;
5 e" ], Y+ ^# L mcasp->regs->RBUF0 = 0;
9 p. A. x0 H1 s& W
/ M0 _7 C2 `, g mcasp->regs->XGBLCTL |= GBLCTL_XSMRST_ON;
9 ?& @9 U! g1 Z+ E4 N8 e1 S while ( ( mcasp->regs->XGBLCTL & GBLCTL_XSMRST_ON ) != GBLCTL_XSMRST_ON );( y3 ^/ W9 ]* K8 e6 ]
mcasp->regs->RGBLCTL |= GBLCTL_RSMRST_ON;
$ O4 W* f' y5 a while ( ( mcasp->regs->RGBLCTL & GBLCTL_RSMRST_ON ) != GBLCTL_RSMRST_ON );
' T2 P. k1 L! [' ?/ k8 @/ s3 e& Z0 g9 m# H& G) v0 F
mcasp->regs->XGBLCTL |= GBLCTL_XFRST_ON; . d. V: I6 V- v) j$ n% ?% p
while ( ( mcasp->regs->XGBLCTL & GBLCTL_XFRST_ON ) != GBLCTL_XFRST_ON );
% u7 I5 r9 g' c$ [+ _9 t1 q mcasp->regs->RGBLCTL |= GBLCTL_RFRST_ON;
$ I( r8 ^; T$ t% R, _ while ( ( mcasp->regs->RGBLCTL & GBLCTL_RFRST_ON ) != GBLCTL_RFRST_ON );
$ D$ I1 P; ?2 X7 M. }8 a5 n6 P- Y
CSR = 0x0000;
" w! d- u8 i. ~) \, a" c( E0 K. P INTC_INTMUX1 = 0x3d;
' j9 ~9 w b5 o1 k6 } ISTP = (unsigned int)vectors;
+ P( U2 }7 `8 c# U9 P0 K% { ICR = 0xFFF0; 6 N) ?7 G7 V9 }3 o6 K; ^' |
IER |= 0x12; $ r/ y. N8 u p1 {+ {% `
CSR |= 0x01;
4 ]) b( O1 \' s: _! X: p% G) R$ U7 {& j9 y1 a
# g0 ?- B: y$ P6 d% @! K% S8 Y/ W; B
6 n/ V8 V& [. g9 l6 ?( b* h还有就是两个输入输出函数:
2 {5 u* B( |& |9 \void output_sample(Int32 out_data)
! P: f" t6 R! K" q9 |8 g5 R8 A{9 V1 ^$ z! y2 G) Y1 ~
AIC31_data.uint = out_data; " k7 v1 o% I1 h1 p8 I3 i
MCASP1_XBUF5_32BIT = AIC31_data.uint;% L! n' u, Y6 m# I* z7 U
}8 z) h* m. E2 r* h
8 _. O- P# o" i6 ]4 C jInt32 input_sample(void)9 j S+ }9 q1 L, q
{ * T u, V0 m! G r) c, c: y
AIC31_data.uint = MCASP1_RBUF0_32BIT;
" y4 `/ O0 X* o1 @7 { return (AIC31_data.uint);1 [: d+ L* [+ r# B- `: w
}
' y. i# i/ g* L# f7 H, L& h/ P+ g7 {& f* B' e0 N. S
|
|