|
|
C6747和C6748感觉差不多,我想实现McASP发送中断方式控制音频信号,在轮询的例程基础上改的,轮询程序可以实现,但是中断一直实现不了,也找不到错误,求大神帮忙!下边是主要程序:' i. p* ^, c2 ]4 o# }7 ^
main文件:$ t1 ?: P' @0 Z+ g, t7 W; X
interrupt void interrupt4(void) P" q' C4 O! z, u7 L
{3 k0 q' O9 j/ u# b* E6 m0 Q
Uint32 sample;
* V$ i* F5 \7 U2 [
$ D% V; M7 _; n" q i sample = input_sample(); // read L + R samples from ADC9 h0 U; L; F0 s5 J1 v
output_sample(sample); // write L + R samples to DAC / r o }8 E/ W$ `
return;
, e2 i+ o# L- b}0 b6 ~# A2 h# U8 y
2 b$ s1 I, ?, C& C, ?
int main( void )
0 h7 v |+ U6 g( j) x{, V# g, S6 y* ?0 Q$ }4 I
4 L1 F* }6 Z5 {- P. v3 d /* Initialize BSL */! _1 c" A/ \$ u1 F6 I' k
EVMC6747_init( );" R' h/ J% R# C7 j/ U, g& N, I
/* Call evmc6747_intr function */
( ~% A8 O) Z. L) h: L aic3106_init( );3 S1 v+ a1 r' N* g
while(1);
* ?# L4 s$ S* J$ P7 R2 ]0 a}) \' F# v; h, a U
7 t. t6 n. h' u& l1 M( A' n
) m y& { K* l" baic3106_init文件的一部分,McASP配置部分,采用内部时钟,I2S方式,同步传输。音频芯片的配置应该没问题! U& u6 t' [$ O4 S1 w) a/ J: E
/* Initialize MCASP1 */
5 p, s$ I& ^8 a, S8 I0 y# P mcasp = &MCASP_MODULE_1;
& B6 X! e* c. z- p mcasp->regs->GBLCTL = 0; // Reset* P3 y0 E4 z3 ?2 ~, [4 S ^; o' k
mcasp->regs->RGBLCTL = 0; // Reset RX" R$ w! P& o4 m$ S# }
mcasp->regs->XGBLCTL = 0; // Reset TX
: F: D7 I+ C# V; @* ^! H* E mcasp->regs->PWRDEMU = 1; // Free-running$ I+ l) h" }1 e t
// configure McASP0 receive registers
2 A+ d8 x: n5 O" ?" F! W0 W/ g mcasp->regs->RMASK = 0xFFFFFFFF; // No padding used" [8 ]0 S1 T3 U$ G9 [- Z
mcasp->regs->RFMT = 0x00018078; // MSB 16bit, 0-delay, no pad, CFGBus( t" F6 z( q# x
mcasp->regs->AFSRCTL = 0x00000112; // 2TDM, 1bit Falling, External FS, word
: a* P( ?8 Q7 r( m% h mcasp->regs->ACLKRCTL = 0x000000AF; // Rising INTERNAL CLK,(from tx side)7 e# f" h, q# U$ l8 r7 Y6 C& ^
mcasp->regs->AHCLKRCTL = 0x00000000; // INT CLK (from tx side)' s/ x. P7 O$ Y) s x) h
mcasp->regs->RTDM = 0x00000003; // Slots 0,1
+ c# c' ?: v- j( a1 ~# S mcasp->regs->RINTCTL = 0x00000000; // Not used
* O# Z I2 A0 q9 x mcasp->regs->RCLKCHK = 0x00FF0008; // 255-MAX 0-MIN, div-by-256
5 ~# B* Q5 X- d& [$ l& ]' y$ y1 v) z$ S2 T
mcasp->regs->XMASK = 0xFFFFFFFF; // No padding used
* n, u u1 Z/ Y mcasp->regs->XFMT = 0x00018078; // MSB 16bit, 0-delay, no pad, CFGBus1 G/ D+ q# p" Q2 C F5 f8 N) P4 U
mcasp->regs->AFSXCTL = 0x00000112; // 2TDM, 1bit Rising edge INTERNAL FS, word- i* \0 Q7 ^& J5 \- t: I) h! w; i
mcasp->regs->ACLKXCTL = 0x000000AF; // ASYNC, Rising INTERNAL CLK, div-by-16# e$ N( W. }: q4 P: z6 W1 G
mcasp->regs->AHCLKXCTL = 0x00000000; // EXT CLK
! R$ q1 _8 E0 C+ o mcasp->regs->XTDM = 0x00000003; // Slots 0,1
6 H8 |1 c* _5 n% u4 d6 I$ ] mcasp->regs->XINTCTL = 0x00000020; // interrupt on transmit- {. T/ _* B. W# e- V: F' f4 C
mcasp->regs->XCLKCHK = 0x00FF0008; // 255-MAX 0-MIN, div-by-256" b4 J" A3 T; \2 R! a
! j/ o: V- u. F. P8 t1 Y" I# X mcasp->regs->SRCTL5 = 0x000D; // MCASP1.AXR1[5] --> DIN
2 y$ n: E8 d: u$ U" j* }$ _2 T mcasp->regs->SRCTL0 = 0x000E; // MCASP1.AXR1[0] <-- DOUT3 G/ X, N3 {$ M) ?) a* E
mcasp->regs->PFUNC = 0; // All MCASPs
1 y+ e# l8 x5 ?" J mcasp->regs->PDIR = 0x14000020; // All inputs except AXR0[5], ACLKX1, AFSX1
$ H3 K! L( E$ z) @1 i6 |9 e( M& a' m4 V0 p1 R5 _! x3 S$ x- t! ~
mcasp->regs->DITCTL = 0x00000000; // Not used U9 j3 U3 C4 Q# X* {& p
mcasp->regs->DLBCTL = 0x00000000; // Not used# U" F; R5 M" ]! J# ~& E9 t
mcasp->regs->AMUTE = 0x00000000; // Not used
. R' ~" d+ C) B; ^
3 n1 T+ W4 P' Z, _& D) y/* Starting sections of the McASP*/) ~. u6 h Q/ j, p$ C8 j
mcasp->regs->XGBLCTL |= GBLCTL_XHCLKRST_ON;
. _' [0 A3 H4 P6 G3 b) T# ^- Y while ( ( mcasp->regs->XGBLCTL & GBLCTL_XHCLKRST_ON ) != GBLCTL_XHCLKRST_ON );
2 }+ |1 `% ^( ^ mcasp->regs->RGBLCTL |= GBLCTL_RHCLKRST_ON; : r2 V2 o: i w0 ]" c8 N$ L
while ( ( mcasp->regs->RGBLCTL & GBLCTL_RHCLKRST_ON ) != GBLCTL_RHCLKRST_ON );
7 S- H6 @4 }& |, n0 V$ c, J7 |$ k: c" Z2 Y6 c
mcasp->regs->XGBLCTL |= GBLCTL_XCLKRST_ON; ' k& F( a3 \4 O5 z
while ( ( mcasp->regs->XGBLCTL & GBLCTL_XCLKRST_ON ) != GBLCTL_XCLKRST_ON );/ y7 S/ ~/ A: T0 c: D- h
mcasp->regs->RGBLCTL |= GBLCTL_RCLKRST_ON;
( C" y+ B* m# r+ Q$ N, t5 H4 R9 Y6 M! [ while ( ( mcasp->regs->RGBLCTL & GBLCTL_RCLKRST_ON ) != GBLCTL_RCLKRST_ON );# l+ O9 Q4 c3 O$ f" W t
( V- n* F+ n9 \) l
mcasp->regs->XSTAT = 0x0000ffff;
6 @& N k3 U+ C6 a8 q mcasp->regs->RSTAT = 0x0000ffff; % f) V8 l" r- U0 K4 C
/ c4 \6 @9 }$ j$ M' ]0 c
mcasp->regs->XGBLCTL |= GBLCTL_XSRCLR_ON;7 \7 }) n$ v: R4 y) O/ R1 Y
while ( ( mcasp->regs->XGBLCTL & GBLCTL_XSRCLR_ON ) != GBLCTL_XSRCLR_ON );
/ F4 K) i0 v7 C& H* x- a mcasp->regs->RGBLCTL |= GBLCTL_RSRCLR_ON;
0 n s$ j$ y0 g9 T9 V1 w while ( ( mcasp->regs->RGBLCTL & GBLCTL_RSRCLR_ON ) != GBLCTL_RSRCLR_ON );) L M. i0 Y% ]
" |4 g0 L! G9 V) e2 B$ }* W
/* Write a 0, so that no underrun occurs after releasing the state machine */
+ p# O: h7 F( P7 a mcasp->regs->XBUF5 = 0;
+ E2 o1 x [* f2 b mcasp->regs->RBUF0 = 0;5 U" ^+ G3 Y: j1 ]
) C. s0 x3 M: I. D3 x9 G& n- P+ s
mcasp->regs->XGBLCTL |= GBLCTL_XSMRST_ON;
/ n- [ a; |. ~3 U( C while ( ( mcasp->regs->XGBLCTL & GBLCTL_XSMRST_ON ) != GBLCTL_XSMRST_ON );
4 k( _$ D. N% f* {" Q1 b0 L mcasp->regs->RGBLCTL |= GBLCTL_RSMRST_ON;
7 e9 {& A0 W4 @0 b3 x4 `1 a6 `$ F while ( ( mcasp->regs->RGBLCTL & GBLCTL_RSMRST_ON ) != GBLCTL_RSMRST_ON );
3 O! q' D6 h5 f+ g1 k7 D/ D( y" M: f
mcasp->regs->XGBLCTL |= GBLCTL_XFRST_ON; 4 Q+ m" T% z3 I+ h4 H+ U
while ( ( mcasp->regs->XGBLCTL & GBLCTL_XFRST_ON ) != GBLCTL_XFRST_ON );% V6 v% q$ @& F) g2 ?/ d* j! q4 ?
mcasp->regs->RGBLCTL |= GBLCTL_RFRST_ON;
% j, I: x: q. A* {' \ while ( ( mcasp->regs->RGBLCTL & GBLCTL_RFRST_ON ) != GBLCTL_RFRST_ON );' x7 M# m; j, `. o& w \
5 D8 w7 y0 ?: B: C
CSR = 0x0000;
. r8 @. H* `3 o. R; ^+ f INTC_INTMUX1 = 0x3d;
: x9 c" R; m1 d3 E# J ISTP = (unsigned int)vectors;
( R& m$ S/ e2 h. ] q6 N/ [# Y; T ICR = 0xFFF0;
+ g Z! Z' F) n$ d IER |= 0x12;
7 {$ j4 D1 X9 r' i CSR |= 0x01; $ y+ f4 u+ T7 D6 e5 u- P: _& P/ R% K
1 G* m3 T5 N7 i% x& T! }* @# D
! i4 ~; H/ S) Z$ [. U- K( _3 ]3 ^0 P! Z" F+ }
还有就是两个输入输出函数:4 s. e5 K/ K) s2 Z W* x
void output_sample(Int32 out_data)4 v3 F9 [6 u0 I2 O8 A( j5 P
{
+ t5 o; i" M$ R) w. K AIC31_data.uint = out_data; 7 w7 J( c; [/ ~7 T q( E/ Q
MCASP1_XBUF5_32BIT = AIC31_data.uint;' I+ W; N0 s- A1 K( S7 y8 O
}
7 { _, N$ _, H
! Q8 S& i2 f, K4 Z: v. }, rInt32 input_sample(void)
9 X' z3 r; c: x9 ]* n0 r1 v, i! P{
d3 V' Q5 V- V5 G& X" ~4 a AIC31_data.uint = MCASP1_RBUF0_32BIT;
8 M5 K! D/ @8 Y5 n. @ return (AIC31_data.uint);, v0 F: z. f: M3 b/ R9 Y! O* f
}
& J# T2 D1 i# V. b
! X/ g) j6 P2 u6 K3 W2 E |
|