|
|
C6747和C6748感觉差不多,我想实现McASP发送中断方式控制音频信号,在轮询的例程基础上改的,轮询程序可以实现,但是中断一直实现不了,也找不到错误,求大神帮忙!下边是主要程序:
7 O9 f$ H6 {+ V; G) O1 H! dmain文件:! s% A2 A7 `: P x q. Y9 L
interrupt void interrupt4(void)
& ?( Z9 [5 p+ y# I9 j% t+ [{1 t J* E/ Z" d0 A* X0 w0 q
Uint32 sample;( [; P0 p& Z2 |7 m' A4 w) l5 H
' Q. S: z$ m( s3 M$ s
sample = input_sample(); // read L + R samples from ADC
* S9 g: a: s# J% q! {- D output_sample(sample); // write L + R samples to DAC
3 t, M$ Y" u( }! D/ g% M return;
2 e0 ~& k: e7 V} n) G6 L$ i" O. I) u7 R# u
1 Q# ? F( \0 k0 _
int main( void )9 a% N8 p6 H* z' J* V" S
{$ G0 E/ C) Y0 E% U3 r
k- `& ?2 a9 T& Q
/* Initialize BSL */# ]9 o3 G6 ?7 V9 z3 m
EVMC6747_init( );
$ D6 b( _2 U( W/ } /* Call evmc6747_intr function */+ Z* a0 h, ^, Y2 G! O, e
aic3106_init( );4 ~4 ], ?5 c* ^0 [0 _1 ?" t
while(1);3 I% a; I0 {9 G6 T% N; X
}/ z, n5 r& p% P2 i0 I
! w1 M+ K( ~. W- C6 @$ [( Z- Q+ C: k3 [8 r; ]& G% }
aic3106_init文件的一部分,McASP配置部分,采用内部时钟,I2S方式,同步传输。音频芯片的配置应该没问题2 S4 o% l1 U$ S4 C! e
/* Initialize MCASP1 *// i1 L d# a6 Z" r1 O
mcasp = &MCASP_MODULE_1;
1 {: N5 C( c/ `; q. o( ] mcasp->regs->GBLCTL = 0; // Reset
) L, r6 T, X. N$ E, m2 s+ N9 t mcasp->regs->RGBLCTL = 0; // Reset RX& b6 K* W' ]6 P& u$ S& m
mcasp->regs->XGBLCTL = 0; // Reset TX' [5 I; c7 h# h& {3 e7 d2 u
mcasp->regs->PWRDEMU = 1; // Free-running3 r1 u# i' k' l, z) e2 T' N2 \
// configure McASP0 receive registers" s( q- r. j! p+ h
mcasp->regs->RMASK = 0xFFFFFFFF; // No padding used
5 Z& [* _8 M* A" j4 T4 D; p- e% h mcasp->regs->RFMT = 0x00018078; // MSB 16bit, 0-delay, no pad, CFGBus! ]) m" K1 q! u" F% X& E
mcasp->regs->AFSRCTL = 0x00000112; // 2TDM, 1bit Falling, External FS, word
. v N8 m" y- N5 ~: M" g; V* b+ h mcasp->regs->ACLKRCTL = 0x000000AF; // Rising INTERNAL CLK,(from tx side)
- `6 a9 U) N% g mcasp->regs->AHCLKRCTL = 0x00000000; // INT CLK (from tx side)% ^8 U6 y& F, N7 y, }" @& O, Y
mcasp->regs->RTDM = 0x00000003; // Slots 0,1% t$ k8 Y0 b3 Q# N
mcasp->regs->RINTCTL = 0x00000000; // Not used
* w# t1 h/ F7 q: z8 V& a mcasp->regs->RCLKCHK = 0x00FF0008; // 255-MAX 0-MIN, div-by-2568 T1 M" L$ K& E
1 Y9 C) O( c2 O* R: V
mcasp->regs->XMASK = 0xFFFFFFFF; // No padding used
" W- Y! L4 b1 u/ r# f mcasp->regs->XFMT = 0x00018078; // MSB 16bit, 0-delay, no pad, CFGBus
4 j8 F) s' H( }3 f mcasp->regs->AFSXCTL = 0x00000112; // 2TDM, 1bit Rising edge INTERNAL FS, word: q" J; g! `- y) _/ ]3 j8 c' G) [
mcasp->regs->ACLKXCTL = 0x000000AF; // ASYNC, Rising INTERNAL CLK, div-by-16 x, m- H, @* N5 }8 M
mcasp->regs->AHCLKXCTL = 0x00000000; // EXT CLK; c% y* i9 i- f! B2 e6 h/ m: Y x
mcasp->regs->XTDM = 0x00000003; // Slots 0,1( S g/ i. j& O! v7 e. t" y
mcasp->regs->XINTCTL = 0x00000020; // interrupt on transmit
- ~: s8 U- Y" e& T4 z3 a% q: [- Y mcasp->regs->XCLKCHK = 0x00FF0008; // 255-MAX 0-MIN, div-by-2567 p9 F, y# M$ y( e0 F6 L
0 p5 }( r4 h( \; J
mcasp->regs->SRCTL5 = 0x000D; // MCASP1.AXR1[5] --> DIN
% F% x1 t; u# c# r2 Z( c mcasp->regs->SRCTL0 = 0x000E; // MCASP1.AXR1[0] <-- DOUT$ c, X6 N+ Y$ e. Y
mcasp->regs->PFUNC = 0; // All MCASPs
9 T* Q, r3 f& L& |) v1 \6 _; J' m mcasp->regs->PDIR = 0x14000020; // All inputs except AXR0[5], ACLKX1, AFSX1" q, `4 s- ~' f
/ \- X) P8 P3 a9 Z0 l) q
mcasp->regs->DITCTL = 0x00000000; // Not used
1 U& _ g. @( j) x mcasp->regs->DLBCTL = 0x00000000; // Not used
: [/ M s% g' ~4 I! T: T mcasp->regs->AMUTE = 0x00000000; // Not used
: V( G7 ]* ^. F$ b* o0 b, j- q' A! {( U+ c7 E: }; S% x# Y
/* Starting sections of the McASP*/
- @5 l" F1 `% h3 h mcasp->regs->XGBLCTL |= GBLCTL_XHCLKRST_ON; / s4 J$ P2 M3 |# s ?3 H
while ( ( mcasp->regs->XGBLCTL & GBLCTL_XHCLKRST_ON ) != GBLCTL_XHCLKRST_ON ); $ }$ V l+ B1 l' i8 _6 ?7 O- m6 @+ V
mcasp->regs->RGBLCTL |= GBLCTL_RHCLKRST_ON;
4 N7 _$ M* H8 T) y/ N0 i while ( ( mcasp->regs->RGBLCTL & GBLCTL_RHCLKRST_ON ) != GBLCTL_RHCLKRST_ON );9 {3 x) L y% |' O
/ H# v7 \1 _ i- l# j# h
mcasp->regs->XGBLCTL |= GBLCTL_XCLKRST_ON; 5 d1 F* f3 @) `0 ^+ ], u
while ( ( mcasp->regs->XGBLCTL & GBLCTL_XCLKRST_ON ) != GBLCTL_XCLKRST_ON );
! z: n' F' `3 h4 a. t$ q mcasp->regs->RGBLCTL |= GBLCTL_RCLKRST_ON; 3 a2 F2 E# w D+ ]. Q" @
while ( ( mcasp->regs->RGBLCTL & GBLCTL_RCLKRST_ON ) != GBLCTL_RCLKRST_ON );) ~9 J/ ]0 F9 j3 S5 m. X
9 x" A! i9 ^& r
mcasp->regs->XSTAT = 0x0000ffff;
# q1 [3 l& A% y R, A9 x mcasp->regs->RSTAT = 0x0000ffff;
: z4 |9 e Y4 d/ @3 L& S6 N/ X q( u0 L1 `
mcasp->regs->XGBLCTL |= GBLCTL_XSRCLR_ON;7 } H$ h5 q- N4 B0 l, d
while ( ( mcasp->regs->XGBLCTL & GBLCTL_XSRCLR_ON ) != GBLCTL_XSRCLR_ON );& g5 _# V! ^2 T; [, Q+ n2 A; D v- t
mcasp->regs->RGBLCTL |= GBLCTL_RSRCLR_ON;
# W7 Y3 G6 r; M- X. }7 v2 @ while ( ( mcasp->regs->RGBLCTL & GBLCTL_RSRCLR_ON ) != GBLCTL_RSRCLR_ON );
4 \0 c- D7 u3 k! J7 J5 v3 k
3 P9 I# S5 t: F; w5 [ /* Write a 0, so that no underrun occurs after releasing the state machine */5 Y ~2 M$ F: Z
mcasp->regs->XBUF5 = 0;
' P" f- g- P6 j0 _ mcasp->regs->RBUF0 = 0;
% o P. \+ q c8 b0 g8 u8 ~; B4 O k% K+ E- O, _: J$ ^/ l$ d& ]
mcasp->regs->XGBLCTL |= GBLCTL_XSMRST_ON;
5 x$ l# D5 F/ w" ~/ ~ while ( ( mcasp->regs->XGBLCTL & GBLCTL_XSMRST_ON ) != GBLCTL_XSMRST_ON );( `+ @0 z# d5 Y' w) Y2 q
mcasp->regs->RGBLCTL |= GBLCTL_RSMRST_ON; 2 u) p; R5 E7 }
while ( ( mcasp->regs->RGBLCTL & GBLCTL_RSMRST_ON ) != GBLCTL_RSMRST_ON );- u. R7 H0 G- `7 t# c
% g D0 `" ^$ N- [/ M) b% k
mcasp->regs->XGBLCTL |= GBLCTL_XFRST_ON;
2 v( J6 F+ i3 q# `' _ while ( ( mcasp->regs->XGBLCTL & GBLCTL_XFRST_ON ) != GBLCTL_XFRST_ON );
) P; g# N/ e ^ L( u# X, S+ O) g mcasp->regs->RGBLCTL |= GBLCTL_RFRST_ON; $ B7 q& h% {/ q A
while ( ( mcasp->regs->RGBLCTL & GBLCTL_RFRST_ON ) != GBLCTL_RFRST_ON );+ n+ ]- q( r% z" [+ B: q9 T
: e8 }- i1 l! y: h
CSR = 0x0000;
2 P; |, L6 z. j: }% b+ X INTC_INTMUX1 = 0x3d;& Q5 _2 z" ]! a
ISTP = (unsigned int)vectors;# W. |. |6 A5 k/ V7 u
ICR = 0xFFF0; / A( B D7 p3 b; _0 }: Q
IER |= 0x12;
3 J6 c- t9 x3 A9 T% W, } CSR |= 0x01; ; c1 x3 L& Q+ W) K4 Q4 ~3 V
% ^& v+ ?' e' B' i) U @" M7 n
9 I" K, T' V" a' v
4 v3 w ^1 h# }. J; n) V# ?
还有就是两个输入输出函数:
2 y* A: m% x% @% e9 d6 Xvoid output_sample(Int32 out_data)6 I+ H! T: ~& i
{8 H5 I# ?. n2 j0 }- N6 }( m+ q* K- {
AIC31_data.uint = out_data;
8 ~7 G6 j! c' Y% S MCASP1_XBUF5_32BIT = AIC31_data.uint;
$ x9 S! d. I" q2 ^}! V' Y8 d2 s- O0 T# K
% J! [( {6 Z1 R. j9 a
Int32 input_sample(void)
" g$ j/ k& A& t, k1 Y/ R{
) }' c. _! G6 F6 C AIC31_data.uint = MCASP1_RBUF0_32BIT;
- l$ l# `6 g9 U8 ~& w return (AIC31_data.uint);1 R' Y3 H# X, g8 s1 d$ @# [
}
7 I; D7 {$ r2 }8 }+ e
$ V( R3 p. |5 { |
|