|
|
C6747和C6748感觉差不多,我想实现McASP发送中断方式控制音频信号,在轮询的例程基础上改的,轮询程序可以实现,但是中断一直实现不了,也找不到错误,求大神帮忙!下边是主要程序:
; V/ x5 ~ t6 `+ Ymain文件:
& o6 p; {9 e D' yinterrupt void interrupt4(void)
6 h( \4 k# Y1 j. W p4 q{/ J" s6 L* u( I, x$ T( x
Uint32 sample;
- J: f' M+ l7 u; [. {( O! W7 @; Z; W% z4 n
sample = input_sample(); // read L + R samples from ADC% P: B( L( L6 h- e
output_sample(sample); // write L + R samples to DAC
+ g- A ^3 ^4 s$ f: e: { return;! O# e5 x; H. P- Z+ v
}% ^: s1 N% H# n) a$ I" X( F
0 M, c1 x1 E5 {; V; b. n* `2 H+ Vint main( void )
) f) I$ {' H) U5 z{
, U) v) H6 T- n* E: J
# U' \# C7 v3 r$ L5 L( v( F /* Initialize BSL */" S% |9 h; e* _3 ^- ~
EVMC6747_init( );- w& R$ \* i9 y! G' i0 `6 r
/* Call evmc6747_intr function */* x, U" q F$ i, ?: B3 Q
aic3106_init( );
$ G& h& `! V- J& H5 q) I while(1);
% _* v2 ]* p( K# d}! h" F; o- f2 s, w! C' s0 h
2 q2 |3 l8 B Z L9 W; F- S
: K$ A3 s7 t( w* P, k
aic3106_init文件的一部分,McASP配置部分,采用内部时钟,I2S方式,同步传输。音频芯片的配置应该没问题
! h+ s9 U: c8 C7 Y$ o/* Initialize MCASP1 */
% o; r" G: r! c+ `0 p% B mcasp = &MCASP_MODULE_1;
! T, l# J1 {# A# ]% Y mcasp->regs->GBLCTL = 0; // Reset
) a' f9 a- {; X/ e( L mcasp->regs->RGBLCTL = 0; // Reset RX
1 N; E6 g& }3 P mcasp->regs->XGBLCTL = 0; // Reset TX
- W! P" G- N( ?0 a3 | mcasp->regs->PWRDEMU = 1; // Free-running0 u% ]7 p* x1 E( A/ w# T
// configure McASP0 receive registers9 m5 N6 C2 ~4 p6 A
mcasp->regs->RMASK = 0xFFFFFFFF; // No padding used$ }' s. W2 J4 f3 j% Q! M0 b% }. g
mcasp->regs->RFMT = 0x00018078; // MSB 16bit, 0-delay, no pad, CFGBus
3 B8 r3 H, \0 u* I% k7 N0 n mcasp->regs->AFSRCTL = 0x00000112; // 2TDM, 1bit Falling, External FS, word( j- F6 ]+ b s, ~0 B
mcasp->regs->ACLKRCTL = 0x000000AF; // Rising INTERNAL CLK,(from tx side)3 i: H U- P6 G C2 U! g. }" P
mcasp->regs->AHCLKRCTL = 0x00000000; // INT CLK (from tx side)
2 j" |4 r+ t; c+ q( ?. }4 q mcasp->regs->RTDM = 0x00000003; // Slots 0,1
' {0 K; V( j# F! u! ]- g mcasp->regs->RINTCTL = 0x00000000; // Not used9 {1 t, ?( f% k2 S1 @9 ^
mcasp->regs->RCLKCHK = 0x00FF0008; // 255-MAX 0-MIN, div-by-256
6 f/ Q' q ~/ a2 R1 _3 { C5 E: i' @* m$ B
mcasp->regs->XMASK = 0xFFFFFFFF; // No padding used1 E" F/ h/ O! K. w d
mcasp->regs->XFMT = 0x00018078; // MSB 16bit, 0-delay, no pad, CFGBus
4 g# ^" c! @5 i mcasp->regs->AFSXCTL = 0x00000112; // 2TDM, 1bit Rising edge INTERNAL FS, word
8 L/ `; q, _% O) N mcasp->regs->ACLKXCTL = 0x000000AF; // ASYNC, Rising INTERNAL CLK, div-by-163 I' c) n- j5 F# `% ^& K% s& U; @
mcasp->regs->AHCLKXCTL = 0x00000000; // EXT CLK1 l' _' Z5 V5 f9 z/ R
mcasp->regs->XTDM = 0x00000003; // Slots 0,1. m- _$ M7 Y9 D- U( L
mcasp->regs->XINTCTL = 0x00000020; // interrupt on transmit
0 ]- ?2 L0 w/ V4 N% R1 J ?7 } mcasp->regs->XCLKCHK = 0x00FF0008; // 255-MAX 0-MIN, div-by-2565 z# g* R% M( d5 R! j
+ r- Z: ^2 K9 a! i2 J( u; B
mcasp->regs->SRCTL5 = 0x000D; // MCASP1.AXR1[5] --> DIN0 O: Z1 a/ {3 y' j* t% H
mcasp->regs->SRCTL0 = 0x000E; // MCASP1.AXR1[0] <-- DOUT
& Y/ A; _( a0 y/ {! T5 }4 y mcasp->regs->PFUNC = 0; // All MCASPs
z4 m! L! U5 t mcasp->regs->PDIR = 0x14000020; // All inputs except AXR0[5], ACLKX1, AFSX1
6 l: Y$ Z; Y, O& r6 ?. M9 G4 Y9 g& r
mcasp->regs->DITCTL = 0x00000000; // Not used$ @/ I+ Y* |, b
mcasp->regs->DLBCTL = 0x00000000; // Not used
( M4 m( H- @/ B5 i! `2 N* w% a! ^ mcasp->regs->AMUTE = 0x00000000; // Not used
# C. T' R4 ~2 ]; v2 x. \" w0 x" \. R4 k( V; c" p
/* Starting sections of the McASP*/" h6 g6 o( V- o5 l
mcasp->regs->XGBLCTL |= GBLCTL_XHCLKRST_ON;
$ y+ Y0 Z" E9 X- ] while ( ( mcasp->regs->XGBLCTL & GBLCTL_XHCLKRST_ON ) != GBLCTL_XHCLKRST_ON ); 1 f$ t) g2 n4 C" N3 }7 `
mcasp->regs->RGBLCTL |= GBLCTL_RHCLKRST_ON;
3 K1 W4 U: z9 I4 u; m" t while ( ( mcasp->regs->RGBLCTL & GBLCTL_RHCLKRST_ON ) != GBLCTL_RHCLKRST_ON );
$ Z x4 V/ ~4 X# ]5 Q, p6 Y) l$ X# L* F- Q) q5 c- \
mcasp->regs->XGBLCTL |= GBLCTL_XCLKRST_ON;
/ ?2 l$ X- U$ l( G$ |1 E: ~% l c" _% v while ( ( mcasp->regs->XGBLCTL & GBLCTL_XCLKRST_ON ) != GBLCTL_XCLKRST_ON );
p$ m. [; a# } [& a mcasp->regs->RGBLCTL |= GBLCTL_RCLKRST_ON; * j' Q2 e* R: m! Y$ s$ B
while ( ( mcasp->regs->RGBLCTL & GBLCTL_RCLKRST_ON ) != GBLCTL_RCLKRST_ON );& |0 o: a" w+ I. [, {3 k
. x# Q' Q+ w# r! `3 N
mcasp->regs->XSTAT = 0x0000ffff;
: Z. y8 @% E' b( ]8 [) T mcasp->regs->RSTAT = 0x0000ffff;
) U+ B x9 S! K( ^4 B& v8 g* ~" y# U0 z/ p* _4 @! Q; v
mcasp->regs->XGBLCTL |= GBLCTL_XSRCLR_ON;( Y( a+ U( g% Y- |6 V
while ( ( mcasp->regs->XGBLCTL & GBLCTL_XSRCLR_ON ) != GBLCTL_XSRCLR_ON );0 O0 m) f! h. D! E, ]
mcasp->regs->RGBLCTL |= GBLCTL_RSRCLR_ON; : Y; w0 c1 ~! C& [$ e
while ( ( mcasp->regs->RGBLCTL & GBLCTL_RSRCLR_ON ) != GBLCTL_RSRCLR_ON );/ N! I; ^- g( Q/ F3 l
% @ v5 G- r9 F6 N
/* Write a 0, so that no underrun occurs after releasing the state machine */; z* B. \) v3 ]8 v8 c. |
mcasp->regs->XBUF5 = 0;2 G/ p" X3 R; W" P) V) p
mcasp->regs->RBUF0 = 0;
* A# w. K& S B, V+ @1 a* k* e) U" `! c- d9 O
mcasp->regs->XGBLCTL |= GBLCTL_XSMRST_ON;
6 ~8 S$ U2 U1 K+ \/ Z$ K# C while ( ( mcasp->regs->XGBLCTL & GBLCTL_XSMRST_ON ) != GBLCTL_XSMRST_ON );' f) s K! H$ w0 v
mcasp->regs->RGBLCTL |= GBLCTL_RSMRST_ON; ! Y6 E2 \1 ?. P) C$ E+ D
while ( ( mcasp->regs->RGBLCTL & GBLCTL_RSMRST_ON ) != GBLCTL_RSMRST_ON );9 O/ r5 s7 L, s4 ?( S. p/ \6 H
/ M/ K: L( x/ V8 t% V S
mcasp->regs->XGBLCTL |= GBLCTL_XFRST_ON;
9 t6 N9 ^& i( K while ( ( mcasp->regs->XGBLCTL & GBLCTL_XFRST_ON ) != GBLCTL_XFRST_ON );2 m$ m& D0 t$ t3 X: N! I& v T
mcasp->regs->RGBLCTL |= GBLCTL_RFRST_ON; - d9 q5 W+ s0 e+ t6 k9 Q5 z2 q
while ( ( mcasp->regs->RGBLCTL & GBLCTL_RFRST_ON ) != GBLCTL_RFRST_ON );+ D% t; Y2 {$ h3 z8 A, h9 v, L
1 u+ n3 C6 ~3 O" J
CSR = 0x0000;# H! t; T* l7 ]) ]7 @
INTC_INTMUX1 = 0x3d;: i5 V6 `! {, ]1 q) g$ x3 e
ISTP = (unsigned int)vectors;
0 Y" b- o. D0 v ICR = 0xFFF0;
1 _# c; ?) w- j" @3 G. U IER |= 0x12;
7 B P; ^% R* d4 J8 c6 n8 u F CSR |= 0x01; 0 `) p; K& q& o( U* |% I4 }
g4 N9 b% k4 f2 X& \4 {
" N( h" m8 O6 f- ]1 ]' F+ P5 o5 q( ~' H0 [' M
还有就是两个输入输出函数:
; ~) U, s" B+ m+ J4 s+ |9 t' jvoid output_sample(Int32 out_data)
3 |6 I: H+ d/ q0 p{! R6 G& B; o! i* A0 O5 Y
AIC31_data.uint = out_data;
/ K3 d+ Y; g. u( ]; p8 O E8 h MCASP1_XBUF5_32BIT = AIC31_data.uint;
7 ?9 e3 H% }. ^" I8 ~ R}
! m0 W& E5 J) ]; R) U! F/ r( Z9 r
# P$ Z8 f2 N& z$ D0 S4 @4 ~4 bInt32 input_sample(void)
6 W8 }7 V4 }% N' R{
! |& w9 m7 d- \ AIC31_data.uint = MCASP1_RBUF0_32BIT;
4 I: @2 b. P* B: l p7 `4 q1 v return (AIC31_data.uint);
/ I- z: k5 V9 n}
" B7 v* l, H/ B, g
9 E6 i, J2 E0 B1 Z3 r8 |2 g7 j |
|