|
|
C6747和C6748感觉差不多,我想实现McASP发送中断方式控制音频信号,在轮询的例程基础上改的,轮询程序可以实现,但是中断一直实现不了,也找不到错误,求大神帮忙!下边是主要程序:2 ~ p9 s7 z) k5 |) q
main文件:
x% c4 z0 U3 b" Q& J# A# ], iinterrupt void interrupt4(void)
# d6 M! U/ C1 r7 g- k$ X{+ @' \, v7 q: O( y) k; G
Uint32 sample;
1 j# [% B- O s
5 m: `6 H, b- m% U5 b! H! ] sample = input_sample(); // read L + R samples from ADC6 u$ r; n g G6 E6 ]* U# L3 e
output_sample(sample); // write L + R samples to DAC 0 r0 {. a, ^7 I( R/ |( f
return;4 L- c4 r; s6 K: A& G. a5 [
}
. Z) J! {+ z8 o3 {% A- C3 y
+ y2 J# f; @; d7 k8 u4 Oint main( void )
, X4 U6 h- f$ G" K5 x8 ?: N{
% K- r: E8 T: X& b9 N
$ d3 a2 L# g! w0 P/ J! N) G& A2 k4 p /* Initialize BSL */
8 X0 P# ^" J, v5 c! a EVMC6747_init( );& ] \0 P& J2 B. F
/* Call evmc6747_intr function */
0 j. ?6 a7 ]$ A6 R' e5 Q$ L aic3106_init( );5 ?9 y# y! J% ]+ u* t
while(1);4 a# l) o7 x& v- P+ n6 @" x
}) ?; ~2 S( s" l# B
* e; e( n, L. C! F: O$ C! V0 y1 @* q" l3 V
aic3106_init文件的一部分,McASP配置部分,采用内部时钟,I2S方式,同步传输。音频芯片的配置应该没问题% k% D/ g3 W6 i5 e( J
/* Initialize MCASP1 */% O: Q9 ?: J; D. V/ L
mcasp = &MCASP_MODULE_1;
" n @! w) m7 r( M mcasp->regs->GBLCTL = 0; // Reset( Z; F! C; _* P
mcasp->regs->RGBLCTL = 0; // Reset RX9 j% Z; q: ?& L7 W6 ?- ?5 O
mcasp->regs->XGBLCTL = 0; // Reset TX
3 R8 f$ j/ |5 z4 A mcasp->regs->PWRDEMU = 1; // Free-running
1 F+ t+ P0 a% o e // configure McASP0 receive registers
5 s, M; ^9 K4 R1 f1 `0 G mcasp->regs->RMASK = 0xFFFFFFFF; // No padding used4 p0 _9 N( F' U6 c i
mcasp->regs->RFMT = 0x00018078; // MSB 16bit, 0-delay, no pad, CFGBus/ K6 W/ @0 f& k& J
mcasp->regs->AFSRCTL = 0x00000112; // 2TDM, 1bit Falling, External FS, word
3 D, H( J/ O: O, ] mcasp->regs->ACLKRCTL = 0x000000AF; // Rising INTERNAL CLK,(from tx side)! O ~0 ^0 B# t& C7 y: ~7 F
mcasp->regs->AHCLKRCTL = 0x00000000; // INT CLK (from tx side); ^& U' a1 H! C0 F3 v' [6 _
mcasp->regs->RTDM = 0x00000003; // Slots 0,12 I5 ^, a6 k1 x" q ~# _
mcasp->regs->RINTCTL = 0x00000000; // Not used
+ g7 |9 Z: h7 L) n$ |! K6 E mcasp->regs->RCLKCHK = 0x00FF0008; // 255-MAX 0-MIN, div-by-256
+ K6 i3 ], _& B/ M$ |& X
* E- I0 t8 ?. b) `' d mcasp->regs->XMASK = 0xFFFFFFFF; // No padding used
1 d8 d: S2 g0 N mcasp->regs->XFMT = 0x00018078; // MSB 16bit, 0-delay, no pad, CFGBus
0 H, v9 }7 T, ~9 g mcasp->regs->AFSXCTL = 0x00000112; // 2TDM, 1bit Rising edge INTERNAL FS, word
% c5 D4 _0 i, q# s v+ m+ Z8 P mcasp->regs->ACLKXCTL = 0x000000AF; // ASYNC, Rising INTERNAL CLK, div-by-16
- V$ w- ]0 t4 q. D1 B. X l mcasp->regs->AHCLKXCTL = 0x00000000; // EXT CLK$ C7 ~. n/ n5 v( L
mcasp->regs->XTDM = 0x00000003; // Slots 0,1
% m' L" o" h- Y1 @' e3 z mcasp->regs->XINTCTL = 0x00000020; // interrupt on transmit
0 [( U: u4 ~* ~- |7 I9 N) K mcasp->regs->XCLKCHK = 0x00FF0008; // 255-MAX 0-MIN, div-by-256* P8 v- O% j8 g! ]$ z- }! G) ? j, s
+ |* F, c2 q1 ~5 n; I3 u mcasp->regs->SRCTL5 = 0x000D; // MCASP1.AXR1[5] --> DIN0 R6 t0 ]9 P4 }" p# M: c+ D% D
mcasp->regs->SRCTL0 = 0x000E; // MCASP1.AXR1[0] <-- DOUT+ ~1 Z3 |9 \" z3 c% f$ _
mcasp->regs->PFUNC = 0; // All MCASPs: i8 A$ Z4 K/ W2 P) A$ Y4 l! ]
mcasp->regs->PDIR = 0x14000020; // All inputs except AXR0[5], ACLKX1, AFSX1
: H1 F, ?! v5 J: S: E0 D( C4 {2 w' j! x5 x6 ?: q
mcasp->regs->DITCTL = 0x00000000; // Not used
. W( J5 n7 W: o6 W2 V$ D" o' q mcasp->regs->DLBCTL = 0x00000000; // Not used
. P2 R0 e8 ^5 ]7 j mcasp->regs->AMUTE = 0x00000000; // Not used
! X+ ^1 S! o0 d$ r2 ]6 L& B1 N; [7 r" x1 \. D, n7 Q1 d
/* Starting sections of the McASP*/
& E+ J0 Z, I" r9 K' O+ L4 ^, Q3 _ mcasp->regs->XGBLCTL |= GBLCTL_XHCLKRST_ON;
5 g) a+ `+ \* a& G9 Y8 T& G while ( ( mcasp->regs->XGBLCTL & GBLCTL_XHCLKRST_ON ) != GBLCTL_XHCLKRST_ON ); 2 k3 D! k' Y! I- b2 W
mcasp->regs->RGBLCTL |= GBLCTL_RHCLKRST_ON;
5 x& u! l$ ]2 Z7 M& u6 A while ( ( mcasp->regs->RGBLCTL & GBLCTL_RHCLKRST_ON ) != GBLCTL_RHCLKRST_ON );% k0 c! V* h/ d& A4 [
8 a* _. u6 T }1 C' c
mcasp->regs->XGBLCTL |= GBLCTL_XCLKRST_ON; 6 N4 p- y% M' ~. E6 U. _& l. u
while ( ( mcasp->regs->XGBLCTL & GBLCTL_XCLKRST_ON ) != GBLCTL_XCLKRST_ON );" c5 @0 w! P5 j
mcasp->regs->RGBLCTL |= GBLCTL_RCLKRST_ON; 8 y# H0 ~0 c% D8 F h
while ( ( mcasp->regs->RGBLCTL & GBLCTL_RCLKRST_ON ) != GBLCTL_RCLKRST_ON );
# J& G. P5 _0 l$ J$ x4 @( h3 t$ e/ K" D
mcasp->regs->XSTAT = 0x0000ffff; 0 z+ W* H+ w( d- H n
mcasp->regs->RSTAT = 0x0000ffff;
* M- d3 ~ T4 X# V* D8 Q+ p9 Z: \' B' T- R5 k
mcasp->regs->XGBLCTL |= GBLCTL_XSRCLR_ON;) E8 J# L' y0 Y D7 Z* n. z8 S
while ( ( mcasp->regs->XGBLCTL & GBLCTL_XSRCLR_ON ) != GBLCTL_XSRCLR_ON );
; k. g: l3 x5 F; Y5 M mcasp->regs->RGBLCTL |= GBLCTL_RSRCLR_ON;
6 Q+ W5 M' J. p3 t/ v while ( ( mcasp->regs->RGBLCTL & GBLCTL_RSRCLR_ON ) != GBLCTL_RSRCLR_ON );
* a) @& j, r' w4 ]: g! ^2 ~* P( ~
/* Write a 0, so that no underrun occurs after releasing the state machine */
3 R c. J: I" \ mcasp->regs->XBUF5 = 0;
2 p/ f+ B+ w, r+ X mcasp->regs->RBUF0 = 0;
! ]" Y0 ]* B8 X, _9 k2 x; u
) T @# E( t5 |, z( V9 z, z; @ mcasp->regs->XGBLCTL |= GBLCTL_XSMRST_ON;
! n5 B+ V, p1 Q7 ~4 ^ while ( ( mcasp->regs->XGBLCTL & GBLCTL_XSMRST_ON ) != GBLCTL_XSMRST_ON );7 K. v5 m5 V2 U3 d7 C8 e
mcasp->regs->RGBLCTL |= GBLCTL_RSMRST_ON; ) Y+ P; c1 h- b9 N' t
while ( ( mcasp->regs->RGBLCTL & GBLCTL_RSMRST_ON ) != GBLCTL_RSMRST_ON );
. O" M2 I5 j+ H7 y$ J6 Y) @3 B$ H5 d7 r8 ]$ f5 L
mcasp->regs->XGBLCTL |= GBLCTL_XFRST_ON; 2 b# j( J5 m/ V$ {& G6 _( Q
while ( ( mcasp->regs->XGBLCTL & GBLCTL_XFRST_ON ) != GBLCTL_XFRST_ON );
, U7 U' r3 s- C. Q+ U mcasp->regs->RGBLCTL |= GBLCTL_RFRST_ON; 9 c$ g% `) U o6 k& C7 e
while ( ( mcasp->regs->RGBLCTL & GBLCTL_RFRST_ON ) != GBLCTL_RFRST_ON );
8 f& n) ?7 @3 L! K' z
. f, |, M# q$ c; D CSR = 0x0000;
4 h$ A3 p6 [ @ INTC_INTMUX1 = 0x3d;# s3 x! Z4 K9 ]
ISTP = (unsigned int)vectors;
- ~/ X7 x- H L u6 X# x ICR = 0xFFF0; ( ]% T7 D: m6 E6 p$ {6 R# z: `
IER |= 0x12;
e8 Z; i7 _4 c" w* j CSR |= 0x01;
7 e$ m3 f/ a) R4 `8 l) U' r! v8 P c7 y: J: @, C
" m/ Y% k3 e P' `6 g1 J6 C& q9 }9 J
还有就是两个输入输出函数:9 V9 h5 K% v% G6 z
void output_sample(Int32 out_data) i* i7 J; O2 q! ?
{
3 R! Y$ a, e0 T AIC31_data.uint = out_data;
5 W! {& e. z6 B% o" {% \ MCASP1_XBUF5_32BIT = AIC31_data.uint;( i( M, P) u& O0 s0 j
}7 j3 ]) q! \) }5 }' K
4 n/ n# a# p5 `; t- v
Int32 input_sample(void)
2 l! \! E1 c0 t. y{ , o$ ~, }, h4 M, I$ D* P( `0 J
AIC31_data.uint = MCASP1_RBUF0_32BIT;
+ f! g3 z' ]. n4 U3 q% u; {: K return (AIC31_data.uint);' R( n7 b4 t8 _' A
}
% n4 P# F2 C+ i- W' N& X
' e e# s5 Z7 W* b* v: t |
|