|
|
C6747和C6748感觉差不多,我想实现McASP发送中断方式控制音频信号,在轮询的例程基础上改的,轮询程序可以实现,但是中断一直实现不了,也找不到错误,求大神帮忙!下边是主要程序:
) p- q( o' E4 A2 Lmain文件:8 Q8 m0 P7 e0 ~: ?4 e; y
interrupt void interrupt4(void)
# e1 i, Y: B3 `; y( ^9 e$ ]- L{1 x9 L* B. b5 X$ w( L7 |
Uint32 sample;2 u1 j3 K! C! r& ]
7 a1 A7 `- q+ V" @( O: r
sample = input_sample(); // read L + R samples from ADC- f% J6 U: M, E$ [. U
output_sample(sample); // write L + R samples to DAC 1 X# G, `) K' |* M1 F9 w+ \
return;4 J% \" `; W c" V0 X8 b1 g2 E
}# |* v& b6 h8 ?$ K9 e, B
( i% B3 \3 o0 v- f- _int main( void )
# F1 j/ G' N# J{8 Q) ~) D" p. y' P) R) m2 P, P
* _6 Q A: @" O
/* Initialize BSL */
* T2 R9 [+ }1 v; z# U( j EVMC6747_init( );
, y: L7 q0 w. x' y, Q /* Call evmc6747_intr function */
5 _) {+ n. i9 g# T' x aic3106_init( );
# S' C4 @- B5 z. S4 T3 T1 j- ] while(1);. A6 E. ^5 ^ E! e: h- \7 v( u
}
" C5 W9 \' ]( O6 h1 p, U
! f2 {. p: q$ I* @& j
/ I6 J$ U) K) ?! B waic3106_init文件的一部分,McASP配置部分,采用内部时钟,I2S方式,同步传输。音频芯片的配置应该没问题
2 a" P# m2 B) w8 {/* Initialize MCASP1 */
- Q" S/ @# R+ P! R! o mcasp = &MCASP_MODULE_1;/ u4 Y9 Q( ~* }8 q
mcasp->regs->GBLCTL = 0; // Reset+ W9 {! y& X( E8 p! \' ^6 J
mcasp->regs->RGBLCTL = 0; // Reset RX
" H2 |# ?& U5 c' [ mcasp->regs->XGBLCTL = 0; // Reset TX
+ E' k; h5 K% r7 i, ` mcasp->regs->PWRDEMU = 1; // Free-running5 ^" D0 s. X# N! ?+ t& H
// configure McASP0 receive registers* W3 K4 ]: b, ?/ `5 ~
mcasp->regs->RMASK = 0xFFFFFFFF; // No padding used
# Z# l2 m( X1 h8 N! S mcasp->regs->RFMT = 0x00018078; // MSB 16bit, 0-delay, no pad, CFGBus
0 z' @0 h- ?# B# \) ?( [: E. f mcasp->regs->AFSRCTL = 0x00000112; // 2TDM, 1bit Falling, External FS, word
5 x# }& d2 k. Q" \: q" ]* C mcasp->regs->ACLKRCTL = 0x000000AF; // Rising INTERNAL CLK,(from tx side)
$ w' c: Z- i0 m0 f6 [# U mcasp->regs->AHCLKRCTL = 0x00000000; // INT CLK (from tx side)
/ m \. d& x' W mcasp->regs->RTDM = 0x00000003; // Slots 0,1* l* j* Z3 V: ]; W. K j; M$ I8 i- i
mcasp->regs->RINTCTL = 0x00000000; // Not used& S7 i; a9 S i. i! f
mcasp->regs->RCLKCHK = 0x00FF0008; // 255-MAX 0-MIN, div-by-256
. Y T1 G8 X3 Z/ d% `( {. E# [) m) l& Z ~# s# r0 j
mcasp->regs->XMASK = 0xFFFFFFFF; // No padding used3 }# Z& v: Y* _ }! ]1 `* M/ @
mcasp->regs->XFMT = 0x00018078; // MSB 16bit, 0-delay, no pad, CFGBus+ y' a, l6 R e# K2 {$ y" F
mcasp->regs->AFSXCTL = 0x00000112; // 2TDM, 1bit Rising edge INTERNAL FS, word
0 B" f! i3 {7 U4 ]) x$ |8 F mcasp->regs->ACLKXCTL = 0x000000AF; // ASYNC, Rising INTERNAL CLK, div-by-16
5 z" j& J4 N8 q; Y mcasp->regs->AHCLKXCTL = 0x00000000; // EXT CLK
. J. p: s% \) {. y& l0 _ mcasp->regs->XTDM = 0x00000003; // Slots 0,1* t6 e7 p2 W2 i0 e
mcasp->regs->XINTCTL = 0x00000020; // interrupt on transmit
9 w# c! [9 w& n mcasp->regs->XCLKCHK = 0x00FF0008; // 255-MAX 0-MIN, div-by-256
" V& @& X0 t) P+ d2 F6 G3 z c' U6 k; s1 S; f
mcasp->regs->SRCTL5 = 0x000D; // MCASP1.AXR1[5] --> DIN7 O% w+ P- u" G' b6 V
mcasp->regs->SRCTL0 = 0x000E; // MCASP1.AXR1[0] <-- DOUT8 Y% z* [6 ] n" n) {$ I" i6 i8 _
mcasp->regs->PFUNC = 0; // All MCASPs
# I+ P7 R$ t& w; T' | mcasp->regs->PDIR = 0x14000020; // All inputs except AXR0[5], ACLKX1, AFSX12 l3 |6 W, ]7 K* r
9 g4 a, G3 ]4 j
mcasp->regs->DITCTL = 0x00000000; // Not used$ i7 s' i% d( V: o5 B% p0 T( y
mcasp->regs->DLBCTL = 0x00000000; // Not used2 }0 g0 f+ P: I! j' t' Z
mcasp->regs->AMUTE = 0x00000000; // Not used
- \* ?* \# _2 W% r3 v5 m, j/ c; u) w U2 p6 \
/* Starting sections of the McASP*/0 X( h5 P4 ^ a2 _. k
mcasp->regs->XGBLCTL |= GBLCTL_XHCLKRST_ON;
$ r" ^+ c/ Q( c8 Y! Q while ( ( mcasp->regs->XGBLCTL & GBLCTL_XHCLKRST_ON ) != GBLCTL_XHCLKRST_ON );
! e3 k/ g- r- F) Z( n+ R" w mcasp->regs->RGBLCTL |= GBLCTL_RHCLKRST_ON;
! j! q5 }1 o# r9 `" G% d while ( ( mcasp->regs->RGBLCTL & GBLCTL_RHCLKRST_ON ) != GBLCTL_RHCLKRST_ON );8 z0 p+ ]: H) K
$ J( Z7 n1 N; }
mcasp->regs->XGBLCTL |= GBLCTL_XCLKRST_ON; 3 |$ z- W9 S2 |# _. e* o4 c
while ( ( mcasp->regs->XGBLCTL & GBLCTL_XCLKRST_ON ) != GBLCTL_XCLKRST_ON );8 a8 v3 k4 H: _! }- \" h. N
mcasp->regs->RGBLCTL |= GBLCTL_RCLKRST_ON; 5 V7 }: G d/ P9 |
while ( ( mcasp->regs->RGBLCTL & GBLCTL_RCLKRST_ON ) != GBLCTL_RCLKRST_ON );) t! u8 S1 L1 [: Y6 B$ A
! x5 ^/ y6 c6 _/ d
mcasp->regs->XSTAT = 0x0000ffff;
; G& N) F9 _; x6 s- v mcasp->regs->RSTAT = 0x0000ffff; , |2 @( l% X' ~! D1 n
5 ?) K c$ U1 u3 o mcasp->regs->XGBLCTL |= GBLCTL_XSRCLR_ON;
* S+ J5 q+ i9 K0 O- k- m& Z$ z* S( ?) R while ( ( mcasp->regs->XGBLCTL & GBLCTL_XSRCLR_ON ) != GBLCTL_XSRCLR_ON );; z, D# \6 Q) n k2 @& \
mcasp->regs->RGBLCTL |= GBLCTL_RSRCLR_ON;
+ R2 q& M4 q# w- ^ while ( ( mcasp->regs->RGBLCTL & GBLCTL_RSRCLR_ON ) != GBLCTL_RSRCLR_ON );4 Z5 c6 ~) c( N( Y8 F. t' Z
* I' F& v6 D* Z
/* Write a 0, so that no underrun occurs after releasing the state machine */+ d. r! C5 G* X. e4 b4 m
mcasp->regs->XBUF5 = 0;
- [' o5 n: ^) y9 C, N9 ~; \ mcasp->regs->RBUF0 = 0;4 ? l4 n' l1 s' A8 M& Y" R
/ M' x% o b( [
mcasp->regs->XGBLCTL |= GBLCTL_XSMRST_ON;
6 Y) t" A% A; ?6 R while ( ( mcasp->regs->XGBLCTL & GBLCTL_XSMRST_ON ) != GBLCTL_XSMRST_ON );" K6 V7 ?0 o* I" T$ k9 ~% M& j, r
mcasp->regs->RGBLCTL |= GBLCTL_RSMRST_ON; ) i6 L4 G! w u
while ( ( mcasp->regs->RGBLCTL & GBLCTL_RSMRST_ON ) != GBLCTL_RSMRST_ON );
# m2 f& h# ^$ I+ E" f! @) M6 C) i; J' W+ ]9 N
mcasp->regs->XGBLCTL |= GBLCTL_XFRST_ON; ' |( f: v* f2 r, K S+ W
while ( ( mcasp->regs->XGBLCTL & GBLCTL_XFRST_ON ) != GBLCTL_XFRST_ON );* n5 n5 d# _# a+ P( U
mcasp->regs->RGBLCTL |= GBLCTL_RFRST_ON; 6 a2 y/ R7 D9 b. q6 A
while ( ( mcasp->regs->RGBLCTL & GBLCTL_RFRST_ON ) != GBLCTL_RFRST_ON );$ O, I4 T5 i- f* [- S$ @* n
" o# U. t9 e/ k+ ]9 H1 ^ CSR = 0x0000;; C" _# w* b! U8 O: Z
INTC_INTMUX1 = 0x3d;
: B. F# {7 f, J$ I7 `$ h8 l ISTP = (unsigned int)vectors;6 ^0 J8 e { B3 p3 R9 q
ICR = 0xFFF0; + \& D$ V8 r) Q9 ~
IER |= 0x12; 8 V3 g0 r& p i5 A0 O
CSR |= 0x01;
; g& L8 m& r" c3 S/ V; T/ u7 O2 }9 X6 a3 s
* W l% d5 Y, J4 O
1 F% K# L+ K! v& g, m6 p还有就是两个输入输出函数:
& y" n0 b; t, ^' g2 X6 [) U. _void output_sample(Int32 out_data)
8 u1 L9 E$ | L" U+ }% s{$ X" D, V! r7 J- J, u7 p% \8 {3 W
AIC31_data.uint = out_data;
' t0 I9 t; M; H* K! v MCASP1_XBUF5_32BIT = AIC31_data.uint;
! H( ~, K& e3 I7 o0 }! E' }}
9 `9 Y* q5 G" u5 D0 ]8 }2 K0 e8 w: ]
Int32 input_sample(void)& ]1 d/ B& H6 O+ H" h6 s
{ 5 \" ~6 Z2 e& R; y0 ~7 ~1 C) {
AIC31_data.uint = MCASP1_RBUF0_32BIT;& c! p7 I3 | m$ ^! |+ @+ i% j6 _
return (AIC31_data.uint);/ I3 r+ C/ ]( ]+ A5 h' `: z
}* [0 p- u, v% w
& |* ^* K0 H$ S6 y" n' y5 c
|
|