|
|
C6747和C6748感觉差不多,我想实现McASP发送中断方式控制音频信号,在轮询的例程基础上改的,轮询程序可以实现,但是中断一直实现不了,也找不到错误,求大神帮忙!下边是主要程序:! o7 R# Z) g/ k& G
main文件:+ G2 W' I, b' u7 g
interrupt void interrupt4(void)
$ V; b* F( e+ T9 f{
) ~1 A' l+ C! C) F# T3 h8 s Uint32 sample;
( j8 \( B8 q/ J" U+ `8 A6 d6 ?7 e. W9 M, ~7 `. p
sample = input_sample(); // read L + R samples from ADC
9 P+ d* K5 z I6 L4 q0 K% l output_sample(sample); // write L + R samples to DAC 2 S' O0 t4 v. d& k& L7 t5 x
return;
4 I' K6 L' H: \; d3 |3 C! z}/ g" C7 m4 p- i7 I. C/ O
6 N5 N4 v6 b7 q0 c( n
int main( void )6 Y! O& r( q8 t. B
{
( t0 a8 F6 F6 F- a( M% V* n
: D% `3 X( \; u2 G /* Initialize BSL */! G2 X: p2 ~8 P
EVMC6747_init( );! L7 C& P+ O7 n6 o
/* Call evmc6747_intr function */, v" j" a @6 Z# g$ ]
aic3106_init( );
( F# T( m+ U( J/ m/ n while(1);# @! ~( l2 _% A# {- ^+ Z, Q
}
; K+ J m, u3 E
8 l2 }9 }6 _/ e& ?- R3 f0 y
" w" P5 H$ K+ ~' c$ E( zaic3106_init文件的一部分,McASP配置部分,采用内部时钟,I2S方式,同步传输。音频芯片的配置应该没问题
, J+ x6 Y& U" s5 }/ f! Z/* Initialize MCASP1 */* a7 T8 e& l$ I, |! d, i+ a
mcasp = &MCASP_MODULE_1;( `6 N& I. k; J' y- X" ~
mcasp->regs->GBLCTL = 0; // Reset3 m4 \, f/ B3 @, [
mcasp->regs->RGBLCTL = 0; // Reset RX: O" \7 w# C1 ?: ~! X2 J& O/ |
mcasp->regs->XGBLCTL = 0; // Reset TX9 H& b9 s, a2 {' E$ ^0 X$ }- F
mcasp->regs->PWRDEMU = 1; // Free-running
6 `) u. O) ~+ j5 t# R // configure McASP0 receive registers6 K- o& [% }1 F$ d, c
mcasp->regs->RMASK = 0xFFFFFFFF; // No padding used9 x2 r- O: C! Z2 ^% U* n; |
mcasp->regs->RFMT = 0x00018078; // MSB 16bit, 0-delay, no pad, CFGBus
: T; D% L" P# _& Z) Q mcasp->regs->AFSRCTL = 0x00000112; // 2TDM, 1bit Falling, External FS, word
* ^. o* _# `6 X8 F: B% L mcasp->regs->ACLKRCTL = 0x000000AF; // Rising INTERNAL CLK,(from tx side)/ H. A5 r# x! |3 {
mcasp->regs->AHCLKRCTL = 0x00000000; // INT CLK (from tx side)
% M4 x% D5 C0 z1 g4 Y mcasp->regs->RTDM = 0x00000003; // Slots 0,11 ] i: ?6 P5 N" b9 ~
mcasp->regs->RINTCTL = 0x00000000; // Not used3 w# T2 }) t6 E( c& v
mcasp->regs->RCLKCHK = 0x00FF0008; // 255-MAX 0-MIN, div-by-256; z1 C6 E! [- g0 Z% M* E7 w
X/ H1 B1 S* r8 j" k+ q/ S- K mcasp->regs->XMASK = 0xFFFFFFFF; // No padding used9 |- q) I2 l& o* t4 x& @
mcasp->regs->XFMT = 0x00018078; // MSB 16bit, 0-delay, no pad, CFGBus3 P, p& K3 x0 V0 @/ k* c2 j& s
mcasp->regs->AFSXCTL = 0x00000112; // 2TDM, 1bit Rising edge INTERNAL FS, word
' P- ?- h* Z$ n# ^. s mcasp->regs->ACLKXCTL = 0x000000AF; // ASYNC, Rising INTERNAL CLK, div-by-16" E0 u' P5 T# x# Q# T: N2 x/ b
mcasp->regs->AHCLKXCTL = 0x00000000; // EXT CLK# w& e/ O5 y7 ^3 K" B+ }; ~
mcasp->regs->XTDM = 0x00000003; // Slots 0,11 N: P* L' X1 _5 l
mcasp->regs->XINTCTL = 0x00000020; // interrupt on transmit, g4 T# } i p
mcasp->regs->XCLKCHK = 0x00FF0008; // 255-MAX 0-MIN, div-by-2566 t3 r1 A8 ?% e" B
\4 E! k8 K r' u7 z7 j1 L( V G
mcasp->regs->SRCTL5 = 0x000D; // MCASP1.AXR1[5] --> DIN2 h# `; x: `4 I
mcasp->regs->SRCTL0 = 0x000E; // MCASP1.AXR1[0] <-- DOUT: W8 A; Z# l1 f# h. d) A& m% S
mcasp->regs->PFUNC = 0; // All MCASPs
5 [: F: M4 C/ E' V8 ]& j/ x1 H9 k mcasp->regs->PDIR = 0x14000020; // All inputs except AXR0[5], ACLKX1, AFSX19 f, R) |& p4 Q
: y! M; F1 \/ I: z9 ] mcasp->regs->DITCTL = 0x00000000; // Not used
5 h. K4 M L% f( @# v B) _ mcasp->regs->DLBCTL = 0x00000000; // Not used
" Q7 N! F" Z% M4 N7 w mcasp->regs->AMUTE = 0x00000000; // Not used
; p; ~% _7 B& f) X. D
# t; ^* W# i+ ^8 x* H& i$ u+ I1 g/* Starting sections of the McASP*/
1 o, T) \3 N: y X1 y# } mcasp->regs->XGBLCTL |= GBLCTL_XHCLKRST_ON; / T1 ]8 M5 \( K. B; E+ d+ O
while ( ( mcasp->regs->XGBLCTL & GBLCTL_XHCLKRST_ON ) != GBLCTL_XHCLKRST_ON );
& c( j% [- E: r* t* N$ l mcasp->regs->RGBLCTL |= GBLCTL_RHCLKRST_ON;
( ~0 r; O9 }( c5 p$ u4 w while ( ( mcasp->regs->RGBLCTL & GBLCTL_RHCLKRST_ON ) != GBLCTL_RHCLKRST_ON );
) x/ R) [+ f' h& ]% p# B7 d' O' r) ~. E" D. \
mcasp->regs->XGBLCTL |= GBLCTL_XCLKRST_ON; 9 A( B0 o5 B7 L' o5 [$ c
while ( ( mcasp->regs->XGBLCTL & GBLCTL_XCLKRST_ON ) != GBLCTL_XCLKRST_ON );" O, m0 n( ^ g8 O, i5 V
mcasp->regs->RGBLCTL |= GBLCTL_RCLKRST_ON;
& f& _' {; \5 G6 i while ( ( mcasp->regs->RGBLCTL & GBLCTL_RCLKRST_ON ) != GBLCTL_RCLKRST_ON );! h, c) w! q' S. W
( y9 J" D* i' ^9 ]% {- Z mcasp->regs->XSTAT = 0x0000ffff;
* j$ X+ l/ w7 m* m mcasp->regs->RSTAT = 0x0000ffff;
8 G* v+ V3 i* R1 j3 Z
( q9 y8 v1 Y; Y9 W8 v. [: w+ D mcasp->regs->XGBLCTL |= GBLCTL_XSRCLR_ON;
- t8 x7 |/ E6 L6 Y3 U while ( ( mcasp->regs->XGBLCTL & GBLCTL_XSRCLR_ON ) != GBLCTL_XSRCLR_ON );
3 \, C$ m8 {. U/ t% Y# v mcasp->regs->RGBLCTL |= GBLCTL_RSRCLR_ON; 7 S. K0 Q, u6 v0 W: H$ q7 N' K" f
while ( ( mcasp->regs->RGBLCTL & GBLCTL_RSRCLR_ON ) != GBLCTL_RSRCLR_ON );9 r7 x& {, s- G
P0 c- A& c: w) B2 H /* Write a 0, so that no underrun occurs after releasing the state machine */
/ D2 N+ M% L D# T& L mcasp->regs->XBUF5 = 0;, f3 B8 q! e4 E: i% ~. E
mcasp->regs->RBUF0 = 0;" r1 x; p b0 V9 l G7 \3 X) }) U
$ ]0 S3 T9 u! m" d7 t6 i( p. f% O mcasp->regs->XGBLCTL |= GBLCTL_XSMRST_ON;
! ^5 }0 ^1 u( _- R0 j7 Q while ( ( mcasp->regs->XGBLCTL & GBLCTL_XSMRST_ON ) != GBLCTL_XSMRST_ON );8 E- ~/ G! G5 }, x: L7 N0 [/ p5 C1 `
mcasp->regs->RGBLCTL |= GBLCTL_RSMRST_ON;
5 M8 [" k) u* T while ( ( mcasp->regs->RGBLCTL & GBLCTL_RSMRST_ON ) != GBLCTL_RSMRST_ON );8 S6 j+ S( t1 x5 y* T6 D) g
+ i: p5 Z% @( t6 D* U$ C" M
mcasp->regs->XGBLCTL |= GBLCTL_XFRST_ON;
$ p' J7 i, k( I. A$ Z while ( ( mcasp->regs->XGBLCTL & GBLCTL_XFRST_ON ) != GBLCTL_XFRST_ON );. r. O+ ?8 p2 j* y4 |9 p+ I
mcasp->regs->RGBLCTL |= GBLCTL_RFRST_ON; * c2 Y6 K0 ?4 @$ q
while ( ( mcasp->regs->RGBLCTL & GBLCTL_RFRST_ON ) != GBLCTL_RFRST_ON );, U. Y. M0 c1 H$ g- |" Z
: e! {% {: j5 w0 `4 T CSR = 0x0000;
3 X& M0 D$ G4 Y INTC_INTMUX1 = 0x3d;
) W @. ^0 ]% V- x! | ISTP = (unsigned int)vectors;! P4 b3 ]( B" E7 n8 K) V8 R
ICR = 0xFFF0; + J/ [" }# i) A2 v
IER |= 0x12;
' S, v. B/ d+ R* d2 L. h/ B: ? J3 g CSR |= 0x01; ( d0 f8 N( P. |2 l t. O( P0 ^* d
$ _+ g7 T1 T8 R; ?: ^5 P; t) K v3 j5 c" Q5 P
, X( W1 H: m5 p) V9 D$ s L
还有就是两个输入输出函数:# A8 j% O+ g% e8 d
void output_sample(Int32 out_data)8 _& D+ A2 G* F* ?$ t5 c
{
; s+ ?, z4 g u7 I) F' ] AIC31_data.uint = out_data;
2 p8 P# }. x2 r5 z$ G' z MCASP1_XBUF5_32BIT = AIC31_data.uint;
6 N! t4 \+ W. m- D, F}: d- P' F$ M3 \- h
) q2 o& o/ k0 y g
Int32 input_sample(void)
1 e' W7 J' x# \# n! p{
$ x) v" v+ G) t AIC31_data.uint = MCASP1_RBUF0_32BIT;
% H' y9 w. z( N' K$ _; r, N return (AIC31_data.uint);
' r ~4 R V: Q) [5 x}2 p9 r9 a8 |" n% c3 V
l1 v j6 Z* ^5 Z$ b( S: p |
|