|
|
C6747和C6748感觉差不多,我想实现McASP发送中断方式控制音频信号,在轮询的例程基础上改的,轮询程序可以实现,但是中断一直实现不了,也找不到错误,求大神帮忙!下边是主要程序:
- o, i$ y) d2 H" v$ c2 pmain文件:
9 `/ e1 c. r O/ C2 J% zinterrupt void interrupt4(void) ' T5 s; S6 B6 {; y5 E8 C$ n
{
& z6 D9 d% k" b; k9 | Uint32 sample;
& @! v7 A: \, t/ I8 ]2 A' j3 }. z, Y0 i
sample = input_sample(); // read L + R samples from ADC2 n/ x2 P8 X2 y" G* ]* s* N
output_sample(sample); // write L + R samples to DAC
7 J( q' O8 F* I# X9 } return;
( G' F) R: @6 r" S) ~}6 B5 D, g# S+ t0 k+ t, e( t7 W6 v
/ X; k, r0 ?' u5 P0 [
int main( void )7 @! e1 i( T6 C) ]
{# b6 c& U' h, s% L8 g
: j# z, L9 U" B2 I3 f /* Initialize BSL */' z& P9 q1 j/ O% ]. |
EVMC6747_init( );
1 Y( ?9 k. m' m: Z /* Call evmc6747_intr function */8 X$ `2 g7 ]/ T( u& e9 x7 O- u
aic3106_init( );
& t# y O$ O# @4 y2 P while(1);9 a6 H5 d4 ^! D9 E; C
}
0 {) }$ g0 A- d$ \$ o, X o. w7 T+ n/ z# y0 e2 _9 `0 }
! |% G: K$ K5 q% O
aic3106_init文件的一部分,McASP配置部分,采用内部时钟,I2S方式,同步传输。音频芯片的配置应该没问题) b: C, _( k) n& L+ k
/* Initialize MCASP1 */ O1 _! I P1 A
mcasp = &MCASP_MODULE_1;
- b- ?6 ^( g6 i8 I; x mcasp->regs->GBLCTL = 0; // Reset0 R+ i6 z3 p8 E: [; d1 q
mcasp->regs->RGBLCTL = 0; // Reset RX" j) P$ M2 i6 u, L, f' G
mcasp->regs->XGBLCTL = 0; // Reset TX
& r8 _% }4 R f1 p" P9 o( C# D mcasp->regs->PWRDEMU = 1; // Free-running7 O4 ?. r- s5 [, j) B- X
// configure McASP0 receive registers
% B; E' T( D7 }: i, Z mcasp->regs->RMASK = 0xFFFFFFFF; // No padding used% M, Q. l% w! X2 v" O2 B6 Z
mcasp->regs->RFMT = 0x00018078; // MSB 16bit, 0-delay, no pad, CFGBus
: R5 L& i8 Z/ x( o! K mcasp->regs->AFSRCTL = 0x00000112; // 2TDM, 1bit Falling, External FS, word6 ~ P+ ]; v- }; T
mcasp->regs->ACLKRCTL = 0x000000AF; // Rising INTERNAL CLK,(from tx side)# |; Z# v& D' C% c+ b& [
mcasp->regs->AHCLKRCTL = 0x00000000; // INT CLK (from tx side)0 c& i5 X1 b5 b5 n3 {
mcasp->regs->RTDM = 0x00000003; // Slots 0,1/ Y, L, O6 b% C) Q( o X
mcasp->regs->RINTCTL = 0x00000000; // Not used. K s" y. \& u5 E
mcasp->regs->RCLKCHK = 0x00FF0008; // 255-MAX 0-MIN, div-by-2566 p0 Z# B% I3 S2 b* x5 d
; N- K2 m; [, X" C% q
mcasp->regs->XMASK = 0xFFFFFFFF; // No padding used5 |7 S9 c5 s: R5 c
mcasp->regs->XFMT = 0x00018078; // MSB 16bit, 0-delay, no pad, CFGBus
+ E0 F3 @- h6 B* @7 \2 c mcasp->regs->AFSXCTL = 0x00000112; // 2TDM, 1bit Rising edge INTERNAL FS, word; o* F" n0 q3 k
mcasp->regs->ACLKXCTL = 0x000000AF; // ASYNC, Rising INTERNAL CLK, div-by-169 p7 }; n+ S$ T
mcasp->regs->AHCLKXCTL = 0x00000000; // EXT CLK
+ \, M2 D! p5 w% J6 F mcasp->regs->XTDM = 0x00000003; // Slots 0,1
# g- m( }: X2 h1 U# W; K$ Q mcasp->regs->XINTCTL = 0x00000020; // interrupt on transmit
. y, {0 E* a( u mcasp->regs->XCLKCHK = 0x00FF0008; // 255-MAX 0-MIN, div-by-256
. F$ V- a; @0 G$ Z3 {" J5 l# O( K! `
mcasp->regs->SRCTL5 = 0x000D; // MCASP1.AXR1[5] --> DIN
3 O* D3 j! `% R# B9 g+ z( R5 D3 d: n mcasp->regs->SRCTL0 = 0x000E; // MCASP1.AXR1[0] <-- DOUT. m: M; z2 _* N! O
mcasp->regs->PFUNC = 0; // All MCASPs
" g1 y4 Y5 t; i& W6 L mcasp->regs->PDIR = 0x14000020; // All inputs except AXR0[5], ACLKX1, AFSX13 g5 c* a( Y) }' l2 {
/ ] s4 @/ h# Z$ g/ B+ x
mcasp->regs->DITCTL = 0x00000000; // Not used
; `9 p) p% t: `4 A6 H0 S: l mcasp->regs->DLBCTL = 0x00000000; // Not used8 Z4 A# ?+ e& p8 c# h$ Z& W
mcasp->regs->AMUTE = 0x00000000; // Not used
# d- e9 y" e# N% M8 O A) w. f& h4 \+ t- N4 a' X
/* Starting sections of the McASP*/
# b" M6 ]9 m3 M c mcasp->regs->XGBLCTL |= GBLCTL_XHCLKRST_ON;
+ U7 o1 {# z! A$ H while ( ( mcasp->regs->XGBLCTL & GBLCTL_XHCLKRST_ON ) != GBLCTL_XHCLKRST_ON );
( w$ I; C6 C' g. A mcasp->regs->RGBLCTL |= GBLCTL_RHCLKRST_ON; : }1 A! _1 ?; i0 S$ w: Q, O
while ( ( mcasp->regs->RGBLCTL & GBLCTL_RHCLKRST_ON ) != GBLCTL_RHCLKRST_ON );: j& z: Z6 f1 e( z% Y
: L; z% v" f3 F! A7 @3 X6 [# S mcasp->regs->XGBLCTL |= GBLCTL_XCLKRST_ON; ( _" M$ l* F/ F0 w: w$ m0 [0 H, d
while ( ( mcasp->regs->XGBLCTL & GBLCTL_XCLKRST_ON ) != GBLCTL_XCLKRST_ON );
4 n/ D1 W1 V6 o1 L( M; @ mcasp->regs->RGBLCTL |= GBLCTL_RCLKRST_ON;
- k, {% z @# x( j% S while ( ( mcasp->regs->RGBLCTL & GBLCTL_RCLKRST_ON ) != GBLCTL_RCLKRST_ON );% A) A" Q1 R# O! n0 H( z- ~: I
6 e1 \0 E: d) S% j1 @. _
mcasp->regs->XSTAT = 0x0000ffff; 1 B# x% \; B3 W, r; U
mcasp->regs->RSTAT = 0x0000ffff; & C2 J: {4 s( a7 j* \9 Y* h
% u+ j* e4 j5 |) r/ F2 P* J
mcasp->regs->XGBLCTL |= GBLCTL_XSRCLR_ON;
2 s. v' y, L6 B/ h# W' z while ( ( mcasp->regs->XGBLCTL & GBLCTL_XSRCLR_ON ) != GBLCTL_XSRCLR_ON );; B6 i4 T" q# [. M! B! b; Y
mcasp->regs->RGBLCTL |= GBLCTL_RSRCLR_ON;
/ W, c) E i C while ( ( mcasp->regs->RGBLCTL & GBLCTL_RSRCLR_ON ) != GBLCTL_RSRCLR_ON );+ v; e0 f! f& M
6 _1 ], v. |6 U$ [2 n6 k; d7 s /* Write a 0, so that no underrun occurs after releasing the state machine */. U q1 n; C6 ?& K1 X8 {
mcasp->regs->XBUF5 = 0; E8 e' F. g c, n% \& c1 e( I* w
mcasp->regs->RBUF0 = 0;
+ h d6 E) `, d4 H/ o0 B& M+ o7 ?3 t6 C) @$ ]
mcasp->regs->XGBLCTL |= GBLCTL_XSMRST_ON; ! n3 _ I! Z. x7 Z% e
while ( ( mcasp->regs->XGBLCTL & GBLCTL_XSMRST_ON ) != GBLCTL_XSMRST_ON );4 {9 X0 \" K5 F" A
mcasp->regs->RGBLCTL |= GBLCTL_RSMRST_ON; + v2 L, f. x! l/ b
while ( ( mcasp->regs->RGBLCTL & GBLCTL_RSMRST_ON ) != GBLCTL_RSMRST_ON );/ u; T" y, Z1 L2 l
* B! D: U$ Z) L2 ]
mcasp->regs->XGBLCTL |= GBLCTL_XFRST_ON;
' t: h0 M$ P8 R while ( ( mcasp->regs->XGBLCTL & GBLCTL_XFRST_ON ) != GBLCTL_XFRST_ON );* ?0 F% n9 f4 E$ P
mcasp->regs->RGBLCTL |= GBLCTL_RFRST_ON;
- C7 @/ h9 j% x; A& _" V while ( ( mcasp->regs->RGBLCTL & GBLCTL_RFRST_ON ) != GBLCTL_RFRST_ON );
* k8 Y! g( K/ _6 I& w. u3 B0 E! o5 N D% }. Q6 O' ~5 W0 q& U5 u
CSR = 0x0000;4 w; f& j! q# K1 f8 q- ]0 e8 M0 U
INTC_INTMUX1 = 0x3d;9 M6 h8 W3 O5 l2 ~
ISTP = (unsigned int)vectors;
- F; @( p! Q' H0 n, ^0 f ICR = 0xFFF0; . E6 L, L8 b. x! U+ O
IER |= 0x12; 0 S% ^& r& ^. `" ?
CSR |= 0x01; 6 @' h# Y/ R/ C- I G- L4 E' b
' c' ?( U. H+ L. ~% y) V3 s6 b( N0 ]6 a+ `9 P1 E$ ?6 ?2 I
: A# g; g7 E9 s- m还有就是两个输入输出函数:% E. W3 I/ g+ s. C! H5 O
void output_sample(Int32 out_data)
! X9 i6 ~0 R) L- B1 M7 |& _' S{ p7 Z d2 q% x, L" E" L& F
AIC31_data.uint = out_data;
5 b( }9 ^+ F- Z+ T MCASP1_XBUF5_32BIT = AIC31_data.uint;$ ^4 g: W: f6 q
}3 Y. _. S0 U8 c' J0 |. S3 k
. ]( b2 d* m: t* U+ }9 H- a
Int32 input_sample(void)
" K# b. S- N, Z{ ' x0 V& b/ e, C0 C
AIC31_data.uint = MCASP1_RBUF0_32BIT;
: l5 }3 I6 v: }( c& v' r9 n return (AIC31_data.uint);& Y4 J* W, M, s; k$ f. H9 I
}
. q& B+ {* R( A8 ]9 t8 N/ u* W
|
|