|
|
C6747和C6748感觉差不多,我想实现McASP发送中断方式控制音频信号,在轮询的例程基础上改的,轮询程序可以实现,但是中断一直实现不了,也找不到错误,求大神帮忙!下边是主要程序:; r6 U, P! i; R4 l5 D
main文件:
/ `8 L# ]* g' ^" I3 C# cinterrupt void interrupt4(void) & `, O) S: u( l& f' u
{
5 m7 T( m* p9 J: [ Uint32 sample;
3 K% b' f0 r. F7 g! k1 a3 ]* t* \1 s8 @6 c6 q
sample = input_sample(); // read L + R samples from ADC
6 w O1 L# L! U1 j output_sample(sample); // write L + R samples to DAC - r. [- m# P7 |' c4 y. n9 G: D
return;. c) T. z7 U. N' F7 M- z
}
4 }0 D# [# T* i! k. U3 z7 N. @! O, g' G1 d9 [$ l. S0 w
int main( void )
) g" A) r: N- n- v7 e! H$ u6 a/ n{1 [; @7 u( x- ]
1 M. u' o7 Y- k' {3 [# N* \
/* Initialize BSL */1 p, N* O$ J4 C( U8 p, G
EVMC6747_init( ); J: \" y7 V8 p) t4 Y
/* Call evmc6747_intr function */1 F6 _& w: y7 E6 s! U( p% \" a# ~
aic3106_init( );
% c0 w U* A# r while(1);$ H- [- T: u7 V* p! [( n
}$ y1 ^" ?, `: v) U, S) _
: N% R1 T* Y2 d' _% O* m+ l+ O9 j
+ W7 \+ r, I8 X
aic3106_init文件的一部分,McASP配置部分,采用内部时钟,I2S方式,同步传输。音频芯片的配置应该没问题
, Q2 s* V; B% A2 o2 a/* Initialize MCASP1 */
% }. y- ?! ?5 g) ]! s) \/ T mcasp = &MCASP_MODULE_1;
( E5 p' f6 B1 K5 d3 V0 f% H mcasp->regs->GBLCTL = 0; // Reset
4 t/ N+ t0 M9 \8 U! U mcasp->regs->RGBLCTL = 0; // Reset RX
, k+ O2 P+ e4 z9 |/ T mcasp->regs->XGBLCTL = 0; // Reset TX4 Q8 h9 a. T- J" O* L4 d. R8 _! t
mcasp->regs->PWRDEMU = 1; // Free-running; b6 Z+ d J% n
// configure McASP0 receive registers9 T. i8 \! {% S4 O
mcasp->regs->RMASK = 0xFFFFFFFF; // No padding used' v- ` p {7 P& I3 |
mcasp->regs->RFMT = 0x00018078; // MSB 16bit, 0-delay, no pad, CFGBus
# d6 d8 }7 M! K' h+ F mcasp->regs->AFSRCTL = 0x00000112; // 2TDM, 1bit Falling, External FS, word
- C2 V' k7 q2 e3 U( y mcasp->regs->ACLKRCTL = 0x000000AF; // Rising INTERNAL CLK,(from tx side)8 i x5 w# ~& p6 G& N1 j. m
mcasp->regs->AHCLKRCTL = 0x00000000; // INT CLK (from tx side)/ n- v) F' M. }/ J* g' V3 [ @
mcasp->regs->RTDM = 0x00000003; // Slots 0,1! E/ q" T* f9 K* A* K, ^4 v
mcasp->regs->RINTCTL = 0x00000000; // Not used
: w$ m, d5 e* Z mcasp->regs->RCLKCHK = 0x00FF0008; // 255-MAX 0-MIN, div-by-256' ^6 G. ^3 ?+ T- p
' U( u& H$ y v mcasp->regs->XMASK = 0xFFFFFFFF; // No padding used" c5 G9 n- [1 E/ T7 c6 V
mcasp->regs->XFMT = 0x00018078; // MSB 16bit, 0-delay, no pad, CFGBus
( p9 O/ H0 q0 {, a" o. ? mcasp->regs->AFSXCTL = 0x00000112; // 2TDM, 1bit Rising edge INTERNAL FS, word
/ Y% ]* W; ^9 w5 ]! i5 P mcasp->regs->ACLKXCTL = 0x000000AF; // ASYNC, Rising INTERNAL CLK, div-by-16
5 I2 f: {; v4 ~& x6 g$ _ mcasp->regs->AHCLKXCTL = 0x00000000; // EXT CLK. R: c% Q& @ d# U1 N0 E3 W
mcasp->regs->XTDM = 0x00000003; // Slots 0,1
& \- E ^$ h& R; j; x/ H mcasp->regs->XINTCTL = 0x00000020; // interrupt on transmit
* U$ O6 C" x* f. z1 \( l% y mcasp->regs->XCLKCHK = 0x00FF0008; // 255-MAX 0-MIN, div-by-256 D8 e$ j W: s- K! i8 u
^- E5 V$ t0 F5 l2 F mcasp->regs->SRCTL5 = 0x000D; // MCASP1.AXR1[5] --> DIN* Y8 f5 N" L- d* m& d0 g
mcasp->regs->SRCTL0 = 0x000E; // MCASP1.AXR1[0] <-- DOUT
; M, @2 A: R* ?3 f3 V mcasp->regs->PFUNC = 0; // All MCASPs) @, n3 Q( W& Q6 c
mcasp->regs->PDIR = 0x14000020; // All inputs except AXR0[5], ACLKX1, AFSX1
n" M2 q9 O1 H7 g. j- t' q7 {6 w9 r0 I- }( h% W
mcasp->regs->DITCTL = 0x00000000; // Not used
. H6 l- l3 z' R mcasp->regs->DLBCTL = 0x00000000; // Not used5 V1 g' V8 J/ ]4 T) o
mcasp->regs->AMUTE = 0x00000000; // Not used
% c. n: T# H" n' O' x. ]" V* \( x! N2 S- @: B5 a) f
/* Starting sections of the McASP*/
( s. ^7 E* @. _$ V" q" Z; g) G* S mcasp->regs->XGBLCTL |= GBLCTL_XHCLKRST_ON;
0 u* N' T+ F [+ @' J8 @, d2 F1 r while ( ( mcasp->regs->XGBLCTL & GBLCTL_XHCLKRST_ON ) != GBLCTL_XHCLKRST_ON );
3 {: W- e9 q# B- H mcasp->regs->RGBLCTL |= GBLCTL_RHCLKRST_ON; 8 h z& L9 D9 b6 d' X
while ( ( mcasp->regs->RGBLCTL & GBLCTL_RHCLKRST_ON ) != GBLCTL_RHCLKRST_ON );
5 I! y* ^9 w0 e- X5 e; R
, V2 F1 ?/ L4 z- w mcasp->regs->XGBLCTL |= GBLCTL_XCLKRST_ON; 6 p! T, [: q) e
while ( ( mcasp->regs->XGBLCTL & GBLCTL_XCLKRST_ON ) != GBLCTL_XCLKRST_ON );* g2 U1 n$ D2 X7 o
mcasp->regs->RGBLCTL |= GBLCTL_RCLKRST_ON; 9 o! p" H }; H+ O7 P& o" J
while ( ( mcasp->regs->RGBLCTL & GBLCTL_RCLKRST_ON ) != GBLCTL_RCLKRST_ON );
! l3 A. n+ ^3 s p$ z7 W; W4 H0 u8 u! ~( \" ~* _
mcasp->regs->XSTAT = 0x0000ffff; . f4 \9 @* _2 Q( T' R) K
mcasp->regs->RSTAT = 0x0000ffff;
( j- v, V; ]3 W4 ~3 A2 d
6 {3 h: ?: |1 @$ z0 i! H% h) I+ f mcasp->regs->XGBLCTL |= GBLCTL_XSRCLR_ON;3 j |4 ?! J% ]+ c! y
while ( ( mcasp->regs->XGBLCTL & GBLCTL_XSRCLR_ON ) != GBLCTL_XSRCLR_ON );
1 X+ w" i, ]/ N6 {7 A mcasp->regs->RGBLCTL |= GBLCTL_RSRCLR_ON; 0 v- [) W2 v3 Y% c4 ?
while ( ( mcasp->regs->RGBLCTL & GBLCTL_RSRCLR_ON ) != GBLCTL_RSRCLR_ON );
& S0 r( m' `& x: ^$ @& n5 Y, E' r/ p d0 [2 {
/* Write a 0, so that no underrun occurs after releasing the state machine */
) Q" A- ^ b7 X: [6 G) _' I mcasp->regs->XBUF5 = 0;
b) D3 ^% ^, ^: O! t1 ^- P mcasp->regs->RBUF0 = 0;9 j+ [4 N' N- w+ \, J ^: U
" l! x7 u) S; a9 |7 _ mcasp->regs->XGBLCTL |= GBLCTL_XSMRST_ON;
# P( U. t' _+ y: @0 P) e3 h9 e while ( ( mcasp->regs->XGBLCTL & GBLCTL_XSMRST_ON ) != GBLCTL_XSMRST_ON );
" R" ?( I& z# \. i mcasp->regs->RGBLCTL |= GBLCTL_RSMRST_ON;
2 V) B: Q: r* N; U& d2 F& j, j while ( ( mcasp->regs->RGBLCTL & GBLCTL_RSMRST_ON ) != GBLCTL_RSMRST_ON );- Q5 Z. i* N1 o, I8 U: `
. c+ u) ^1 K! J! w mcasp->regs->XGBLCTL |= GBLCTL_XFRST_ON; 2 u2 a1 A1 e( u" f8 Q+ e6 Y
while ( ( mcasp->regs->XGBLCTL & GBLCTL_XFRST_ON ) != GBLCTL_XFRST_ON );# P0 ?% n2 h; r4 l6 E5 R3 _
mcasp->regs->RGBLCTL |= GBLCTL_RFRST_ON; 1 f5 z, F0 A7 u4 t. V
while ( ( mcasp->regs->RGBLCTL & GBLCTL_RFRST_ON ) != GBLCTL_RFRST_ON );2 p" V' J( _; q/ q S
# Q) I3 J; I* f v, I
CSR = 0x0000;
- u& ]1 c$ Z" p. D& \0 V INTC_INTMUX1 = 0x3d;$ t: S% S9 Z) v
ISTP = (unsigned int)vectors;
9 }. Z8 `+ V. g! v, `+ g* t1 b: u' y/ D ICR = 0xFFF0; 3 u: i" |7 }7 W- m1 ^
IER |= 0x12;
& s8 y1 ^* ~+ F CSR |= 0x01;
6 C0 t( j9 B0 u2 L$ a% [7 Z
& y$ n4 ~/ E8 J9 B6 U) T, a3 _$ b: B4 v- C+ h. l! o1 R
% d) c @. c& `6 T) ^, ^. J还有就是两个输入输出函数:
# X# k7 ^( y8 |! s0 X2 lvoid output_sample(Int32 out_data)0 s) [3 \5 f/ _$ V
{ }6 ]$ c: i- r& d3 s
AIC31_data.uint = out_data; : P& Z* z8 R0 W8 T3 ~& |+ M$ _6 F2 j
MCASP1_XBUF5_32BIT = AIC31_data.uint;
1 p& r8 L2 U1 ~- A$ b}
% |5 u# f1 L8 w& [1 [# M6 p- ^9 q3 x* B
Int32 input_sample(void)' H- a E( q. z+ U
{ ( m: T9 J( r3 ^3 ]3 b
AIC31_data.uint = MCASP1_RBUF0_32BIT;& p- U! {) m( [3 E. a
return (AIC31_data.uint);
, p7 d, U* m: a: e- U( ?; y# f7 X, R}
3 \( @# L- p0 T: F9 o" M3 l" H0 L$ n2 K3 ?4 p) I
|
|