|
|
C6747和C6748感觉差不多,我想实现McASP发送中断方式控制音频信号,在轮询的例程基础上改的,轮询程序可以实现,但是中断一直实现不了,也找不到错误,求大神帮忙!下边是主要程序:
2 W% `) ~* C- l# I+ x& R! Emain文件:) m j0 h, c7 ^/ Z
interrupt void interrupt4(void) 6 y5 C0 {; h) X) R3 p# J( P# D3 Z- s
{6 v. x k' e% t1 ~# S" k/ o
Uint32 sample;% R% u6 w' A4 x7 k
! p, F! H' b- V. E
sample = input_sample(); // read L + R samples from ADC
" r v, M. i: O' q) H& b output_sample(sample); // write L + R samples to DAC # i' `: K+ \7 u. N' E* e9 P
return;
" `( @5 `4 \' [4 Q}
5 v7 f. s6 c- A- C8 E' p4 x6 S) d9 O8 I$ M6 v: ^4 l
int main( void )
& U5 B6 N: O9 y) ~3 Q{
4 Z- ^6 Q( E7 I1 v! C+ C4 c5 e7 ^! s5 g6 |2 }% L+ t
/* Initialize BSL */6 }$ [' A$ k+ D
EVMC6747_init( );( J0 P: d. Z9 t, N }
/* Call evmc6747_intr function */
. v4 M9 s4 |8 O2 h7 C aic3106_init( );, Y4 M% P0 g M8 x+ s
while(1);
- i: ^# {1 L6 N0 b' w' Z; D: w}
0 J6 |. Y; g% I' y2 t ^; x& W* Y5 _6 C) v- i+ G3 G
. ~3 A' `% p! v2 y$ kaic3106_init文件的一部分,McASP配置部分,采用内部时钟,I2S方式,同步传输。音频芯片的配置应该没问题& ]- F. A$ c; U! j. j* W
/* Initialize MCASP1 */
; E) u" d& V: c# U mcasp = &MCASP_MODULE_1;+ M2 U, a1 t+ [9 w9 U+ l5 O" Y
mcasp->regs->GBLCTL = 0; // Reset5 Z- f& y. _, [& |6 P+ w/ A
mcasp->regs->RGBLCTL = 0; // Reset RX- o" |# {2 `0 l* `5 |8 B
mcasp->regs->XGBLCTL = 0; // Reset TX+ h! m: ?" h0 k( _, }% F: q
mcasp->regs->PWRDEMU = 1; // Free-running% J8 c( t. y& q5 z# m8 G, F. w
// configure McASP0 receive registers
4 P9 a# ]9 ~1 @# ? mcasp->regs->RMASK = 0xFFFFFFFF; // No padding used4 h5 k6 m$ ~9 I9 ^4 _1 n) o1 U
mcasp->regs->RFMT = 0x00018078; // MSB 16bit, 0-delay, no pad, CFGBus( E7 J2 t' O7 w. f7 _
mcasp->regs->AFSRCTL = 0x00000112; // 2TDM, 1bit Falling, External FS, word
& `& C( B) G$ o3 ~& W b' S mcasp->regs->ACLKRCTL = 0x000000AF; // Rising INTERNAL CLK,(from tx side)
' m* j8 i% c( F6 r0 k mcasp->regs->AHCLKRCTL = 0x00000000; // INT CLK (from tx side)
3 F, @1 x7 Q2 v mcasp->regs->RTDM = 0x00000003; // Slots 0,1
1 {- T7 l+ Y1 }- d mcasp->regs->RINTCTL = 0x00000000; // Not used
4 a# e7 r6 e$ L& U mcasp->regs->RCLKCHK = 0x00FF0008; // 255-MAX 0-MIN, div-by-256
9 k! l' d2 ~ t! q/ \
' k/ k Y; L$ b* v mcasp->regs->XMASK = 0xFFFFFFFF; // No padding used
' K. q8 X# D% m! S- B( K mcasp->regs->XFMT = 0x00018078; // MSB 16bit, 0-delay, no pad, CFGBus
8 H; h/ {) k: q- x% g6 ~" } mcasp->regs->AFSXCTL = 0x00000112; // 2TDM, 1bit Rising edge INTERNAL FS, word& A, g. w5 c$ x% ~( D8 I! s
mcasp->regs->ACLKXCTL = 0x000000AF; // ASYNC, Rising INTERNAL CLK, div-by-164 r5 ~% x8 J3 Q; \
mcasp->regs->AHCLKXCTL = 0x00000000; // EXT CLK
# `* ^7 J& J& a& E9 O% R: f1 b mcasp->regs->XTDM = 0x00000003; // Slots 0,19 s" `0 v0 I6 S) T/ G& o8 b
mcasp->regs->XINTCTL = 0x00000020; // interrupt on transmit
6 Z4 o! Y4 k) k$ P- g* | mcasp->regs->XCLKCHK = 0x00FF0008; // 255-MAX 0-MIN, div-by-256. L% O* c$ A* y! J
9 |# P( Y0 D& J0 T# Q mcasp->regs->SRCTL5 = 0x000D; // MCASP1.AXR1[5] --> DIN& `" ]# f; C3 t+ T3 ~: Q$ N! x/ M) j) E
mcasp->regs->SRCTL0 = 0x000E; // MCASP1.AXR1[0] <-- DOUT
. i5 K. t/ }: q/ ^5 C6 \' ^+ d mcasp->regs->PFUNC = 0; // All MCASPs& y( T$ Y( L! E& s
mcasp->regs->PDIR = 0x14000020; // All inputs except AXR0[5], ACLKX1, AFSX1
8 q* W: V. u+ o: p1 L5 Q9 g3 M
1 l: \) y: w' f mcasp->regs->DITCTL = 0x00000000; // Not used
4 v: d" ^. U( I9 @ mcasp->regs->DLBCTL = 0x00000000; // Not used* J! Q; h2 \* ? x7 m3 z; C
mcasp->regs->AMUTE = 0x00000000; // Not used( F# e0 I; k: d& t9 {
3 k6 ^* I P+ r# a9 J1 ~, a2 a9 Y
/* Starting sections of the McASP*/( t9 _6 r) _ i% B$ C
mcasp->regs->XGBLCTL |= GBLCTL_XHCLKRST_ON;
' g ?' [! O! | h' [9 [ while ( ( mcasp->regs->XGBLCTL & GBLCTL_XHCLKRST_ON ) != GBLCTL_XHCLKRST_ON ); # \5 @6 Q! X6 Y+ Z
mcasp->regs->RGBLCTL |= GBLCTL_RHCLKRST_ON;
$ J+ m$ A1 f/ g* e0 ]1 G( h while ( ( mcasp->regs->RGBLCTL & GBLCTL_RHCLKRST_ON ) != GBLCTL_RHCLKRST_ON );# R; b A+ ^/ X$ E2 E
. P! ]( P. Q% E8 t mcasp->regs->XGBLCTL |= GBLCTL_XCLKRST_ON; 7 b5 a' F- b$ A6 r. @$ u7 t$ m
while ( ( mcasp->regs->XGBLCTL & GBLCTL_XCLKRST_ON ) != GBLCTL_XCLKRST_ON );. \8 M" |. Y# X) K! {
mcasp->regs->RGBLCTL |= GBLCTL_RCLKRST_ON; ! I2 P- y; L; _1 c, Q8 t1 U- b
while ( ( mcasp->regs->RGBLCTL & GBLCTL_RCLKRST_ON ) != GBLCTL_RCLKRST_ON );
- G, }2 P' M! S0 g" J% Z8 M: a: z! M8 X, Z- E
mcasp->regs->XSTAT = 0x0000ffff;
V, \* ?! D! u( [$ k* U2 z& c! V mcasp->regs->RSTAT = 0x0000ffff;
' b2 u) `! s) |' {
4 O; t, R4 O/ M1 `) o1 \ mcasp->regs->XGBLCTL |= GBLCTL_XSRCLR_ON;9 o1 ]% W, w# E% C; V
while ( ( mcasp->regs->XGBLCTL & GBLCTL_XSRCLR_ON ) != GBLCTL_XSRCLR_ON );- F; u3 k4 o* W; Q0 W: {
mcasp->regs->RGBLCTL |= GBLCTL_RSRCLR_ON;
; T3 V; \! f7 n. s$ U while ( ( mcasp->regs->RGBLCTL & GBLCTL_RSRCLR_ON ) != GBLCTL_RSRCLR_ON );
: ~# c8 b1 U, Z/ V
, `# P% G3 f5 s8 P, h /* Write a 0, so that no underrun occurs after releasing the state machine */
% y4 Y* x+ f" N9 W8 E( C mcasp->regs->XBUF5 = 0;
1 P6 e1 m" W* a" p/ Z. K+ _( W mcasp->regs->RBUF0 = 0;
Y/ r- X5 r1 Y/ [6 T1 H0 y) C8 B+ ?! j' o. Q+ r! ~ `: T4 w7 i
mcasp->regs->XGBLCTL |= GBLCTL_XSMRST_ON; : e* @0 }: G( X) [" a+ G! P
while ( ( mcasp->regs->XGBLCTL & GBLCTL_XSMRST_ON ) != GBLCTL_XSMRST_ON ); u% t! V8 Z: p8 F# x7 M8 [
mcasp->regs->RGBLCTL |= GBLCTL_RSMRST_ON; - q1 N. I D/ j6 u- w' Q# y; r0 A& b6 G
while ( ( mcasp->regs->RGBLCTL & GBLCTL_RSMRST_ON ) != GBLCTL_RSMRST_ON );
$ Y `! L5 \% O0 m' S4 V' r' s
4 P1 v; C$ i& t, f1 s; g$ V mcasp->regs->XGBLCTL |= GBLCTL_XFRST_ON;
- O% }( {& S l% Z while ( ( mcasp->regs->XGBLCTL & GBLCTL_XFRST_ON ) != GBLCTL_XFRST_ON );% w2 L5 B5 b7 K" Z
mcasp->regs->RGBLCTL |= GBLCTL_RFRST_ON; 4 i2 i; v" k$ O& W! i' p
while ( ( mcasp->regs->RGBLCTL & GBLCTL_RFRST_ON ) != GBLCTL_RFRST_ON );
- K- V! |' f4 I2 p
" B( r7 ^2 H5 [8 p1 M CSR = 0x0000;
/ [5 n% F' L4 t. r5 ~) B' V( O INTC_INTMUX1 = 0x3d;5 O- A' W5 D# p8 w3 E% `, ^7 y
ISTP = (unsigned int)vectors;
% L& l2 @% A! |- p0 h' |2 S1 d) y ICR = 0xFFF0;
2 @3 N I6 n& ]6 N; [ IER |= 0x12; 6 ~3 T/ p) g! M$ Q6 a+ o) U
CSR |= 0x01; : s& F3 K& [3 L0 k
+ L+ z6 a3 S9 z) f* u8 M
% ~9 \ Q) v N- w; Z
5 h Y: P. o/ f1 e* M( y
还有就是两个输入输出函数:
9 Z& j/ ~/ y( |4 W& @ W$ d/ pvoid output_sample(Int32 out_data)6 E, C4 ^# O! G8 V: G/ W, A9 d
{
; a/ t6 I: f3 g; B2 l' r$ Q AIC31_data.uint = out_data; 6 |' C2 l& F' y5 Y8 F" P! \
MCASP1_XBUF5_32BIT = AIC31_data.uint;
# V( g# \' O4 K}- B+ C) w2 ^5 C( G. B }
/ X. t+ ]. j. s
Int32 input_sample(void)6 i! S8 f$ b6 l8 o7 }$ p" ~7 s
{
# |( o+ T+ |9 {' c$ i: Y0 f- } AIC31_data.uint = MCASP1_RBUF0_32BIT;
7 {3 F7 J; e; C return (AIC31_data.uint);) Z8 g3 p0 T8 g! ~- F
}
9 _! D$ v2 Y% E. c* c4 c1 Z( o6 E0 q
$ D: W& ?. r- V. D; | |
|