|
|
C6747和C6748感觉差不多,我想实现McASP发送中断方式控制音频信号,在轮询的例程基础上改的,轮询程序可以实现,但是中断一直实现不了,也找不到错误,求大神帮忙!下边是主要程序: l0 O: a5 K5 a% W( ]
main文件:' z& e; J9 B& ~7 y+ z
interrupt void interrupt4(void) ; }' [4 X0 X; ^; M
{
I7 y8 y7 l# w, _ Uint32 sample;
( Q9 s1 g! ~+ s9 k/ ~& f! \
: t" V) `: H* Y! w sample = input_sample(); // read L + R samples from ADC
4 B) Q" X" [& U output_sample(sample); // write L + R samples to DAC
/ K Q6 n& l. Q0 p* t& } return; v* n; m9 f* V) [9 s; _: z' S
}! ~2 \: {( f2 G( L, ?: c
2 g- p" t" I: M6 `7 i% g: ]( r
int main( void )- ?8 q( u: m+ T+ {6 f) M7 w
{
\# | I8 d9 |/ ]
* A# ?6 _3 z1 U8 Q4 A5 u /* Initialize BSL */
3 {2 N% m- r/ ]0 u' q EVMC6747_init( );& E* v: ? y. V) `
/* Call evmc6747_intr function */
4 I9 s9 {1 D/ C4 {: z+ a/ A9 z aic3106_init( );+ p5 e. A6 r. G+ E/ \- P& ^# {
while(1);
4 j3 _+ B* N$ U1 V& j2 r& ?}1 m5 F) }+ |- E5 P( `' g+ x
. G7 k) T/ o6 f; H: k
5 J1 p/ a7 I" \# W$ t' k
aic3106_init文件的一部分,McASP配置部分,采用内部时钟,I2S方式,同步传输。音频芯片的配置应该没问题
( C& J' z. w( H6 t# B/* Initialize MCASP1 */
# |2 ~& \. f# s mcasp = &MCASP_MODULE_1;
$ k# a e* [, q. M% A, p9 } mcasp->regs->GBLCTL = 0; // Reset1 @6 A) ?& D" Y2 K2 N
mcasp->regs->RGBLCTL = 0; // Reset RX0 d& Y4 N1 ^6 B$ O
mcasp->regs->XGBLCTL = 0; // Reset TX
, j+ H: l2 _3 o/ u mcasp->regs->PWRDEMU = 1; // Free-running
& z' f9 G/ j) i7 n& t // configure McASP0 receive registers
) v# [, f( @/ b, U mcasp->regs->RMASK = 0xFFFFFFFF; // No padding used$ U: E. p/ a6 G& G8 s& m
mcasp->regs->RFMT = 0x00018078; // MSB 16bit, 0-delay, no pad, CFGBus
/ W( S+ g2 @) V6 ?& d* }& A1 g6 l mcasp->regs->AFSRCTL = 0x00000112; // 2TDM, 1bit Falling, External FS, word: j1 x6 @: [6 V! R. k
mcasp->regs->ACLKRCTL = 0x000000AF; // Rising INTERNAL CLK,(from tx side)
& D8 j/ ]( E6 r6 B% u1 j mcasp->regs->AHCLKRCTL = 0x00000000; // INT CLK (from tx side)6 u" }$ v% ^' ?5 f5 R
mcasp->regs->RTDM = 0x00000003; // Slots 0,1
. Q* v) i8 j7 m( N mcasp->regs->RINTCTL = 0x00000000; // Not used# k2 } t2 d7 h
mcasp->regs->RCLKCHK = 0x00FF0008; // 255-MAX 0-MIN, div-by-256
, y% x; \1 A! ^ ^5 C* o# h4 E
mcasp->regs->XMASK = 0xFFFFFFFF; // No padding used
/ K$ k8 ^8 E4 L% G! P* I mcasp->regs->XFMT = 0x00018078; // MSB 16bit, 0-delay, no pad, CFGBus
1 \' t. y, U9 n ~$ d. _ mcasp->regs->AFSXCTL = 0x00000112; // 2TDM, 1bit Rising edge INTERNAL FS, word
7 F+ q. \7 p% P" q" w6 T K" A mcasp->regs->ACLKXCTL = 0x000000AF; // ASYNC, Rising INTERNAL CLK, div-by-169 z! z: T X% Q! A6 n6 o! O& y
mcasp->regs->AHCLKXCTL = 0x00000000; // EXT CLK
2 z. z0 s8 \9 t% g2 g: Z0 E) h mcasp->regs->XTDM = 0x00000003; // Slots 0,18 T6 M' N% n/ I! P2 g/ r
mcasp->regs->XINTCTL = 0x00000020; // interrupt on transmit- |& T2 ^: x/ ~# b6 Y! S+ F7 C
mcasp->regs->XCLKCHK = 0x00FF0008; // 255-MAX 0-MIN, div-by-2567 H$ m7 z1 d+ e7 S
" P8 e; T. M* s O! {" q
mcasp->regs->SRCTL5 = 0x000D; // MCASP1.AXR1[5] --> DIN& L3 p/ A, h0 A+ [" ^. K& s; S
mcasp->regs->SRCTL0 = 0x000E; // MCASP1.AXR1[0] <-- DOUT
: E# f2 B1 R ` mcasp->regs->PFUNC = 0; // All MCASPs8 }- z o$ D# r2 I+ u
mcasp->regs->PDIR = 0x14000020; // All inputs except AXR0[5], ACLKX1, AFSX1/ K6 S7 W! h4 }; W( K% r& X% g
% M z/ L" V& x: a( e" K$ {
mcasp->regs->DITCTL = 0x00000000; // Not used
[5 Q+ E& K" H! Q) r* } mcasp->regs->DLBCTL = 0x00000000; // Not used
4 W7 M; D! O. t- V2 L mcasp->regs->AMUTE = 0x00000000; // Not used
0 L4 S C. @; K4 p2 y
; ?( l1 G: l. z4 i8 J/* Starting sections of the McASP*/
1 i8 I" J3 [1 l4 k0 N mcasp->regs->XGBLCTL |= GBLCTL_XHCLKRST_ON;
7 x/ y7 D& A# _, T0 j" K+ j while ( ( mcasp->regs->XGBLCTL & GBLCTL_XHCLKRST_ON ) != GBLCTL_XHCLKRST_ON ); ) O) P ]7 t4 C) r4 V
mcasp->regs->RGBLCTL |= GBLCTL_RHCLKRST_ON; 4 u3 b* n5 m1 ^" q0 C
while ( ( mcasp->regs->RGBLCTL & GBLCTL_RHCLKRST_ON ) != GBLCTL_RHCLKRST_ON );
, u" M5 Q6 P5 d
# }' h8 Y; G) D6 l1 H0 k% X mcasp->regs->XGBLCTL |= GBLCTL_XCLKRST_ON; 1 S( R/ {4 v5 y8 ~1 {9 r2 H3 ^* c% v2 c
while ( ( mcasp->regs->XGBLCTL & GBLCTL_XCLKRST_ON ) != GBLCTL_XCLKRST_ON );4 h: K) j }- [; E5 m
mcasp->regs->RGBLCTL |= GBLCTL_RCLKRST_ON;
8 B% {8 ?$ m7 V1 p1 d0 n while ( ( mcasp->regs->RGBLCTL & GBLCTL_RCLKRST_ON ) != GBLCTL_RCLKRST_ON );
B% Y- Z- f/ Q4 ~: y, b5 k8 N8 x" N; `5 H! a! k: M- l
mcasp->regs->XSTAT = 0x0000ffff; ' H) s* `/ p1 ^* h' W3 Q2 F
mcasp->regs->RSTAT = 0x0000ffff;
" ]4 a) o* w* `6 ]# i' m: Z" n! l
) `+ K: _; E" V: o: a- h7 `& U mcasp->regs->XGBLCTL |= GBLCTL_XSRCLR_ON;
; h c/ B/ [: f( z; b while ( ( mcasp->regs->XGBLCTL & GBLCTL_XSRCLR_ON ) != GBLCTL_XSRCLR_ON );+ a* f. f* X% ?
mcasp->regs->RGBLCTL |= GBLCTL_RSRCLR_ON;
2 S( I( I$ o4 S" w6 r while ( ( mcasp->regs->RGBLCTL & GBLCTL_RSRCLR_ON ) != GBLCTL_RSRCLR_ON );
3 d9 n& b$ q& Y) ]# S6 H' \# P
. B0 u3 L' R# |: _ /* Write a 0, so that no underrun occurs after releasing the state machine */- c$ v- h' S; X' J6 D! T) b3 l, P
mcasp->regs->XBUF5 = 0;( \0 P$ n. x4 S, W! H7 ?! t* g
mcasp->regs->RBUF0 = 0;3 n b+ W# b6 ^9 E
! h3 K/ L1 h* n6 v4 a0 h, r
mcasp->regs->XGBLCTL |= GBLCTL_XSMRST_ON;
: T- E( O$ K8 \$ ` while ( ( mcasp->regs->XGBLCTL & GBLCTL_XSMRST_ON ) != GBLCTL_XSMRST_ON ); C7 X7 N! F& W. j% {
mcasp->regs->RGBLCTL |= GBLCTL_RSMRST_ON; 0 I7 w p; d4 y$ D
while ( ( mcasp->regs->RGBLCTL & GBLCTL_RSMRST_ON ) != GBLCTL_RSMRST_ON );4 T; n7 W# T- ]) k% U
_ {. [% s/ }2 o; ? mcasp->regs->XGBLCTL |= GBLCTL_XFRST_ON; ! w" y" x$ H E" y% T) `1 Z! c: F
while ( ( mcasp->regs->XGBLCTL & GBLCTL_XFRST_ON ) != GBLCTL_XFRST_ON );* S. L6 f2 Z" \( c: M
mcasp->regs->RGBLCTL |= GBLCTL_RFRST_ON;
' b! V0 r6 [ V O while ( ( mcasp->regs->RGBLCTL & GBLCTL_RFRST_ON ) != GBLCTL_RFRST_ON );
7 n' ^8 n8 C4 H+ Q$ v- t& e' a6 U, P2 s% z) \" Y* i6 |- x
CSR = 0x0000;
2 R6 r3 M# h, B/ F/ i8 t INTC_INTMUX1 = 0x3d;
! @8 t* ^2 |' O7 ^& t ISTP = (unsigned int)vectors;
& B G0 [* V) x. T ICR = 0xFFF0; - k# e; r' I \ p
IER |= 0x12;
5 N: T* l) P9 y" U/ k CSR |= 0x01; 3 p5 E" P6 {9 @! n; y* [) J
* C' W- S% P: `' I4 t3 Y: \1 U6 z1 W
k9 a. n# f+ q还有就是两个输入输出函数:8 p/ ?! ?* s; a. {2 r
void output_sample(Int32 out_data)
4 D# u/ D! t( w" Y( [{, \0 D0 h; @# ~$ z
AIC31_data.uint = out_data; * D) H* R+ J2 ?
MCASP1_XBUF5_32BIT = AIC31_data.uint;3 U5 H. ^$ t; \" H7 w
} _. @' r9 s+ C+ O5 r, L. j
1 l6 N2 I1 U! [, C. M
Int32 input_sample(void)# X- }# A# V& \0 t
{
1 N+ J J/ g1 x- ^9 ? AIC31_data.uint = MCASP1_RBUF0_32BIT;; u P$ S* o. v1 ]2 `, X
return (AIC31_data.uint);
6 r2 [) ?2 I5 }}
' F& t9 Y0 e9 j- d7 Y' K7 c: H6 o0 z
|
|