|
|
C6747和C6748感觉差不多,我想实现McASP发送中断方式控制音频信号,在轮询的例程基础上改的,轮询程序可以实现,但是中断一直实现不了,也找不到错误,求大神帮忙!下边是主要程序:
; T; W+ a1 A: U8 V2 [main文件:1 y4 `; T4 C7 K2 E
interrupt void interrupt4(void)
" k4 {5 v7 O2 }+ U1 q( k{* T% K }. I0 @ C" F+ P. c9 b& l
Uint32 sample;! U; b1 b7 d: h( x
" j1 i) c/ }6 d7 V- u1 P7 M
sample = input_sample(); // read L + R samples from ADC
4 v/ {! D5 t' g; S9 |+ H% X output_sample(sample); // write L + R samples to DAC
7 t+ M4 O7 ?3 \4 O return;
* c, [0 ~4 C- k+ q( A" b}
$ H, j+ w" }1 H2 N1 d/ }! }& P$ M( U; W% D2 x5 h, e& g
int main( void )" b4 c* a: h! g/ m; x
{$ g; O4 h' F5 q9 M# D7 l
6 g' j2 H! \+ r: u8 W! B2 j
/* Initialize BSL */( ]. J2 ?" T' s. b/ t( i
EVMC6747_init( );
) K$ P; P2 a+ a8 _: `" R( d% F /* Call evmc6747_intr function */
" f" j' V, d5 v aic3106_init( );
! A5 \* @1 I1 Y0 C. t- m: W4 Z while(1);$ @4 D: D& z w
}5 d% @- b6 ^' D4 [& n
8 h4 Z p( J) |9 v4 J) ]
6 W# i+ f( H E5 F; O7 [& Aaic3106_init文件的一部分,McASP配置部分,采用内部时钟,I2S方式,同步传输。音频芯片的配置应该没问题2 R- z" U1 w) V5 H9 P
/* Initialize MCASP1 */
6 y& L9 T( X0 E8 P# N mcasp = &MCASP_MODULE_1;& h$ H, q2 T7 Q& t- I
mcasp->regs->GBLCTL = 0; // Reset
: B2 i0 ]. S: b* B) ?( t8 m2 N7 c mcasp->regs->RGBLCTL = 0; // Reset RX
4 V" S J$ {! [! o; v; s mcasp->regs->XGBLCTL = 0; // Reset TX
( w, `- C) x6 f2 m1 } mcasp->regs->PWRDEMU = 1; // Free-running3 H j8 ~4 ?2 W& B0 t9 }4 g7 Z
// configure McASP0 receive registers( N6 \( x$ T& I" `
mcasp->regs->RMASK = 0xFFFFFFFF; // No padding used
+ E) q6 n& t0 H, l$ D0 J mcasp->regs->RFMT = 0x00018078; // MSB 16bit, 0-delay, no pad, CFGBus& j: Z( J% H6 F' P- g4 k: @. {1 f
mcasp->regs->AFSRCTL = 0x00000112; // 2TDM, 1bit Falling, External FS, word
% n Q7 J- E' F+ B& A2 B" V$ _ mcasp->regs->ACLKRCTL = 0x000000AF; // Rising INTERNAL CLK,(from tx side)# m. ]6 S9 T v$ O
mcasp->regs->AHCLKRCTL = 0x00000000; // INT CLK (from tx side)/ \; a! H% v4 y7 L; w, }( ]3 `
mcasp->regs->RTDM = 0x00000003; // Slots 0,1
- a) h0 L1 ?$ X1 M% \ mcasp->regs->RINTCTL = 0x00000000; // Not used! Z. ^2 ]; ^4 ?6 c3 S, l$ t2 x7 c3 f4 {
mcasp->regs->RCLKCHK = 0x00FF0008; // 255-MAX 0-MIN, div-by-256; o+ y" d4 m# N, C6 B8 @# R: S6 ~
$ E4 Q( x3 p0 K# |* R& N) y7 B mcasp->regs->XMASK = 0xFFFFFFFF; // No padding used% n* m" @+ L- ?/ p. ]" C
mcasp->regs->XFMT = 0x00018078; // MSB 16bit, 0-delay, no pad, CFGBus
0 d5 O- j2 _) q# q t mcasp->regs->AFSXCTL = 0x00000112; // 2TDM, 1bit Rising edge INTERNAL FS, word# t1 V, k! p6 \$ z
mcasp->regs->ACLKXCTL = 0x000000AF; // ASYNC, Rising INTERNAL CLK, div-by-16
|! d% A% H" d mcasp->regs->AHCLKXCTL = 0x00000000; // EXT CLK
$ F$ H8 ?, x2 P2 c; U mcasp->regs->XTDM = 0x00000003; // Slots 0,1
( @. F& \8 t5 R7 \ mcasp->regs->XINTCTL = 0x00000020; // interrupt on transmit( Q# K9 ]. s6 l; K; K
mcasp->regs->XCLKCHK = 0x00FF0008; // 255-MAX 0-MIN, div-by-2560 @7 y* w! b0 u& R/ x
; }7 B8 [0 Q9 `. P' j: K9 |
mcasp->regs->SRCTL5 = 0x000D; // MCASP1.AXR1[5] --> DIN: ?2 I1 G$ }+ R8 a- e2 l
mcasp->regs->SRCTL0 = 0x000E; // MCASP1.AXR1[0] <-- DOUT( e2 E6 H; Q4 {
mcasp->regs->PFUNC = 0; // All MCASPs: ?% T" c& J' p. g3 m
mcasp->regs->PDIR = 0x14000020; // All inputs except AXR0[5], ACLKX1, AFSX17 Z* R% G$ c7 k8 ]2 V# i6 \$ u
, ^9 ~5 [# }4 p
mcasp->regs->DITCTL = 0x00000000; // Not used
1 h1 }3 A5 D$ X7 T2 j, R mcasp->regs->DLBCTL = 0x00000000; // Not used
& w4 f# u5 f8 G( @- b& ~3 J5 |/ g$ s mcasp->regs->AMUTE = 0x00000000; // Not used
1 ?& ]0 P g. S5 m( y) w9 D" a. F3 N% @3 k
/* Starting sections of the McASP*/& `& F; Y- m" Z5 C
mcasp->regs->XGBLCTL |= GBLCTL_XHCLKRST_ON; D/ |- }# p0 Y3 b2 ~1 Y) Y8 e
while ( ( mcasp->regs->XGBLCTL & GBLCTL_XHCLKRST_ON ) != GBLCTL_XHCLKRST_ON ); 8 j& U0 K& C8 N& |' T0 |7 s
mcasp->regs->RGBLCTL |= GBLCTL_RHCLKRST_ON;
3 x! Z7 }3 C! w; c: p, a8 A while ( ( mcasp->regs->RGBLCTL & GBLCTL_RHCLKRST_ON ) != GBLCTL_RHCLKRST_ON );
$ U) l7 G4 X5 g2 Z9 D8 a; h
+ Z4 T" y! V5 v6 ? mcasp->regs->XGBLCTL |= GBLCTL_XCLKRST_ON; 8 Y: Q- ~) ~) k+ z$ W! J w
while ( ( mcasp->regs->XGBLCTL & GBLCTL_XCLKRST_ON ) != GBLCTL_XCLKRST_ON );- X0 |2 e8 O1 Y2 e8 r" q
mcasp->regs->RGBLCTL |= GBLCTL_RCLKRST_ON;
. w, t$ h( j U3 q j* f while ( ( mcasp->regs->RGBLCTL & GBLCTL_RCLKRST_ON ) != GBLCTL_RCLKRST_ON );) [$ P* E, l! E, X+ I4 y4 B z
( ^ [8 w4 a1 Z7 `( G+ }3 T! T
mcasp->regs->XSTAT = 0x0000ffff;
8 C! c+ l, _1 k5 ^8 @ mcasp->regs->RSTAT = 0x0000ffff; % h8 L- K0 o+ z. ~- n$ y
3 i" ?+ }0 a2 l2 }
mcasp->regs->XGBLCTL |= GBLCTL_XSRCLR_ON;
6 d. L5 s% t8 \" w$ o while ( ( mcasp->regs->XGBLCTL & GBLCTL_XSRCLR_ON ) != GBLCTL_XSRCLR_ON );
- _+ P' k2 Z! K- K2 ?7 w mcasp->regs->RGBLCTL |= GBLCTL_RSRCLR_ON;
[2 m6 F' w0 U* E# S while ( ( mcasp->regs->RGBLCTL & GBLCTL_RSRCLR_ON ) != GBLCTL_RSRCLR_ON );
) \2 Y; W9 \& \( H& a
\- ^& U) n* \3 L: Y /* Write a 0, so that no underrun occurs after releasing the state machine */
& ]% j: z& i% ?) D1 q$ P( z2 h mcasp->regs->XBUF5 = 0;8 f2 a& F5 W- m1 `2 O# l& u. N
mcasp->regs->RBUF0 = 0;
/ j# g2 ~8 }# a3 |! z) B, O1 x3 }; d* Q; Q; z0 r1 v
mcasp->regs->XGBLCTL |= GBLCTL_XSMRST_ON;
; W# F6 a/ W: a while ( ( mcasp->regs->XGBLCTL & GBLCTL_XSMRST_ON ) != GBLCTL_XSMRST_ON );
( g, ~: V& K& V mcasp->regs->RGBLCTL |= GBLCTL_RSMRST_ON; " r$ q+ v9 C3 n- l
while ( ( mcasp->regs->RGBLCTL & GBLCTL_RSMRST_ON ) != GBLCTL_RSMRST_ON );" @* j6 q& A, [
; S. Q7 [- @7 ?6 w0 [" t
mcasp->regs->XGBLCTL |= GBLCTL_XFRST_ON;
+ o9 f* g. z/ ?9 P while ( ( mcasp->regs->XGBLCTL & GBLCTL_XFRST_ON ) != GBLCTL_XFRST_ON );
" q; z! ~- ^8 M, m# Y) Z mcasp->regs->RGBLCTL |= GBLCTL_RFRST_ON;
6 b, i/ X, a, d8 H% F while ( ( mcasp->regs->RGBLCTL & GBLCTL_RFRST_ON ) != GBLCTL_RFRST_ON );% a) w7 P% _" L' ^
8 U( F) c Z/ O" _9 N# G3 t
CSR = 0x0000;7 G$ K' `/ C3 ^% ~3 l" p! \- u
INTC_INTMUX1 = 0x3d;
7 O$ _! l$ v3 q9 t) [ i! o# T- F ISTP = (unsigned int)vectors;; L$ ]. L5 H$ s7 X. N3 H- M6 T
ICR = 0xFFF0;
" I9 t- ]$ k* d5 r. T4 M7 d IER |= 0x12; 5 B; d- Y8 ^8 z) R$ u
CSR |= 0x01; " g/ s7 K4 g5 H6 I# U
( f( _& Z1 w+ L4 K+ s$ ~8 }* F* ~8 b, P( Z/ b$ l- B
1 y ~% W- H: x' t" v. t8 F还有就是两个输入输出函数: z( J+ i& u+ C/ o' B, \
void output_sample(Int32 out_data)5 O( Q8 B8 n9 |5 M2 _- m
{: f( E& n- t7 k( `
AIC31_data.uint = out_data; ) }, }& ^1 L. D, T& e& c, J
MCASP1_XBUF5_32BIT = AIC31_data.uint;3 J! p; C( C- t4 t J. ]
}
" D' G ?* f' H; S% e0 U" k( b5 {! E; A; ~4 \) V$ c+ O) }5 Z
Int32 input_sample(void)" W$ w3 C, Q# m# j' V
{
7 u0 j) @* F5 K6 l AIC31_data.uint = MCASP1_RBUF0_32BIT;
% C& I" z& D5 j( { return (AIC31_data.uint);9 V; u3 I% [: L1 k5 b b! j$ \" d
}
; g9 v7 d0 y- ~7 s3 c6 z
% ]0 f' G( P \' s7 b7 f: N" z5 F |
|