|
|
C6747和C6748感觉差不多,我想实现McASP发送中断方式控制音频信号,在轮询的例程基础上改的,轮询程序可以实现,但是中断一直实现不了,也找不到错误,求大神帮忙!下边是主要程序:' F0 l$ p4 X" p& F/ W. y
main文件:7 Z: P4 B8 r8 P
interrupt void interrupt4(void)
6 J: M% J9 D7 S{
; c6 L! k* E& f* r6 C. `& b/ V Uint32 sample;- @- h1 K3 L+ [/ a. E8 k, h
" K6 `% h# [! T& Y. B
sample = input_sample(); // read L + R samples from ADC
2 F- O; p9 M5 z( P1 U1 b2 `0 g output_sample(sample); // write L + R samples to DAC
8 O' ^% S; I/ J return;. K. u7 x9 w8 G# |8 c; e+ K" s
}6 W& |1 ?3 P5 p* i2 k
6 K8 Q( K* A# d' h! D: S4 ?
int main( void )2 [$ L# @7 V! Z+ J; J; _
{/ d% X2 V1 M. D" w# U
: P5 W) V; E2 k W
/* Initialize BSL */4 j( l0 ?% h7 a* p) ~* Q
EVMC6747_init( );
, _' s' j0 v# X# v( h /* Call evmc6747_intr function */) `! I/ Y- {9 N! V8 M
aic3106_init( );$ g Q* l- a; |
while(1);% N# e! Y/ B8 O2 G8 O* P
}
' D4 ?% {5 P: f9 _
9 C7 J, e; R0 r! A! \1 j/ e
( l) e3 ^3 Q7 {) D/ O' P, P( F1 maic3106_init文件的一部分,McASP配置部分,采用内部时钟,I2S方式,同步传输。音频芯片的配置应该没问题3 Z3 \; f/ w; w# ~- ^6 x9 h, ?
/* Initialize MCASP1 */, x& i+ m: ~$ `3 C# [) A
mcasp = &MCASP_MODULE_1;6 ^6 b: L0 b. N5 j" g$ X s, u
mcasp->regs->GBLCTL = 0; // Reset9 w* C' T5 K: q
mcasp->regs->RGBLCTL = 0; // Reset RX
# g& r V! f* ?4 }" d- S" u$ G0 }; G mcasp->regs->XGBLCTL = 0; // Reset TX
' @8 B3 H2 g/ L8 ?! u0 I, A mcasp->regs->PWRDEMU = 1; // Free-running- ^9 j/ r$ \0 M& J& h7 R
// configure McASP0 receive registers1 i* J. v7 ^% f( [: \% p7 p
mcasp->regs->RMASK = 0xFFFFFFFF; // No padding used/ e7 r" r* X, w3 W* d: A
mcasp->regs->RFMT = 0x00018078; // MSB 16bit, 0-delay, no pad, CFGBus5 ^9 c" r9 ?( P" Z. g4 L
mcasp->regs->AFSRCTL = 0x00000112; // 2TDM, 1bit Falling, External FS, word, n. x9 p7 t n- o1 h1 W- l
mcasp->regs->ACLKRCTL = 0x000000AF; // Rising INTERNAL CLK,(from tx side)) U" }, r9 S$ ~2 A" e/ d) l3 }
mcasp->regs->AHCLKRCTL = 0x00000000; // INT CLK (from tx side)
. ^3 d; o4 ~8 ]3 e* F% F. d mcasp->regs->RTDM = 0x00000003; // Slots 0,1! o$ k" Y" F4 S9 X/ ?
mcasp->regs->RINTCTL = 0x00000000; // Not used
e; ]" P5 T/ E( T- t mcasp->regs->RCLKCHK = 0x00FF0008; // 255-MAX 0-MIN, div-by-256
$ I5 N$ }2 A. q; L* K
6 y' K8 z( R, E9 g7 m, n mcasp->regs->XMASK = 0xFFFFFFFF; // No padding used
" @. q- Q# g, ~ mcasp->regs->XFMT = 0x00018078; // MSB 16bit, 0-delay, no pad, CFGBus
/ R) ]1 k' R, p. a$ p9 W mcasp->regs->AFSXCTL = 0x00000112; // 2TDM, 1bit Rising edge INTERNAL FS, word: w3 p9 S, h* r( e
mcasp->regs->ACLKXCTL = 0x000000AF; // ASYNC, Rising INTERNAL CLK, div-by-164 O: W8 s+ C$ {: y+ R! p4 }" C
mcasp->regs->AHCLKXCTL = 0x00000000; // EXT CLK, T( ^( n8 Z7 d0 q; w6 s5 U
mcasp->regs->XTDM = 0x00000003; // Slots 0,1
' C+ X7 a8 |# F4 P mcasp->regs->XINTCTL = 0x00000020; // interrupt on transmit3 I- G9 F) M! A5 I2 ] t! _
mcasp->regs->XCLKCHK = 0x00FF0008; // 255-MAX 0-MIN, div-by-256
& n/ N5 V$ X9 b( t R. ^( _6 D* p8 [6 M- K5 P
mcasp->regs->SRCTL5 = 0x000D; // MCASP1.AXR1[5] --> DIN
- r8 [6 I1 d5 `, m% L mcasp->regs->SRCTL0 = 0x000E; // MCASP1.AXR1[0] <-- DOUT2 k! y; d5 J( Z# o" m
mcasp->regs->PFUNC = 0; // All MCASPs' e; @0 ^: w$ k- ~* o4 f
mcasp->regs->PDIR = 0x14000020; // All inputs except AXR0[5], ACLKX1, AFSX1
! e5 C+ L, \1 }' I/ b$ }- `1 m
7 M' L5 F* ]: o mcasp->regs->DITCTL = 0x00000000; // Not used! l8 A2 |! E$ Q1 H7 J9 p
mcasp->regs->DLBCTL = 0x00000000; // Not used1 t2 E/ p3 l' t3 J- d
mcasp->regs->AMUTE = 0x00000000; // Not used. ` m4 Y+ q2 P) H! b, D {% [
# p' e+ r2 |, C/ x8 I/ M/* Starting sections of the McASP*/# j8 O2 x1 f+ s5 _/ t* s- Y- w
mcasp->regs->XGBLCTL |= GBLCTL_XHCLKRST_ON;
) q+ Z1 R, s" o* ]. [ while ( ( mcasp->regs->XGBLCTL & GBLCTL_XHCLKRST_ON ) != GBLCTL_XHCLKRST_ON ); . |6 [5 c f, s$ J1 U; y/ ]
mcasp->regs->RGBLCTL |= GBLCTL_RHCLKRST_ON; $ q' U9 L) i' V( ]* R6 R
while ( ( mcasp->regs->RGBLCTL & GBLCTL_RHCLKRST_ON ) != GBLCTL_RHCLKRST_ON );$ h; n0 G5 q& S/ O" B: @0 q
& j7 Z; U( J3 }; D
mcasp->regs->XGBLCTL |= GBLCTL_XCLKRST_ON; - H% {0 `+ N/ [+ d- [
while ( ( mcasp->regs->XGBLCTL & GBLCTL_XCLKRST_ON ) != GBLCTL_XCLKRST_ON );
) x& I1 L/ J2 m, d7 k6 ] mcasp->regs->RGBLCTL |= GBLCTL_RCLKRST_ON; * T1 V- n- @9 P9 ?/ W f$ R
while ( ( mcasp->regs->RGBLCTL & GBLCTL_RCLKRST_ON ) != GBLCTL_RCLKRST_ON );
. y* K8 e: C# Y9 c3 y5 j; R8 C/ ~6 |. T
mcasp->regs->XSTAT = 0x0000ffff; 6 L9 r# C/ m. s; p: d- ~' w6 \7 W
mcasp->regs->RSTAT = 0x0000ffff; % `, m, c8 N7 f6 g& t0 E% o
4 d+ L' p& U- G
mcasp->regs->XGBLCTL |= GBLCTL_XSRCLR_ON;
1 D/ v, K x* o while ( ( mcasp->regs->XGBLCTL & GBLCTL_XSRCLR_ON ) != GBLCTL_XSRCLR_ON );1 p! n* e$ z* b2 b+ [0 I* q
mcasp->regs->RGBLCTL |= GBLCTL_RSRCLR_ON; 7 O. Y" v8 `9 ~0 \% e
while ( ( mcasp->regs->RGBLCTL & GBLCTL_RSRCLR_ON ) != GBLCTL_RSRCLR_ON );* ]! A5 r1 I. w4 b% H' e+ D3 i# s
& `! s1 [0 r: L& }# T /* Write a 0, so that no underrun occurs after releasing the state machine */) H( O* P( [5 ?; A. f# z$ } l
mcasp->regs->XBUF5 = 0;
- [3 J$ ]1 K5 c mcasp->regs->RBUF0 = 0;) a/ w" g1 Q& |3 D6 `1 v; T+ Z
' L9 V6 u" I. Y' g! u mcasp->regs->XGBLCTL |= GBLCTL_XSMRST_ON; 9 c% r! v9 i9 X& k! k( V
while ( ( mcasp->regs->XGBLCTL & GBLCTL_XSMRST_ON ) != GBLCTL_XSMRST_ON );
5 G4 K0 T& j/ E- [" }- a9 G7 a, G mcasp->regs->RGBLCTL |= GBLCTL_RSMRST_ON;
# E# z8 u; W, Z* F8 ^0 R while ( ( mcasp->regs->RGBLCTL & GBLCTL_RSMRST_ON ) != GBLCTL_RSMRST_ON );; }1 x" \! s6 a8 Z3 s& r1 q
' ^ |# U- L% \& s. H mcasp->regs->XGBLCTL |= GBLCTL_XFRST_ON; X# R3 e! N \ u% o4 d, P
while ( ( mcasp->regs->XGBLCTL & GBLCTL_XFRST_ON ) != GBLCTL_XFRST_ON );
1 g. v& ^8 G# U% l8 j3 W/ a mcasp->regs->RGBLCTL |= GBLCTL_RFRST_ON; 0 f/ V/ }9 l: W/ j3 p, |
while ( ( mcasp->regs->RGBLCTL & GBLCTL_RFRST_ON ) != GBLCTL_RFRST_ON );
9 W1 G7 O: ^+ q( L E4 d A( i2 n; r+ V& K0 ? P
CSR = 0x0000; J4 t1 Y8 q! `, t1 z0 p1 W0 k% p
INTC_INTMUX1 = 0x3d;
}/ I1 n/ X; q' D% o2 I! x! `3 }, n) d ISTP = (unsigned int)vectors;: q& O3 g9 q1 M, v) j
ICR = 0xFFF0; * M7 F$ A" N, E7 f4 p
IER |= 0x12; - s5 N& g# T( Q; H h; s! \3 q ?
CSR |= 0x01; 6 r4 Z! \$ `/ m' a$ j3 x, `
' L; q" R% @( }! W- y4 k0 D. h L
: t/ I4 I& {1 }
0 K4 W+ d3 O$ g3 q% _还有就是两个输入输出函数: p/ ^4 n( @# t0 k* W f' @6 b
void output_sample(Int32 out_data)
! ^; }9 A) Q$ T7 X6 h8 v' f{
. a4 M' K' y) ~' A! q AIC31_data.uint = out_data;
" C( P# B- D: Z) w! I2 s1 s MCASP1_XBUF5_32BIT = AIC31_data.uint;8 H- R+ q3 z! T$ ?
}5 x% l6 ?- l% P8 x# x) C
" L$ B3 M& Y- B7 m R. c
Int32 input_sample(void)
. r8 C4 h/ B; ^4 O4 y H, w: T. }{ ) z" ^/ ~( K& I8 N
AIC31_data.uint = MCASP1_RBUF0_32BIT;7 N! s% l/ m) N9 u5 `
return (AIC31_data.uint);
* X' Y( |# e, e- p( ^5 b* G+ I! b}
# {. Z- Y( @5 K. u* q% B( ]4 w$ A+ H& z7 u1 J# g6 A8 ~
|
|