|
|
C6747和C6748感觉差不多,我想实现McASP发送中断方式控制音频信号,在轮询的例程基础上改的,轮询程序可以实现,但是中断一直实现不了,也找不到错误,求大神帮忙!下边是主要程序:
) U7 ?, q: R3 \# |) P1 d, x" Zmain文件:
7 K) [: V; q! G/ N7 t/ n Dinterrupt void interrupt4(void) * f$ H0 x. M- g# ]8 ~1 n6 Y; y7 n
{) ~' d( q6 u6 A3 Q/ U
Uint32 sample;
7 K9 S, M- `7 i8 J6 |7 J9 l# p2 Y) U; [4 y7 z
sample = input_sample(); // read L + R samples from ADC
+ W1 V) X. b. t/ n, D* h output_sample(sample); // write L + R samples to DAC
4 S/ P/ e Y, o6 x6 l return;' W0 T+ r1 P- K7 s- I% H
}. m: e( F- T% c, L C
" O4 P. \4 X% B' zint main( void )$ x. u4 o- J4 }* s" |
{
8 d+ X% Z" L8 d0 A# o/ A& e0 s/ K* n6 k- H5 d' h
/* Initialize BSL */1 O1 Y" u" W4 v# z) M
EVMC6747_init( );
% X1 X1 Y$ I- p: Y( r. J /* Call evmc6747_intr function */4 h w6 \( s: D* w( n9 l
aic3106_init( );
: t6 S! Y" _2 @ while(1);
( ?" o" I: j( u3 g" P" C( R, c6 C}
, Q3 ^8 f5 n5 K8 c: M
: n. x$ `; }& |6 g
- p' S) c0 O; g1 r. P, Aaic3106_init文件的一部分,McASP配置部分,采用内部时钟,I2S方式,同步传输。音频芯片的配置应该没问题
+ S6 D" Y/ ]4 C/* Initialize MCASP1 */
6 {2 ]. F& H; z1 g# M5 y ^& w' z) N mcasp = &MCASP_MODULE_1;
/ D6 Q5 ]9 D# ]5 O0 { mcasp->regs->GBLCTL = 0; // Reset t7 Y7 H# i2 R$ R# ^
mcasp->regs->RGBLCTL = 0; // Reset RX
+ {( a ?, C I; t: Q1 P& Z+ k mcasp->regs->XGBLCTL = 0; // Reset TX- l z: J+ D# G. b4 S* {5 ^* _
mcasp->regs->PWRDEMU = 1; // Free-running
+ l& I- B) g0 b ]! [0 E1 z# E // configure McASP0 receive registers* [ Y9 |6 O0 c; u" o
mcasp->regs->RMASK = 0xFFFFFFFF; // No padding used3 @' r( e9 R8 `1 A
mcasp->regs->RFMT = 0x00018078; // MSB 16bit, 0-delay, no pad, CFGBus
i5 m# n. Z F- E mcasp->regs->AFSRCTL = 0x00000112; // 2TDM, 1bit Falling, External FS, word$ [# i. ?! X! c. C v
mcasp->regs->ACLKRCTL = 0x000000AF; // Rising INTERNAL CLK,(from tx side)( S2 p" | q8 E, T
mcasp->regs->AHCLKRCTL = 0x00000000; // INT CLK (from tx side)1 |' \$ {/ P) V. ~
mcasp->regs->RTDM = 0x00000003; // Slots 0,1
6 Z: F5 Y# X- |5 H mcasp->regs->RINTCTL = 0x00000000; // Not used
; X! D, ]' b( h6 y* ] mcasp->regs->RCLKCHK = 0x00FF0008; // 255-MAX 0-MIN, div-by-256
; Y/ [+ {0 T0 ~, i* k
" _/ o: r( o! ? a2 g: ] mcasp->regs->XMASK = 0xFFFFFFFF; // No padding used
. r$ n4 f; x) t8 p2 }9 ~* q8 ^0 g mcasp->regs->XFMT = 0x00018078; // MSB 16bit, 0-delay, no pad, CFGBus
$ h. m, F9 C; ` h8 ?# Z& O! W mcasp->regs->AFSXCTL = 0x00000112; // 2TDM, 1bit Rising edge INTERNAL FS, word
J# r3 V; S k9 [# t* Y% u) X* `) |9 Y$ i5 w mcasp->regs->ACLKXCTL = 0x000000AF; // ASYNC, Rising INTERNAL CLK, div-by-16
. R/ f7 `: I8 n5 L" {! ]5 ~2 P$ [ mcasp->regs->AHCLKXCTL = 0x00000000; // EXT CLK3 w4 }& j4 F; I- e4 j: O
mcasp->regs->XTDM = 0x00000003; // Slots 0,1" o! w$ y* |5 p1 `- D, [
mcasp->regs->XINTCTL = 0x00000020; // interrupt on transmit
0 Z4 X! L4 I6 g1 ]8 r% u mcasp->regs->XCLKCHK = 0x00FF0008; // 255-MAX 0-MIN, div-by-256
/ d1 x; X$ i) A9 t) n7 Z% I/ J
" S6 t1 I7 m! p O( Y6 W( h mcasp->regs->SRCTL5 = 0x000D; // MCASP1.AXR1[5] --> DIN
) c* e; D( f# m5 } mcasp->regs->SRCTL0 = 0x000E; // MCASP1.AXR1[0] <-- DOUT, \7 o( [5 L& g) {2 e
mcasp->regs->PFUNC = 0; // All MCASPs3 q& v/ d/ j! Z; ^# Z( E
mcasp->regs->PDIR = 0x14000020; // All inputs except AXR0[5], ACLKX1, AFSX1, I/ U5 O" u6 D8 X) \; l9 D
! q3 e6 @1 W, E( B$ _$ J2 } mcasp->regs->DITCTL = 0x00000000; // Not used( _* b. P$ h" F0 m
mcasp->regs->DLBCTL = 0x00000000; // Not used' g9 k1 ]9 ]3 ?4 x
mcasp->regs->AMUTE = 0x00000000; // Not used% y' C$ O; k: }3 f0 e
1 Y& F3 U- V T; A/ M7 L: h/* Starting sections of the McASP*/3 \* O) Q+ H6 c5 [
mcasp->regs->XGBLCTL |= GBLCTL_XHCLKRST_ON;
, U: ^" k5 X1 Z9 I2 e V- j) a while ( ( mcasp->regs->XGBLCTL & GBLCTL_XHCLKRST_ON ) != GBLCTL_XHCLKRST_ON );
" [2 W+ y, u' Q* R8 j mcasp->regs->RGBLCTL |= GBLCTL_RHCLKRST_ON; & U7 l% ^' x! Y$ E* q0 y( t
while ( ( mcasp->regs->RGBLCTL & GBLCTL_RHCLKRST_ON ) != GBLCTL_RHCLKRST_ON );
+ c. L+ K8 f6 }/ g2 F) {0 E$ `8 @" t0 `3 C0 Q) _! m& b [4 g+ g
mcasp->regs->XGBLCTL |= GBLCTL_XCLKRST_ON;
D h" {: E" \5 } while ( ( mcasp->regs->XGBLCTL & GBLCTL_XCLKRST_ON ) != GBLCTL_XCLKRST_ON );
4 |6 V) Q0 X& I mcasp->regs->RGBLCTL |= GBLCTL_RCLKRST_ON;
. A; O6 a% {2 a9 ?+ ?9 Y4 H) K, X while ( ( mcasp->regs->RGBLCTL & GBLCTL_RCLKRST_ON ) != GBLCTL_RCLKRST_ON );
0 i/ a, H1 `3 r" @
; D1 z2 w7 H' G, T( A, |! N mcasp->regs->XSTAT = 0x0000ffff; . \, C. \0 t/ h
mcasp->regs->RSTAT = 0x0000ffff;
# Z% y9 z! A6 h# Q0 E& q9 ] p$ M0 g: H. s- H/ u% W5 c& }# G
mcasp->regs->XGBLCTL |= GBLCTL_XSRCLR_ON;3 x% Q s1 i4 X0 Y0 f- h
while ( ( mcasp->regs->XGBLCTL & GBLCTL_XSRCLR_ON ) != GBLCTL_XSRCLR_ON );1 _6 l6 w. T! D6 g" V6 c) h# c% H
mcasp->regs->RGBLCTL |= GBLCTL_RSRCLR_ON;
5 y5 a4 v8 E l. n5 G+ v3 N while ( ( mcasp->regs->RGBLCTL & GBLCTL_RSRCLR_ON ) != GBLCTL_RSRCLR_ON );
# d6 q& J( [4 ^; X' Y5 A' C/ z% n2 D8 U" s
/* Write a 0, so that no underrun occurs after releasing the state machine */$ O* |/ U8 D; V+ \6 {
mcasp->regs->XBUF5 = 0;# ]4 F/ r% {7 }' ~6 u5 s
mcasp->regs->RBUF0 = 0;
; u) }: ~) X" F! ^& y a) y
+ ~3 H! p5 p2 A5 a mcasp->regs->XGBLCTL |= GBLCTL_XSMRST_ON; ; e( S7 a8 Q! K
while ( ( mcasp->regs->XGBLCTL & GBLCTL_XSMRST_ON ) != GBLCTL_XSMRST_ON );
3 @9 |5 a# L) P1 i1 v$ J% z mcasp->regs->RGBLCTL |= GBLCTL_RSMRST_ON; ( M y7 r+ l! J8 ^$ V! b8 u
while ( ( mcasp->regs->RGBLCTL & GBLCTL_RSMRST_ON ) != GBLCTL_RSMRST_ON );
, s6 d; Y, G. b$ @; f' ~0 X; \8 a$ E l& o2 U3 Y* W
mcasp->regs->XGBLCTL |= GBLCTL_XFRST_ON;
4 {" w/ O0 J& L: \ while ( ( mcasp->regs->XGBLCTL & GBLCTL_XFRST_ON ) != GBLCTL_XFRST_ON );) |$ a) t7 {: U! [; v
mcasp->regs->RGBLCTL |= GBLCTL_RFRST_ON; ! g5 n; B) q5 f1 R) X- d# J
while ( ( mcasp->regs->RGBLCTL & GBLCTL_RFRST_ON ) != GBLCTL_RFRST_ON );. C0 S6 I' P9 c$ c+ v
) h; _% I/ a9 Q" _1 I+ X8 k* U8 l
CSR = 0x0000;
# S; @9 I$ p2 L* { INTC_INTMUX1 = 0x3d;, z" t: o9 y# l: U' o& C$ `
ISTP = (unsigned int)vectors;8 }1 K* |; a4 D% z
ICR = 0xFFF0; 5 C: @8 t: a" E' L: Q5 y+ x
IER |= 0x12;
1 q+ {7 K" H/ D* C+ f* X- b5 a, i CSR |= 0x01;
/ ~% O. y' J3 P3 P) k' `8 G, o' I+ T3 P! n/ B) L/ v/ f, k
5 D* Z( v" [, Y. `% L- Y# J$ k
) k3 U. F. w% c* G还有就是两个输入输出函数:- \3 u" Z. t2 d: r& X9 o
void output_sample(Int32 out_data)
0 N7 y6 _* U" X1 u' b2 c- N{0 J# J' s# N1 ~$ [
AIC31_data.uint = out_data; * u( r8 i, g8 W# o( s" C [
MCASP1_XBUF5_32BIT = AIC31_data.uint;) N4 k4 N! A; q8 T0 d: P8 g
}
+ O ~% E: o& \3 E# y8 \
: l8 W; |5 l9 x( r1 [Int32 input_sample(void)
* {" @1 x+ R! G{
" L' r2 L, c4 s+ C/ K1 w AIC31_data.uint = MCASP1_RBUF0_32BIT;! }6 W7 L$ l0 t2 q
return (AIC31_data.uint);2 Q1 \* f w. Q% Z
}# m5 Z: P; Q% t; [
7 n' k; w. k% ]$ b1 n' [' @# p' g |
|