|
|
C6747和C6748感觉差不多,我想实现McASP发送中断方式控制音频信号,在轮询的例程基础上改的,轮询程序可以实现,但是中断一直实现不了,也找不到错误,求大神帮忙!下边是主要程序:
$ D3 P3 {8 [& W$ z$ ^: C2 Tmain文件:: O3 s- x/ P1 \4 l% z1 B
interrupt void interrupt4(void) ( [. ?' U/ i+ a. t& \) z
{! d/ s1 F2 ?( j* }: b
Uint32 sample;# A8 T) O* D$ @8 [. C
* _+ q- L$ X. t3 e9 y# x0 H( t sample = input_sample(); // read L + R samples from ADC
' z2 {0 @6 z) @ P. X7 e output_sample(sample); // write L + R samples to DAC ; P8 [) a ~: S% Y+ t+ o, m* W
return;
) l8 T& i" Y0 F$ {}
& O& e: i& T! p1 c7 Q1 ~
* V' E N3 r- C/ [: \7 Mint main( void ): [( R p2 a3 {0 L; Y g' v! W
{& `2 Y7 X/ F6 R& ^4 O7 l
4 t3 ` r! s! O% i3 y
/* Initialize BSL */8 K0 J& u5 ] k) y* z, y
EVMC6747_init( );
' j' E) n3 t* A' o; ~: c# [, @6 X /* Call evmc6747_intr function */
9 |2 k1 r) g% ~, g$ |/ V: i/ J aic3106_init( );
; Y8 }+ b3 {3 R: d" [; ^ while(1);: X- B4 v$ W# z& Z. C, ?
}
. d1 ]3 h6 _$ d8 h) k2 @* g1 x; x; y! z+ y( b
2 }3 `1 ?, M7 i& ^3 |
aic3106_init文件的一部分,McASP配置部分,采用内部时钟,I2S方式,同步传输。音频芯片的配置应该没问题
, H" N6 [: q/ D$ B V4 D P/* Initialize MCASP1 */, F+ j% q) q8 E1 @
mcasp = &MCASP_MODULE_1;
1 W/ v4 E7 z( l' Z. ^ mcasp->regs->GBLCTL = 0; // Reset+ w1 h+ W. F3 i
mcasp->regs->RGBLCTL = 0; // Reset RX
! u( [& g" X3 H/ f mcasp->regs->XGBLCTL = 0; // Reset TX1 S% t! I2 Y" T5 v0 Q/ v5 M
mcasp->regs->PWRDEMU = 1; // Free-running
" z" a) F4 b" K- w6 _ // configure McASP0 receive registers3 o3 B& ~# ?: p9 f& h1 G
mcasp->regs->RMASK = 0xFFFFFFFF; // No padding used3 z h( h5 n: T1 R, y2 _! h4 @3 p u
mcasp->regs->RFMT = 0x00018078; // MSB 16bit, 0-delay, no pad, CFGBus
) f. Q$ }8 u0 ]0 c mcasp->regs->AFSRCTL = 0x00000112; // 2TDM, 1bit Falling, External FS, word" H+ Q v8 p! M! q `' \
mcasp->regs->ACLKRCTL = 0x000000AF; // Rising INTERNAL CLK,(from tx side)
3 F+ l. y( D; W: D' U. x2 \6 n$ [ mcasp->regs->AHCLKRCTL = 0x00000000; // INT CLK (from tx side)# e& h1 q; D. H; ?
mcasp->regs->RTDM = 0x00000003; // Slots 0,1
1 ^% U9 B7 l: j1 _1 B6 @- b2 v mcasp->regs->RINTCTL = 0x00000000; // Not used+ {9 j3 V# r2 P+ @, b% E) O8 F' |
mcasp->regs->RCLKCHK = 0x00FF0008; // 255-MAX 0-MIN, div-by-256+ Z$ f0 w# Q+ F0 D0 u% O
9 I5 N- l. m8 a0 D; S2 I
mcasp->regs->XMASK = 0xFFFFFFFF; // No padding used5 R+ A: d* Z- P$ a
mcasp->regs->XFMT = 0x00018078; // MSB 16bit, 0-delay, no pad, CFGBus0 x1 b6 W0 J6 Y0 q
mcasp->regs->AFSXCTL = 0x00000112; // 2TDM, 1bit Rising edge INTERNAL FS, word
/ D2 _! f7 _7 u- G mcasp->regs->ACLKXCTL = 0x000000AF; // ASYNC, Rising INTERNAL CLK, div-by-16
5 L: t6 H* n5 d- d mcasp->regs->AHCLKXCTL = 0x00000000; // EXT CLK
$ C, p1 v8 T0 N! T& X% L# A& v mcasp->regs->XTDM = 0x00000003; // Slots 0,1
* w6 K) q& x# g: ^/ M0 }1 z7 G+ i mcasp->regs->XINTCTL = 0x00000020; // interrupt on transmit
* v: h- s' t2 \; n4 ^ mcasp->regs->XCLKCHK = 0x00FF0008; // 255-MAX 0-MIN, div-by-256
$ T) ]* z/ U: A- _: n& @
2 ?- g, F" j: \4 K0 U mcasp->regs->SRCTL5 = 0x000D; // MCASP1.AXR1[5] --> DIN" [( U" }' v: r! n
mcasp->regs->SRCTL0 = 0x000E; // MCASP1.AXR1[0] <-- DOUT
; k: r. B3 m7 o4 G mcasp->regs->PFUNC = 0; // All MCASPs; A# q! M8 j/ z- W n) U0 H; W$ l1 n
mcasp->regs->PDIR = 0x14000020; // All inputs except AXR0[5], ACLKX1, AFSX1. N% j% G. V1 V! \1 z" o& l
1 Q- r1 k# i/ o: B; D$ z3 T mcasp->regs->DITCTL = 0x00000000; // Not used
* z% i) B7 Q; [& ~; I! K mcasp->regs->DLBCTL = 0x00000000; // Not used
7 @4 g6 T4 w; D# ^& e+ s4 f mcasp->regs->AMUTE = 0x00000000; // Not used, Y3 n$ s2 T+ ], n* ]5 {& {5 H) t
! F- F' z: }7 u; Q. e% B5 f* r/* Starting sections of the McASP*/8 n3 L/ q# V* k& d* A
mcasp->regs->XGBLCTL |= GBLCTL_XHCLKRST_ON; 6 G5 E1 K6 C8 M% X+ d1 W) v2 i
while ( ( mcasp->regs->XGBLCTL & GBLCTL_XHCLKRST_ON ) != GBLCTL_XHCLKRST_ON ); ; k) v: T% a+ f z0 c: |
mcasp->regs->RGBLCTL |= GBLCTL_RHCLKRST_ON;
1 ^% J& X6 V: d. ]9 X7 \/ { while ( ( mcasp->regs->RGBLCTL & GBLCTL_RHCLKRST_ON ) != GBLCTL_RHCLKRST_ON );
% A7 I! C- ?+ t' r; f3 X6 o; } e* q7 D7 U* @6 ~
mcasp->regs->XGBLCTL |= GBLCTL_XCLKRST_ON;
- G$ M* ?" Z: }9 @ V/ S, c while ( ( mcasp->regs->XGBLCTL & GBLCTL_XCLKRST_ON ) != GBLCTL_XCLKRST_ON );7 i7 [9 u- }0 K4 L
mcasp->regs->RGBLCTL |= GBLCTL_RCLKRST_ON; ; C2 i5 N4 R7 P& `9 g5 R8 w" j$ Y: x
while ( ( mcasp->regs->RGBLCTL & GBLCTL_RCLKRST_ON ) != GBLCTL_RCLKRST_ON );
. N8 q0 V8 Y- D" ?# d) n; o: y+ L7 m% [( }! |0 `$ Y1 r8 P( J
mcasp->regs->XSTAT = 0x0000ffff; , |; K8 a! X' Q& B
mcasp->regs->RSTAT = 0x0000ffff;
& Y5 F2 s2 G6 I) Y
0 ~1 T: k7 s) n- Q mcasp->regs->XGBLCTL |= GBLCTL_XSRCLR_ON;/ \ e7 o9 p5 ~6 \3 |$ B
while ( ( mcasp->regs->XGBLCTL & GBLCTL_XSRCLR_ON ) != GBLCTL_XSRCLR_ON );1 K0 H1 E+ A, @' ^0 u4 Q o
mcasp->regs->RGBLCTL |= GBLCTL_RSRCLR_ON;
7 F. s' k3 S0 `, A while ( ( mcasp->regs->RGBLCTL & GBLCTL_RSRCLR_ON ) != GBLCTL_RSRCLR_ON ); `) ?, p! v9 i0 [8 K4 {( R! |5 w
$ U @, w/ V" X, G& Y2 B- s
/* Write a 0, so that no underrun occurs after releasing the state machine */
: c, L/ e" ~5 Y, a7 G mcasp->regs->XBUF5 = 0;
0 ^% f3 M2 w% k5 E+ [0 i mcasp->regs->RBUF0 = 0;
( Y% R' i( x7 y; Y3 Q3 F5 _# y* l
u6 d: [( V: k- j+ t: g" g mcasp->regs->XGBLCTL |= GBLCTL_XSMRST_ON;
- J* M5 r5 ^4 o+ j3 s" h while ( ( mcasp->regs->XGBLCTL & GBLCTL_XSMRST_ON ) != GBLCTL_XSMRST_ON );- X! {* b% U8 [! j
mcasp->regs->RGBLCTL |= GBLCTL_RSMRST_ON;
0 Y2 D& G O7 B0 o& U# a' [: _ while ( ( mcasp->regs->RGBLCTL & GBLCTL_RSMRST_ON ) != GBLCTL_RSMRST_ON );, N3 j( ^0 k2 p5 D9 E
. m! Y/ H4 U9 @6 o0 [' A mcasp->regs->XGBLCTL |= GBLCTL_XFRST_ON;
7 {/ X& d! U6 k% ?1 W while ( ( mcasp->regs->XGBLCTL & GBLCTL_XFRST_ON ) != GBLCTL_XFRST_ON );0 I' {1 d: M2 O- N# L
mcasp->regs->RGBLCTL |= GBLCTL_RFRST_ON;
+ i' P* E: f3 W* k, |$ f while ( ( mcasp->regs->RGBLCTL & GBLCTL_RFRST_ON ) != GBLCTL_RFRST_ON );7 q1 y' s U H- M6 L
, ]8 p5 f! f9 x1 D. {0 o
CSR = 0x0000;" A- n/ _2 ~) u, t. I# f- ?
INTC_INTMUX1 = 0x3d;& T" l+ u0 b6 ?% r% ^$ _9 K' S
ISTP = (unsigned int)vectors;1 K" ]9 y: h7 I5 Q8 Q" n
ICR = 0xFFF0;
: `5 o, X6 Z% @ IER |= 0x12;
" _$ U7 u! Y$ ]' c CSR |= 0x01; $ X, I1 T% n5 e& k
- R. s1 N- j! n, F* U9 k- B' Q
|$ @6 T$ I5 @ e4 Z
! c: c5 t2 W( a `4 u6 m# L% e4 \
还有就是两个输入输出函数:* ~2 e$ z t, D1 H
void output_sample(Int32 out_data)4 M6 N0 k5 A1 T Z% e2 _+ M$ V& g
{
! S# e+ A8 R Z B7 S% { AIC31_data.uint = out_data;
, j. Z5 ?' o) T C" @8 [# D' |" S MCASP1_XBUF5_32BIT = AIC31_data.uint;; i; J; X" C& K9 G7 T+ \
}! u7 M' ?* A" F" F* h
" I( d0 k8 @- S( `! m# [8 `) h
Int32 input_sample(void)
( G8 ]# b4 y; P{ % {# P% P$ R% [8 b) E6 b
AIC31_data.uint = MCASP1_RBUF0_32BIT;
. y4 s: q l! d return (AIC31_data.uint);* a# B& Z2 b5 R5 `* g
}( H) O1 M7 ?% F% r
1 \! s6 B. ]2 C1 r1 r4 a# s |
|