|
|
C6747和C6748感觉差不多,我想实现McASP发送中断方式控制音频信号,在轮询的例程基础上改的,轮询程序可以实现,但是中断一直实现不了,也找不到错误,求大神帮忙!下边是主要程序:
7 p4 S. \) \ W4 k7 q: Zmain文件:7 ]+ E' S6 B/ h' b4 E
interrupt void interrupt4(void) N$ o2 @5 T( \; s; l, w+ w6 ~* e
{# Q' [/ v' y* \* s
Uint32 sample;. h# n, ?$ i# k5 ?/ K( p# A% V
$ M+ H2 t! x# m$ |
sample = input_sample(); // read L + R samples from ADC9 f1 l- G" u/ D
output_sample(sample); // write L + R samples to DAC
, O; l# G& u4 r, S% ?7 t# U return;
5 x" C( q0 \, @+ S2 Z9 [" Q}
- M1 V, m+ F# D4 u
/ a0 F! J: ~0 W, M% s, t; \int main( void )# j2 D2 Q) K& V* j4 f- d
{
) S! e2 j$ ?8 `. j% U
# }" M, i; e h* H# b. U8 L /* Initialize BSL */' N1 r8 v" d& d& m4 @1 \; I
EVMC6747_init( );3 V0 M* E e2 L! I |$ X
/* Call evmc6747_intr function */
9 `0 W& D4 I% o) [0 T- z/ \) f3 J aic3106_init( );: G6 P* j! G9 O
while(1);
4 A9 s; `. v* L4 g: Z}. T+ ]" S( t+ T" h; d1 w
" v9 A- J! R0 G7 y* L- x; l
1 p; t" D `- l/ U" \' B. h
aic3106_init文件的一部分,McASP配置部分,采用内部时钟,I2S方式,同步传输。音频芯片的配置应该没问题
, Q" w" x( x7 v. \+ v$ D9 N7 v/* Initialize MCASP1 */
. w' H; g! q% D$ Y, _ mcasp = &MCASP_MODULE_1;
1 L$ \) T" Z* D! Z5 J mcasp->regs->GBLCTL = 0; // Reset% W* z9 b8 s6 s( k" v* j
mcasp->regs->RGBLCTL = 0; // Reset RX
# b; W% i4 i. t& K1 p# w- y mcasp->regs->XGBLCTL = 0; // Reset TX
3 M3 x$ L, ]; b# R1 Y mcasp->regs->PWRDEMU = 1; // Free-running, J. K) K0 S+ h+ i
// configure McASP0 receive registers
7 Q3 f* X! D, n$ O/ z; I+ D6 i mcasp->regs->RMASK = 0xFFFFFFFF; // No padding used1 ]$ H+ B" Z* C- _9 I4 y
mcasp->regs->RFMT = 0x00018078; // MSB 16bit, 0-delay, no pad, CFGBus
2 y7 g( o$ ^# N1 L, _7 r) c) H mcasp->regs->AFSRCTL = 0x00000112; // 2TDM, 1bit Falling, External FS, word
0 q5 P9 R. S q# ^% V5 {7 ]- I mcasp->regs->ACLKRCTL = 0x000000AF; // Rising INTERNAL CLK,(from tx side)# V2 J, j" g ?& }( O P& r
mcasp->regs->AHCLKRCTL = 0x00000000; // INT CLK (from tx side)
3 \6 ]7 }1 e9 V0 R mcasp->regs->RTDM = 0x00000003; // Slots 0,1
4 F& E' H9 f8 O3 n mcasp->regs->RINTCTL = 0x00000000; // Not used
, [, k: m7 a: Z: C! P mcasp->regs->RCLKCHK = 0x00FF0008; // 255-MAX 0-MIN, div-by-256& ^4 M8 Z W5 m( V1 |) V
. I3 Z5 M# A$ ~: m( B5 ?8 I# U mcasp->regs->XMASK = 0xFFFFFFFF; // No padding used
: l0 _: D+ _4 X+ x mcasp->regs->XFMT = 0x00018078; // MSB 16bit, 0-delay, no pad, CFGBus- {. T+ R! P* k5 o/ }5 H
mcasp->regs->AFSXCTL = 0x00000112; // 2TDM, 1bit Rising edge INTERNAL FS, word
: O1 @4 r2 E) ] mcasp->regs->ACLKXCTL = 0x000000AF; // ASYNC, Rising INTERNAL CLK, div-by-16
: z r6 M& D# [: U mcasp->regs->AHCLKXCTL = 0x00000000; // EXT CLK% R+ i' _+ i* W+ g5 L4 c) A
mcasp->regs->XTDM = 0x00000003; // Slots 0,1# J- W3 d" X. W8 G% h
mcasp->regs->XINTCTL = 0x00000020; // interrupt on transmit+ e4 }" m3 b6 c' P; O1 z7 w
mcasp->regs->XCLKCHK = 0x00FF0008; // 255-MAX 0-MIN, div-by-256
* s0 Y) n4 y. \, D3 \9 a7 s; ^
$ c# `) w: q t0 _! b2 V mcasp->regs->SRCTL5 = 0x000D; // MCASP1.AXR1[5] --> DIN
; g6 H% a D3 f7 A4 h mcasp->regs->SRCTL0 = 0x000E; // MCASP1.AXR1[0] <-- DOUT
& w7 O6 ]7 R3 j' H( P mcasp->regs->PFUNC = 0; // All MCASPs
5 G6 }2 A/ R) W6 q: [3 j mcasp->regs->PDIR = 0x14000020; // All inputs except AXR0[5], ACLKX1, AFSX19 J3 m$ q: r- f; g' ~2 _' ]
4 M5 @& ~' W% m, J
mcasp->regs->DITCTL = 0x00000000; // Not used9 |- `, N( }* F. A
mcasp->regs->DLBCTL = 0x00000000; // Not used0 Z2 ?) ~# y1 R( T: r9 ^! h
mcasp->regs->AMUTE = 0x00000000; // Not used
+ ^" C3 F9 K- J5 s% ?
' {& f. r( q8 h, f/* Starting sections of the McASP*/
% b/ z( x- P9 z4 ^; m mcasp->regs->XGBLCTL |= GBLCTL_XHCLKRST_ON;
) _5 s7 ]' x; S+ t$ ?* k; r while ( ( mcasp->regs->XGBLCTL & GBLCTL_XHCLKRST_ON ) != GBLCTL_XHCLKRST_ON );
/ V+ \) x! S$ t5 ~) `' f& g; ^ mcasp->regs->RGBLCTL |= GBLCTL_RHCLKRST_ON; & T8 k9 A. c: M
while ( ( mcasp->regs->RGBLCTL & GBLCTL_RHCLKRST_ON ) != GBLCTL_RHCLKRST_ON );
. x3 l; o; N. I# ^" R
" d1 b) j. |) c# @& P5 e* Q; c mcasp->regs->XGBLCTL |= GBLCTL_XCLKRST_ON; 0 B7 C2 @$ m) L
while ( ( mcasp->regs->XGBLCTL & GBLCTL_XCLKRST_ON ) != GBLCTL_XCLKRST_ON );3 R' R+ r5 s1 Z5 [) y# f
mcasp->regs->RGBLCTL |= GBLCTL_RCLKRST_ON; ) T4 C4 B! D4 N% C
while ( ( mcasp->regs->RGBLCTL & GBLCTL_RCLKRST_ON ) != GBLCTL_RCLKRST_ON );/ O: N% i g7 F4 \5 l% D( B* L
: J' ~" }! j5 g9 K# B mcasp->regs->XSTAT = 0x0000ffff; ! d, [* E/ }4 j/ k
mcasp->regs->RSTAT = 0x0000ffff;
: t* s4 B0 Z, V2 V, m1 `1 a0 l6 _$ T9 [$ y/ m
mcasp->regs->XGBLCTL |= GBLCTL_XSRCLR_ON;
% ~. x" f6 t) Q" A6 J S$ T while ( ( mcasp->regs->XGBLCTL & GBLCTL_XSRCLR_ON ) != GBLCTL_XSRCLR_ON );! Y ]- I7 I- a
mcasp->regs->RGBLCTL |= GBLCTL_RSRCLR_ON; , G4 ^0 V* Z2 r1 F6 o0 x
while ( ( mcasp->regs->RGBLCTL & GBLCTL_RSRCLR_ON ) != GBLCTL_RSRCLR_ON );
5 U9 S7 u& L: ?- Y: ~, q
* t& o' ]9 b. i2 t) E% J, N /* Write a 0, so that no underrun occurs after releasing the state machine */+ x2 j2 k( h4 i E0 V% A
mcasp->regs->XBUF5 = 0;
/ r# H8 q/ }& |3 B mcasp->regs->RBUF0 = 0;
: d* w* E# E1 A/ z: L( k
# g8 F4 }7 T3 d# m/ d mcasp->regs->XGBLCTL |= GBLCTL_XSMRST_ON;
' _6 d3 t! R R' Z while ( ( mcasp->regs->XGBLCTL & GBLCTL_XSMRST_ON ) != GBLCTL_XSMRST_ON );
; W8 }" `9 ~$ R! R mcasp->regs->RGBLCTL |= GBLCTL_RSMRST_ON; ) j2 k4 M3 H; b; P/ L6 D, p
while ( ( mcasp->regs->RGBLCTL & GBLCTL_RSMRST_ON ) != GBLCTL_RSMRST_ON );$ v! Z/ ]1 W; H! r
7 b+ I7 R* D! ~) ~0 ]6 Z1 M; s- [. Z mcasp->regs->XGBLCTL |= GBLCTL_XFRST_ON;
8 |- ~9 E$ ?6 [" j# G) Y# Y& K2 } while ( ( mcasp->regs->XGBLCTL & GBLCTL_XFRST_ON ) != GBLCTL_XFRST_ON );
5 N, T( ~9 i3 }9 u mcasp->regs->RGBLCTL |= GBLCTL_RFRST_ON; 1 c6 @% L. d+ Z! Y" ~$ {
while ( ( mcasp->regs->RGBLCTL & GBLCTL_RFRST_ON ) != GBLCTL_RFRST_ON );9 g7 N6 F: Z3 M+ B0 J
/ O7 a9 A4 g% \' D' e: O CSR = 0x0000;
$ Q" f5 k' I6 O5 O4 M% V, ? INTC_INTMUX1 = 0x3d;6 I; m5 G# X3 l1 b3 U
ISTP = (unsigned int)vectors;. `8 L6 P+ X) Z
ICR = 0xFFF0;
) P+ Z$ N# h: Y1 g; ` IER |= 0x12; 7 d3 R6 ]. e% b9 ]8 n
CSR |= 0x01;
5 P2 j3 T8 T2 ~8 b# R3 B: {* _% W+ d3 J E# M
! q# E; }8 S9 s' j% ]- o
1 i1 n+ I# w$ U( D/ D( s3 s
还有就是两个输入输出函数:# w# t" ?3 f! }% ]
void output_sample(Int32 out_data)
# i8 v# f+ @# w8 ]# m" O5 |# @ S{+ F3 Y. W6 }" \( v G8 ?
AIC31_data.uint = out_data;
+ `7 k, s! p9 v1 i6 q( ? MCASP1_XBUF5_32BIT = AIC31_data.uint;9 `" Z) `# a- k* t3 M0 O
}' U1 E& w6 v) R @5 j7 e
: V1 `8 ]9 n6 {2 g. R8 [/ s/ fInt32 input_sample(void) I L) N" g# ~6 l2 h3 [" {
{ : o% H3 l) ^% U; J; B% f1 l; k
AIC31_data.uint = MCASP1_RBUF0_32BIT;
$ q8 \! _5 X( i K% M1 b return (AIC31_data.uint);
% T$ h! l# w6 y4 c C}0 N& ` [% `! t1 Q x! w6 L! k
0 i" q$ q3 K- }* t |
|