|
|
C6747和C6748感觉差不多,我想实现McASP发送中断方式控制音频信号,在轮询的例程基础上改的,轮询程序可以实现,但是中断一直实现不了,也找不到错误,求大神帮忙!下边是主要程序:( E0 J. [7 ]; @
main文件:2 H7 [# s8 P% v- L
interrupt void interrupt4(void)
/ s' O. z. A$ P( I$ {% t7 ], a{) G0 X0 Q( A4 R3 k8 M' p
Uint32 sample;# ?& R/ A! V9 Q) B0 O, l
9 A6 r# j3 v1 t% U
sample = input_sample(); // read L + R samples from ADC- ]& h0 k8 h8 D5 i' @* c7 V7 l
output_sample(sample); // write L + R samples to DAC
. v3 n# @$ f; c1 [; t+ `7 ^ return;! h' L( ]6 i( S2 k$ o( }/ v0 `! I# p
}
0 z/ L( E+ O" c* {- W1 x0 g1 K$ @1 Z$ j) @
int main( void )& u) U. i9 P7 o# M2 m- F
{- [; {1 \% [7 X; h0 A( w
. k& h) o) @6 e4 [
/* Initialize BSL */( r6 U+ _7 y& M# @
EVMC6747_init( );
! w( B6 z* E2 h /* Call evmc6747_intr function */* m- o! C$ W e/ i+ g/ x
aic3106_init( );
0 @- K/ H' q8 A3 h( C4 P$ k- u while(1);
5 z, \; e" B2 a( u}! P4 e2 i3 n0 e2 f e' U% c& N. D; D
3 V1 J- `" L& U
. u4 u( u% ?5 c4 ?. Saic3106_init文件的一部分,McASP配置部分,采用内部时钟,I2S方式,同步传输。音频芯片的配置应该没问题1 }, I# O6 q s4 _$ z5 l
/* Initialize MCASP1 */; @2 u! \ v; e# f( F+ Y( W
mcasp = &MCASP_MODULE_1;
9 E$ k% v/ R- C0 u8 v mcasp->regs->GBLCTL = 0; // Reset
i) b* v5 S7 u mcasp->regs->RGBLCTL = 0; // Reset RX- B$ r, p9 t& O: I2 x- E
mcasp->regs->XGBLCTL = 0; // Reset TX
1 t4 X, ~$ ~' }4 r3 Q+ R+ Y/ p mcasp->regs->PWRDEMU = 1; // Free-running; }- i8 U8 U+ B
// configure McASP0 receive registers
! w; d- u4 r, r/ I) a9 P mcasp->regs->RMASK = 0xFFFFFFFF; // No padding used
4 }9 D$ F$ J7 }8 Q8 j! `; A. s mcasp->regs->RFMT = 0x00018078; // MSB 16bit, 0-delay, no pad, CFGBus
8 h( F, T5 a) A* i1 u' Z mcasp->regs->AFSRCTL = 0x00000112; // 2TDM, 1bit Falling, External FS, word: `/ Z. n6 r1 s7 X* F5 m; z
mcasp->regs->ACLKRCTL = 0x000000AF; // Rising INTERNAL CLK,(from tx side)
9 t& U; g& X: \- c mcasp->regs->AHCLKRCTL = 0x00000000; // INT CLK (from tx side)3 v0 F2 _! u! i
mcasp->regs->RTDM = 0x00000003; // Slots 0,1) P& R7 {' X9 E6 c. U8 a E
mcasp->regs->RINTCTL = 0x00000000; // Not used
7 P4 E' A8 [4 | mcasp->regs->RCLKCHK = 0x00FF0008; // 255-MAX 0-MIN, div-by-256
$ D6 G" Q, ~% |" W9 L5 {5 K! w. K; d5 d1 x1 a
mcasp->regs->XMASK = 0xFFFFFFFF; // No padding used, e% a, d9 G( S& K4 @- h4 Y, j; p' N
mcasp->regs->XFMT = 0x00018078; // MSB 16bit, 0-delay, no pad, CFGBus0 _. _; j$ h- I) Y. D
mcasp->regs->AFSXCTL = 0x00000112; // 2TDM, 1bit Rising edge INTERNAL FS, word
: V6 n+ s8 Z5 R1 ]) @ mcasp->regs->ACLKXCTL = 0x000000AF; // ASYNC, Rising INTERNAL CLK, div-by-16
/ f* d; S6 b; @8 e4 t# {# J mcasp->regs->AHCLKXCTL = 0x00000000; // EXT CLK' x% W# r+ |/ [3 q' j* n
mcasp->regs->XTDM = 0x00000003; // Slots 0,1
. O! P% B/ K3 O- y5 u9 U mcasp->regs->XINTCTL = 0x00000020; // interrupt on transmit
0 Q8 m! l _- w, j: C8 u+ Y mcasp->regs->XCLKCHK = 0x00FF0008; // 255-MAX 0-MIN, div-by-256( `. [. }9 C7 g8 g$ A
1 e& w# D2 @* Q6 |; W0 ~) O mcasp->regs->SRCTL5 = 0x000D; // MCASP1.AXR1[5] --> DIN0 o. F# d5 r, t* w7 b
mcasp->regs->SRCTL0 = 0x000E; // MCASP1.AXR1[0] <-- DOUT1 h/ Z+ X& `9 Z+ k6 d" H( |; d
mcasp->regs->PFUNC = 0; // All MCASPs& O" Q+ L, B! p7 F0 L6 N! j
mcasp->regs->PDIR = 0x14000020; // All inputs except AXR0[5], ACLKX1, AFSX1
( {8 Q) b2 o9 P) C
: X+ E! \6 u- O; I mcasp->regs->DITCTL = 0x00000000; // Not used2 E2 h' f- I* b7 T* Q$ I& [
mcasp->regs->DLBCTL = 0x00000000; // Not used+ ]" \4 q$ S* T
mcasp->regs->AMUTE = 0x00000000; // Not used
1 {2 ^: g3 W8 K3 v( I
3 e4 E/ t9 k) F% o2 p# U/* Starting sections of the McASP*/! b. h3 G* Q$ W$ x7 r$ }" Y" _
mcasp->regs->XGBLCTL |= GBLCTL_XHCLKRST_ON;
) m/ f# N5 B9 N1 A while ( ( mcasp->regs->XGBLCTL & GBLCTL_XHCLKRST_ON ) != GBLCTL_XHCLKRST_ON );
: @+ N5 N R( f% K! s mcasp->regs->RGBLCTL |= GBLCTL_RHCLKRST_ON;
, @' D( {$ E7 {% p0 p" S) J4 j while ( ( mcasp->regs->RGBLCTL & GBLCTL_RHCLKRST_ON ) != GBLCTL_RHCLKRST_ON );
, a' r$ q9 c' u, i
, J' w: s. P0 C: L mcasp->regs->XGBLCTL |= GBLCTL_XCLKRST_ON; % n( G0 R" x) b" O. d
while ( ( mcasp->regs->XGBLCTL & GBLCTL_XCLKRST_ON ) != GBLCTL_XCLKRST_ON );
- i) l7 S8 ?0 e5 n' \0 H$ _# Q mcasp->regs->RGBLCTL |= GBLCTL_RCLKRST_ON; ! L! n# v6 C8 C! ^! `) k
while ( ( mcasp->regs->RGBLCTL & GBLCTL_RCLKRST_ON ) != GBLCTL_RCLKRST_ON );
$ ~) M" m* {5 Q2 W( k8 q& @6 O% q: z9 J) p; v- a
mcasp->regs->XSTAT = 0x0000ffff; ; g( D% h: k1 M, D' X! i
mcasp->regs->RSTAT = 0x0000ffff; ; p+ f" }! X5 n
6 u+ ^9 v9 L! Q6 m; A' B6 \) d mcasp->regs->XGBLCTL |= GBLCTL_XSRCLR_ON;0 G4 x$ Y3 X0 A- L' N' \$ `
while ( ( mcasp->regs->XGBLCTL & GBLCTL_XSRCLR_ON ) != GBLCTL_XSRCLR_ON );3 B, S: k v; l3 ^$ L
mcasp->regs->RGBLCTL |= GBLCTL_RSRCLR_ON; . t3 J- y# Q9 C: G
while ( ( mcasp->regs->RGBLCTL & GBLCTL_RSRCLR_ON ) != GBLCTL_RSRCLR_ON );
. i" r( z! Y; c" J* K1 m( t. d3 g$ r: E4 F0 w9 S3 s ~' L& {
/* Write a 0, so that no underrun occurs after releasing the state machine *// |9 Y; M1 @+ x3 j3 m, t
mcasp->regs->XBUF5 = 0;1 a$ s0 w* j/ q0 ^
mcasp->regs->RBUF0 = 0;: C+ U' T* h% _$ l
6 j* f1 r' {- Q! r5 E& \$ @ mcasp->regs->XGBLCTL |= GBLCTL_XSMRST_ON;
$ }4 \: p0 v7 V! h8 ~' W while ( ( mcasp->regs->XGBLCTL & GBLCTL_XSMRST_ON ) != GBLCTL_XSMRST_ON );- O$ S, s( b# T- m
mcasp->regs->RGBLCTL |= GBLCTL_RSMRST_ON;
) u! @: ]! n/ B# L3 f! k" W while ( ( mcasp->regs->RGBLCTL & GBLCTL_RSMRST_ON ) != GBLCTL_RSMRST_ON );6 ?" @" j1 |7 J* n! F
$ w% [/ w" I- D0 v- l u3 S& {
mcasp->regs->XGBLCTL |= GBLCTL_XFRST_ON; & {6 H& }; L( Z/ o% H3 ?" e
while ( ( mcasp->regs->XGBLCTL & GBLCTL_XFRST_ON ) != GBLCTL_XFRST_ON );
' S$ U" } k8 x% _" [4 `- R mcasp->regs->RGBLCTL |= GBLCTL_RFRST_ON; 9 @- u( Q$ G7 S% j
while ( ( mcasp->regs->RGBLCTL & GBLCTL_RFRST_ON ) != GBLCTL_RFRST_ON );' Q( k' G/ M( b1 G6 z' v
# ]* H: J+ \$ G
CSR = 0x0000;
/ k! ^! [* L$ h- X9 Q INTC_INTMUX1 = 0x3d;4 r* M/ `" N; O* J+ k
ISTP = (unsigned int)vectors;8 G$ g( y L. q& m. v
ICR = 0xFFF0; - i. d3 i% ^: H$ }
IER |= 0x12;
- _- c8 s) m2 v. v* w CSR |= 0x01;
% M- }: P1 K# q9 n: X) C
: u5 @! ^4 b& S1 q; f0 A- [ l( M( Z1 C- x g4 I. l* f' y6 |& O
% Y G. K& |$ A5 ]. M" b3 k4 U7 N( n还有就是两个输入输出函数:
9 e w: C5 M E( S5 o5 i% qvoid output_sample(Int32 out_data)4 Q, w& h: T) A- s
{+ K$ P8 {7 i% s4 F9 |# U" M
AIC31_data.uint = out_data; , A, _' \6 h) J: Y" n" G/ M
MCASP1_XBUF5_32BIT = AIC31_data.uint;/ F% r0 e* ]$ z- H3 v6 ]# x
}
- L# l, C* a& h0 c* E% c+ F
: e- n2 v& K; |; o( Z1 @& OInt32 input_sample(void)5 _9 _; n: Y+ p+ l- Q6 v
{
' _! R, P, Q! V+ Z( y3 l) s AIC31_data.uint = MCASP1_RBUF0_32BIT;
$ V: V7 }- Q8 B6 C1 M' K- C0 k' \0 d return (AIC31_data.uint);- t% E0 M; A% S
}$ H, |2 N; h- O8 X! V
1 n% C% ~; l) a6 F5 ~ H
|
|