|
|
C6747和C6748感觉差不多,我想实现McASP发送中断方式控制音频信号,在轮询的例程基础上改的,轮询程序可以实现,但是中断一直实现不了,也找不到错误,求大神帮忙!下边是主要程序:! _8 c8 F; T$ Q; c: j* C* E; h9 p
main文件:9 a( C1 q0 r4 O
interrupt void interrupt4(void)
, P0 R! J/ q; o& x6 S( F: _' u{$ Z; Y! a. B# y1 _1 E3 c/ V2 @: I
Uint32 sample;. N4 M7 ]# {9 E$ V6 Q- Y# o
4 v. h$ V) O" i4 l
sample = input_sample(); // read L + R samples from ADC
0 [) V$ c5 r) B# | output_sample(sample); // write L + R samples to DAC
6 l) ?4 a h. f8 T) T return;7 z% d" {3 D. t, L# W: A5 k
}/ D1 F( E' K m2 p
5 X- s3 B3 q# ? a0 |+ i7 Mint main( void )) x* C' ~1 ?/ m$ r2 Y
{
/ Q; F7 s2 z, K) m: _; C; N6 {2 p5 ?9 v; Y z9 m; S, S- R
/* Initialize BSL */; F5 `, g' E$ u$ i7 r" {
EVMC6747_init( );) ]- `8 [, ]# o' @ H( Z7 q9 B
/* Call evmc6747_intr function */# Y2 t- P3 ]7 v1 M* i( c6 w
aic3106_init( );) S! q3 o, N8 H; A4 {& J
while(1);) o4 f; {% z! z1 n8 C$ y. Q
}
s9 M9 J/ \/ e, _# H) [8 `; R9 y2 E' |' m4 _
, B7 t i) h, K+ E) q- r( k. i+ F
aic3106_init文件的一部分,McASP配置部分,采用内部时钟,I2S方式,同步传输。音频芯片的配置应该没问题) Q- B# t( P3 ]4 E
/* Initialize MCASP1 */* _/ a9 v* Q8 Y4 C/ Y+ [
mcasp = &MCASP_MODULE_1;
& ~- \7 k8 h& L) c0 X mcasp->regs->GBLCTL = 0; // Reset
$ V8 k! M ^- ?5 b) t mcasp->regs->RGBLCTL = 0; // Reset RX
, ?1 z1 I- I4 U mcasp->regs->XGBLCTL = 0; // Reset TX
4 ]9 ?2 l: B8 u- V0 O) d mcasp->regs->PWRDEMU = 1; // Free-running2 Z" r, ?0 K7 ? c& N6 j( a1 {4 Z
// configure McASP0 receive registers$ J/ O: ^: o* m7 t
mcasp->regs->RMASK = 0xFFFFFFFF; // No padding used
1 w5 r, r$ r8 H/ p. P mcasp->regs->RFMT = 0x00018078; // MSB 16bit, 0-delay, no pad, CFGBus
; d! K3 H6 M% ?) y! j' s mcasp->regs->AFSRCTL = 0x00000112; // 2TDM, 1bit Falling, External FS, word$ ?8 J) E9 v7 {2 |
mcasp->regs->ACLKRCTL = 0x000000AF; // Rising INTERNAL CLK,(from tx side)& q. l& f7 e- F) y0 x$ _# k
mcasp->regs->AHCLKRCTL = 0x00000000; // INT CLK (from tx side)
" L2 s) \. M3 h6 `" _* j2 F mcasp->regs->RTDM = 0x00000003; // Slots 0,1
" u1 [3 b5 ^0 o! U, g% h mcasp->regs->RINTCTL = 0x00000000; // Not used+ w% J1 u0 s) `+ l" Y! {5 R$ N
mcasp->regs->RCLKCHK = 0x00FF0008; // 255-MAX 0-MIN, div-by-256
/ p2 l. o& R) @0 ~# F U, D
6 X8 }+ A2 T. [# b0 | _ mcasp->regs->XMASK = 0xFFFFFFFF; // No padding used
. I( N& {; S+ T6 F% @2 v mcasp->regs->XFMT = 0x00018078; // MSB 16bit, 0-delay, no pad, CFGBus
5 m5 U0 R7 M4 w) @ r2 U mcasp->regs->AFSXCTL = 0x00000112; // 2TDM, 1bit Rising edge INTERNAL FS, word
4 o' v, N% T7 F mcasp->regs->ACLKXCTL = 0x000000AF; // ASYNC, Rising INTERNAL CLK, div-by-16
( G. r# a6 b* V; y% H# S mcasp->regs->AHCLKXCTL = 0x00000000; // EXT CLK' z" Y) x9 b8 q$ f6 M
mcasp->regs->XTDM = 0x00000003; // Slots 0,1
6 L$ Y L' ]0 v5 h" L# U mcasp->regs->XINTCTL = 0x00000020; // interrupt on transmit
. ]8 N4 ~+ x0 `$ T( t. s mcasp->regs->XCLKCHK = 0x00FF0008; // 255-MAX 0-MIN, div-by-256
- Z' F5 F3 X$ \% }# X9 o: D
1 V: I0 R7 `3 {8 s- V* r mcasp->regs->SRCTL5 = 0x000D; // MCASP1.AXR1[5] --> DIN
% i( s! x9 V8 t: W1 W( j mcasp->regs->SRCTL0 = 0x000E; // MCASP1.AXR1[0] <-- DOUT
# t: b8 V, C( j1 p5 O* `% W- t mcasp->regs->PFUNC = 0; // All MCASPs
9 Z2 B& q0 L1 D" e* R; Q mcasp->regs->PDIR = 0x14000020; // All inputs except AXR0[5], ACLKX1, AFSX1' {- b7 Y2 C# p1 g
/ f: w" Y9 Y" ~+ N% A mcasp->regs->DITCTL = 0x00000000; // Not used
- I- e& ]- U9 o mcasp->regs->DLBCTL = 0x00000000; // Not used+ q- S; ?. o' Q) C* G5 A
mcasp->regs->AMUTE = 0x00000000; // Not used
1 [( w; D' W+ R. m( ?2 ` \ O6 r) `* _
/* Starting sections of the McASP*/+ j1 ~ G9 W! U5 F
mcasp->regs->XGBLCTL |= GBLCTL_XHCLKRST_ON;
& z1 s" V3 W! f0 r. ~: R while ( ( mcasp->regs->XGBLCTL & GBLCTL_XHCLKRST_ON ) != GBLCTL_XHCLKRST_ON );
0 H5 H) X# F* a; `4 x+ i$ Y mcasp->regs->RGBLCTL |= GBLCTL_RHCLKRST_ON; 3 m( O8 k9 m; S% {& [
while ( ( mcasp->regs->RGBLCTL & GBLCTL_RHCLKRST_ON ) != GBLCTL_RHCLKRST_ON );
6 @- ?2 Z2 `* e3 `
6 y" r% c& `9 a$ n7 a mcasp->regs->XGBLCTL |= GBLCTL_XCLKRST_ON; : e& D* c8 J0 U7 a* Y4 q. q3 N
while ( ( mcasp->regs->XGBLCTL & GBLCTL_XCLKRST_ON ) != GBLCTL_XCLKRST_ON );
$ F8 x9 w' V+ B9 E mcasp->regs->RGBLCTL |= GBLCTL_RCLKRST_ON;
! E8 }/ M$ E2 B% u+ r6 a" i& i; h while ( ( mcasp->regs->RGBLCTL & GBLCTL_RCLKRST_ON ) != GBLCTL_RCLKRST_ON );
9 i* [- b2 j* T# @8 {1 P4 M4 P, G5 @0 O+ l( G
mcasp->regs->XSTAT = 0x0000ffff;
/ F( c' ^) ? m7 d: [5 u mcasp->regs->RSTAT = 0x0000ffff; : N* {- d5 ^/ j
: `6 o& Q, p3 B @8 `. C/ k mcasp->regs->XGBLCTL |= GBLCTL_XSRCLR_ON;
& |8 s' y t2 {/ }- z while ( ( mcasp->regs->XGBLCTL & GBLCTL_XSRCLR_ON ) != GBLCTL_XSRCLR_ON );
. b4 n' S) X0 @: w* P/ Q# V mcasp->regs->RGBLCTL |= GBLCTL_RSRCLR_ON;
1 N. j+ f% h4 O while ( ( mcasp->regs->RGBLCTL & GBLCTL_RSRCLR_ON ) != GBLCTL_RSRCLR_ON );
* J' W2 N8 G8 R) K# m+ r
2 j& \& M% s6 S- J% F /* Write a 0, so that no underrun occurs after releasing the state machine */
" r3 ?( s/ P6 [, v& ^7 @( m mcasp->regs->XBUF5 = 0;
7 ]' L8 X+ a- ? mcasp->regs->RBUF0 = 0;% k/ x& M: Z8 f W" f* }
0 T) P9 f7 t9 W# N. V mcasp->regs->XGBLCTL |= GBLCTL_XSMRST_ON;
3 t8 [4 h5 s, G! e: L2 G) C while ( ( mcasp->regs->XGBLCTL & GBLCTL_XSMRST_ON ) != GBLCTL_XSMRST_ON );0 b4 t5 d( k) d# W7 _; @
mcasp->regs->RGBLCTL |= GBLCTL_RSMRST_ON;
. Q- t8 D6 t/ o$ H% C2 K while ( ( mcasp->regs->RGBLCTL & GBLCTL_RSMRST_ON ) != GBLCTL_RSMRST_ON );
2 e x0 c& v1 \& [5 r, F9 ^# T+ p) B( l* f" m
mcasp->regs->XGBLCTL |= GBLCTL_XFRST_ON;
" F( R' k3 T. n. J+ V; I7 g3 ` while ( ( mcasp->regs->XGBLCTL & GBLCTL_XFRST_ON ) != GBLCTL_XFRST_ON );
+ r9 L, R2 I) r8 S$ j! H mcasp->regs->RGBLCTL |= GBLCTL_RFRST_ON; ! e; c4 @5 \1 G$ ?; ^ D
while ( ( mcasp->regs->RGBLCTL & GBLCTL_RFRST_ON ) != GBLCTL_RFRST_ON );
2 Q) C* _& W+ t# i2 J- Z! n! [. _, U; q# I* t7 g
CSR = 0x0000;' ?" \! q% Q; F3 B5 ?$ O
INTC_INTMUX1 = 0x3d;
& j; o% R A0 E( R7 f* F- `8 | ISTP = (unsigned int)vectors;$ R: f4 `4 t8 Q/ p
ICR = 0xFFF0;
1 A) i8 Z/ X- t" K# N IER |= 0x12;
9 f, j# c1 J9 t2 C% A CSR |= 0x01; / D( l$ O( }. |% E; Q
, |4 f! ^( a% |8 h) J0 A
/ g+ j# q5 G) H/ Q2 f% A* ^ a9 {* \7 O. V
还有就是两个输入输出函数:
9 T: ~ j! |. h; @% R5 jvoid output_sample(Int32 out_data)( U0 b( K9 u9 N( ?2 E$ u+ q( g
{" e' E7 r; P: |
AIC31_data.uint = out_data; i3 I" o2 n; `( x, p3 s
MCASP1_XBUF5_32BIT = AIC31_data.uint;! ?- P) e# g! E8 d
}" o0 O' `& M; o: M: l& d/ }
; V2 |8 q; n b" |Int32 input_sample(void)7 s# U" M) k9 w" H( e. |
{
/ m3 V/ M9 o/ K7 A) J+ y4 l& S AIC31_data.uint = MCASP1_RBUF0_32BIT;
V8 F3 N1 v, k# C return (AIC31_data.uint);
: l0 k, J9 t- E8 ^. h* O}$ U8 V/ [+ s6 o# k8 R
1 Y% P C. a6 ?* X X+ |; F |
|