|
|
C6747和C6748感觉差不多,我想实现McASP发送中断方式控制音频信号,在轮询的例程基础上改的,轮询程序可以实现,但是中断一直实现不了,也找不到错误,求大神帮忙!下边是主要程序:
' H) }; I M0 G( [3 k% R5 bmain文件:( F/ U0 ~- `' Q% f9 |3 j6 H8 E
interrupt void interrupt4(void)
^# X ^* o; V" J1 U{ ~$ F. `- a' r* P/ F2 N, L. l
Uint32 sample;3 N# i6 ^/ L: G; ~) g
( a; S. n7 u+ v, Y9 p sample = input_sample(); // read L + R samples from ADC
! a& t' S' M) b& \$ d, t' q output_sample(sample); // write L + R samples to DAC ; i6 j$ R# @' z- B6 }; e
return;
5 `# F' c. r0 c9 {9 t( t' o& w}3 D0 |* u! ?# J0 z
: E; x& m, s% s8 ~! H
int main( void )
- p b( {- y2 N2 O/ ~7 F& x/ i{
+ \% c- x; I5 P1 z1 B% |' H( Y/ d
D* l/ x; |9 q /* Initialize BSL */
' r. i! Z9 Z* W# G) n EVMC6747_init( );
- z0 f9 v5 p: w, o+ t /* Call evmc6747_intr function */
1 K1 X2 T. i* F2 l aic3106_init( );
. u6 D% s/ k* n+ T7 N* g while(1);0 F' i) A& C. C* ]
}- g$ l7 W5 y Z1 _
+ p6 v/ A! u& K6 C, M; _/ H8 Q
' r3 c: v3 w; p1 V8 `" Y
aic3106_init文件的一部分,McASP配置部分,采用内部时钟,I2S方式,同步传输。音频芯片的配置应该没问题
( J! ^$ B7 l- ?" D+ j: E/* Initialize MCASP1 */% z, v% p4 ~; L
mcasp = &MCASP_MODULE_1;3 G, m: {# q" Z1 C. H) u
mcasp->regs->GBLCTL = 0; // Reset
$ C8 A7 K6 M( D9 S mcasp->regs->RGBLCTL = 0; // Reset RX
P8 Y' S! C9 V; s, l; R mcasp->regs->XGBLCTL = 0; // Reset TX
, Y! d3 ^4 ?, v. Q5 R5 b mcasp->regs->PWRDEMU = 1; // Free-running
+ K) ?! }- t! W0 f$ T' h$ P // configure McASP0 receive registers
7 i, {4 X7 `: U7 A) B mcasp->regs->RMASK = 0xFFFFFFFF; // No padding used
0 `; G- N; A3 f$ n" j" e- H! o( j mcasp->regs->RFMT = 0x00018078; // MSB 16bit, 0-delay, no pad, CFGBus+ H" S0 ~" I' r4 `0 `& b9 Y
mcasp->regs->AFSRCTL = 0x00000112; // 2TDM, 1bit Falling, External FS, word
- \: K% T+ g/ o/ y" H' R mcasp->regs->ACLKRCTL = 0x000000AF; // Rising INTERNAL CLK,(from tx side)& q! }4 t. |3 c
mcasp->regs->AHCLKRCTL = 0x00000000; // INT CLK (from tx side)7 i C7 U: r( C% J7 k9 v
mcasp->regs->RTDM = 0x00000003; // Slots 0,1
* N& `& E8 t- \8 l mcasp->regs->RINTCTL = 0x00000000; // Not used
% a+ _4 A& l' i/ m. f mcasp->regs->RCLKCHK = 0x00FF0008; // 255-MAX 0-MIN, div-by-256
; |* I- @; x- ^( i7 W& s
2 m7 B, g% m v8 ?( x mcasp->regs->XMASK = 0xFFFFFFFF; // No padding used1 ?: s' ^) V1 v4 I3 r4 R
mcasp->regs->XFMT = 0x00018078; // MSB 16bit, 0-delay, no pad, CFGBus: P |( i C2 G& T+ P
mcasp->regs->AFSXCTL = 0x00000112; // 2TDM, 1bit Rising edge INTERNAL FS, word0 o K( Q' p# ^/ A8 ?
mcasp->regs->ACLKXCTL = 0x000000AF; // ASYNC, Rising INTERNAL CLK, div-by-16/ n; [8 K. r# W) a+ G$ i
mcasp->regs->AHCLKXCTL = 0x00000000; // EXT CLK
( q1 u* t/ i7 s% d+ I- ~ mcasp->regs->XTDM = 0x00000003; // Slots 0,1
; h1 p8 F- K% Q; T) m$ y% [9 | mcasp->regs->XINTCTL = 0x00000020; // interrupt on transmit
7 n8 L. j: b2 R, _0 |& T& j mcasp->regs->XCLKCHK = 0x00FF0008; // 255-MAX 0-MIN, div-by-256
( y& v1 n+ G' y% W- [/ G: P2 d( j& a' a4 v5 B' ?' Z4 w% r
mcasp->regs->SRCTL5 = 0x000D; // MCASP1.AXR1[5] --> DIN) n* T5 n8 K' E& ^5 i3 A% b
mcasp->regs->SRCTL0 = 0x000E; // MCASP1.AXR1[0] <-- DOUT
! Q+ b! l( C& a! {5 J) j9 g mcasp->regs->PFUNC = 0; // All MCASPs
0 R, x' |$ Q( i/ \# X mcasp->regs->PDIR = 0x14000020; // All inputs except AXR0[5], ACLKX1, AFSX1
5 {) S+ `2 }% T% O/ p- n$ n7 a1 w1 D; i" m1 f
mcasp->regs->DITCTL = 0x00000000; // Not used
1 z7 j. R, z% \( V' h mcasp->regs->DLBCTL = 0x00000000; // Not used. d- _+ |. H* |, E
mcasp->regs->AMUTE = 0x00000000; // Not used
% Y3 {! c) f: ~( N5 X m+ L7 f
# ~" i: E( V( W0 l- K/* Starting sections of the McASP*/1 U: x, I2 e2 z8 |2 e
mcasp->regs->XGBLCTL |= GBLCTL_XHCLKRST_ON;
( e5 C7 s/ H$ p! e2 \4 H" [ while ( ( mcasp->regs->XGBLCTL & GBLCTL_XHCLKRST_ON ) != GBLCTL_XHCLKRST_ON );
, v* G# S3 R( M# K. K2 f mcasp->regs->RGBLCTL |= GBLCTL_RHCLKRST_ON;
/ \) N1 x. z+ ?5 O( H2 r# B while ( ( mcasp->regs->RGBLCTL & GBLCTL_RHCLKRST_ON ) != GBLCTL_RHCLKRST_ON );
9 b/ V4 `3 u4 n% ~# s4 ^3 E; F, [* e% T8 u5 v' F) ^
mcasp->regs->XGBLCTL |= GBLCTL_XCLKRST_ON; / L0 _3 f3 d- ]5 {( Q$ M& Z
while ( ( mcasp->regs->XGBLCTL & GBLCTL_XCLKRST_ON ) != GBLCTL_XCLKRST_ON );3 o! S. @" Z1 q7 v& _
mcasp->regs->RGBLCTL |= GBLCTL_RCLKRST_ON;
8 Q" k; S0 z8 B5 x while ( ( mcasp->regs->RGBLCTL & GBLCTL_RCLKRST_ON ) != GBLCTL_RCLKRST_ON );
% E% {2 U. F$ N% z
" w0 l3 o/ ]4 o/ Q6 F' R+ Y mcasp->regs->XSTAT = 0x0000ffff; 3 q* G$ U1 _7 {$ K
mcasp->regs->RSTAT = 0x0000ffff; " \* ]7 Y: i' \5 a
; u) x0 p. _1 P/ l f2 a3 M
mcasp->regs->XGBLCTL |= GBLCTL_XSRCLR_ON;
" j5 ~ j6 F- b' o, ^7 c2 d while ( ( mcasp->regs->XGBLCTL & GBLCTL_XSRCLR_ON ) != GBLCTL_XSRCLR_ON );! V' B1 F7 e) e$ m2 V' |& h
mcasp->regs->RGBLCTL |= GBLCTL_RSRCLR_ON;
" j; v8 s5 c1 v* |' ]0 p/ o! k while ( ( mcasp->regs->RGBLCTL & GBLCTL_RSRCLR_ON ) != GBLCTL_RSRCLR_ON );
; b/ T) s) r( u
7 F# X! A3 D. y$ f9 S5 M /* Write a 0, so that no underrun occurs after releasing the state machine */
3 L2 d( E' `. R2 f% b. \ mcasp->regs->XBUF5 = 0;+ o4 T& F V- b1 n9 Y; K3 D
mcasp->regs->RBUF0 = 0;
. j: a7 ~; u) a5 {% c$ g! K. z
$ r. r, a: x, e mcasp->regs->XGBLCTL |= GBLCTL_XSMRST_ON; / X5 e0 F9 U, {0 M: ?
while ( ( mcasp->regs->XGBLCTL & GBLCTL_XSMRST_ON ) != GBLCTL_XSMRST_ON );7 T$ P: a; ^" o! Z
mcasp->regs->RGBLCTL |= GBLCTL_RSMRST_ON; 9 {. P& A a4 X' r, z2 X* {
while ( ( mcasp->regs->RGBLCTL & GBLCTL_RSMRST_ON ) != GBLCTL_RSMRST_ON );! k# w1 o8 f4 |, {" Z9 @
$ d# x- o0 k2 ?) ~
mcasp->regs->XGBLCTL |= GBLCTL_XFRST_ON; 2 @* D8 |% O; V& {8 k* h V( H2 {4 q
while ( ( mcasp->regs->XGBLCTL & GBLCTL_XFRST_ON ) != GBLCTL_XFRST_ON );
/ }0 F" P! Z$ U( _* v W: s mcasp->regs->RGBLCTL |= GBLCTL_RFRST_ON; , ]& `* i: O. g6 k2 V
while ( ( mcasp->regs->RGBLCTL & GBLCTL_RFRST_ON ) != GBLCTL_RFRST_ON );
+ R& r3 `5 B% N0 y
I& p' ~8 `3 v# t9 a# G CSR = 0x0000;, W# ]% j. J T- G
INTC_INTMUX1 = 0x3d;
7 |& y5 p. L7 W ISTP = (unsigned int)vectors;
( |/ T* @! w5 I* R ICR = 0xFFF0; 0 j' U: g. R0 D; H: B) ^
IER |= 0x12;
' V+ M0 C7 K6 M2 \; F CSR |= 0x01; 8 n- A$ I6 u: j W
$ G/ X) \$ I( [9 J( Q( R) r- E, C
) S( b1 h* w" Y* }. P/ P# ?
- n6 `+ q& j2 v3 b还有就是两个输入输出函数:. ~- c- e3 k+ ~* o( o, q6 y
void output_sample(Int32 out_data)
; b+ f) U: K. [( I- d) g, n+ d- }' O( Z{/ S$ w9 A# D, I
AIC31_data.uint = out_data;
9 F, X$ r7 F" c+ s7 c* g MCASP1_XBUF5_32BIT = AIC31_data.uint;+ {9 p- x# A) t' ^0 z
}
5 j; u9 D( H0 n- S0 V
0 I; _0 U2 M' I3 j; f% J4 A( BInt32 input_sample(void)8 ?5 b, v( }+ q
{ - |. s+ I7 `' H2 {5 F8 B4 N
AIC31_data.uint = MCASP1_RBUF0_32BIT;3 O4 G# Y" ?" y* K& |
return (AIC31_data.uint);% o: y: S$ |0 Y- _; `5 d6 R8 j
}
7 u; k! C* L' p, ]" g9 j( t0 D' \. L! v/ g
|
|