|
|
C6747和C6748感觉差不多,我想实现McASP发送中断方式控制音频信号,在轮询的例程基础上改的,轮询程序可以实现,但是中断一直实现不了,也找不到错误,求大神帮忙!下边是主要程序:
, `. L/ @8 _& N' smain文件:
5 e% K' w, I7 [! Sinterrupt void interrupt4(void)
& A5 I q* m/ z& \+ r( t/ F{" _3 }9 Z& `! m& C% ~
Uint32 sample;
5 d1 r6 Z, }8 N i% g$ L& |; p9 P4 _# ^
sample = input_sample(); // read L + R samples from ADC& w$ ?+ w7 G. g# ^7 |7 M
output_sample(sample); // write L + R samples to DAC
- C5 g) r8 [; v4 i, ^7 x return;# p/ X. K/ J* G3 m& t* S
}' z& `, @* x+ g+ Y5 Y. X6 k& z
+ G* D& @9 K$ L! D, Fint main( void )6 S6 F( z+ \$ j$ |0 Z
{
# u0 L! o% g2 m
: C$ k% U& l+ b2 J3 R# L' | /* Initialize BSL */. C4 u4 x7 @4 W% g1 z1 A" |+ p7 n
EVMC6747_init( );
. H: }) ~. S) o5 S$ n. s5 h- r) X( w; X /* Call evmc6747_intr function */
3 Z0 C1 t; i) g3 P1 o8 U m3 M, b aic3106_init( );
4 c( ?& C3 Z y" a; S4 r while(1);
, C" F0 Q% S6 K* @! i}: {/ W' d# n5 W" |
7 v4 M3 |) |1 I' E3 ~ S4 @+ c. A: X' r1 f; f7 O5 d0 ^; O
aic3106_init文件的一部分,McASP配置部分,采用内部时钟,I2S方式,同步传输。音频芯片的配置应该没问题
1 m# L8 s2 T& L4 S/* Initialize MCASP1 */
* q' C& ~: B! h& ^9 C mcasp = &MCASP_MODULE_1;
8 r% z% \5 t+ z" p$ {* p$ t mcasp->regs->GBLCTL = 0; // Reset* q7 b7 P; Y6 ?% C& G
mcasp->regs->RGBLCTL = 0; // Reset RX4 O. M9 I- G0 ]$ n$ G9 I5 T
mcasp->regs->XGBLCTL = 0; // Reset TX/ c" C/ j* C; p
mcasp->regs->PWRDEMU = 1; // Free-running6 Z+ T- n* w% C6 _8 S! Q
// configure McASP0 receive registers
3 X4 S! M) @: t+ U' \ mcasp->regs->RMASK = 0xFFFFFFFF; // No padding used
: k) Z' h: A4 g' }5 | mcasp->regs->RFMT = 0x00018078; // MSB 16bit, 0-delay, no pad, CFGBus4 l6 Z5 S# p+ w; |4 k7 q+ H/ s* q
mcasp->regs->AFSRCTL = 0x00000112; // 2TDM, 1bit Falling, External FS, word
* k, Z& l0 @7 n& @! b mcasp->regs->ACLKRCTL = 0x000000AF; // Rising INTERNAL CLK,(from tx side)2 B' Y8 ~: ~; p
mcasp->regs->AHCLKRCTL = 0x00000000; // INT CLK (from tx side)
- m& P9 Y+ [, \% i N4 i mcasp->regs->RTDM = 0x00000003; // Slots 0,1
6 ~0 B+ }+ O7 k9 S( g3 ]9 ] mcasp->regs->RINTCTL = 0x00000000; // Not used: B# p- ?( K H
mcasp->regs->RCLKCHK = 0x00FF0008; // 255-MAX 0-MIN, div-by-2567 f* n7 [! X; ~$ B6 [
# a' q* g- b/ n0 ^ mcasp->regs->XMASK = 0xFFFFFFFF; // No padding used
7 G* U* K' b! a) H( r* G mcasp->regs->XFMT = 0x00018078; // MSB 16bit, 0-delay, no pad, CFGBus
$ T% M* ^4 w6 n3 P+ `% g4 | k! u mcasp->regs->AFSXCTL = 0x00000112; // 2TDM, 1bit Rising edge INTERNAL FS, word
# J3 U- }: C% t5 c( k' w& y mcasp->regs->ACLKXCTL = 0x000000AF; // ASYNC, Rising INTERNAL CLK, div-by-16' \/ y6 t5 }/ F
mcasp->regs->AHCLKXCTL = 0x00000000; // EXT CLK
" r" }/ S! x: @1 k- t1 F' z mcasp->regs->XTDM = 0x00000003; // Slots 0,1
; F5 q/ m3 X/ J1 W' B mcasp->regs->XINTCTL = 0x00000020; // interrupt on transmit A3 C) z6 M1 ]
mcasp->regs->XCLKCHK = 0x00FF0008; // 255-MAX 0-MIN, div-by-256
1 M2 V" J# R0 h4 J* }7 W4 K3 n
3 l, p+ o$ V" u: g% p, N4 ~0 e mcasp->regs->SRCTL5 = 0x000D; // MCASP1.AXR1[5] --> DIN/ e' U' c# l# l# N+ W+ G
mcasp->regs->SRCTL0 = 0x000E; // MCASP1.AXR1[0] <-- DOUT
. C& b% u' g; x+ D mcasp->regs->PFUNC = 0; // All MCASPs- q- L! K B% k3 {8 v$ b/ n* \/ \
mcasp->regs->PDIR = 0x14000020; // All inputs except AXR0[5], ACLKX1, AFSX17 u0 H0 v9 F& p( h9 f' p
) r' V/ {: m8 c0 u- F3 m1 j
mcasp->regs->DITCTL = 0x00000000; // Not used
4 L5 L8 Z4 M* ] mcasp->regs->DLBCTL = 0x00000000; // Not used( Z. E; B0 z, P, O+ _" l
mcasp->regs->AMUTE = 0x00000000; // Not used+ i8 z% ~7 t7 C# J4 ~" r" ^
% y1 b, R& a. l
/* Starting sections of the McASP*/" H+ j, a9 [' M, h
mcasp->regs->XGBLCTL |= GBLCTL_XHCLKRST_ON; ) \6 _6 ?1 J7 a4 F& y' ]
while ( ( mcasp->regs->XGBLCTL & GBLCTL_XHCLKRST_ON ) != GBLCTL_XHCLKRST_ON ); 8 e7 U- x; O( m1 N
mcasp->regs->RGBLCTL |= GBLCTL_RHCLKRST_ON;
: {- n5 K. Q0 D while ( ( mcasp->regs->RGBLCTL & GBLCTL_RHCLKRST_ON ) != GBLCTL_RHCLKRST_ON );( p3 b3 I, {( U/ T" y2 y
: p* l x2 f- w' d6 r9 u( |3 q
mcasp->regs->XGBLCTL |= GBLCTL_XCLKRST_ON; : E7 j6 ` [% U1 t& p; U* n& Q
while ( ( mcasp->regs->XGBLCTL & GBLCTL_XCLKRST_ON ) != GBLCTL_XCLKRST_ON );: C" @# ^4 Q' X
mcasp->regs->RGBLCTL |= GBLCTL_RCLKRST_ON;
8 _7 i9 d9 g1 n( [# N) o while ( ( mcasp->regs->RGBLCTL & GBLCTL_RCLKRST_ON ) != GBLCTL_RCLKRST_ON );, P* d8 J6 r4 i: L! g; `) b
, p+ i6 v1 n6 _ m) e* {
mcasp->regs->XSTAT = 0x0000ffff; 9 t6 m& {8 O( S- {( `; \
mcasp->regs->RSTAT = 0x0000ffff; - s3 i4 Z& Q# z6 ~ d" E
' A/ |$ m+ M8 R9 R! | mcasp->regs->XGBLCTL |= GBLCTL_XSRCLR_ON;2 J0 z; f) v9 E$ R- Q$ X
while ( ( mcasp->regs->XGBLCTL & GBLCTL_XSRCLR_ON ) != GBLCTL_XSRCLR_ON );# N- m* V2 P6 S: n7 V! n
mcasp->regs->RGBLCTL |= GBLCTL_RSRCLR_ON; + g9 [1 [9 t. d7 z" v
while ( ( mcasp->regs->RGBLCTL & GBLCTL_RSRCLR_ON ) != GBLCTL_RSRCLR_ON );
$ F$ U0 ^' e- l& E+ J( j1 ~) V K) ~: W
/* Write a 0, so that no underrun occurs after releasing the state machine */
# B4 v2 X* Y+ @ mcasp->regs->XBUF5 = 0;
( X% V- o! W; B W5 }- R9 k" M mcasp->regs->RBUF0 = 0;/ |6 s4 s c. s9 d
) | ~( D& @3 j3 }3 l
mcasp->regs->XGBLCTL |= GBLCTL_XSMRST_ON;
' a% M* J( |' V% {+ ?( g; k while ( ( mcasp->regs->XGBLCTL & GBLCTL_XSMRST_ON ) != GBLCTL_XSMRST_ON );7 B7 R# o; a7 v6 \
mcasp->regs->RGBLCTL |= GBLCTL_RSMRST_ON;
0 H* P8 [# P, x3 j m& _ while ( ( mcasp->regs->RGBLCTL & GBLCTL_RSMRST_ON ) != GBLCTL_RSMRST_ON );
; V/ Y7 {! @2 \& k% W. q! K& g# C" |; r
mcasp->regs->XGBLCTL |= GBLCTL_XFRST_ON; ; `3 V' `; m' h0 N
while ( ( mcasp->regs->XGBLCTL & GBLCTL_XFRST_ON ) != GBLCTL_XFRST_ON );
+ [1 P6 o, G6 q. P' p! L/ ] mcasp->regs->RGBLCTL |= GBLCTL_RFRST_ON;
9 y2 M S: n8 S! R8 Q0 P" K0 { while ( ( mcasp->regs->RGBLCTL & GBLCTL_RFRST_ON ) != GBLCTL_RFRST_ON );2 I: ~& u/ j+ q6 \- ^
! |3 P1 b X- S9 |8 l
CSR = 0x0000;
5 n9 {8 ]; F* N. D INTC_INTMUX1 = 0x3d;( h$ {6 y) L6 V5 e6 b
ISTP = (unsigned int)vectors;. ?) }: p) l5 z. X# ~8 o* K4 T" `/ N
ICR = 0xFFF0;
- m2 S- I: r2 B0 y IER |= 0x12; $ j7 B: N3 K( u$ P& |9 k" q$ [ a: {7 B
CSR |= 0x01; & `$ D% q6 c/ C! e& E: y! @, z
5 ]% m8 c; H9 f2 O: M
7 f K; ?2 J6 Q, p' K) e% v5 Q
# g! M) [6 j: e( j% s8 {/ d( `还有就是两个输入输出函数:# c5 m& G+ i3 T: z
void output_sample(Int32 out_data)
+ a) z' U; p- C4 H{0 O5 `4 E& J( x( n; X0 e0 Y' F( [9 D
AIC31_data.uint = out_data; 0 ]4 q6 ]% T8 Q. i, S6 L
MCASP1_XBUF5_32BIT = AIC31_data.uint;; N9 M! i E {, O$ t% B
}. t! H3 S5 s" \+ r* ^" M# E
2 ~9 g& ^) D* z
Int32 input_sample(void)# b: ?5 M* x- o( O+ p: A1 i
{
0 u/ \* G# X. d9 F5 p/ C AIC31_data.uint = MCASP1_RBUF0_32BIT;; ]: ]7 P) p8 s) ?( m
return (AIC31_data.uint);
, x9 B' V: j8 k' u O1 R" x}
6 I8 {! t( U+ Y6 n) ]& ?) l" f# N5 v" H; |/ F
|
|