|
|
C6747和C6748感觉差不多,我想实现McASP发送中断方式控制音频信号,在轮询的例程基础上改的,轮询程序可以实现,但是中断一直实现不了,也找不到错误,求大神帮忙!下边是主要程序:0 q: b6 G: }" U X* ~
main文件:0 S" |7 R0 j/ p" j( v% T
interrupt void interrupt4(void) ; Z/ p. T+ g. e+ ]+ L4 T
{7 C2 l% y7 u; e0 n
Uint32 sample;" y: f& i% L V7 n3 X( v, d) x
( |1 g# P. S8 z, u8 s0 u1 i* h sample = input_sample(); // read L + R samples from ADC
6 s1 R% u( S' ? output_sample(sample); // write L + R samples to DAC
( `" I$ z- l7 v' X& \' m9 y! z8 { return;* X) { r8 ]7 c
}* n! Y, e$ `8 L) ]& I, S
) ] i% S1 U% O) ]; @" i1 {int main( void )
: R' J6 v$ a* k{
/ M' u/ z7 \* F5 y8 R% n3 {' I$ q U1 x; Q
/* Initialize BSL */
; p T- b7 p) _& D EVMC6747_init( );
1 M( I% {, a" X /* Call evmc6747_intr function */1 F4 \3 r+ Y4 m/ u$ q C& | Y9 o
aic3106_init( );
! L7 ^' g3 S" h& Z while(1);
# \, o4 B- i' _( I A$ S% i& \8 X2 H}) i) h& b# M- c# g8 o
& ~+ B+ F6 |% k
; i* P6 d) v3 D; k8 M/ m1 u" i f
aic3106_init文件的一部分,McASP配置部分,采用内部时钟,I2S方式,同步传输。音频芯片的配置应该没问题
: e1 R+ c: q F' C* h% [/* Initialize MCASP1 */
+ Y7 W! o$ t. J m+ r6 Y2 y! d mcasp = &MCASP_MODULE_1;
1 M: }7 l" A" ?8 W! F mcasp->regs->GBLCTL = 0; // Reset
9 Q1 ^0 y$ R" q! R& A8 E mcasp->regs->RGBLCTL = 0; // Reset RX
- s. A) H6 [0 o mcasp->regs->XGBLCTL = 0; // Reset TX
9 _4 ^: A( O) L$ J# G1 u mcasp->regs->PWRDEMU = 1; // Free-running
+ H6 W/ D; d% C // configure McASP0 receive registers$ `3 [# D! _$ N, Q' `. i# H
mcasp->regs->RMASK = 0xFFFFFFFF; // No padding used
/ p, G( M& L. o; O mcasp->regs->RFMT = 0x00018078; // MSB 16bit, 0-delay, no pad, CFGBus
, H/ t: ^* U! g mcasp->regs->AFSRCTL = 0x00000112; // 2TDM, 1bit Falling, External FS, word
) q% f* A0 Z+ S7 P- n8 \% z2 r mcasp->regs->ACLKRCTL = 0x000000AF; // Rising INTERNAL CLK,(from tx side)2 w* X+ Y0 k: U, h
mcasp->regs->AHCLKRCTL = 0x00000000; // INT CLK (from tx side)
1 S0 z2 h" R8 L! n' r; k W mcasp->regs->RTDM = 0x00000003; // Slots 0,1/ | p* I3 v5 t
mcasp->regs->RINTCTL = 0x00000000; // Not used
" Q* C8 v$ }% n f+ L1 B mcasp->regs->RCLKCHK = 0x00FF0008; // 255-MAX 0-MIN, div-by-2568 C5 [" X5 _/ Z( i7 A
* j7 p! m3 C, E mcasp->regs->XMASK = 0xFFFFFFFF; // No padding used
3 L' F3 t' C n9 o/ f mcasp->regs->XFMT = 0x00018078; // MSB 16bit, 0-delay, no pad, CFGBus
1 Q" M. a2 l# `) C; l- { mcasp->regs->AFSXCTL = 0x00000112; // 2TDM, 1bit Rising edge INTERNAL FS, word
" W6 O8 _- n5 n1 p mcasp->regs->ACLKXCTL = 0x000000AF; // ASYNC, Rising INTERNAL CLK, div-by-16, z3 V( K# T! ^5 C
mcasp->regs->AHCLKXCTL = 0x00000000; // EXT CLK$ \- a% c: Z# Z+ L, w
mcasp->regs->XTDM = 0x00000003; // Slots 0,1( Y; h8 _) d6 D2 T) T; C* ^
mcasp->regs->XINTCTL = 0x00000020; // interrupt on transmit/ L) S- s3 l3 j: X* V" F* m. I
mcasp->regs->XCLKCHK = 0x00FF0008; // 255-MAX 0-MIN, div-by-256
$ b4 O/ K6 A. G {" [; ~# B7 |! m- w, c+ C* Q( q. O
mcasp->regs->SRCTL5 = 0x000D; // MCASP1.AXR1[5] --> DIN
0 q* g& I8 R6 r% Y. x3 u. F mcasp->regs->SRCTL0 = 0x000E; // MCASP1.AXR1[0] <-- DOUT
, j8 d3 c2 M1 ?* f2 R mcasp->regs->PFUNC = 0; // All MCASPs' i5 x" K: b8 ~- b; g1 E3 T: q
mcasp->regs->PDIR = 0x14000020; // All inputs except AXR0[5], ACLKX1, AFSX1
% ]: V# [2 T' n: ^4 i5 u5 p. `3 p" z* T8 E; E2 I: A9 A
mcasp->regs->DITCTL = 0x00000000; // Not used( X; P- {0 T0 r$ ~" J
mcasp->regs->DLBCTL = 0x00000000; // Not used
, V) |* R$ O1 m5 a! V mcasp->regs->AMUTE = 0x00000000; // Not used! A, U4 G! g }. a x. X
$ c" M2 J1 ~. Z1 @+ @' U9 f2 a9 ?
/* Starting sections of the McASP*/% |. X" ~( s8 A% B
mcasp->regs->XGBLCTL |= GBLCTL_XHCLKRST_ON;
5 m. n, ^% B% I8 O4 e9 y while ( ( mcasp->regs->XGBLCTL & GBLCTL_XHCLKRST_ON ) != GBLCTL_XHCLKRST_ON );
. Z) Q6 R6 n5 f2 r mcasp->regs->RGBLCTL |= GBLCTL_RHCLKRST_ON;
7 C W3 i* f7 Q0 C' r7 T while ( ( mcasp->regs->RGBLCTL & GBLCTL_RHCLKRST_ON ) != GBLCTL_RHCLKRST_ON );3 ^7 S/ ^! ^) h& ?$ L9 J. O
" i, r f3 m ]: q4 ?4 q @
mcasp->regs->XGBLCTL |= GBLCTL_XCLKRST_ON;
8 s9 T* U& | p& M while ( ( mcasp->regs->XGBLCTL & GBLCTL_XCLKRST_ON ) != GBLCTL_XCLKRST_ON );
0 n! _1 D, c% l, z0 S% T9 _ mcasp->regs->RGBLCTL |= GBLCTL_RCLKRST_ON;
8 j$ a! d% a" m. v! F8 g" Y while ( ( mcasp->regs->RGBLCTL & GBLCTL_RCLKRST_ON ) != GBLCTL_RCLKRST_ON );
1 N0 D0 d S; K8 P6 `0 E; `
4 {8 S0 d; W/ @( n; P0 J) A2 W mcasp->regs->XSTAT = 0x0000ffff; , K! C0 u1 E6 } B
mcasp->regs->RSTAT = 0x0000ffff; & _* V" d. U. T( }& a. }$ l' h' r, O
: S# R8 f; h; S0 s
mcasp->regs->XGBLCTL |= GBLCTL_XSRCLR_ON;
) u$ [' ?, ^* v9 Y! c+ B% y7 Y while ( ( mcasp->regs->XGBLCTL & GBLCTL_XSRCLR_ON ) != GBLCTL_XSRCLR_ON );) @ f$ R( H& D" `
mcasp->regs->RGBLCTL |= GBLCTL_RSRCLR_ON;
0 R& E3 h9 A/ g% r9 p% a/ p while ( ( mcasp->regs->RGBLCTL & GBLCTL_RSRCLR_ON ) != GBLCTL_RSRCLR_ON );
: n5 A: P) p, d/ x, N3 [
9 s W: K8 C: j7 p. z: a4 r, \ /* Write a 0, so that no underrun occurs after releasing the state machine */
* B8 c( |3 k7 D; {7 t. s$ _ mcasp->regs->XBUF5 = 0;9 I- F2 j& N ?( h6 W
mcasp->regs->RBUF0 = 0;
9 m5 j! a" S5 ~5 g* R5 R5 o+ q7 b
mcasp->regs->XGBLCTL |= GBLCTL_XSMRST_ON;
! N! o# h9 H3 I: Z* t while ( ( mcasp->regs->XGBLCTL & GBLCTL_XSMRST_ON ) != GBLCTL_XSMRST_ON );
7 j' I/ Q# }, n4 @; a& m$ ~ mcasp->regs->RGBLCTL |= GBLCTL_RSMRST_ON; 8 ^; H7 { J' ?; P! x: V- C
while ( ( mcasp->regs->RGBLCTL & GBLCTL_RSMRST_ON ) != GBLCTL_RSMRST_ON );
9 r3 X" j: n! ^' r% {" y1 o5 x) s9 U% {) m9 w3 q/ `% U/ c3 c6 m
mcasp->regs->XGBLCTL |= GBLCTL_XFRST_ON;
) j9 N: l& M5 T6 Q8 T while ( ( mcasp->regs->XGBLCTL & GBLCTL_XFRST_ON ) != GBLCTL_XFRST_ON );' m, Y, _3 h. Q( U2 x Z: f c9 _
mcasp->regs->RGBLCTL |= GBLCTL_RFRST_ON;
( Y; h- b" f7 `9 ]1 B. t- a while ( ( mcasp->regs->RGBLCTL & GBLCTL_RFRST_ON ) != GBLCTL_RFRST_ON );! r7 b4 |; J; j
# J0 M' |: g' W$ B" O
CSR = 0x0000;* h$ |' c: ~, g) N' X& [% \2 k
INTC_INTMUX1 = 0x3d;% T+ b( B8 V* c* _( Q' d
ISTP = (unsigned int)vectors;
% c; A8 t8 ?2 Y0 m ICR = 0xFFF0; , ]" P8 n" N4 q# u- t; [2 i# n
IER |= 0x12;
- q: Q _9 T; a; z5 G& d CSR |= 0x01; 4 s+ G& n) ^) \
) s j- S6 |/ V3 I3 _* [
( Y7 d# X5 L# [( I( [3 }
# F" V3 [8 v! ~5 u a8 W0 a) }还有就是两个输入输出函数:2 n8 p) \/ z; m; ~# w5 c
void output_sample(Int32 out_data)
+ H8 N; f1 ]7 V. `3 p. V1 ~1 W{1 v. ~# c( S9 q) c' R' m
AIC31_data.uint = out_data;
5 e) V3 b( {1 v" U0 i, d5 Y MCASP1_XBUF5_32BIT = AIC31_data.uint;+ o# Q9 O. f3 t8 V4 C! f2 v I1 s
}
" Q/ F, z$ j* F7 q+ K8 _5 k4 U3 O
, L( E7 T2 l5 w( S4 X$ D$ gInt32 input_sample(void)
9 t% A3 c. W7 n. q7 R8 U{
: h2 z3 u0 d3 y7 P2 t AIC31_data.uint = MCASP1_RBUF0_32BIT;
$ n0 `9 g! c, Z, e# g$ \' X return (AIC31_data.uint);
+ @" l$ [! R" y3 @2 o) W2 k}7 x4 k2 d4 T6 p' v( C7 |# \
! i m' n6 F0 v7 w$ i. _ |
|