|
|
C6747和C6748感觉差不多,我想实现McASP发送中断方式控制音频信号,在轮询的例程基础上改的,轮询程序可以实现,但是中断一直实现不了,也找不到错误,求大神帮忙!下边是主要程序:
9 x1 X4 T e2 a6 v; |0 v( }( ?5 ~main文件:3 r, w$ Z( p% v2 Z! p1 g
interrupt void interrupt4(void) T$ {+ f* \! i5 `: B
{- l2 B: X- G9 ^0 G6 Q! T
Uint32 sample;
4 [" N8 K D6 W; C" \7 [7 Q% X. M0 m/ A- T8 I z5 ]
sample = input_sample(); // read L + R samples from ADC+ `# _4 \% U0 i" _
output_sample(sample); // write L + R samples to DAC ! z* {5 V( E- D7 T
return;' ~3 }9 ?/ ~4 \- T6 @
} {# L B. g- Z, b# W2 A
" V3 k/ L# f, P8 \int main( void )
- g8 v3 `) c f# g: [ D4 H( P: Q& }{; p& T0 b7 h' M! x
% Z: C, Q, @ E2 W; R5 [& S /* Initialize BSL */% b8 F& ?6 N; w. A+ j
EVMC6747_init( );
j% ~% L' j$ B( }( Y2 N Z5 M7 k /* Call evmc6747_intr function */
; j8 t4 p- t7 X1 j& m0 T* }: ~ aic3106_init( );( f% z, @! v, `# U
while(1);) M/ G8 x+ a( N2 g/ w3 C
}- n: w8 v# l& X$ Y& q
7 F: M) K7 @0 @7 }7 G+ y
7 ~: G, g% ^. z* R% M
aic3106_init文件的一部分,McASP配置部分,采用内部时钟,I2S方式,同步传输。音频芯片的配置应该没问题3 [, `, ?/ E% T6 Q$ c+ ~
/* Initialize MCASP1 */
+ y% R( C( B3 {5 W mcasp = &MCASP_MODULE_1;
# K2 g8 n0 Z" [7 \( a9 G* V6 Q. K mcasp->regs->GBLCTL = 0; // Reset- F+ V7 E8 Q: b2 @9 ]) Q k
mcasp->regs->RGBLCTL = 0; // Reset RX1 G! k4 |- h, G0 S$ c9 p( s9 i% `6 c
mcasp->regs->XGBLCTL = 0; // Reset TX) u' q! b$ g* X9 o& l" ?7 U" w+ Q
mcasp->regs->PWRDEMU = 1; // Free-running
( i" ?% G) a4 B! i- M. r+ Y // configure McASP0 receive registers
4 ^3 U5 O5 K2 }2 j5 s9 B+ U4 ^+ o, C mcasp->regs->RMASK = 0xFFFFFFFF; // No padding used# | n- U: M# U# f% u
mcasp->regs->RFMT = 0x00018078; // MSB 16bit, 0-delay, no pad, CFGBus
4 B! C: k) h7 l' X" p: P+ O# I* B mcasp->regs->AFSRCTL = 0x00000112; // 2TDM, 1bit Falling, External FS, word& B- b+ V/ {/ l7 P+ f
mcasp->regs->ACLKRCTL = 0x000000AF; // Rising INTERNAL CLK,(from tx side)
" b& K' R$ h. g- i" x' ^/ S mcasp->regs->AHCLKRCTL = 0x00000000; // INT CLK (from tx side)9 b- L0 J! J7 ?$ Q( n2 K
mcasp->regs->RTDM = 0x00000003; // Slots 0,1
- w: S" A- v1 @5 [* M$ o mcasp->regs->RINTCTL = 0x00000000; // Not used& M+ P+ i9 L2 A0 T7 d( d
mcasp->regs->RCLKCHK = 0x00FF0008; // 255-MAX 0-MIN, div-by-256
* E7 ?# q( V7 V5 A6 D
* A9 }+ A" s! B- z7 d' i T mcasp->regs->XMASK = 0xFFFFFFFF; // No padding used* }. c4 c) B( D5 U, {+ f
mcasp->regs->XFMT = 0x00018078; // MSB 16bit, 0-delay, no pad, CFGBus2 R6 ^: q/ f8 G, |3 S; g0 p
mcasp->regs->AFSXCTL = 0x00000112; // 2TDM, 1bit Rising edge INTERNAL FS, word0 P8 c4 F0 l8 Y/ ~
mcasp->regs->ACLKXCTL = 0x000000AF; // ASYNC, Rising INTERNAL CLK, div-by-16
) P& b: e6 j9 V* O$ }+ S2 X. q* O mcasp->regs->AHCLKXCTL = 0x00000000; // EXT CLK7 x# V; C$ t8 g2 w9 G# u! e
mcasp->regs->XTDM = 0x00000003; // Slots 0,1
, X" k* V+ @2 b3 | mcasp->regs->XINTCTL = 0x00000020; // interrupt on transmit
0 E& i/ `* c+ I6 t) B# x mcasp->regs->XCLKCHK = 0x00FF0008; // 255-MAX 0-MIN, div-by-256
- F0 U" H: |. M& b! P% M/ @+ {0 l! Q$ N$ S% W+ r
mcasp->regs->SRCTL5 = 0x000D; // MCASP1.AXR1[5] --> DIN
. [1 _; e/ P: \3 L8 C7 k# C mcasp->regs->SRCTL0 = 0x000E; // MCASP1.AXR1[0] <-- DOUT6 _6 ]' K& |9 _7 X, d( D' ^/ Q+ m
mcasp->regs->PFUNC = 0; // All MCASPs9 {" \5 R1 v. ~! u6 \3 g! \
mcasp->regs->PDIR = 0x14000020; // All inputs except AXR0[5], ACLKX1, AFSX1
0 T8 x8 f/ I. ?" k$ L: }! p- f* V* S1 ], X' T4 g2 k
mcasp->regs->DITCTL = 0x00000000; // Not used5 s2 E- v, N9 n. U/ L. x4 }: H
mcasp->regs->DLBCTL = 0x00000000; // Not used; M" @ [" B7 G H* q$ D$ m3 K
mcasp->regs->AMUTE = 0x00000000; // Not used
/ a# w) V! H, S( j T1 g2 _0 v# ^. `- _5 F1 T' Q
/* Starting sections of the McASP*/
# Q# v1 ?; \" b4 J) X. N mcasp->regs->XGBLCTL |= GBLCTL_XHCLKRST_ON;
* w& ]9 S; q* Z1 L! F$ H while ( ( mcasp->regs->XGBLCTL & GBLCTL_XHCLKRST_ON ) != GBLCTL_XHCLKRST_ON );
% c: v! Q2 v+ w* ], Z9 ~; D3 B mcasp->regs->RGBLCTL |= GBLCTL_RHCLKRST_ON; 1 P9 `# e1 C _3 M, c
while ( ( mcasp->regs->RGBLCTL & GBLCTL_RHCLKRST_ON ) != GBLCTL_RHCLKRST_ON );4 N$ {3 Q8 Z3 }1 ]) c& T
/ _1 {" v0 T: Y5 L mcasp->regs->XGBLCTL |= GBLCTL_XCLKRST_ON; 5 e# p6 K2 w, @3 u O
while ( ( mcasp->regs->XGBLCTL & GBLCTL_XCLKRST_ON ) != GBLCTL_XCLKRST_ON );
& ?8 L! Q9 L) }9 I2 }+ w( N mcasp->regs->RGBLCTL |= GBLCTL_RCLKRST_ON;
, h% B( w+ c: i5 Y while ( ( mcasp->regs->RGBLCTL & GBLCTL_RCLKRST_ON ) != GBLCTL_RCLKRST_ON );
8 k& K& t* j7 u$ O& p' G- z+ ?
6 } y* ], j9 d1 M1 A; k mcasp->regs->XSTAT = 0x0000ffff;
, ~; x! G7 V# G! n7 e7 T mcasp->regs->RSTAT = 0x0000ffff; ! e- j' u- H+ [. i
- b5 C* N, X$ N* V1 ?
mcasp->regs->XGBLCTL |= GBLCTL_XSRCLR_ON;
+ c7 Y. z* o8 v* |: t while ( ( mcasp->regs->XGBLCTL & GBLCTL_XSRCLR_ON ) != GBLCTL_XSRCLR_ON );3 W. k! W) T V( R) k/ R- n
mcasp->regs->RGBLCTL |= GBLCTL_RSRCLR_ON;
& Z- y- G. {7 `6 T! A: r8 h while ( ( mcasp->regs->RGBLCTL & GBLCTL_RSRCLR_ON ) != GBLCTL_RSRCLR_ON );
2 J) F; I2 J5 j1 U4 d; N
2 y$ f/ S$ |4 N /* Write a 0, so that no underrun occurs after releasing the state machine */
0 N% A' m! f+ T9 N4 [ mcasp->regs->XBUF5 = 0;- n5 A p9 C2 }4 @9 X) S# e
mcasp->regs->RBUF0 = 0;9 A2 G# f8 m1 A! o& R, ]7 M
2 ^0 T9 x' n/ Z( A& j
mcasp->regs->XGBLCTL |= GBLCTL_XSMRST_ON; ; l5 }+ N. c; _& `
while ( ( mcasp->regs->XGBLCTL & GBLCTL_XSMRST_ON ) != GBLCTL_XSMRST_ON );
U4 n% |9 y2 t0 [2 Z mcasp->regs->RGBLCTL |= GBLCTL_RSMRST_ON; * M/ v% t/ O3 H! y- C% R
while ( ( mcasp->regs->RGBLCTL & GBLCTL_RSMRST_ON ) != GBLCTL_RSMRST_ON );: @1 o2 k @$ {4 r( F
0 N# U' b' K- s _' B# x$ | mcasp->regs->XGBLCTL |= GBLCTL_XFRST_ON;
- F% k/ l3 D+ u5 q5 v while ( ( mcasp->regs->XGBLCTL & GBLCTL_XFRST_ON ) != GBLCTL_XFRST_ON );0 u1 V8 _. y8 ]0 v% h; R
mcasp->regs->RGBLCTL |= GBLCTL_RFRST_ON;
( o; b$ h2 m- H% L# _/ m while ( ( mcasp->regs->RGBLCTL & GBLCTL_RFRST_ON ) != GBLCTL_RFRST_ON );4 a7 ]" @% I8 T: a* ?: n1 r3 [
1 ]6 [1 \' j U; y; F: q8 ?1 W
CSR = 0x0000;
/ a0 W/ n4 t( a INTC_INTMUX1 = 0x3d;/ v6 a9 c/ w4 B' A
ISTP = (unsigned int)vectors;
/ I: K( C) j- i- Z- S* \ ICR = 0xFFF0;
( j8 |+ V& L# o! [& E2 p IER |= 0x12; , G3 k' Q$ O$ H+ j5 Q. J
CSR |= 0x01;
- _( I8 `: v$ Q2 N4 N' c+ E4 [; ~$ m/ q4 ]" X
( D; ~4 h4 J1 x1 Y8 Y+ a( I/ K* k, x( E m
还有就是两个输入输出函数:* ]+ g! n# w3 N8 ~/ ]0 k3 J! L
void output_sample(Int32 out_data)4 T9 Z# p& D* m& S( ]1 y* T0 l) G
{
! h; O: I. t2 @3 G! K7 W9 G. r# Q AIC31_data.uint = out_data; / h$ Z# J! g* V! u3 U! E: j
MCASP1_XBUF5_32BIT = AIC31_data.uint;
9 ?" @. ~3 u& i}* V! f: t4 I& E' R% A+ p) G
8 G) L6 Y( [: Q+ j+ U$ [
Int32 input_sample(void)' \+ l1 ]: x+ O6 o6 l0 [0 L* E( a
{
! n, B- L' c4 y6 U# f4 h/ F* M( ^ AIC31_data.uint = MCASP1_RBUF0_32BIT;
$ ?" ^! F- j ?% P return (AIC31_data.uint);
& X k" b2 \$ l9 p9 Y}7 P2 N! x0 j( P' E
! a( f4 N1 S7 K: A5 d
|
|