|
|
C6747和C6748感觉差不多,我想实现McASP发送中断方式控制音频信号,在轮询的例程基础上改的,轮询程序可以实现,但是中断一直实现不了,也找不到错误,求大神帮忙!下边是主要程序:- o% g6 l$ z8 e& S$ e8 Q
main文件:# _. o8 Y: P) Q1 G
interrupt void interrupt4(void)
; m- y: L: ]5 s; F{( p2 Y" d+ X9 e% p$ X- |
Uint32 sample;/ W: s- D; d2 f
, M' K' f4 R9 q- E% f( z sample = input_sample(); // read L + R samples from ADC( `. N4 m$ H/ y- y2 a# g/ i9 Q
output_sample(sample); // write L + R samples to DAC , N# x# {! c" f# F( u2 T4 c
return;6 d. K/ N A' g: r) V( Y9 {
}
% \$ x% C# }$ s) R" Q+ u. k
D7 W( S0 k# q+ l9 Sint main( void )
" f9 v4 ?- `7 ]{
4 e! E+ J8 U3 [. X+ y& k; \; j! h! K4 q9 \5 e# X
/* Initialize BSL */
6 M- {7 x }. y* @ EVMC6747_init( );3 l& U+ b4 j% a1 e }
/* Call evmc6747_intr function */
$ i: Y5 g1 O) E. B. X aic3106_init( );5 ]5 `/ Q# z- G6 [
while(1);1 t- w w0 r& J% y3 V4 x
}; { ?4 R1 O' \
' ?% l. u$ T9 B
Q3 J% j9 ]: \4 _( r2 U Zaic3106_init文件的一部分,McASP配置部分,采用内部时钟,I2S方式,同步传输。音频芯片的配置应该没问题
0 h! [. G- r4 T0 z* L7 L/* Initialize MCASP1 */) B: Z; C6 z& B! \9 @) r
mcasp = &MCASP_MODULE_1;
3 ^* W- i' z7 }8 @+ m6 c mcasp->regs->GBLCTL = 0; // Reset6 z$ z& @6 K/ j; a: Y
mcasp->regs->RGBLCTL = 0; // Reset RX1 v6 \1 F' O" m) I: A2 g7 r
mcasp->regs->XGBLCTL = 0; // Reset TX8 W% }4 x# y6 M# }- @+ K8 V
mcasp->regs->PWRDEMU = 1; // Free-running
3 m& C1 j0 ?: c6 D" L6 C2 ~ // configure McASP0 receive registers
$ [4 W0 L$ u; y0 W mcasp->regs->RMASK = 0xFFFFFFFF; // No padding used
. }' B5 ?( Q: \+ o- Y mcasp->regs->RFMT = 0x00018078; // MSB 16bit, 0-delay, no pad, CFGBus6 q" I \3 d9 G4 Q2 H' U
mcasp->regs->AFSRCTL = 0x00000112; // 2TDM, 1bit Falling, External FS, word$ m/ K8 J& q. a! T6 D
mcasp->regs->ACLKRCTL = 0x000000AF; // Rising INTERNAL CLK,(from tx side)
3 i9 ^0 w5 B1 I5 p( K, D' L mcasp->regs->AHCLKRCTL = 0x00000000; // INT CLK (from tx side)/ z; y. X" A+ j4 H$ d1 D' H7 H
mcasp->regs->RTDM = 0x00000003; // Slots 0,1
5 Z, \; k. v* m9 U5 @0 L& } mcasp->regs->RINTCTL = 0x00000000; // Not used
" K$ e) s: @6 h7 ?( x' r mcasp->regs->RCLKCHK = 0x00FF0008; // 255-MAX 0-MIN, div-by-2562 B2 y- B. Y# u) e5 v
) p& u& |5 {, y9 [: M# C
mcasp->regs->XMASK = 0xFFFFFFFF; // No padding used) ?: ^3 K. D" R' b9 n3 V/ D
mcasp->regs->XFMT = 0x00018078; // MSB 16bit, 0-delay, no pad, CFGBus7 F1 O- c) g/ f; H% p
mcasp->regs->AFSXCTL = 0x00000112; // 2TDM, 1bit Rising edge INTERNAL FS, word
; c; h0 W ~! P2 D) G- S mcasp->regs->ACLKXCTL = 0x000000AF; // ASYNC, Rising INTERNAL CLK, div-by-16- F8 a; C" l d5 w
mcasp->regs->AHCLKXCTL = 0x00000000; // EXT CLK5 c4 R; S: m2 `4 y! {- h6 ^
mcasp->regs->XTDM = 0x00000003; // Slots 0,1$ {' B7 C$ t/ ^' B
mcasp->regs->XINTCTL = 0x00000020; // interrupt on transmit3 Q8 ~) ?" I8 q `$ T9 b
mcasp->regs->XCLKCHK = 0x00FF0008; // 255-MAX 0-MIN, div-by-2561 G$ }# z7 d. Y2 g1 T( i
- Z% w' I; {, r# u
mcasp->regs->SRCTL5 = 0x000D; // MCASP1.AXR1[5] --> DIN7 [& N' k& b# e4 ~3 Z$ ^
mcasp->regs->SRCTL0 = 0x000E; // MCASP1.AXR1[0] <-- DOUT
9 D) _5 F! X8 l/ d5 n! y mcasp->regs->PFUNC = 0; // All MCASPs- m! ]! Z$ i* C
mcasp->regs->PDIR = 0x14000020; // All inputs except AXR0[5], ACLKX1, AFSX1$ ?3 s% h4 Y& U
6 [7 T! [4 z; g, r, V: h$ v" h mcasp->regs->DITCTL = 0x00000000; // Not used* v: N9 d. P: ^3 b. C2 m: \
mcasp->regs->DLBCTL = 0x00000000; // Not used
2 e! {/ Z# C0 z3 s2 E! ~ mcasp->regs->AMUTE = 0x00000000; // Not used
* ^, \; s; J1 ^. z' i/ y( y) p6 l
4 j; H! q. {2 V- A0 @/* Starting sections of the McASP*/
) f% I2 f V& G; }+ _* v mcasp->regs->XGBLCTL |= GBLCTL_XHCLKRST_ON;
* c+ r0 Y6 j L2 A+ N$ [ while ( ( mcasp->regs->XGBLCTL & GBLCTL_XHCLKRST_ON ) != GBLCTL_XHCLKRST_ON ); ( H- H+ p9 ^3 S1 Y. {7 f: G
mcasp->regs->RGBLCTL |= GBLCTL_RHCLKRST_ON; . u4 H) o$ C# ?; [% L0 }
while ( ( mcasp->regs->RGBLCTL & GBLCTL_RHCLKRST_ON ) != GBLCTL_RHCLKRST_ON );
. O( ^4 e0 h3 b, }! F$ _. O) f B" l9 ]1 d+ y& u# r2 L! R
mcasp->regs->XGBLCTL |= GBLCTL_XCLKRST_ON;
; E& ^7 {! {0 w5 }, T while ( ( mcasp->regs->XGBLCTL & GBLCTL_XCLKRST_ON ) != GBLCTL_XCLKRST_ON );
+ c0 I* u6 q% {! o* u2 b/ ] mcasp->regs->RGBLCTL |= GBLCTL_RCLKRST_ON; 5 V0 e9 r, \- U" K8 B
while ( ( mcasp->regs->RGBLCTL & GBLCTL_RCLKRST_ON ) != GBLCTL_RCLKRST_ON );9 \* \7 v- I" K [9 c
. T& u6 r0 u% s L, o: Y4 ^& b; w
mcasp->regs->XSTAT = 0x0000ffff; 6 T& J& a/ W+ g$ C& f
mcasp->regs->RSTAT = 0x0000ffff;
, i6 m5 x+ z9 E) Q9 ?5 Y- m( x' m% o0 {" P0 A$ d) H" r) r
mcasp->regs->XGBLCTL |= GBLCTL_XSRCLR_ON;
+ H1 m' I' Z4 a6 J. e while ( ( mcasp->regs->XGBLCTL & GBLCTL_XSRCLR_ON ) != GBLCTL_XSRCLR_ON );
( @) j) a) l: U' S, K2 t mcasp->regs->RGBLCTL |= GBLCTL_RSRCLR_ON; ; A7 o2 V9 s+ `
while ( ( mcasp->regs->RGBLCTL & GBLCTL_RSRCLR_ON ) != GBLCTL_RSRCLR_ON );
( V/ P! B) R& s& t& x/ }9 l
- d; G, J8 ?- N /* Write a 0, so that no underrun occurs after releasing the state machine */5 j" o5 {( a8 Y6 Z' Y" E" f
mcasp->regs->XBUF5 = 0;
V. N' k! \ E$ B mcasp->regs->RBUF0 = 0;
6 ]% z$ @' Q) _2 t! l$ H b- ]$ k3 G" ^) c& P0 t
mcasp->regs->XGBLCTL |= GBLCTL_XSMRST_ON; 5 k5 J/ u, D2 |
while ( ( mcasp->regs->XGBLCTL & GBLCTL_XSMRST_ON ) != GBLCTL_XSMRST_ON );
6 \3 X$ D" I# h% [; W( X; Z7 a& L' u mcasp->regs->RGBLCTL |= GBLCTL_RSMRST_ON;
. {: O; Z- q% m. B1 I while ( ( mcasp->regs->RGBLCTL & GBLCTL_RSMRST_ON ) != GBLCTL_RSMRST_ON );7 }6 G# M4 O$ k) i; _1 E9 R1 ?3 L
5 t5 {3 @% X5 n- \+ A7 K
mcasp->regs->XGBLCTL |= GBLCTL_XFRST_ON;
9 ?& m( [+ P3 j/ Q while ( ( mcasp->regs->XGBLCTL & GBLCTL_XFRST_ON ) != GBLCTL_XFRST_ON );
. L+ W! v( q( A9 N mcasp->regs->RGBLCTL |= GBLCTL_RFRST_ON;
% Q( i5 |2 g+ E' _; Y while ( ( mcasp->regs->RGBLCTL & GBLCTL_RFRST_ON ) != GBLCTL_RFRST_ON );
j% s* M+ M( N# S
Y6 E* y8 M9 X1 o! t7 Z5 y" o) r CSR = 0x0000; S' u) O% N& S0 n
INTC_INTMUX1 = 0x3d;
2 z& ?* ?; y5 Q. F" \4 ~& l, _. i ISTP = (unsigned int)vectors;
+ l* F: O2 `5 d ICR = 0xFFF0; 9 x- U0 @. u' [
IER |= 0x12;
* C( S7 v6 [+ h B2 e CSR |= 0x01; 9 G2 x n7 C1 G' M
" Y; ~) v' N, m: p. M8 H7 \
0 u( J4 h5 W- C+ @
" l4 M; b. e" N' b8 |还有就是两个输入输出函数:4 X- j) w! {- f$ P' v1 x$ c0 v
void output_sample(Int32 out_data)
: L& M D2 D* @8 Y6 ^{
5 w0 p+ i) \: F% g* H, } AIC31_data.uint = out_data; " `0 M. p. U8 W" y: q
MCASP1_XBUF5_32BIT = AIC31_data.uint;; l9 s& ?* z+ {& o# e! `
}
( r( `" }" o; V" z: P5 Q" l" i. R5 M2 e/ f5 q
Int32 input_sample(void)
: j5 g% O. N1 _( d5 ~# G{ l! H3 {) n: }- h$ f; v; U
AIC31_data.uint = MCASP1_RBUF0_32BIT;
) F2 I; [) ]/ u. B. {: o return (AIC31_data.uint);( a# Z% ~' t# _# d3 e# G$ q
}
" V* y1 ~) {# V N0 w4 m/ D! |2 Z" l4 A* p: a3 F
|
|