|
|
C6747和C6748感觉差不多,我想实现McASP发送中断方式控制音频信号,在轮询的例程基础上改的,轮询程序可以实现,但是中断一直实现不了,也找不到错误,求大神帮忙!下边是主要程序:
3 c: \5 I# j3 }main文件:- @: R% D* w9 S2 A$ A. i
interrupt void interrupt4(void)
# M& L9 h P1 m1 p1 `/ d{+ C4 U% O' t) g
Uint32 sample;
3 Z: \3 F" _+ ?5 _
+ l m" z! M I+ q sample = input_sample(); // read L + R samples from ADC( {" c# i7 I" W- d' @
output_sample(sample); // write L + R samples to DAC
$ ]6 E1 \4 M/ c' W0 @3 s! X8 }; w return;0 G, n: e/ d k5 z4 j
}( U: q$ J6 b$ N) A; Y' C
- {* g, c, b$ |" _
int main( void )! x2 ~& r( x6 Y) a, Y5 h1 s% ~
{
$ o1 ^! ?5 C1 j
- G- k, a0 B4 t( ~( m% [ /* Initialize BSL */
# F) F' [7 a. F' ]) M- F EVMC6747_init( );- C1 ~. c; H" `0 G) v
/* Call evmc6747_intr function */; R- `1 ~# X/ |0 t6 M: F
aic3106_init( );
# `2 n- k+ t* o# }3 j while(1);+ l c2 g5 k: p$ v( j9 [0 W5 c2 j
}( a, q5 R6 _+ P+ s* o
5 b" ]: Y) _* f2 y! P. J
. J" j! z$ h0 T; } B1 v! N$ oaic3106_init文件的一部分,McASP配置部分,采用内部时钟,I2S方式,同步传输。音频芯片的配置应该没问题& u# \$ d$ l/ p9 o
/* Initialize MCASP1 */
5 c& ?8 j5 ]: M4 D# v mcasp = &MCASP_MODULE_1;% E% N! C$ s: S: g( J
mcasp->regs->GBLCTL = 0; // Reset
# g1 r7 k0 ]; ^8 w1 X7 U7 z mcasp->regs->RGBLCTL = 0; // Reset RX
* B4 T! Z/ V; l: P% J mcasp->regs->XGBLCTL = 0; // Reset TX9 v! Z8 G9 p5 t; x( [& E2 C! q
mcasp->regs->PWRDEMU = 1; // Free-running
! }0 }0 Y" ]! z8 v4 i // configure McASP0 receive registers; ]( C, Y. O1 N1 v9 H# k
mcasp->regs->RMASK = 0xFFFFFFFF; // No padding used
$ F S, `. E ]( r5 u mcasp->regs->RFMT = 0x00018078; // MSB 16bit, 0-delay, no pad, CFGBus! p' M* U1 P4 k7 v2 X1 ~5 J" z
mcasp->regs->AFSRCTL = 0x00000112; // 2TDM, 1bit Falling, External FS, word1 Y; {: z/ f: j" y0 U! c4 R' Z/ U" j
mcasp->regs->ACLKRCTL = 0x000000AF; // Rising INTERNAL CLK,(from tx side)
5 S6 o& H4 a6 k% j* Z5 l mcasp->regs->AHCLKRCTL = 0x00000000; // INT CLK (from tx side)
. s1 y- z# v4 r$ K mcasp->regs->RTDM = 0x00000003; // Slots 0,1
# I2 x+ t2 Y+ Z* _' k mcasp->regs->RINTCTL = 0x00000000; // Not used6 s' v4 p6 u. z. _& z
mcasp->regs->RCLKCHK = 0x00FF0008; // 255-MAX 0-MIN, div-by-256
- T$ [; R! X8 |& t( ^, _ \. Q0 P$ n% X" G5 y9 t5 s/ H
mcasp->regs->XMASK = 0xFFFFFFFF; // No padding used+ ? e8 L! q; b+ u) ?
mcasp->regs->XFMT = 0x00018078; // MSB 16bit, 0-delay, no pad, CFGBus; o2 c B% u: P
mcasp->regs->AFSXCTL = 0x00000112; // 2TDM, 1bit Rising edge INTERNAL FS, word3 y, T2 c2 y9 q& Y
mcasp->regs->ACLKXCTL = 0x000000AF; // ASYNC, Rising INTERNAL CLK, div-by-16
8 T: v1 ~3 y/ I0 G2 Y mcasp->regs->AHCLKXCTL = 0x00000000; // EXT CLK
. n- ~9 z+ M E mcasp->regs->XTDM = 0x00000003; // Slots 0,1
$ v6 D1 |& N2 f( J mcasp->regs->XINTCTL = 0x00000020; // interrupt on transmit
6 q3 G/ E% _; i" ^ mcasp->regs->XCLKCHK = 0x00FF0008; // 255-MAX 0-MIN, div-by-256% j! C/ `' Y9 C" Q+ f; ]2 K% @
9 {* b: j: j+ N7 ?2 F3 Q1 V
mcasp->regs->SRCTL5 = 0x000D; // MCASP1.AXR1[5] --> DIN# ?5 n4 @8 c3 _- a
mcasp->regs->SRCTL0 = 0x000E; // MCASP1.AXR1[0] <-- DOUT
9 `) K) x1 d+ s3 W. D mcasp->regs->PFUNC = 0; // All MCASPs
% p& r7 s" [8 K9 S% Y1 i. G. F mcasp->regs->PDIR = 0x14000020; // All inputs except AXR0[5], ACLKX1, AFSX1$ d J/ }( Q# `6 ]; c, S1 z
. _3 c& m! a: a) \ mcasp->regs->DITCTL = 0x00000000; // Not used* z& j6 O. B: m9 k9 h5 ~( I
mcasp->regs->DLBCTL = 0x00000000; // Not used: M M7 J; _+ m6 M% o9 n
mcasp->regs->AMUTE = 0x00000000; // Not used
. I( |* V" X& L& A) u( h- R
9 L; z! `+ E7 Y" a* U/ s/* Starting sections of the McASP*/
; V' B* X5 g) K$ f: { mcasp->regs->XGBLCTL |= GBLCTL_XHCLKRST_ON; ( G: X( c3 }# @9 c' r- N5 x8 ^
while ( ( mcasp->regs->XGBLCTL & GBLCTL_XHCLKRST_ON ) != GBLCTL_XHCLKRST_ON );
0 G9 l2 o& i3 z7 A7 Z H, ~5 H mcasp->regs->RGBLCTL |= GBLCTL_RHCLKRST_ON; 0 s( E1 b7 X8 B' R
while ( ( mcasp->regs->RGBLCTL & GBLCTL_RHCLKRST_ON ) != GBLCTL_RHCLKRST_ON );+ h" m: P. G; G' o& x: k, u
8 p& e' W9 k0 f8 v, \# h
mcasp->regs->XGBLCTL |= GBLCTL_XCLKRST_ON;
1 B+ X$ v( n* s* w4 ]8 |( } while ( ( mcasp->regs->XGBLCTL & GBLCTL_XCLKRST_ON ) != GBLCTL_XCLKRST_ON );' r4 Y7 b8 T; _2 i) v- o' y! q
mcasp->regs->RGBLCTL |= GBLCTL_RCLKRST_ON;
5 M3 R& @0 C4 w! d+ w while ( ( mcasp->regs->RGBLCTL & GBLCTL_RCLKRST_ON ) != GBLCTL_RCLKRST_ON );! @4 u; o8 I% V" n& W5 e9 C1 }3 ^
& @! B* Q8 d: W, J6 Q! K
mcasp->regs->XSTAT = 0x0000ffff;
' x: C, n6 N9 x M! n mcasp->regs->RSTAT = 0x0000ffff;
$ q Y& Z/ Z% U. O; Q# F5 h d! R9 P: {$ d: K, B) k
mcasp->regs->XGBLCTL |= GBLCTL_XSRCLR_ON;, A: J7 A4 P9 C3 {- |
while ( ( mcasp->regs->XGBLCTL & GBLCTL_XSRCLR_ON ) != GBLCTL_XSRCLR_ON );" P% L* Z) L% e' O8 }
mcasp->regs->RGBLCTL |= GBLCTL_RSRCLR_ON; 1 g4 {4 ], t5 C A2 r( j
while ( ( mcasp->regs->RGBLCTL & GBLCTL_RSRCLR_ON ) != GBLCTL_RSRCLR_ON );9 W, s5 N4 {$ N/ t) M! x: N
' I. I8 W/ u8 R, O0 `4 Q. U /* Write a 0, so that no underrun occurs after releasing the state machine */
4 {, X3 a5 v, v1 M+ }" d8 k mcasp->regs->XBUF5 = 0;
8 T$ y7 \" p' A$ g/ u- m mcasp->regs->RBUF0 = 0;
; Q$ }. r. ~, W' K0 h, |& c% A+ [' K- Q* F$ y- g8 x0 Y
mcasp->regs->XGBLCTL |= GBLCTL_XSMRST_ON; " Y4 Q$ R# k4 ]8 C6 B4 Z
while ( ( mcasp->regs->XGBLCTL & GBLCTL_XSMRST_ON ) != GBLCTL_XSMRST_ON );
, _( J* r! p6 T. ?+ _( O9 N mcasp->regs->RGBLCTL |= GBLCTL_RSMRST_ON; 9 o- ]4 y5 b! r* `7 D X9 h
while ( ( mcasp->regs->RGBLCTL & GBLCTL_RSMRST_ON ) != GBLCTL_RSMRST_ON );
, T6 q& q: }) j$ i
+ F% m% ?5 a8 L0 i mcasp->regs->XGBLCTL |= GBLCTL_XFRST_ON; " }% K1 z' D. n# Z4 _' W3 R" }" [
while ( ( mcasp->regs->XGBLCTL & GBLCTL_XFRST_ON ) != GBLCTL_XFRST_ON );
1 x7 Q: z" O; n1 [( c: P mcasp->regs->RGBLCTL |= GBLCTL_RFRST_ON; ' x9 H" }7 @* h: C4 {3 I4 V
while ( ( mcasp->regs->RGBLCTL & GBLCTL_RFRST_ON ) != GBLCTL_RFRST_ON );1 o' i" d6 j. H/ s+ V" \' k
9 c, v2 U) z- { CSR = 0x0000;- g5 I- ?1 J* ?+ a2 N
INTC_INTMUX1 = 0x3d;3 B* g- v: X" Q! ^
ISTP = (unsigned int)vectors;
8 j9 A1 j* s! r' i ICR = 0xFFF0;
! v9 ?# P4 P) ]( F( f IER |= 0x12;
5 p$ }8 q+ |. R CSR |= 0x01;
, C% H' A; s+ E4 [- n! @! W+ K4 X- M. q% z6 s
! t' Q: w# K% I [' v& r& u4 r( G% v- J
还有就是两个输入输出函数:, P7 W, E: \( l0 t
void output_sample(Int32 out_data)8 j& B/ k1 i+ w8 s
{
% O1 X! _7 l, U# w. O0 J) q7 } AIC31_data.uint = out_data;
4 i" ?+ u! ]. Z6 w# b) T1 V' b MCASP1_XBUF5_32BIT = AIC31_data.uint;
! |: D& C. M. |3 @1 s k}
5 ^9 N& X! ?( Q6 H9 p( C8 ^9 w
1 [$ X" t$ J3 ~Int32 input_sample(void)# d, R8 F. G% e; Y) Z+ g2 s( b
{ . t) Z* v2 T+ e; B
AIC31_data.uint = MCASP1_RBUF0_32BIT;
/ o* x; V7 T! ]; S2 t' M return (AIC31_data.uint);3 B* {, `& K' ^$ C4 N. V9 R4 }9 Y3 X
}. |3 ]* W/ r* o6 z5 H: `2 T
$ F; o$ k1 Z: E9 H6 P/ c& Q! }9 u |
|