|
|
C6747和C6748感觉差不多,我想实现McASP发送中断方式控制音频信号,在轮询的例程基础上改的,轮询程序可以实现,但是中断一直实现不了,也找不到错误,求大神帮忙!下边是主要程序:: H5 P- F6 q$ d1 a; n9 ]
main文件:
$ l( D" e+ N0 u0 E# w% Hinterrupt void interrupt4(void) , S, I( R6 T5 C9 q4 A) X! B# V
{
8 ]9 a4 e w0 A! c. |: J3 M2 E Uint32 sample;3 c7 \/ ~# t! A0 P* s& d( g8 c
0 h& n& k# z7 v3 j9 t! t3 Q
sample = input_sample(); // read L + R samples from ADC
/ A* h* R) e# P8 U5 n' [4 a" I, r output_sample(sample); // write L + R samples to DAC
! \' u$ S0 _4 ?" x$ J/ g6 d return;; }8 u S. W. ]" E
}9 b7 k) u b/ R
2 m6 R4 z: P8 V! s$ ]$ ?int main( void )
- C! r% d, A' ?4 I M. I{
9 n$ r/ ]; T7 t. r! ?( L( u
4 q7 X& A) ]# [9 @! @' \( Z /* Initialize BSL */
2 Z! K3 I( R1 ^ EVMC6747_init( );
: F& R5 L9 n K7 Y: ]# n$ D /* Call evmc6747_intr function */
1 f% {2 w: v! O; ]! i aic3106_init( );4 c1 M( G" ]7 b7 `! D* O, j
while(1);7 z! z9 [3 Z+ Z4 g# v9 C% E- w
}
' _1 ?7 C3 H" ~1 K2 ~3 a: u$ f/ ]2 A
, \# ?0 R* }: K" i; I* }
aic3106_init文件的一部分,McASP配置部分,采用内部时钟,I2S方式,同步传输。音频芯片的配置应该没问题
* S2 D% j2 U2 G# Y: z, N/* Initialize MCASP1 */# T2 `9 m0 U: \ `4 M. H
mcasp = &MCASP_MODULE_1;8 C( Q. M8 K% q( u% h! f# F- W5 V
mcasp->regs->GBLCTL = 0; // Reset+ n7 ^% K1 K1 Z/ H# y7 g
mcasp->regs->RGBLCTL = 0; // Reset RX
6 b" S. a/ H1 F; `6 d mcasp->regs->XGBLCTL = 0; // Reset TX; @6 |0 a: v7 o) [. l$ w4 j) [! q5 _
mcasp->regs->PWRDEMU = 1; // Free-running: \2 Y* U& O ?1 j( O) B
// configure McASP0 receive registers' g; u K5 s6 f6 M
mcasp->regs->RMASK = 0xFFFFFFFF; // No padding used
- @! @6 |# h2 n mcasp->regs->RFMT = 0x00018078; // MSB 16bit, 0-delay, no pad, CFGBus
$ M" R+ C9 H0 k' L" E3 X) N0 c+ y mcasp->regs->AFSRCTL = 0x00000112; // 2TDM, 1bit Falling, External FS, word
e' i( h6 g4 Y$ {, u+ @# W mcasp->regs->ACLKRCTL = 0x000000AF; // Rising INTERNAL CLK,(from tx side)
. }; H7 S% L! j8 B' S mcasp->regs->AHCLKRCTL = 0x00000000; // INT CLK (from tx side)$ [3 C+ h6 q4 J% P, k7 B
mcasp->regs->RTDM = 0x00000003; // Slots 0,1
* D' e6 H( a1 P9 t5 [" w0 C mcasp->regs->RINTCTL = 0x00000000; // Not used- O2 u* o% \6 U1 S& x7 m# u: Y
mcasp->regs->RCLKCHK = 0x00FF0008; // 255-MAX 0-MIN, div-by-256$ e2 m) {' T$ ?1 M& \& ^8 ]
! N+ b# o: [& |
mcasp->regs->XMASK = 0xFFFFFFFF; // No padding used5 N9 T$ A( h' t
mcasp->regs->XFMT = 0x00018078; // MSB 16bit, 0-delay, no pad, CFGBus
2 _+ d7 m5 ?! I+ }) b. n mcasp->regs->AFSXCTL = 0x00000112; // 2TDM, 1bit Rising edge INTERNAL FS, word
, u( a" J# V% ^0 S! n: p mcasp->regs->ACLKXCTL = 0x000000AF; // ASYNC, Rising INTERNAL CLK, div-by-16% {5 ]$ g$ z& q; x' D
mcasp->regs->AHCLKXCTL = 0x00000000; // EXT CLK$ D- d2 h( m3 n. n" p4 W2 T
mcasp->regs->XTDM = 0x00000003; // Slots 0,1
. _6 l6 e: W$ X$ ] mcasp->regs->XINTCTL = 0x00000020; // interrupt on transmit
5 X: t+ d6 q4 S q mcasp->regs->XCLKCHK = 0x00FF0008; // 255-MAX 0-MIN, div-by-256# d! S2 K' f" ]) k5 U# ]5 ~+ o) n
. {+ }; B5 w0 B c; v) Z' C mcasp->regs->SRCTL5 = 0x000D; // MCASP1.AXR1[5] --> DIN/ z, S1 ^, p1 }
mcasp->regs->SRCTL0 = 0x000E; // MCASP1.AXR1[0] <-- DOUT
6 |# @. X& |8 J5 A5 l- N mcasp->regs->PFUNC = 0; // All MCASPs
3 y+ K) q" N a" ~ mcasp->regs->PDIR = 0x14000020; // All inputs except AXR0[5], ACLKX1, AFSX1* G9 u* C. h! i: [3 {* v6 B
, y, S- r. }( T# m4 a! B0 ^ n6 E mcasp->regs->DITCTL = 0x00000000; // Not used
; E8 I4 _5 k" T5 _: N mcasp->regs->DLBCTL = 0x00000000; // Not used9 M2 C: L- A' D+ ?0 i+ }, ^
mcasp->regs->AMUTE = 0x00000000; // Not used6 P# B3 `# O7 e/ T
! j% c) E& h' x2 A' g9 \( u
/* Starting sections of the McASP*/
. {1 k+ D7 T: K8 k8 { mcasp->regs->XGBLCTL |= GBLCTL_XHCLKRST_ON;
7 I* D% ~% D! s" G2 X. H( w while ( ( mcasp->regs->XGBLCTL & GBLCTL_XHCLKRST_ON ) != GBLCTL_XHCLKRST_ON );
2 ?4 g5 G) [( Y. E mcasp->regs->RGBLCTL |= GBLCTL_RHCLKRST_ON;
. |# o0 k1 _3 t: @* ?, n& @( W while ( ( mcasp->regs->RGBLCTL & GBLCTL_RHCLKRST_ON ) != GBLCTL_RHCLKRST_ON );# y, O/ Z; f# W# U1 _
2 m3 u4 x' U& b$ G mcasp->regs->XGBLCTL |= GBLCTL_XCLKRST_ON; 8 l/ h7 {8 v9 t) O4 p1 v3 }
while ( ( mcasp->regs->XGBLCTL & GBLCTL_XCLKRST_ON ) != GBLCTL_XCLKRST_ON );" B8 c% Z- c5 B, j9 D; m. q; }
mcasp->regs->RGBLCTL |= GBLCTL_RCLKRST_ON;
+ M# M/ q8 F% g2 \% \8 ]" y while ( ( mcasp->regs->RGBLCTL & GBLCTL_RCLKRST_ON ) != GBLCTL_RCLKRST_ON );
! d; R8 f8 u3 @! S
l% a3 X: J& }) `; N mcasp->regs->XSTAT = 0x0000ffff; . R1 ^9 b; n; Z9 b2 m5 b7 v) a& J
mcasp->regs->RSTAT = 0x0000ffff;
9 E6 {* H' Y$ N) u& |
8 f0 |9 D d4 t8 { mcasp->regs->XGBLCTL |= GBLCTL_XSRCLR_ON;
- k: `" ?/ }& e while ( ( mcasp->regs->XGBLCTL & GBLCTL_XSRCLR_ON ) != GBLCTL_XSRCLR_ON );
- s- W9 v& C2 a mcasp->regs->RGBLCTL |= GBLCTL_RSRCLR_ON; v3 J* w6 l2 C: H, X
while ( ( mcasp->regs->RGBLCTL & GBLCTL_RSRCLR_ON ) != GBLCTL_RSRCLR_ON );
1 m; F" H$ n* c1 U2 N( O# a: E; j
6 D9 a) |8 k" |( Y /* Write a 0, so that no underrun occurs after releasing the state machine */
+ p& Q$ ]7 |3 N2 Q: E3 K' G* t mcasp->regs->XBUF5 = 0;
7 c6 w9 m& y: R1 T) K* L mcasp->regs->RBUF0 = 0;
/ A2 n5 G" r9 N9 n
5 G% B5 J- Z$ C! L9 V# K mcasp->regs->XGBLCTL |= GBLCTL_XSMRST_ON; 9 x* d0 D- d; O" y% N
while ( ( mcasp->regs->XGBLCTL & GBLCTL_XSMRST_ON ) != GBLCTL_XSMRST_ON );
1 l, i S% @# F* d mcasp->regs->RGBLCTL |= GBLCTL_RSMRST_ON;
+ J9 D$ C6 m! ], }' S: f ` while ( ( mcasp->regs->RGBLCTL & GBLCTL_RSMRST_ON ) != GBLCTL_RSMRST_ON );
, a3 ^. Q2 f3 D5 M, L/ A) b' P' t6 v) {% M1 P9 y2 G
mcasp->regs->XGBLCTL |= GBLCTL_XFRST_ON; ! O9 N+ w/ S9 m. x$ l* q
while ( ( mcasp->regs->XGBLCTL & GBLCTL_XFRST_ON ) != GBLCTL_XFRST_ON );3 w' V( K& e: W8 Y7 W/ x6 e, y& w
mcasp->regs->RGBLCTL |= GBLCTL_RFRST_ON; ! f9 \. }; B3 @7 q
while ( ( mcasp->regs->RGBLCTL & GBLCTL_RFRST_ON ) != GBLCTL_RFRST_ON );
) ^ P# u( ]8 P6 k" O% R; v, h) u8 A' B4 }2 ^
CSR = 0x0000;# g9 k% p! Z$ B6 m i# `
INTC_INTMUX1 = 0x3d;
9 S4 B1 D* k9 ]' Y! J! A ISTP = (unsigned int)vectors;
& O7 b0 @$ Y7 f% X# k7 w: q" ` ICR = 0xFFF0;
' k5 M T+ I: W1 p IER |= 0x12;
$ u7 Z1 B+ E8 ^ CSR |= 0x01; 3 i- W3 \! X6 }/ H8 U# ^% g0 X
8 m% G* y3 g) W9 L. Z& z T+ Y! T S
$ |0 K# i! d- Y4 Q6 G/ a1 ~
还有就是两个输入输出函数:$ |0 H% R5 ~+ H! a+ h4 ?5 {
void output_sample(Int32 out_data)
! r, M! ?8 a8 k4 H8 x% P{- m/ G6 I; p7 r9 q' C; ]/ m
AIC31_data.uint = out_data;
7 S* T) W; P; }* r. o. R MCASP1_XBUF5_32BIT = AIC31_data.uint;
! J. U( f8 k$ Y* w# Z( A& c9 C/ A}0 o' [. m9 q; \9 q+ H0 |
; x/ C! ~7 w: c% w% c" k
Int32 input_sample(void)* l" D% J4 r: }/ U
{ + R$ F+ C" M. Z1 O
AIC31_data.uint = MCASP1_RBUF0_32BIT;& a& T2 [# b3 J: ^
return (AIC31_data.uint);
/ g; t N8 V) J/ Z( U8 K}
$ e0 H- L! d+ h( W. E4 p" s. H' m4 [% k0 j2 }3 E$ u
|
|