|
C6747和C6748感觉差不多,我想实现McASP发送中断方式控制音频信号,在轮询的例程基础上改的,轮询程序可以实现,但是中断一直实现不了,也找不到错误,求大神帮忙!下边是主要程序:
+ h2 @0 n1 Q B: Kmain文件:9 K2 j @0 `" v) M! M
interrupt void interrupt4(void) 2 }) a. q* L9 b
{0 f- D% z( b5 A. E R; [
Uint32 sample;
( ]! c1 f! i" z3 {, {
# i8 k; o$ J, W0 Q/ T sample = input_sample(); // read L + R samples from ADC
% U5 D& ^+ \* ^+ c* ] output_sample(sample); // write L + R samples to DAC
5 H Q+ }: z5 g& M* C; i* p( i return;
. g1 u0 a- [/ y) b3 g+ b6 W}5 z2 \3 d' E: ]1 ^
) X7 H/ u% V* A; K* hint main( void )
6 ?& s4 l/ \6 b{" O3 R7 h6 U6 e7 N2 w
6 w" k& o: ]9 H1 R! M
/* Initialize BSL */9 m" i' x: X" [) T3 g
EVMC6747_init( );
6 `4 S1 a6 l$ j1 N; C( R+ P /* Call evmc6747_intr function */
. K; T% e: ^: F9 V aic3106_init( );
E S9 g9 d: j) _$ z while(1);- L/ W; j5 A8 `5 P6 u
}
% B; I$ X; Y- N% i0 w4 n2 k
4 s1 d4 d+ D/ {& z1 X% r8 q
1 d; i$ P- D9 m; G+ Vaic3106_init文件的一部分,McASP配置部分,采用内部时钟,I2S方式,同步传输。音频芯片的配置应该没问题" {2 G( [3 {- `
/* Initialize MCASP1 */
; y% [3 L' `7 O1 Y, ^. P mcasp = &MCASP_MODULE_1;
, G6 ?) k+ L0 r* Z mcasp->regs->GBLCTL = 0; // Reset
. [# t( P5 B( T) ~) Y7 j r0 M mcasp->regs->RGBLCTL = 0; // Reset RX. A# {4 V1 T0 t
mcasp->regs->XGBLCTL = 0; // Reset TX
- \9 o! F3 J$ p7 A8 \) ~ mcasp->regs->PWRDEMU = 1; // Free-running
9 r. U* S4 Q; h2 U // configure McASP0 receive registers1 d+ J/ ~3 w/ `/ L9 ^" M6 o
mcasp->regs->RMASK = 0xFFFFFFFF; // No padding used
- q, l* G( E/ I/ Y. z9 M, I mcasp->regs->RFMT = 0x00018078; // MSB 16bit, 0-delay, no pad, CFGBus, q w3 x3 ?+ _& B* v* f( |
mcasp->regs->AFSRCTL = 0x00000112; // 2TDM, 1bit Falling, External FS, word3 n, r4 a Q% z$ ?: m- a
mcasp->regs->ACLKRCTL = 0x000000AF; // Rising INTERNAL CLK,(from tx side)
~; z1 A1 I9 \ mcasp->regs->AHCLKRCTL = 0x00000000; // INT CLK (from tx side)& j) E' i7 m: @2 h. D2 L
mcasp->regs->RTDM = 0x00000003; // Slots 0,1$ e8 |6 Z4 w% _5 }- X2 O, b
mcasp->regs->RINTCTL = 0x00000000; // Not used
1 @ f) ?0 u/ t7 D. D$ \ mcasp->regs->RCLKCHK = 0x00FF0008; // 255-MAX 0-MIN, div-by-256
$ k3 E( W! I. s: ], ]. Y: [: b0 n+ L$ N/ X3 h: \# e9 c) U# `0 ]
mcasp->regs->XMASK = 0xFFFFFFFF; // No padding used
4 ~5 h( `5 b9 R6 X mcasp->regs->XFMT = 0x00018078; // MSB 16bit, 0-delay, no pad, CFGBus% g! F. L4 v4 K
mcasp->regs->AFSXCTL = 0x00000112; // 2TDM, 1bit Rising edge INTERNAL FS, word
- [' U+ f% n' J% }3 X mcasp->regs->ACLKXCTL = 0x000000AF; // ASYNC, Rising INTERNAL CLK, div-by-164 `- e) v3 w2 \$ n
mcasp->regs->AHCLKXCTL = 0x00000000; // EXT CLK% ~$ x8 }$ v' a' [, L
mcasp->regs->XTDM = 0x00000003; // Slots 0,1
% L" |+ y: A( A1 A8 | mcasp->regs->XINTCTL = 0x00000020; // interrupt on transmit) }1 ^% T" v& r( \1 {. n4 i
mcasp->regs->XCLKCHK = 0x00FF0008; // 255-MAX 0-MIN, div-by-256
0 E9 y+ S/ D; i* C/ k
& a. x. S, l4 r$ w% O mcasp->regs->SRCTL5 = 0x000D; // MCASP1.AXR1[5] --> DIN: u4 d. Z2 S: `5 B
mcasp->regs->SRCTL0 = 0x000E; // MCASP1.AXR1[0] <-- DOUT
% x& k* E- c9 [! L4 p' Q mcasp->regs->PFUNC = 0; // All MCASPs
a! M. p# M( p+ {! a7 U; ~ mcasp->regs->PDIR = 0x14000020; // All inputs except AXR0[5], ACLKX1, AFSX16 [2 S% R w! b2 {8 D$ `7 z% {1 ^
" A4 ^1 U8 k' Y4 ^
mcasp->regs->DITCTL = 0x00000000; // Not used
5 V4 R, t: p) U) k mcasp->regs->DLBCTL = 0x00000000; // Not used
) u9 L/ r! f) I! e" t0 F mcasp->regs->AMUTE = 0x00000000; // Not used
& ^3 z6 c w& h% c: v4 y1 @1 [7 S8 M+ a* Q- P( G
/* Starting sections of the McASP*/5 L! D% {4 ], p/ v4 s# Q, |
mcasp->regs->XGBLCTL |= GBLCTL_XHCLKRST_ON; 3 M* s% W! G! O# c" Q! I9 s% h
while ( ( mcasp->regs->XGBLCTL & GBLCTL_XHCLKRST_ON ) != GBLCTL_XHCLKRST_ON ); ; a2 G9 ]$ w4 _; A
mcasp->regs->RGBLCTL |= GBLCTL_RHCLKRST_ON;
5 O H( a8 C- O9 S& w while ( ( mcasp->regs->RGBLCTL & GBLCTL_RHCLKRST_ON ) != GBLCTL_RHCLKRST_ON );
& o" y; B; ^( s& |, v' _; X7 R( w+ y) Z. y/ g/ p
mcasp->regs->XGBLCTL |= GBLCTL_XCLKRST_ON;
2 A9 Y* c* }- h* |$ S2 H8 w while ( ( mcasp->regs->XGBLCTL & GBLCTL_XCLKRST_ON ) != GBLCTL_XCLKRST_ON );
" T: ^, X5 d2 L! [, K) W% ^ mcasp->regs->RGBLCTL |= GBLCTL_RCLKRST_ON; ! m) S3 O G' K; @
while ( ( mcasp->regs->RGBLCTL & GBLCTL_RCLKRST_ON ) != GBLCTL_RCLKRST_ON );" [9 N& L- F: }; B1 y0 I
$ d% F' ^! o8 N% z* _* s3 I mcasp->regs->XSTAT = 0x0000ffff; 5 X+ i" U1 ~1 L: x
mcasp->regs->RSTAT = 0x0000ffff; & k6 i) [0 ~5 M- h# E
# M K; [' S# o7 A mcasp->regs->XGBLCTL |= GBLCTL_XSRCLR_ON;
7 M* r8 ~. b5 ~6 o! |: h while ( ( mcasp->regs->XGBLCTL & GBLCTL_XSRCLR_ON ) != GBLCTL_XSRCLR_ON );
: g" f5 M3 J/ S, p# } mcasp->regs->RGBLCTL |= GBLCTL_RSRCLR_ON;
2 |# o l7 Q4 L while ( ( mcasp->regs->RGBLCTL & GBLCTL_RSRCLR_ON ) != GBLCTL_RSRCLR_ON );, p4 I% v* v$ b/ p7 K
4 x/ v) e, `! U) e5 W8 c
/* Write a 0, so that no underrun occurs after releasing the state machine */
0 V/ b3 d; k, I" H* O/ h& N mcasp->regs->XBUF5 = 0;" P( S1 @( i7 L% T4 v. K/ t2 v& U
mcasp->regs->RBUF0 = 0;0 E0 G4 t& E9 X' n' M, i! i* t
- R1 _% y& p! G% n4 l7 I8 m mcasp->regs->XGBLCTL |= GBLCTL_XSMRST_ON;
2 C! z. D' i$ ]8 I while ( ( mcasp->regs->XGBLCTL & GBLCTL_XSMRST_ON ) != GBLCTL_XSMRST_ON );
6 l3 e4 p( o; ~9 o$ F mcasp->regs->RGBLCTL |= GBLCTL_RSMRST_ON;
% k0 k% O/ s- C! e! a$ u while ( ( mcasp->regs->RGBLCTL & GBLCTL_RSMRST_ON ) != GBLCTL_RSMRST_ON );& m! J: F0 A' \& p5 B
7 {* n% {( b" E; S2 B$ Q/ P3 c mcasp->regs->XGBLCTL |= GBLCTL_XFRST_ON;
" u2 v. M! s S% [: _8 g while ( ( mcasp->regs->XGBLCTL & GBLCTL_XFRST_ON ) != GBLCTL_XFRST_ON );0 K6 E& X. v! S, U7 S2 | [. }
mcasp->regs->RGBLCTL |= GBLCTL_RFRST_ON;
* w) W' O$ u& F( i while ( ( mcasp->regs->RGBLCTL & GBLCTL_RFRST_ON ) != GBLCTL_RFRST_ON );' y( e1 c4 ^, j( Y$ `1 W* U: [
- d) v6 A) a; K3 d/ Y+ m2 }1 r
CSR = 0x0000;9 q% E9 e- X7 [0 {) V @
INTC_INTMUX1 = 0x3d;
+ {3 N! t& w6 ^" }) c8 a/ @+ h ISTP = (unsigned int)vectors;6 g! s9 N2 ?9 }
ICR = 0xFFF0;
% x! e( W) ^9 K8 e- \' R IER |= 0x12;
6 d" Z0 n2 J8 b% Y6 g1 F CSR |= 0x01;
3 Z) E8 j8 b3 \2 q5 O* d) M1 Q: G$ \* a6 g& z6 \
; P% D! c* n7 `: y- C
" ^5 c; V' F& S还有就是两个输入输出函数:# w/ _. s) ~% y
void output_sample(Int32 out_data)
, ^9 q! I5 P0 T- V4 i4 I{
3 m4 W, }. J' Z AIC31_data.uint = out_data;
4 K; W+ o( z/ q! ?2 i MCASP1_XBUF5_32BIT = AIC31_data.uint;( ~' G/ `1 q! x8 h* c9 x
}
6 A, u) S/ h) r5 m/ T9 O
" H2 g* E7 r9 k! y7 }1 Z" K% JInt32 input_sample(void)$ Q9 D4 Z1 F' O. R
{
+ T$ R. w6 L8 D$ H6 X+ Z4 D AIC31_data.uint = MCASP1_RBUF0_32BIT;
; r- \* ]; H" Y' @2 W9 y+ E. W/ E4 I return (AIC31_data.uint);
5 t& o3 ~. c8 a) x3 _+ M}% Y' C3 U$ f+ |# h7 u' g
' ~3 D. D4 ^; M* m' X |
|