|
|
C6747和C6748感觉差不多,我想实现McASP发送中断方式控制音频信号,在轮询的例程基础上改的,轮询程序可以实现,但是中断一直实现不了,也找不到错误,求大神帮忙!下边是主要程序:* W y1 m, V3 P4 v
main文件:; V' ?4 }+ `* S4 I( k1 \
interrupt void interrupt4(void)
: i7 \! f* T3 `/ f1 U{
9 S4 }' n' e2 d6 t B+ ^! I; i5 `) A) ^ Uint32 sample;
0 l/ c3 L# e% p% e) V9 r } }% ^9 M1 F4 A7 N
sample = input_sample(); // read L + R samples from ADC
& E9 M( p* Y w$ H output_sample(sample); // write L + R samples to DAC * `' W# y* r; g0 k0 s F
return;1 M5 b/ N5 v+ j$ Q2 P7 c
}% u0 ~9 o" ]" W% {
: e2 o2 Z X" W$ h$ |9 i8 Gint main( void )2 ^$ C. U) U! F( ]2 |
{
7 U- q& c, r: R7 { a7 Q1 E! f( k/ g/ z7 G+ f+ O
/* Initialize BSL */" S/ M! W$ |; T% ^/ G& Y; b
EVMC6747_init( );* q$ t3 T# `$ ]4 Y) u
/* Call evmc6747_intr function */
5 V% Q) j# t: \# _' x% P aic3106_init( );* d( T. k, Q4 A6 J
while(1);, a3 ~6 F. Q7 k
} J" l7 H" a3 I3 k
5 K7 \9 `$ F3 b6 }
0 N% Y: z. P9 R z. ?9 J8 m/ Y
aic3106_init文件的一部分,McASP配置部分,采用内部时钟,I2S方式,同步传输。音频芯片的配置应该没问题/ v% r" l! x. Z( j4 N2 b* n
/* Initialize MCASP1 */* ?! B3 y; I( j4 n. X9 Z
mcasp = &MCASP_MODULE_1;, }! t3 z8 V, G) \+ M
mcasp->regs->GBLCTL = 0; // Reset
& C3 h" W- Y6 c5 O$ A mcasp->regs->RGBLCTL = 0; // Reset RX
5 ?4 W! k* |, s mcasp->regs->XGBLCTL = 0; // Reset TX8 J4 F- S! n1 t: o
mcasp->regs->PWRDEMU = 1; // Free-running8 Y& _# V( r0 U1 \& u7 b8 Z
// configure McASP0 receive registers& n! Q$ h8 i, l& l* Q# P" F
mcasp->regs->RMASK = 0xFFFFFFFF; // No padding used( j; C( W1 ^% C' [; a
mcasp->regs->RFMT = 0x00018078; // MSB 16bit, 0-delay, no pad, CFGBus
! D; }- o3 s" P; A7 M; @ F0 u mcasp->regs->AFSRCTL = 0x00000112; // 2TDM, 1bit Falling, External FS, word
9 Q9 a# }5 [% q7 F- m$ d mcasp->regs->ACLKRCTL = 0x000000AF; // Rising INTERNAL CLK,(from tx side) t* Q( O. i$ M( l* j6 V
mcasp->regs->AHCLKRCTL = 0x00000000; // INT CLK (from tx side)- }$ ^6 i) f! _1 t" K5 d( e/ H- v
mcasp->regs->RTDM = 0x00000003; // Slots 0,1
$ m* {& h. \2 } d mcasp->regs->RINTCTL = 0x00000000; // Not used' l# F4 e; G, _1 x
mcasp->regs->RCLKCHK = 0x00FF0008; // 255-MAX 0-MIN, div-by-256+ X! c3 e9 X8 _$ w8 ]( g. e4 x
4 x% C7 J; q4 W* d' l' l
mcasp->regs->XMASK = 0xFFFFFFFF; // No padding used
' O% I) U4 L* a3 w6 r& U1 z. H mcasp->regs->XFMT = 0x00018078; // MSB 16bit, 0-delay, no pad, CFGBus% n$ ]; `" V9 d0 ?
mcasp->regs->AFSXCTL = 0x00000112; // 2TDM, 1bit Rising edge INTERNAL FS, word2 H' V: t3 @! \
mcasp->regs->ACLKXCTL = 0x000000AF; // ASYNC, Rising INTERNAL CLK, div-by-16
' q+ \" s( e) y5 [* D mcasp->regs->AHCLKXCTL = 0x00000000; // EXT CLK3 ^5 F2 K; e1 p
mcasp->regs->XTDM = 0x00000003; // Slots 0,1
" L/ c* T& N6 J mcasp->regs->XINTCTL = 0x00000020; // interrupt on transmit: V J, U2 U3 `* J' Q1 F
mcasp->regs->XCLKCHK = 0x00FF0008; // 255-MAX 0-MIN, div-by-256: `4 R) E% R) w# U
. R. t3 r9 ~( k% d& m mcasp->regs->SRCTL5 = 0x000D; // MCASP1.AXR1[5] --> DIN/ A+ F2 v% {8 u
mcasp->regs->SRCTL0 = 0x000E; // MCASP1.AXR1[0] <-- DOUT
! F7 Z g( K! K# f+ j, u8 c/ D, Y( C mcasp->regs->PFUNC = 0; // All MCASPs
) i/ U+ t6 L$ W1 b5 ] mcasp->regs->PDIR = 0x14000020; // All inputs except AXR0[5], ACLKX1, AFSX1+ E9 \; s1 A2 y% k$ T) O) {8 K! U. b
9 t9 C4 `% B! q$ E. t5 T mcasp->regs->DITCTL = 0x00000000; // Not used" R4 h0 ?3 Y" H2 a- I
mcasp->regs->DLBCTL = 0x00000000; // Not used
) k* f( r5 s3 ]" H) C mcasp->regs->AMUTE = 0x00000000; // Not used/ G) P' K' |& g. _' m
+ {% ]8 M2 }. |) `* ~
/* Starting sections of the McASP*/
; F& C! _( S( [0 k mcasp->regs->XGBLCTL |= GBLCTL_XHCLKRST_ON;
$ r7 l' Z' A8 l5 k9 u8 A while ( ( mcasp->regs->XGBLCTL & GBLCTL_XHCLKRST_ON ) != GBLCTL_XHCLKRST_ON ); $ P. m3 o( f) Q! d$ u. N4 Q) G5 M
mcasp->regs->RGBLCTL |= GBLCTL_RHCLKRST_ON;
7 a5 C/ V* m ]) }* ^ while ( ( mcasp->regs->RGBLCTL & GBLCTL_RHCLKRST_ON ) != GBLCTL_RHCLKRST_ON );
% `& a. C9 N5 o
& v; A2 L. G1 Q; @ mcasp->regs->XGBLCTL |= GBLCTL_XCLKRST_ON; 9 p0 \6 j+ ^( k' q. p- _1 i9 \/ e
while ( ( mcasp->regs->XGBLCTL & GBLCTL_XCLKRST_ON ) != GBLCTL_XCLKRST_ON );
, R% k, ^" p6 b2 h; _/ Q mcasp->regs->RGBLCTL |= GBLCTL_RCLKRST_ON;
; z% d3 A4 j0 H4 l) |3 z while ( ( mcasp->regs->RGBLCTL & GBLCTL_RCLKRST_ON ) != GBLCTL_RCLKRST_ON );" G3 s4 L X5 W
1 m; ?5 [, \% O% ^0 Z+ e mcasp->regs->XSTAT = 0x0000ffff; - d3 a( y8 N7 B( R. g# J
mcasp->regs->RSTAT = 0x0000ffff; - O2 \* K. j7 ~! k3 @3 F3 t! S
4 t- p. h7 L; j* ^4 L
mcasp->regs->XGBLCTL |= GBLCTL_XSRCLR_ON;
4 E7 E2 y8 t+ c6 n8 A6 _8 Z while ( ( mcasp->regs->XGBLCTL & GBLCTL_XSRCLR_ON ) != GBLCTL_XSRCLR_ON );
( g s: j- b0 o mcasp->regs->RGBLCTL |= GBLCTL_RSRCLR_ON; - t# C! f. A$ z3 i
while ( ( mcasp->regs->RGBLCTL & GBLCTL_RSRCLR_ON ) != GBLCTL_RSRCLR_ON );
7 Q) M' j$ N& A/ N( a0 u$ x! w. e6 g
/* Write a 0, so that no underrun occurs after releasing the state machine */
: W! n0 [ Z6 z; a4 @ mcasp->regs->XBUF5 = 0;
/ j& X+ e, d/ e8 H mcasp->regs->RBUF0 = 0;4 \6 B6 b. ?, o0 [% S
% b) k* T" G; d" q5 c mcasp->regs->XGBLCTL |= GBLCTL_XSMRST_ON; k. y6 z8 A8 y$ {+ {
while ( ( mcasp->regs->XGBLCTL & GBLCTL_XSMRST_ON ) != GBLCTL_XSMRST_ON );
U9 U7 G8 ^, t* o6 r mcasp->regs->RGBLCTL |= GBLCTL_RSMRST_ON;
9 Z" E) `2 z6 I3 u2 n8 K% ~ while ( ( mcasp->regs->RGBLCTL & GBLCTL_RSMRST_ON ) != GBLCTL_RSMRST_ON );/ r( v2 m3 U' U: d
5 v/ q0 W( e# @( S5 ^8 O
mcasp->regs->XGBLCTL |= GBLCTL_XFRST_ON; & B T* ~. U/ g9 ?2 S4 D+ M3 R8 [
while ( ( mcasp->regs->XGBLCTL & GBLCTL_XFRST_ON ) != GBLCTL_XFRST_ON );, i$ Z. H" r {8 c. N- H
mcasp->regs->RGBLCTL |= GBLCTL_RFRST_ON;
/ Q7 o1 u' n+ I. V while ( ( mcasp->regs->RGBLCTL & GBLCTL_RFRST_ON ) != GBLCTL_RFRST_ON ); t+ b Q4 @( p. U K( r
- @! M+ C! Y9 B+ E0 k+ V
CSR = 0x0000;
2 }* f9 h+ c7 q- b0 m INTC_INTMUX1 = 0x3d;8 ?7 v! p6 t p
ISTP = (unsigned int)vectors;9 v* G2 ~3 a4 O! m9 n8 c
ICR = 0xFFF0;
7 C+ z# U( {! x) Y IER |= 0x12; % t8 ^. P( j1 F: L. n! |1 j# D
CSR |= 0x01;
7 Y! G/ w7 b% z9 [, w
: f$ K/ d2 U$ l5 `7 S! q* i
+ m0 O) `7 g4 B- H M* W) c( e% Q: Y" _' D' v" D- v* N2 y
还有就是两个输入输出函数:' t, c0 f6 v/ O7 e- U! b
void output_sample(Int32 out_data)
6 l' B0 M3 I: ^5 L, D& K. i3 E3 ^{3 M7 W; J3 F1 s \
AIC31_data.uint = out_data;
& W2 Z& S( j$ v; p1 _! b5 E; c MCASP1_XBUF5_32BIT = AIC31_data.uint;
7 O f0 j3 K2 b}9 t7 P8 O( n4 l( w
; a3 n% O) D) w+ ]5 O- ]; vInt32 input_sample(void) J5 @$ t! U' y) u4 q- ~
{ : T/ L' F' D( `! h
AIC31_data.uint = MCASP1_RBUF0_32BIT;" Y9 k3 S. i% |2 M9 }
return (AIC31_data.uint);
/ n) P9 q: Q2 T n& M}
6 l" f- o7 _2 S: {; |
& Z6 B; p& X; I4 m5 L: l |
|