|
|
C6747和C6748感觉差不多,我想实现McASP发送中断方式控制音频信号,在轮询的例程基础上改的,轮询程序可以实现,但是中断一直实现不了,也找不到错误,求大神帮忙!下边是主要程序:
, Z9 L! a# r- @( |$ s. ~! H" wmain文件:* ^- K- _, h) Z- w8 e
interrupt void interrupt4(void)
' p' F0 e( q. ]& ]( Y{) t, K7 I( T# w8 [
Uint32 sample;
b" Z" H/ a" ~) R+ B0 a/ A( a4 V3 O8 _5 E8 C( r6 h% Z
sample = input_sample(); // read L + R samples from ADC
) `* @" ~0 s' F output_sample(sample); // write L + R samples to DAC
! _; X: J; V3 Y return; b, R" q/ ]: u3 P
}4 F6 T/ ^- e( z
0 h' \( k8 r |6 m0 G" {int main( void )
/ g- P$ _7 N( Y V{
% b3 |6 y& ^. C0 x' K5 A
* q* j4 v! b6 |- T5 \9 d. J: K /* Initialize BSL */
( g1 _+ i' {, k6 {, V7 _ EVMC6747_init( );) E. Z( D# _2 Q3 V. Z0 V: l
/* Call evmc6747_intr function */5 O: i0 W( a* j/ L, N
aic3106_init( );
0 d4 q* [1 c% r# r! T while(1);
9 I7 {6 M. V& n; W/ U. I}
7 b5 X8 s4 Y; P, W; b0 b( m5 s: l0 R) O5 T0 A( h( u- R5 k8 C
* B+ u8 a! g R0 V
aic3106_init文件的一部分,McASP配置部分,采用内部时钟,I2S方式,同步传输。音频芯片的配置应该没问题3 L3 {' h: R( u
/* Initialize MCASP1 */
' ]& s a9 L6 F: m \6 d1 s: I mcasp = &MCASP_MODULE_1;) c: E$ v1 {5 _5 p( K5 `$ P
mcasp->regs->GBLCTL = 0; // Reset
9 S. ^9 t+ N1 o mcasp->regs->RGBLCTL = 0; // Reset RX5 g0 x+ c' l5 a: T8 c4 ]
mcasp->regs->XGBLCTL = 0; // Reset TX# L5 D0 W0 ~0 _
mcasp->regs->PWRDEMU = 1; // Free-running+ w: j/ b5 m- l
// configure McASP0 receive registers
( @+ W5 Y+ m/ t* O w& P! e mcasp->regs->RMASK = 0xFFFFFFFF; // No padding used, W! D# Z: C% g- G% C
mcasp->regs->RFMT = 0x00018078; // MSB 16bit, 0-delay, no pad, CFGBus
; n7 Z/ j( \7 f' N mcasp->regs->AFSRCTL = 0x00000112; // 2TDM, 1bit Falling, External FS, word$ J6 f/ C$ E7 d5 o# i# }3 P
mcasp->regs->ACLKRCTL = 0x000000AF; // Rising INTERNAL CLK,(from tx side)6 r' g- g/ z8 ^0 n
mcasp->regs->AHCLKRCTL = 0x00000000; // INT CLK (from tx side)
3 w; `* H) \1 {! W. y8 X mcasp->regs->RTDM = 0x00000003; // Slots 0,1
+ e$ H6 b5 N* T* v# P4 F; u. G' M, \ mcasp->regs->RINTCTL = 0x00000000; // Not used
/ j1 J0 U! D0 O& v {: d$ X mcasp->regs->RCLKCHK = 0x00FF0008; // 255-MAX 0-MIN, div-by-256( r& r, M- h5 @+ P. ?
: u( u+ T% f7 t% M
mcasp->regs->XMASK = 0xFFFFFFFF; // No padding used( }- P# B. |+ ^# S% Y% Q
mcasp->regs->XFMT = 0x00018078; // MSB 16bit, 0-delay, no pad, CFGBus, B$ {/ T# S" ?
mcasp->regs->AFSXCTL = 0x00000112; // 2TDM, 1bit Rising edge INTERNAL FS, word8 B9 a" e( }, o: V* x
mcasp->regs->ACLKXCTL = 0x000000AF; // ASYNC, Rising INTERNAL CLK, div-by-16
8 [3 d. G7 Q' e: N; z mcasp->regs->AHCLKXCTL = 0x00000000; // EXT CLK/ |+ H* z5 r: e! @ q
mcasp->regs->XTDM = 0x00000003; // Slots 0,1% g1 Q( X6 P) A( B! j* {5 H
mcasp->regs->XINTCTL = 0x00000020; // interrupt on transmit
7 }& U: r3 t* W3 R! o+ S: L2 ` mcasp->regs->XCLKCHK = 0x00FF0008; // 255-MAX 0-MIN, div-by-256
- O) \' \( L: M+ Z, p* C& W
+ w; h9 L! y8 J) P! C3 K mcasp->regs->SRCTL5 = 0x000D; // MCASP1.AXR1[5] --> DIN' [; o0 p- l. \" h, r J# J
mcasp->regs->SRCTL0 = 0x000E; // MCASP1.AXR1[0] <-- DOUT
6 m) e, i' G3 d! z" p- r) a. L mcasp->regs->PFUNC = 0; // All MCASPs5 w. @7 W2 W$ d9 v: G6 o3 g
mcasp->regs->PDIR = 0x14000020; // All inputs except AXR0[5], ACLKX1, AFSX1
' ]; V2 n: E. A4 P) c Z# g
5 Z) [2 ~5 T9 S mcasp->regs->DITCTL = 0x00000000; // Not used, J5 V% t7 p [' C8 F
mcasp->regs->DLBCTL = 0x00000000; // Not used$ Q3 U$ w! o0 b
mcasp->regs->AMUTE = 0x00000000; // Not used
/ t2 \3 o! W. f: x
* h( |* e# ]% d# f: {$ M% ]* ]/* Starting sections of the McASP*/
1 d6 f3 L8 ?( E. ]* p7 z- G mcasp->regs->XGBLCTL |= GBLCTL_XHCLKRST_ON;
" g2 l. U9 f/ H( g0 l* F while ( ( mcasp->regs->XGBLCTL & GBLCTL_XHCLKRST_ON ) != GBLCTL_XHCLKRST_ON );
, p6 g( @8 k- }& } mcasp->regs->RGBLCTL |= GBLCTL_RHCLKRST_ON; # Y' `" {; S# l4 g4 }% v
while ( ( mcasp->regs->RGBLCTL & GBLCTL_RHCLKRST_ON ) != GBLCTL_RHCLKRST_ON );
, ~' G1 |4 p/ c1 N' W) G% i+ h1 W; ^- u* I1 ]- p
mcasp->regs->XGBLCTL |= GBLCTL_XCLKRST_ON; B& ^3 _: |) ], ~, H6 S9 x/ P
while ( ( mcasp->regs->XGBLCTL & GBLCTL_XCLKRST_ON ) != GBLCTL_XCLKRST_ON );
; Y9 J; A! [& ]: h1 W6 S mcasp->regs->RGBLCTL |= GBLCTL_RCLKRST_ON;
8 Q) P- l4 ]1 [. N while ( ( mcasp->regs->RGBLCTL & GBLCTL_RCLKRST_ON ) != GBLCTL_RCLKRST_ON );
* W' S/ P3 a2 z. [& v4 }. D1 t3 W# N) ?
mcasp->regs->XSTAT = 0x0000ffff;
4 X0 i, b/ q1 z/ t) D; V0 U X4 ` mcasp->regs->RSTAT = 0x0000ffff;
8 v& \7 t, B" h/ N/ ]
6 U$ [5 E$ [7 c% R mcasp->regs->XGBLCTL |= GBLCTL_XSRCLR_ON;* }: \- A: ?2 H/ Q
while ( ( mcasp->regs->XGBLCTL & GBLCTL_XSRCLR_ON ) != GBLCTL_XSRCLR_ON );# ?8 i$ F* N( E' R% U" f
mcasp->regs->RGBLCTL |= GBLCTL_RSRCLR_ON;
- c/ f- u2 H6 f* Q while ( ( mcasp->regs->RGBLCTL & GBLCTL_RSRCLR_ON ) != GBLCTL_RSRCLR_ON );
/ e$ d4 c- d& `/ T* S( {
' }0 ?% p* S2 V# U' b /* Write a 0, so that no underrun occurs after releasing the state machine */
7 V2 \" s6 f( `# s6 r mcasp->regs->XBUF5 = 0;
& _, Y; J9 ^- N9 S$ Q mcasp->regs->RBUF0 = 0;8 ?. g; e% \5 Q' i5 d
! |( o' P0 {1 A5 q: ` mcasp->regs->XGBLCTL |= GBLCTL_XSMRST_ON; 5 T$ F$ _! z" R6 ^" b
while ( ( mcasp->regs->XGBLCTL & GBLCTL_XSMRST_ON ) != GBLCTL_XSMRST_ON );1 \& J4 ~3 {+ t0 v1 w$ E
mcasp->regs->RGBLCTL |= GBLCTL_RSMRST_ON;
5 a+ B* w* b/ E) ^" T$ ]0 V! x while ( ( mcasp->regs->RGBLCTL & GBLCTL_RSMRST_ON ) != GBLCTL_RSMRST_ON );$ t' E- Q9 V+ \+ J7 v1 y, l! L. z
2 n' Q8 I j3 \5 q) `9 s3 ?. v
mcasp->regs->XGBLCTL |= GBLCTL_XFRST_ON; 6 m8 S d: J$ K# }
while ( ( mcasp->regs->XGBLCTL & GBLCTL_XFRST_ON ) != GBLCTL_XFRST_ON );4 ]2 S, h9 E1 b8 k6 J. Y4 j& q
mcasp->regs->RGBLCTL |= GBLCTL_RFRST_ON;
! F2 L5 V+ }" Z7 o while ( ( mcasp->regs->RGBLCTL & GBLCTL_RFRST_ON ) != GBLCTL_RFRST_ON );7 u' ]0 {. w' e# Z
; S) n& \: a/ \$ ?4 `3 y' v# | CSR = 0x0000;
6 r! H8 w$ d" R* H INTC_INTMUX1 = 0x3d;
9 `& E: Z4 }7 y& c- }5 e' u ISTP = (unsigned int)vectors;4 K% H3 R5 M+ i$ Q @8 C
ICR = 0xFFF0;
3 p; Q! p Y$ H8 h IER |= 0x12;
, O. D3 B, z7 E- g2 V, f1 ~ CSR |= 0x01; : k- }" p& h) v# A0 [) B
+ M! S! z( Y, p) F! R/ O U& v& z5 h0 V! o0 w9 F* L
2 M8 b' o$ I+ Z
还有就是两个输入输出函数:
* z) h7 ~; G" }6 E! V( a, p7 Dvoid output_sample(Int32 out_data)4 y+ r* o# t9 N* k7 K% O
{
9 p1 f& P9 w( E2 i+ [# E AIC31_data.uint = out_data; " z8 `2 l: G( T* E3 s/ V
MCASP1_XBUF5_32BIT = AIC31_data.uint;
% @" ]6 o" ?& ~}( P. ]% ], L; O, f9 I# s
) j: }; F2 o# n! w" oInt32 input_sample(void)
8 t% C" Q- x: |+ J n{ : a- u& |4 E8 T9 E& {& m- A' v
AIC31_data.uint = MCASP1_RBUF0_32BIT;
! K, y0 w0 B3 R return (AIC31_data.uint);
; U* o% t* {# {9 J! z; ^}
( W$ l9 v/ J/ F2 U0 L# O$ f; f( T8 S' p, ^1 A( ~$ w6 ^' N0 \
|
|