|
|
C6747和C6748感觉差不多,我想实现McASP发送中断方式控制音频信号,在轮询的例程基础上改的,轮询程序可以实现,但是中断一直实现不了,也找不到错误,求大神帮忙!下边是主要程序:. u% I; G4 U) l" O# y7 l& q" a7 S1 h
main文件:$ V2 t, N6 {6 g( p# K
interrupt void interrupt4(void) 8 a- o# W% ]! a' H
{
. N( _) ?3 @2 H( c" F/ z Uint32 sample;
6 Z; C& N* C; Z4 K) P( q1 g# P' O) G) m. E, h8 ^/ s3 W) n9 q
sample = input_sample(); // read L + R samples from ADC
9 d* r U5 a9 r' f& o; Z/ ` output_sample(sample); // write L + R samples to DAC % g6 \3 u: z$ V" s6 w. @+ }
return;3 J5 L* I1 u) q) v7 w1 J w0 H( D
}
! k) d0 O* k( a' O+ Y5 _
( y7 C7 A7 m/ Y- f& W, Vint main( void )
9 [5 m$ t, `- q$ d; B{
5 T2 l4 ~! ]4 W- Z- n, M1 \: \( V% P; @" n, j2 o; k3 R) f' _( _" I
/* Initialize BSL */
5 L& I2 h0 n. C# S' p: E" [6 h EVMC6747_init( );
/ ]5 M) \8 r/ b, ^3 k" P /* Call evmc6747_intr function */
4 Y8 K t( O' {7 y3 d aic3106_init( );
- }4 E+ S; k/ D! L8 v0 G while(1);
4 d$ |8 v0 y- v; d7 m1 g}
( D/ G' ^# h5 }* `: A' S3 x, Q: \4 S) O' ^# ?; S v0 u$ t
. ^& H1 R, X% i4 h4 O
aic3106_init文件的一部分,McASP配置部分,采用内部时钟,I2S方式,同步传输。音频芯片的配置应该没问题$ ^) f: P, {- o+ P- c
/* Initialize MCASP1 */
( L" L- B, b4 o6 k# c# F' L5 q- \/ m mcasp = &MCASP_MODULE_1;, C$ E" s, K+ s, n1 a
mcasp->regs->GBLCTL = 0; // Reset
! Z5 x7 ]/ M3 `' p mcasp->regs->RGBLCTL = 0; // Reset RX
, Z5 e" n, t8 c/ B7 l' D mcasp->regs->XGBLCTL = 0; // Reset TX
0 e- E6 t5 J: Q' l0 ?7 d mcasp->regs->PWRDEMU = 1; // Free-running7 \) r7 h/ G9 }. g0 a
// configure McASP0 receive registers8 A8 ^; g/ ^$ H0 k
mcasp->regs->RMASK = 0xFFFFFFFF; // No padding used; L: X# \: [, `
mcasp->regs->RFMT = 0x00018078; // MSB 16bit, 0-delay, no pad, CFGBus
( v# O' t& r% R- } mcasp->regs->AFSRCTL = 0x00000112; // 2TDM, 1bit Falling, External FS, word! ]9 O" C1 U: h! y
mcasp->regs->ACLKRCTL = 0x000000AF; // Rising INTERNAL CLK,(from tx side)
& _8 X$ Q, S( g( j0 m mcasp->regs->AHCLKRCTL = 0x00000000; // INT CLK (from tx side) u) P& X- c8 k+ }
mcasp->regs->RTDM = 0x00000003; // Slots 0,1
( K5 z! H _" s8 Y( Z$ x5 L mcasp->regs->RINTCTL = 0x00000000; // Not used
9 n1 e' Z! k8 y/ U' q- @ mcasp->regs->RCLKCHK = 0x00FF0008; // 255-MAX 0-MIN, div-by-256
7 X+ e. h( y, `. z; z( e# T2 j6 z# R2 T2 o& Z
mcasp->regs->XMASK = 0xFFFFFFFF; // No padding used
; D8 P. q7 @9 \& M: X mcasp->regs->XFMT = 0x00018078; // MSB 16bit, 0-delay, no pad, CFGBus! t9 G5 a9 y' w+ w: Z
mcasp->regs->AFSXCTL = 0x00000112; // 2TDM, 1bit Rising edge INTERNAL FS, word
q6 d0 H# Y, g mcasp->regs->ACLKXCTL = 0x000000AF; // ASYNC, Rising INTERNAL CLK, div-by-16( `, V5 h& t/ T# v- p
mcasp->regs->AHCLKXCTL = 0x00000000; // EXT CLK) i) J, k3 `) I- s+ c: \
mcasp->regs->XTDM = 0x00000003; // Slots 0,1
; }1 K( ], a' F0 r! x7 g mcasp->regs->XINTCTL = 0x00000020; // interrupt on transmit
0 Z. i7 L8 z8 ~7 _& G" f/ [. N+ P mcasp->regs->XCLKCHK = 0x00FF0008; // 255-MAX 0-MIN, div-by-256
c& R9 j1 f" R8 W M
" X; P. `' Q) Y+ \5 p mcasp->regs->SRCTL5 = 0x000D; // MCASP1.AXR1[5] --> DIN
3 A" P/ b8 O. @9 R3 O mcasp->regs->SRCTL0 = 0x000E; // MCASP1.AXR1[0] <-- DOUT1 _; F% [( `* F) C# X" c ?6 s2 j
mcasp->regs->PFUNC = 0; // All MCASPs
$ z$ q8 s( W% `9 k t. h" V6 m mcasp->regs->PDIR = 0x14000020; // All inputs except AXR0[5], ACLKX1, AFSX14 l- u! E+ ^: v* Z: E" u
4 E# o5 X+ ^% K# n4 W# f# A mcasp->regs->DITCTL = 0x00000000; // Not used7 _! _2 }; u9 s9 u( Q/ T$ r
mcasp->regs->DLBCTL = 0x00000000; // Not used
" {9 T& d! ?9 M/ ~$ ^5 o1 V6 p mcasp->regs->AMUTE = 0x00000000; // Not used$ t6 s6 [3 E7 \! P9 k
- e! H/ L( L2 }6 v/* Starting sections of the McASP*/) {6 {+ d i/ w. l
mcasp->regs->XGBLCTL |= GBLCTL_XHCLKRST_ON;
% E x8 U# Y1 V7 L- z; U( Q) D$ X" ] while ( ( mcasp->regs->XGBLCTL & GBLCTL_XHCLKRST_ON ) != GBLCTL_XHCLKRST_ON );
1 T7 r+ k8 N# D' d mcasp->regs->RGBLCTL |= GBLCTL_RHCLKRST_ON; % h V" c3 A5 [5 l% O3 o9 r1 i
while ( ( mcasp->regs->RGBLCTL & GBLCTL_RHCLKRST_ON ) != GBLCTL_RHCLKRST_ON );6 T- R0 o9 J9 j" G/ D
4 ^* |1 w( \' c5 e2 J5 a0 \3 a
mcasp->regs->XGBLCTL |= GBLCTL_XCLKRST_ON; ) D, U4 {; h/ W5 g n! T
while ( ( mcasp->regs->XGBLCTL & GBLCTL_XCLKRST_ON ) != GBLCTL_XCLKRST_ON );$ h" {5 I6 V" e6 ]* P
mcasp->regs->RGBLCTL |= GBLCTL_RCLKRST_ON; # G" Q; M$ `+ ?; E6 w
while ( ( mcasp->regs->RGBLCTL & GBLCTL_RCLKRST_ON ) != GBLCTL_RCLKRST_ON );# S8 ^+ w" j, ]' V) n* H; n% v
L! w! }# G+ v, \ mcasp->regs->XSTAT = 0x0000ffff; / d- Q/ \$ }" t0 [
mcasp->regs->RSTAT = 0x0000ffff;
. V! k0 h# M$ d1 W. W* {7 i/ f" F: T6 [ }+ n. H
mcasp->regs->XGBLCTL |= GBLCTL_XSRCLR_ON;
/ j1 a: S5 r6 ^+ ~; ?7 E while ( ( mcasp->regs->XGBLCTL & GBLCTL_XSRCLR_ON ) != GBLCTL_XSRCLR_ON );2 G: {8 g) |% y0 |1 x1 w6 l
mcasp->regs->RGBLCTL |= GBLCTL_RSRCLR_ON; # q9 u7 \+ z3 X+ y* d
while ( ( mcasp->regs->RGBLCTL & GBLCTL_RSRCLR_ON ) != GBLCTL_RSRCLR_ON );, E4 c3 t9 J$ B
7 Y1 O9 ]' u" C+ d" a9 t# i- V
/* Write a 0, so that no underrun occurs after releasing the state machine */' \9 ]/ t' r1 b; v, t. i% w
mcasp->regs->XBUF5 = 0;: `) z- j$ ]/ P" c) S* F2 L
mcasp->regs->RBUF0 = 0;
6 K4 r0 t8 U: J9 [9 w Q8 W2 T5 O) ? N, v1 L x8 a" {7 s) h
mcasp->regs->XGBLCTL |= GBLCTL_XSMRST_ON; 8 h- |" h" O. n1 L7 H
while ( ( mcasp->regs->XGBLCTL & GBLCTL_XSMRST_ON ) != GBLCTL_XSMRST_ON );+ B; x8 s! y- h, r4 W, l0 r$ x$ R
mcasp->regs->RGBLCTL |= GBLCTL_RSMRST_ON;
" y, W. W0 u" R- ]- n+ d while ( ( mcasp->regs->RGBLCTL & GBLCTL_RSMRST_ON ) != GBLCTL_RSMRST_ON );
8 P6 P' J& J$ M# P, f+ T& c" i1 d7 K
mcasp->regs->XGBLCTL |= GBLCTL_XFRST_ON; 1 ?. J+ h/ ]: }" y7 {
while ( ( mcasp->regs->XGBLCTL & GBLCTL_XFRST_ON ) != GBLCTL_XFRST_ON );
2 \1 H0 y6 v. P mcasp->regs->RGBLCTL |= GBLCTL_RFRST_ON;
& p6 ^$ y& h" `) j, C' w$ d, ] while ( ( mcasp->regs->RGBLCTL & GBLCTL_RFRST_ON ) != GBLCTL_RFRST_ON );6 {4 c3 Q% A7 V* ~2 O
4 F# B% }) a' i1 _+ q
CSR = 0x0000;8 W1 y. v2 }; c; M
INTC_INTMUX1 = 0x3d;' Y7 m# q$ ^8 m. x! q
ISTP = (unsigned int)vectors;
2 S- h6 m1 M1 j7 W; V0 f ICR = 0xFFF0;
+ d& I1 R I) B" D IER |= 0x12; + {; ~0 { L, \- Y
CSR |= 0x01;
" J5 }6 ^3 Q$ z+ \' C4 \( y7 m) I/ T, f6 u/ O) A
; p) C% Z1 P* f! \
; p" g4 n4 O o6 b还有就是两个输入输出函数:* h7 d1 ^! c) X& l5 v
void output_sample(Int32 out_data)
7 [ ?2 m i- F# Q{: Z% L) n: f: D4 D; X
AIC31_data.uint = out_data; @6 C1 p2 P% M- r6 U( V
MCASP1_XBUF5_32BIT = AIC31_data.uint;
8 m- s. ]( a% b" s9 z3 |}; C- H# L( U4 i; A
' ]5 m: l' L+ j
Int32 input_sample(void)
6 L" c C, D) o8 `{ 4 Q$ Y4 R) @/ X* e+ R6 T1 }
AIC31_data.uint = MCASP1_RBUF0_32BIT;1 o4 L, q j& I. {( g0 q/ y8 U
return (AIC31_data.uint);
! [$ X% h! _" g/ r/ `5 N}) {- N# J2 D+ }* K( V N/ E# p* e. |
( H5 r. u6 G1 G, Y9 s. } |
|