|
|
C6747和C6748感觉差不多,我想实现McASP发送中断方式控制音频信号,在轮询的例程基础上改的,轮询程序可以实现,但是中断一直实现不了,也找不到错误,求大神帮忙!下边是主要程序:6 }/ v* X1 U4 K, t8 |
main文件:
6 }# L) l. l7 T3 i- N+ Einterrupt void interrupt4(void)
, z c$ }0 X E$ } U9 d# Z9 y3 G{
, @$ O2 y j) ] Y5 }1 N) K, } Uint32 sample;
: l& W9 z8 T+ e4 e6 y7 e9 O. E8 }- S4 Y0 f+ b
sample = input_sample(); // read L + R samples from ADC6 J( Z& U9 ~/ `! z1 H" N
output_sample(sample); // write L + R samples to DAC - C, n2 a0 S; f. ?
return;
: Z( i8 {! m9 O! ^; a" P% J. H}
# n H6 H$ W. {- {- f/ i& V5 U: [" S4 K8 T _# t
int main( void )+ C; n' T' k' ~
{
& _# |# ?; @0 {- E T& y" O7 P' n' h3 H. `
/* Initialize BSL */" u- P/ G7 }& Q3 [* t8 v: z
EVMC6747_init( );, K7 n0 h% ?( `+ H& A! o; i5 B
/* Call evmc6747_intr function */4 k. b. {- `! E& E0 D# [
aic3106_init( );
, i* G# [8 l4 m6 j, q+ W while(1);
) x2 d$ }9 L# T}2 r( E8 V4 w0 z5 m2 r
# z6 K9 o* O" S! a) d2 P3 F
# R2 {4 A6 f- ]7 R5 B1 R5 gaic3106_init文件的一部分,McASP配置部分,采用内部时钟,I2S方式,同步传输。音频芯片的配置应该没问题
0 f. j/ K/ |; G$ u: i; ~/* Initialize MCASP1 */' i( }& C/ z/ ^, z: F7 [9 L
mcasp = &MCASP_MODULE_1;
. L9 m( B& x2 k& r! s0 E' O mcasp->regs->GBLCTL = 0; // Reset, b+ @; \7 V [! Q5 s" b
mcasp->regs->RGBLCTL = 0; // Reset RX
$ A" G! Y$ m R6 S mcasp->regs->XGBLCTL = 0; // Reset TX( q; C4 W+ I( C, t
mcasp->regs->PWRDEMU = 1; // Free-running: I' f3 U# V( h
// configure McASP0 receive registers
% H' J1 m& d5 s. V( {8 j8 w% e mcasp->regs->RMASK = 0xFFFFFFFF; // No padding used; z6 x C8 C3 ~6 l2 I2 z
mcasp->regs->RFMT = 0x00018078; // MSB 16bit, 0-delay, no pad, CFGBus. j6 A4 j: n! W% X4 [( L* G
mcasp->regs->AFSRCTL = 0x00000112; // 2TDM, 1bit Falling, External FS, word" \( [+ {, F t3 X* ?
mcasp->regs->ACLKRCTL = 0x000000AF; // Rising INTERNAL CLK,(from tx side)
3 X+ H! G2 |/ Z3 b2 ^ mcasp->regs->AHCLKRCTL = 0x00000000; // INT CLK (from tx side)" T. m' e* C4 O
mcasp->regs->RTDM = 0x00000003; // Slots 0,10 H9 n0 b7 R$ Z+ e" D
mcasp->regs->RINTCTL = 0x00000000; // Not used
/ q0 o6 b8 o& r mcasp->regs->RCLKCHK = 0x00FF0008; // 255-MAX 0-MIN, div-by-256" w6 d5 ^7 \! u, I3 u- }
0 U2 g3 J, c/ t6 }3 _7 T# t
mcasp->regs->XMASK = 0xFFFFFFFF; // No padding used
4 d0 H: K/ Q) E; @; C) r7 w mcasp->regs->XFMT = 0x00018078; // MSB 16bit, 0-delay, no pad, CFGBus
* w1 c6 r* g. b a0 Q mcasp->regs->AFSXCTL = 0x00000112; // 2TDM, 1bit Rising edge INTERNAL FS, word( [) n! ] i# Q `; A
mcasp->regs->ACLKXCTL = 0x000000AF; // ASYNC, Rising INTERNAL CLK, div-by-16" r" B6 U. t- Z' O- ^& U: S
mcasp->regs->AHCLKXCTL = 0x00000000; // EXT CLK
# K/ _1 V- q$ L4 C( j6 @ mcasp->regs->XTDM = 0x00000003; // Slots 0,1
) M& K+ [) K. G3 i% M7 P mcasp->regs->XINTCTL = 0x00000020; // interrupt on transmit, T3 h- M- }4 F) c& x, I
mcasp->regs->XCLKCHK = 0x00FF0008; // 255-MAX 0-MIN, div-by-2560 w- H9 K' A; t( h& H; }/ |
) N, \* C+ {( F
mcasp->regs->SRCTL5 = 0x000D; // MCASP1.AXR1[5] --> DIN5 }- A. M; q6 r& C9 i
mcasp->regs->SRCTL0 = 0x000E; // MCASP1.AXR1[0] <-- DOUT
' m/ |& {4 h: D# Q0 [ mcasp->regs->PFUNC = 0; // All MCASPs( ^$ _( W/ O$ e/ u, }% Y! M; O- f
mcasp->regs->PDIR = 0x14000020; // All inputs except AXR0[5], ACLKX1, AFSX1/ G, S: J3 c! R
9 ]& t0 f J. ~8 q- `
mcasp->regs->DITCTL = 0x00000000; // Not used% ~& u8 d. D! N; v7 X% l: [' w
mcasp->regs->DLBCTL = 0x00000000; // Not used8 |, ^4 F, t$ ~. }: T: a9 P
mcasp->regs->AMUTE = 0x00000000; // Not used: N2 B- R; T% Z* I
1 {6 e! N+ L0 b T/ \
/* Starting sections of the McASP*/) T) b7 X0 D' z$ c
mcasp->regs->XGBLCTL |= GBLCTL_XHCLKRST_ON;
) `2 I5 A ~5 t* ? while ( ( mcasp->regs->XGBLCTL & GBLCTL_XHCLKRST_ON ) != GBLCTL_XHCLKRST_ON );
; P6 q" F( r: e* C4 r mcasp->regs->RGBLCTL |= GBLCTL_RHCLKRST_ON;
8 r9 _8 @/ M3 V1 u9 g3 u while ( ( mcasp->regs->RGBLCTL & GBLCTL_RHCLKRST_ON ) != GBLCTL_RHCLKRST_ON );! m$ K2 l" B( G$ Y0 G' m
, }1 Q- u& I+ W mcasp->regs->XGBLCTL |= GBLCTL_XCLKRST_ON; / @ u3 n) z, O$ `
while ( ( mcasp->regs->XGBLCTL & GBLCTL_XCLKRST_ON ) != GBLCTL_XCLKRST_ON );
, y! Z! X3 u& X) I mcasp->regs->RGBLCTL |= GBLCTL_RCLKRST_ON;
8 L% R u4 A, ^9 u while ( ( mcasp->regs->RGBLCTL & GBLCTL_RCLKRST_ON ) != GBLCTL_RCLKRST_ON );
! p+ f$ f1 r, {$ g! p/ C# Y6 f8 K" ^ Z* G6 [/ V" r
mcasp->regs->XSTAT = 0x0000ffff; 0 P/ s6 @; b3 M7 {. a. a+ K$ W
mcasp->regs->RSTAT = 0x0000ffff;
, P# i( Y* s# \* A8 o
. [( {( ~0 ?: W* `9 G4 B- u mcasp->regs->XGBLCTL |= GBLCTL_XSRCLR_ON;$ f& D5 o) e! H: {3 L
while ( ( mcasp->regs->XGBLCTL & GBLCTL_XSRCLR_ON ) != GBLCTL_XSRCLR_ON );
/ B \/ B3 G' m6 j mcasp->regs->RGBLCTL |= GBLCTL_RSRCLR_ON;
8 u/ H- S4 d4 J# a3 h1 {/ F6 f while ( ( mcasp->regs->RGBLCTL & GBLCTL_RSRCLR_ON ) != GBLCTL_RSRCLR_ON );, ]9 T0 ?" m; ?6 Z; i
7 d: d; o* A- |0 O. W9 h
/* Write a 0, so that no underrun occurs after releasing the state machine */) n& u- `7 \% G; {9 o
mcasp->regs->XBUF5 = 0;5 c" V* G% t& Q d p5 a" p
mcasp->regs->RBUF0 = 0;
4 d6 D% `7 ^1 y* H0 c( s. Z& T- p R% V# F) y
mcasp->regs->XGBLCTL |= GBLCTL_XSMRST_ON; ' W/ }6 o0 W2 I5 h
while ( ( mcasp->regs->XGBLCTL & GBLCTL_XSMRST_ON ) != GBLCTL_XSMRST_ON );
4 q4 _0 B9 @, N9 }+ w mcasp->regs->RGBLCTL |= GBLCTL_RSMRST_ON;
% Q: w$ d4 B" B1 u9 R6 w while ( ( mcasp->regs->RGBLCTL & GBLCTL_RSMRST_ON ) != GBLCTL_RSMRST_ON );! n$ j, W" b2 U3 t! Q( Q
5 Y* Q9 Q3 v; _8 I- ]6 z* y* E* Z mcasp->regs->XGBLCTL |= GBLCTL_XFRST_ON;
: j2 d$ m! g; w; V0 K* J while ( ( mcasp->regs->XGBLCTL & GBLCTL_XFRST_ON ) != GBLCTL_XFRST_ON );# I2 C3 |, j& }, P6 `# A
mcasp->regs->RGBLCTL |= GBLCTL_RFRST_ON;
( ?( S9 X/ B x while ( ( mcasp->regs->RGBLCTL & GBLCTL_RFRST_ON ) != GBLCTL_RFRST_ON );
% z; n7 ~3 h$ S9 g' @5 @
3 d- {( e0 i, j CSR = 0x0000;( n% L8 x& C! X- g- E" B
INTC_INTMUX1 = 0x3d;
( B6 f, I/ ^. X: H( A! F* y ISTP = (unsigned int)vectors;+ A, q% Q( P! [; f# `. q$ b) b
ICR = 0xFFF0; : k+ r9 m, Q# _+ r. l
IER |= 0x12;
3 g8 ~6 n$ g, q$ x6 v; y6 l CSR |= 0x01;
) D% J0 Y2 R! P8 ~1 D8 O5 P3 R
% P8 i- x! t! V7 J# \* \1 U
8 N W; a! ^. i. ^2 b% |0 n
: L5 L, G/ c) P, K _还有就是两个输入输出函数:5 {! o4 p9 H8 G$ r2 q, l" z
void output_sample(Int32 out_data)! D0 M2 w+ z! I9 x$ i- |
{1 E( b O# M1 W* l1 G7 J
AIC31_data.uint = out_data; 3 {0 x4 k. B9 M4 P8 {( s
MCASP1_XBUF5_32BIT = AIC31_data.uint;
m K# u' ~3 j3 v6 d& y}! a* [% F) @5 m& q% F0 f
+ h' i# M8 B9 T% cInt32 input_sample(void)! U: l. G3 Q/ W4 Q5 o/ J1 ]8 z" U
{
1 H9 ?( [: \" A* P AIC31_data.uint = MCASP1_RBUF0_32BIT;* q6 x) O1 O' M: w& N* O+ a
return (AIC31_data.uint);
; G K9 N) N2 B7 h; Q}
0 [- S) J9 m! g! s/ E" M6 }1 O; D5 J* U j: ~7 a
|
|