|
|
C6747和C6748感觉差不多,我想实现McASP发送中断方式控制音频信号,在轮询的例程基础上改的,轮询程序可以实现,但是中断一直实现不了,也找不到错误,求大神帮忙!下边是主要程序:
* M8 G; y8 c7 J/ H4 q1 }- g* hmain文件:
3 @3 S$ L! k; i* q" Kinterrupt void interrupt4(void)
$ H0 y7 {" x9 b* f; e5 p{
4 v6 T. a2 Z9 B% E% N/ C& V" { Uint32 sample;
( }0 W: t5 i# q k) n( O* t6 H; R& C% \: l
sample = input_sample(); // read L + R samples from ADC
# ^/ }6 W: E; r9 z; m, Q output_sample(sample); // write L + R samples to DAC - v' e8 g' U1 l0 h' K( ~" |
return;( H3 D! T. D Z+ S3 |
}
" s- z1 M; a8 u; g
+ A3 m0 G1 r* S' r3 Sint main( void )- ^% O) K7 A( Y9 I4 O
{
( c! g3 t9 z, N7 ?1 Z% ~# R
' ^% [ E; ?% T /* Initialize BSL */
$ l/ m1 V5 T% {; E* J EVMC6747_init( );
& ^0 e# ?3 i9 y% T$ F) X5 Q /* Call evmc6747_intr function */- u. E* t- s' T& p7 h
aic3106_init( );* e- @; q" _' c6 o, f3 }. T, u; w
while(1);8 y6 i4 E9 @8 C1 P0 {+ [. s- ^
}" B( J, u2 S' Y }- w& F+ q
( M# p3 S4 t1 E% A! S6 S. }
3 u# ` G' j) V7 k/ U/ H5 h
aic3106_init文件的一部分,McASP配置部分,采用内部时钟,I2S方式,同步传输。音频芯片的配置应该没问题
& E) D& s/ Z( {/* Initialize MCASP1 */& U" z$ {- [1 F6 x7 L
mcasp = &MCASP_MODULE_1;" U" J% n( q7 d% {. z
mcasp->regs->GBLCTL = 0; // Reset
! d5 R- b; O' F mcasp->regs->RGBLCTL = 0; // Reset RX
9 K6 |, N" Z8 ]) w. Y: {' Q9 E3 z mcasp->regs->XGBLCTL = 0; // Reset TX- K1 f7 y; _$ _) J& Y" u: B
mcasp->regs->PWRDEMU = 1; // Free-running
+ T6 Q: g- @0 r4 ^. d5 [$ W8 c! O // configure McASP0 receive registers: f$ e0 e. ^; q% O/ e- p
mcasp->regs->RMASK = 0xFFFFFFFF; // No padding used
* M# J3 r5 @' z/ @- z mcasp->regs->RFMT = 0x00018078; // MSB 16bit, 0-delay, no pad, CFGBus% ^4 H1 v/ J" g; P! s5 C. `( \
mcasp->regs->AFSRCTL = 0x00000112; // 2TDM, 1bit Falling, External FS, word
( D5 q7 k6 c1 X l9 q { mcasp->regs->ACLKRCTL = 0x000000AF; // Rising INTERNAL CLK,(from tx side)7 f0 X4 |' O0 H& ^" |
mcasp->regs->AHCLKRCTL = 0x00000000; // INT CLK (from tx side)
# f! v$ }. `8 `) Y mcasp->regs->RTDM = 0x00000003; // Slots 0,1
8 u: x9 n: E! s/ P2 g$ C H! f mcasp->regs->RINTCTL = 0x00000000; // Not used1 t* M6 _9 E( c/ n) J* b7 a
mcasp->regs->RCLKCHK = 0x00FF0008; // 255-MAX 0-MIN, div-by-256; d% u' W' \6 E. m* I& i
- N$ B' G* v' I/ c |: P mcasp->regs->XMASK = 0xFFFFFFFF; // No padding used
+ H/ O+ f- g6 J/ Z mcasp->regs->XFMT = 0x00018078; // MSB 16bit, 0-delay, no pad, CFGBus0 O! o. u0 V5 L1 g8 |9 z
mcasp->regs->AFSXCTL = 0x00000112; // 2TDM, 1bit Rising edge INTERNAL FS, word9 {& k7 o& M h/ D. n, o
mcasp->regs->ACLKXCTL = 0x000000AF; // ASYNC, Rising INTERNAL CLK, div-by-16
8 |+ C4 Q0 K2 F) r3 b" d8 n. L mcasp->regs->AHCLKXCTL = 0x00000000; // EXT CLK
; N" B" K" { x# n mcasp->regs->XTDM = 0x00000003; // Slots 0,10 O5 ~; r/ h% x# V/ k
mcasp->regs->XINTCTL = 0x00000020; // interrupt on transmit
, P" W' g3 l' w; w' ]& F7 P7 E6 {8 \ mcasp->regs->XCLKCHK = 0x00FF0008; // 255-MAX 0-MIN, div-by-256
, w4 R+ o3 _% I# i# R5 s. A4 \6 I' R& `
mcasp->regs->SRCTL5 = 0x000D; // MCASP1.AXR1[5] --> DIN
; i+ L! E3 t; a" _6 L3 a( k mcasp->regs->SRCTL0 = 0x000E; // MCASP1.AXR1[0] <-- DOUT( ?$ b% ?+ H! ]0 D4 [
mcasp->regs->PFUNC = 0; // All MCASPs& v! p$ N5 u" A6 \) ?1 ]( R8 b% F
mcasp->regs->PDIR = 0x14000020; // All inputs except AXR0[5], ACLKX1, AFSX1" P7 {, u0 Y2 ]0 r* P% _, P
0 F1 _$ S2 K" c0 l2 h$ R
mcasp->regs->DITCTL = 0x00000000; // Not used
t& K4 m* H: b2 o+ c mcasp->regs->DLBCTL = 0x00000000; // Not used2 {5 x2 ~( M3 H1 k# ~1 y( ~4 M
mcasp->regs->AMUTE = 0x00000000; // Not used
/ X3 ~2 t+ d0 ^# V
1 C* S3 z$ W6 j8 b+ Y/* Starting sections of the McASP*/
8 G; m$ v0 c/ c mcasp->regs->XGBLCTL |= GBLCTL_XHCLKRST_ON; 8 ~7 ?1 @7 [) o( r
while ( ( mcasp->regs->XGBLCTL & GBLCTL_XHCLKRST_ON ) != GBLCTL_XHCLKRST_ON ); , V6 q/ ?7 o: u5 j5 b6 _3 n1 X2 B) V
mcasp->regs->RGBLCTL |= GBLCTL_RHCLKRST_ON; : w* i2 x$ U$ w; B) z8 i
while ( ( mcasp->regs->RGBLCTL & GBLCTL_RHCLKRST_ON ) != GBLCTL_RHCLKRST_ON );- S8 s, G( g5 y7 x& `
" W+ R1 k. `/ p' ~ mcasp->regs->XGBLCTL |= GBLCTL_XCLKRST_ON; . \3 w# w% n5 x- y }+ x
while ( ( mcasp->regs->XGBLCTL & GBLCTL_XCLKRST_ON ) != GBLCTL_XCLKRST_ON );
, @5 A8 |$ \+ \: n$ N mcasp->regs->RGBLCTL |= GBLCTL_RCLKRST_ON; ; Q4 K! U @/ L3 x7 k" Z; Z1 z. V2 d
while ( ( mcasp->regs->RGBLCTL & GBLCTL_RCLKRST_ON ) != GBLCTL_RCLKRST_ON );
7 g- J; m( E0 X+ d. C6 I/ I, a3 C( B8 a! i! w" n! y3 e
mcasp->regs->XSTAT = 0x0000ffff; 1 H8 \+ P( _- T5 T
mcasp->regs->RSTAT = 0x0000ffff; " |# W4 p2 n% |* l
5 c( D! K: P; @ c* `7 d4 } mcasp->regs->XGBLCTL |= GBLCTL_XSRCLR_ON;# t i. b$ N- N9 u
while ( ( mcasp->regs->XGBLCTL & GBLCTL_XSRCLR_ON ) != GBLCTL_XSRCLR_ON );
7 N5 ^9 R9 A, u# U mcasp->regs->RGBLCTL |= GBLCTL_RSRCLR_ON;
5 N+ h0 q$ l. m( D while ( ( mcasp->regs->RGBLCTL & GBLCTL_RSRCLR_ON ) != GBLCTL_RSRCLR_ON );
/ n1 ?7 b) i5 b. w; X, j) D" h% a6 @! @7 \+ }& V
/* Write a 0, so that no underrun occurs after releasing the state machine */
8 C- n4 ]6 k+ m" S# u( F' o$ E mcasp->regs->XBUF5 = 0;. X1 X1 b5 v) ~" q2 Y4 ]$ e
mcasp->regs->RBUF0 = 0;0 E/ p( i1 u( D" `* X6 E1 C) f9 \1 P' f
+ F$ b* A8 Y' _) x9 _' a
mcasp->regs->XGBLCTL |= GBLCTL_XSMRST_ON;
1 k! M1 {) O0 g# L while ( ( mcasp->regs->XGBLCTL & GBLCTL_XSMRST_ON ) != GBLCTL_XSMRST_ON );
& S. c/ B2 t5 v" a" U. m8 S mcasp->regs->RGBLCTL |= GBLCTL_RSMRST_ON; 8 U/ z! ?/ z6 x A- \
while ( ( mcasp->regs->RGBLCTL & GBLCTL_RSMRST_ON ) != GBLCTL_RSMRST_ON );
) C" A* [' T. a% n8 [0 H0 c% Z% D* f+ E0 @
mcasp->regs->XGBLCTL |= GBLCTL_XFRST_ON;
6 v* E- b" D& Y. X& p6 t* C' I while ( ( mcasp->regs->XGBLCTL & GBLCTL_XFRST_ON ) != GBLCTL_XFRST_ON );" D1 P$ X! r5 e! m8 ^( ~. ~ p
mcasp->regs->RGBLCTL |= GBLCTL_RFRST_ON;
7 n# {' g3 @( B% A while ( ( mcasp->regs->RGBLCTL & GBLCTL_RFRST_ON ) != GBLCTL_RFRST_ON );
4 X: m8 c, d" N% E" L' } u0 c2 @ H0 s+ p( |. Z6 S
CSR = 0x0000;+ ~; W* Q% @0 |8 Z; k1 F. y, i
INTC_INTMUX1 = 0x3d;% W6 f& ^: R+ @ O
ISTP = (unsigned int)vectors;
6 w* A( C; e: L. P; O6 C ICR = 0xFFF0; , B& u- j7 u) l7 O
IER |= 0x12;
8 B" l$ c/ k' G- | CSR |= 0x01;
9 K- Y! z$ i6 m' r9 L0 z! _
% t/ d0 o; d5 ~& S4 @) M L* k) {; D% Z/ N9 \
: j- w8 W5 L+ A+ Y" \2 @2 ~3 \' `还有就是两个输入输出函数:
! e5 S d* Z1 l1 m: dvoid output_sample(Int32 out_data)
& C" r" M7 r& h% W2 a0 O{. f3 I: x1 o' J) r
AIC31_data.uint = out_data;
5 f) c/ A. F; Z+ H+ |. _ MCASP1_XBUF5_32BIT = AIC31_data.uint;7 ?) @# Z0 l1 }) R& x5 a2 I/ w% W
}
, [+ `8 c+ W2 v6 E+ m
3 P4 ?9 u& B$ {Int32 input_sample(void)" ~! g3 h1 ?7 k j4 v; e+ n
{
% W* A! s" A4 G, G9 d) x AIC31_data.uint = MCASP1_RBUF0_32BIT;
# ~9 B; u- r) g# Q: u: E return (AIC31_data.uint);
+ c- p8 d+ m& u+ b9 r5 @$ g}: R( ~$ l% Z) z* [
* V9 m1 K0 y% I# z
|
|