|
|
C6747和C6748感觉差不多,我想实现McASP发送中断方式控制音频信号,在轮询的例程基础上改的,轮询程序可以实现,但是中断一直实现不了,也找不到错误,求大神帮忙!下边是主要程序:+ u+ c8 E$ z; u& x8 y0 b+ |
main文件:! s' s4 @7 w# }# E3 P
interrupt void interrupt4(void) - {! }- Q* L8 F- n$ A3 f! X9 M4 F1 P, `
{1 `. C. ~8 J3 l' \0 a. }
Uint32 sample;6 g' j7 o. R/ b) g7 ~/ [- `. ]/ S9 S
. y3 O6 P3 j; m1 @0 |
sample = input_sample(); // read L + R samples from ADC
( @: d; \1 k$ [: g G) C- } output_sample(sample); // write L + R samples to DAC : ?% s/ y9 u( Q1 q1 @
return;
& H3 m, z5 E2 {}
0 w% O' w0 E% a
' B5 u# F$ q& i+ n( rint main( void )
# Q+ Q$ P: [6 D7 j# z |. ^& g; M{, j! q# M' F$ p" O6 {- B( b
- y9 S f! C" G# s+ w8 c8 n! x5 p /* Initialize BSL */
7 f/ s2 t; x+ B7 [/ z5 |6 N EVMC6747_init( ); |9 L c/ A8 d0 A; V3 ^2 O& \& \
/* Call evmc6747_intr function */
0 |8 u& K7 h$ v9 w, G9 h aic3106_init( );
4 w( b+ I' [" l- o6 N while(1);* J( H( s" s6 e
}
/ V; ?( F4 Z; j( T1 [6 {2 v) O0 |4 ?5 T) |5 W- I$ v9 N9 g+ V; h
* b. [+ u/ Q- _2 D5 i4 G
aic3106_init文件的一部分,McASP配置部分,采用内部时钟,I2S方式,同步传输。音频芯片的配置应该没问题4 H1 S2 {2 S# X5 G; |9 F
/* Initialize MCASP1 */
! h g2 G, E) ~ mcasp = &MCASP_MODULE_1;! O) q! Q6 R8 I$ L7 _0 B$ _8 N* P" z
mcasp->regs->GBLCTL = 0; // Reset6 ~# `4 U/ i0 w
mcasp->regs->RGBLCTL = 0; // Reset RX3 d( W; _3 l* O' S5 }
mcasp->regs->XGBLCTL = 0; // Reset TX
% K- l2 e( R; R4 v0 _- S7 p5 Q mcasp->regs->PWRDEMU = 1; // Free-running9 d3 P4 u/ Z8 |- q' v
// configure McASP0 receive registers
6 [, `9 w5 l) P- a, d/ D mcasp->regs->RMASK = 0xFFFFFFFF; // No padding used! P6 A5 R+ T. c
mcasp->regs->RFMT = 0x00018078; // MSB 16bit, 0-delay, no pad, CFGBus# \8 d' g0 W2 Y S& ?
mcasp->regs->AFSRCTL = 0x00000112; // 2TDM, 1bit Falling, External FS, word
8 B9 D( K( e1 g# w mcasp->regs->ACLKRCTL = 0x000000AF; // Rising INTERNAL CLK,(from tx side), g4 d: p1 {* l6 M7 x5 D' M- N1 y2 B
mcasp->regs->AHCLKRCTL = 0x00000000; // INT CLK (from tx side)0 V; b1 p' Z/ h$ |' H/ j
mcasp->regs->RTDM = 0x00000003; // Slots 0,1' r- ^! o5 i5 X. h6 b* k$ e6 n
mcasp->regs->RINTCTL = 0x00000000; // Not used" q5 {, z V' F2 X9 o
mcasp->regs->RCLKCHK = 0x00FF0008; // 255-MAX 0-MIN, div-by-256
: g* T% g5 j2 d$ R3 Z3 M A* e W% Y! ^& a7 R2 R; _! v& s+ ]0 W" }
mcasp->regs->XMASK = 0xFFFFFFFF; // No padding used
5 H+ \9 G* x5 J" Y( a& { J# W mcasp->regs->XFMT = 0x00018078; // MSB 16bit, 0-delay, no pad, CFGBus
k5 i$ Z: i5 e0 u; ^ mcasp->regs->AFSXCTL = 0x00000112; // 2TDM, 1bit Rising edge INTERNAL FS, word0 P% f, T6 G& p$ Q- m
mcasp->regs->ACLKXCTL = 0x000000AF; // ASYNC, Rising INTERNAL CLK, div-by-165 j5 [2 C; T6 N( S8 I
mcasp->regs->AHCLKXCTL = 0x00000000; // EXT CLK `% V0 C, K% s) r
mcasp->regs->XTDM = 0x00000003; // Slots 0,1+ d6 Q- ], Y6 d
mcasp->regs->XINTCTL = 0x00000020; // interrupt on transmit
5 r5 R# T# z) h# v mcasp->regs->XCLKCHK = 0x00FF0008; // 255-MAX 0-MIN, div-by-2562 W4 B4 L9 u1 P# T0 S8 U7 C3 W7 F
# M, t7 y& H& v9 u# a
mcasp->regs->SRCTL5 = 0x000D; // MCASP1.AXR1[5] --> DIN. M1 n) W3 Z7 P) h P5 @1 h
mcasp->regs->SRCTL0 = 0x000E; // MCASP1.AXR1[0] <-- DOUT. V, `- R: X+ V- z+ x
mcasp->regs->PFUNC = 0; // All MCASPs0 D. L f$ M j0 K; F
mcasp->regs->PDIR = 0x14000020; // All inputs except AXR0[5], ACLKX1, AFSX1- ~" D' M5 k+ J! ~0 c3 C
/ M- q" y- v! b; F" m. O mcasp->regs->DITCTL = 0x00000000; // Not used
; i1 l) t" S8 @/ `0 k- `6 n" h mcasp->regs->DLBCTL = 0x00000000; // Not used) G* q5 F* ~& l! r& ?0 r& a/ ^; P
mcasp->regs->AMUTE = 0x00000000; // Not used0 x5 i/ O$ Q) e4 k) }& F
* B' k2 g2 R- z* D2 D7 F- h/* Starting sections of the McASP*/
1 ?3 e# Z% \: `2 ~, |5 q mcasp->regs->XGBLCTL |= GBLCTL_XHCLKRST_ON; - z y6 }. v2 R
while ( ( mcasp->regs->XGBLCTL & GBLCTL_XHCLKRST_ON ) != GBLCTL_XHCLKRST_ON ); k& E3 j0 z1 W4 h4 f! N; l
mcasp->regs->RGBLCTL |= GBLCTL_RHCLKRST_ON;
: e" C# a" L5 W7 J; u while ( ( mcasp->regs->RGBLCTL & GBLCTL_RHCLKRST_ON ) != GBLCTL_RHCLKRST_ON );
/ h: z2 f1 L% }7 U1 U' Y$ u5 Z2 L, X9 O3 ^
mcasp->regs->XGBLCTL |= GBLCTL_XCLKRST_ON;
, i+ X b5 J! {; A9 N; h while ( ( mcasp->regs->XGBLCTL & GBLCTL_XCLKRST_ON ) != GBLCTL_XCLKRST_ON );) z4 t( K, Q- @) B( C) ~" S
mcasp->regs->RGBLCTL |= GBLCTL_RCLKRST_ON;
6 K4 T- u) w" o* X/ r7 S% M while ( ( mcasp->regs->RGBLCTL & GBLCTL_RCLKRST_ON ) != GBLCTL_RCLKRST_ON );& j9 Q) U" r5 [" u& l' m1 O& }
" m* f& c& M9 M" O' ~+ T4 N/ ^
mcasp->regs->XSTAT = 0x0000ffff; 0 J0 y5 J. H5 b4 G+ }
mcasp->regs->RSTAT = 0x0000ffff; Q: O& H+ G9 S9 l. B5 y# p7 ?7 t8 n
3 F# O, q& ~4 x mcasp->regs->XGBLCTL |= GBLCTL_XSRCLR_ON;9 l# a0 e. p$ ]) v. D
while ( ( mcasp->regs->XGBLCTL & GBLCTL_XSRCLR_ON ) != GBLCTL_XSRCLR_ON );
d$ e& U. g2 Z0 z4 z& M mcasp->regs->RGBLCTL |= GBLCTL_RSRCLR_ON; + J1 I- {/ l# L, Y; t* p
while ( ( mcasp->regs->RGBLCTL & GBLCTL_RSRCLR_ON ) != GBLCTL_RSRCLR_ON );! n' l+ \- Y9 m8 E v2 O( e3 [
7 J* @% e, X% S. x. W: i
/* Write a 0, so that no underrun occurs after releasing the state machine */7 M @' ?1 q7 n) M% c1 L; r
mcasp->regs->XBUF5 = 0;
C, [0 c( s( e. V) d; [! a i! y mcasp->regs->RBUF0 = 0;
6 J6 ^/ u# F8 z8 J# K O6 M3 F+ A+ x3 E8 D3 O0 W
mcasp->regs->XGBLCTL |= GBLCTL_XSMRST_ON;
; N8 o, H3 [5 ~: w4 F while ( ( mcasp->regs->XGBLCTL & GBLCTL_XSMRST_ON ) != GBLCTL_XSMRST_ON );
# d; X1 Z0 ?2 G* x4 j mcasp->regs->RGBLCTL |= GBLCTL_RSMRST_ON;
}* y+ A. N! L9 Q; \% o+ n while ( ( mcasp->regs->RGBLCTL & GBLCTL_RSMRST_ON ) != GBLCTL_RSMRST_ON );0 O& O5 v' ?% O2 n) d: Z# v7 h
7 @* X" h. J- G0 Q mcasp->regs->XGBLCTL |= GBLCTL_XFRST_ON;
$ ^% d/ J. |9 M N# O; s5 W while ( ( mcasp->regs->XGBLCTL & GBLCTL_XFRST_ON ) != GBLCTL_XFRST_ON );4 H h. T9 |8 X
mcasp->regs->RGBLCTL |= GBLCTL_RFRST_ON;
$ }% Z# ?% c: Y4 `( d while ( ( mcasp->regs->RGBLCTL & GBLCTL_RFRST_ON ) != GBLCTL_RFRST_ON );
" h* x1 s& o; N; p; R( K3 O* z/ w! y
CSR = 0x0000;$ G4 A& i$ t# R1 j4 m
INTC_INTMUX1 = 0x3d;
/ f# ^. Q6 T6 u/ J7 X% n ISTP = (unsigned int)vectors;
) n8 ?, @1 C8 I/ P0 j ICR = 0xFFF0;
- t4 z# J( v j6 {: ^6 S IER |= 0x12;
8 X# n' a$ }& D6 j: Q: C* t/ C CSR |= 0x01; & V7 b6 K! U; ?! b- s2 W9 @" V
" d2 m+ R! @! M5 B; s
: c, g: D2 {0 |- D
" E* v2 x. d% T还有就是两个输入输出函数:, a% M: L! z1 q/ ]( _9 L* F
void output_sample(Int32 out_data)
% Q; l" ]6 T* a. |3 t5 g& {{
" h Y" D* g2 _ AIC31_data.uint = out_data;
' Y- j( l0 ]5 _0 i4 w8 }! s/ g' j MCASP1_XBUF5_32BIT = AIC31_data.uint;
: g3 B' I" C8 d/ q( m3 y}
2 @4 _ i7 v$ u) ~* H' {6 N9 c6 F! R' Q: V# _$ T+ @' N
Int32 input_sample(void)
, I: v7 f. `8 o! v7 B, j9 {* S2 s- ~4 {{
9 S2 ?& D7 c s( W9 V0 \- ^6 x. T AIC31_data.uint = MCASP1_RBUF0_32BIT;
* f# r6 J6 O( ~5 L- j n return (AIC31_data.uint);4 g" s; c' U7 t
}. ]% x! q$ l2 m
) |4 e; F1 d0 J/ p/ D& Q0 u
|
|