|
|
C6747和C6748感觉差不多,我想实现McASP发送中断方式控制音频信号,在轮询的例程基础上改的,轮询程序可以实现,但是中断一直实现不了,也找不到错误,求大神帮忙!下边是主要程序:# B7 V. ?6 M5 L) G& J
main文件:
4 w$ [' o8 v; P6 A. Ninterrupt void interrupt4(void)
* N6 L0 r9 i8 A; s6 y- m- e{
, |7 ?$ I' n. w( x6 V( o) y* R Uint32 sample;2 [* \; I3 L( d( z! o
) a) y8 F+ x6 N$ N
sample = input_sample(); // read L + R samples from ADC
/ ^2 c0 j2 \5 B: a* c! }9 x output_sample(sample); // write L + R samples to DAC " D3 l9 T% `2 A8 J
return;
; I3 O4 C3 A9 Y7 N) ^) k}, ]" n- J) f5 n( q: J
9 t+ T+ a% Z8 v. a5 S) M8 ~' [int main( void )( }: m# h9 v: x& F4 g& ~
{' t" `3 O |5 U( R& N
2 p0 c" W+ b3 \$ V9 I* L /* Initialize BSL */
$ G( x/ f. W4 N0 u0 U' S; Q4 u EVMC6747_init( );
) O! k, J' C3 h7 d) Y0 i! H5 \ /* Call evmc6747_intr function */
7 p" M( }0 q& b6 F aic3106_init( );
" j, j' c, z, i* S8 i while(1);
# q* d' P3 P# ~% b+ Y}
' N+ w( c) i: D3 o- f
; I$ X& I+ \/ Z; U$ o
' [+ g7 _; ~9 ~5 a4 d3 m6 b# c* vaic3106_init文件的一部分,McASP配置部分,采用内部时钟,I2S方式,同步传输。音频芯片的配置应该没问题
6 R L% c9 Q8 E9 O0 E0 Y3 a2 \/* Initialize MCASP1 *// `7 [( S6 c8 }+ [5 }4 A
mcasp = &MCASP_MODULE_1;
- `; u8 v0 l+ _ mcasp->regs->GBLCTL = 0; // Reset& @5 j3 ?9 Z- \; u+ p( V& W
mcasp->regs->RGBLCTL = 0; // Reset RX
; x* i( `" ~3 J3 s0 G mcasp->regs->XGBLCTL = 0; // Reset TX
; A+ ?( R2 R$ G# Q mcasp->regs->PWRDEMU = 1; // Free-running9 A ?) G) L0 t9 G) `5 ]
// configure McASP0 receive registers
& ?( q* N9 q z0 a mcasp->regs->RMASK = 0xFFFFFFFF; // No padding used' y! ^) A' \! x- Z0 ?4 t( j
mcasp->regs->RFMT = 0x00018078; // MSB 16bit, 0-delay, no pad, CFGBus
3 [0 p! I# e: N9 ~5 L( C: s mcasp->regs->AFSRCTL = 0x00000112; // 2TDM, 1bit Falling, External FS, word C6 j* Z1 I* s1 `2 [
mcasp->regs->ACLKRCTL = 0x000000AF; // Rising INTERNAL CLK,(from tx side) G* F4 ?3 C E, y
mcasp->regs->AHCLKRCTL = 0x00000000; // INT CLK (from tx side)
: Z4 R6 P) P6 Y& C! k mcasp->regs->RTDM = 0x00000003; // Slots 0,1
% l+ s9 J! @. l* ^5 x mcasp->regs->RINTCTL = 0x00000000; // Not used
+ G/ n: [$ Y" Q mcasp->regs->RCLKCHK = 0x00FF0008; // 255-MAX 0-MIN, div-by-256
9 w- y% \* v! X% T2 O2 e2 @7 O y
mcasp->regs->XMASK = 0xFFFFFFFF; // No padding used0 |+ b* t# o% B( ?. U2 c% a
mcasp->regs->XFMT = 0x00018078; // MSB 16bit, 0-delay, no pad, CFGBus
7 H) `2 s5 |- S. S# d( h, W mcasp->regs->AFSXCTL = 0x00000112; // 2TDM, 1bit Rising edge INTERNAL FS, word2 r, q" e1 I/ L- }6 {
mcasp->regs->ACLKXCTL = 0x000000AF; // ASYNC, Rising INTERNAL CLK, div-by-16
( t# u9 v& U3 A( F$ o mcasp->regs->AHCLKXCTL = 0x00000000; // EXT CLK$ R) V" K# V$ U* s. }4 d# X
mcasp->regs->XTDM = 0x00000003; // Slots 0,1/ Z3 W" d$ B. e8 a' x
mcasp->regs->XINTCTL = 0x00000020; // interrupt on transmit. S2 \3 g& E- _$ U9 m/ S
mcasp->regs->XCLKCHK = 0x00FF0008; // 255-MAX 0-MIN, div-by-256
+ _" @, Y# B6 w% Q" x" I, @; I$ N: N0 ~7 P: K1 E2 P( U8 F
mcasp->regs->SRCTL5 = 0x000D; // MCASP1.AXR1[5] --> DIN8 i! U2 ?) O+ N9 h. L- s" |
mcasp->regs->SRCTL0 = 0x000E; // MCASP1.AXR1[0] <-- DOUT
1 G6 B3 y9 y. L! }- o/ p) b t mcasp->regs->PFUNC = 0; // All MCASPs2 ^6 I9 |8 |+ y P# Z
mcasp->regs->PDIR = 0x14000020; // All inputs except AXR0[5], ACLKX1, AFSX12 y" y3 A1 _ H$ c a& j9 W* M' r
' @5 E. F0 t* ^% M. n mcasp->regs->DITCTL = 0x00000000; // Not used
/ v8 O/ X. b. h' X0 ~6 z mcasp->regs->DLBCTL = 0x00000000; // Not used* g1 S. H2 ~; G8 D7 x6 Q) H: Z
mcasp->regs->AMUTE = 0x00000000; // Not used* n) X2 `1 f# z- o
( ]8 f6 z* V, n: u% a+ H; t8 n/* Starting sections of the McASP*/
3 R& B2 H4 ?- W% h( N; V5 }6 o6 f mcasp->regs->XGBLCTL |= GBLCTL_XHCLKRST_ON; / Q* N# `: z" O" [
while ( ( mcasp->regs->XGBLCTL & GBLCTL_XHCLKRST_ON ) != GBLCTL_XHCLKRST_ON );
3 [) F3 F: b d/ H. V b mcasp->regs->RGBLCTL |= GBLCTL_RHCLKRST_ON;
6 r$ B: Y" @9 r+ S. p while ( ( mcasp->regs->RGBLCTL & GBLCTL_RHCLKRST_ON ) != GBLCTL_RHCLKRST_ON );7 p& r! d* {2 M8 @
! T$ T7 {2 X$ l2 y8 q7 a mcasp->regs->XGBLCTL |= GBLCTL_XCLKRST_ON;
- w4 _+ s% q4 `* z! \* H while ( ( mcasp->regs->XGBLCTL & GBLCTL_XCLKRST_ON ) != GBLCTL_XCLKRST_ON );- X3 |+ n8 {( Z f w5 x
mcasp->regs->RGBLCTL |= GBLCTL_RCLKRST_ON;
& B9 ^& H! U( y while ( ( mcasp->regs->RGBLCTL & GBLCTL_RCLKRST_ON ) != GBLCTL_RCLKRST_ON );8 n- w( E7 Q4 [2 c
3 J" n. u; @, ^/ q
mcasp->regs->XSTAT = 0x0000ffff;
5 o& ~! k3 V! S' b5 A- V% { mcasp->regs->RSTAT = 0x0000ffff; $ Z4 S1 R2 B/ C6 v, x
1 X# E2 F9 D6 i7 R: b- m mcasp->regs->XGBLCTL |= GBLCTL_XSRCLR_ON;
: q3 h3 U5 e* d) h" l while ( ( mcasp->regs->XGBLCTL & GBLCTL_XSRCLR_ON ) != GBLCTL_XSRCLR_ON );
# U9 c ~- Z* {% [# ^ mcasp->regs->RGBLCTL |= GBLCTL_RSRCLR_ON;
3 K: y% M3 V+ x* V6 V* |, O while ( ( mcasp->regs->RGBLCTL & GBLCTL_RSRCLR_ON ) != GBLCTL_RSRCLR_ON );4 L8 c2 ?6 n1 G% V* q
7 C: U* i0 U7 V. O9 Z' O /* Write a 0, so that no underrun occurs after releasing the state machine */! S5 }/ Z3 O. F/ U0 N2 I9 y
mcasp->regs->XBUF5 = 0;& P1 ]# P) j h- t5 e
mcasp->regs->RBUF0 = 0;6 h# B% d% c. W/ q: k: I g, @) A
) Y4 c+ S$ X0 h `8 U
mcasp->regs->XGBLCTL |= GBLCTL_XSMRST_ON; 5 `; z1 V a, x- a) p! F8 f. N
while ( ( mcasp->regs->XGBLCTL & GBLCTL_XSMRST_ON ) != GBLCTL_XSMRST_ON );
5 T; v8 K. B4 }' O mcasp->regs->RGBLCTL |= GBLCTL_RSMRST_ON; 9 a3 b" B; k$ k( V, r( z: @
while ( ( mcasp->regs->RGBLCTL & GBLCTL_RSMRST_ON ) != GBLCTL_RSMRST_ON );
7 I: E6 `' s9 s! k0 D' q
6 M' M* ?$ l4 ~' W. W# V6 u5 A+ E mcasp->regs->XGBLCTL |= GBLCTL_XFRST_ON; ( }6 q* H) Z0 x' E" Z/ ^; N( U! }
while ( ( mcasp->regs->XGBLCTL & GBLCTL_XFRST_ON ) != GBLCTL_XFRST_ON );4 n+ H$ a7 C" n( g0 g& B
mcasp->regs->RGBLCTL |= GBLCTL_RFRST_ON;
! m0 S1 j5 P ~. G/ y8 c& G while ( ( mcasp->regs->RGBLCTL & GBLCTL_RFRST_ON ) != GBLCTL_RFRST_ON );
4 J# R4 q, [+ c8 }. _7 f3 L+ `. Z5 h4 c( X" O. x0 B7 n
CSR = 0x0000;# T0 i7 v* A) z) J$ u. W" a: o3 S
INTC_INTMUX1 = 0x3d;; T1 S; j# J2 a1 J3 `5 n2 F3 h
ISTP = (unsigned int)vectors;
3 X; q" }, G4 _2 u+ a$ S2 H! A ICR = 0xFFF0; 5 v9 i* ~$ Q% ]; P2 Y4 p: `# |
IER |= 0x12;
# D0 Z( u) L) k$ Z: x$ A" u CSR |= 0x01; + y7 l# M3 _( p |' O; z$ w
5 t3 i2 u' f% M8 d2 |0 ~8 N
% b0 ?, z6 s0 C* r
, k9 U, d1 }' q2 a b. ?5 e: N% X R还有就是两个输入输出函数:6 i8 J# H9 a3 i
void output_sample(Int32 out_data)
0 b+ r) V1 W! f) x: x. ~{/ {0 v% o3 _. z5 b2 i
AIC31_data.uint = out_data;
: `* G/ Q, j7 r$ {5 z! m! y MCASP1_XBUF5_32BIT = AIC31_data.uint;: `7 f, g: t% i# R7 x2 P M" @
}3 j& z& \8 P& [3 R) P0 L7 r
; |' M |6 r+ G. bInt32 input_sample(void). e; I% ?1 F" @- l
{
" \9 D4 p) i( K. {. |6 j. b$ _9 U0 V AIC31_data.uint = MCASP1_RBUF0_32BIT;
% f# \5 |, p1 E$ ?9 G return (AIC31_data.uint);, z- b8 T6 J+ S2 ~, J1 r
}# a# E+ \1 d+ W# p
! X" V6 M2 b% \; S! K4 j |
|