|
|
C6747和C6748感觉差不多,我想实现McASP发送中断方式控制音频信号,在轮询的例程基础上改的,轮询程序可以实现,但是中断一直实现不了,也找不到错误,求大神帮忙!下边是主要程序:: j7 J5 O7 o( ?- ~6 I- \. _" B5 M
main文件:3 R. ^; l, `/ l( W# W* h5 u
interrupt void interrupt4(void) 3 c( Z6 I. [: L; g; d& ~
{3 k, S. M' m4 h
Uint32 sample;
. F2 Q6 y+ M5 Z) u1 k) \/ [/ l! Q! N/ ?* }
sample = input_sample(); // read L + R samples from ADC) W3 |9 j5 a" }
output_sample(sample); // write L + R samples to DAC 8 G7 f' @* H7 x) o: j* E
return;, k; l9 H6 @$ ~$ u! {9 G8 m
}* Q) j* j4 {4 c8 W
4 \) }3 g& ^" q0 w4 vint main( void )6 b% u ?9 }- l% X" l
{
R8 k& {1 v$ r$ K
5 |* I# W: ], R. R& e# b R- q /* Initialize BSL */
2 z( e2 ^4 o" c* _ EVMC6747_init( );1 X( H/ l: ]; d& D# U& u7 {
/* Call evmc6747_intr function */
; R. O. f$ V6 a aic3106_init( );
+ M2 d; `+ [; l6 O4 _( J while(1);
: D0 r7 m: y7 e: n$ D}
* C* s7 D* x: t; H/ V% d( B+ _/ ]1 D* W. N& K5 P1 n
, S$ G" k) `" ` Paic3106_init文件的一部分,McASP配置部分,采用内部时钟,I2S方式,同步传输。音频芯片的配置应该没问题3 m1 t$ C. {+ S& `
/* Initialize MCASP1 */! Z% t: ]* B' A5 O( k
mcasp = &MCASP_MODULE_1;" v4 F; Z" |0 A
mcasp->regs->GBLCTL = 0; // Reset6 N) W5 u/ f6 [& C
mcasp->regs->RGBLCTL = 0; // Reset RX
. e8 s6 t$ C" m mcasp->regs->XGBLCTL = 0; // Reset TX. }5 `! X2 h- G
mcasp->regs->PWRDEMU = 1; // Free-running9 u6 I: g7 R8 [5 U9 n
// configure McASP0 receive registers
4 D; Y# F' S% J mcasp->regs->RMASK = 0xFFFFFFFF; // No padding used
' o3 G5 C# X5 I mcasp->regs->RFMT = 0x00018078; // MSB 16bit, 0-delay, no pad, CFGBus
' H6 ^6 ~6 ? H mcasp->regs->AFSRCTL = 0x00000112; // 2TDM, 1bit Falling, External FS, word
5 s+ b7 k q2 B mcasp->regs->ACLKRCTL = 0x000000AF; // Rising INTERNAL CLK,(from tx side)
+ A& @! S! Z- G, O$ D: G mcasp->regs->AHCLKRCTL = 0x00000000; // INT CLK (from tx side). y4 ~& a2 b; I& Q
mcasp->regs->RTDM = 0x00000003; // Slots 0,1
) z' \) @$ f; Z1 @% g, E) u- h mcasp->regs->RINTCTL = 0x00000000; // Not used. ?" s `" Y+ _8 h
mcasp->regs->RCLKCHK = 0x00FF0008; // 255-MAX 0-MIN, div-by-2569 S) J: p9 ^' y0 T' j0 t' H
4 K4 q3 Z( {: f( v/ K X
mcasp->regs->XMASK = 0xFFFFFFFF; // No padding used$ i/ t, p( W7 x
mcasp->regs->XFMT = 0x00018078; // MSB 16bit, 0-delay, no pad, CFGBus
# y- B& _# }/ T$ ^) c3 W" L/ H6 E mcasp->regs->AFSXCTL = 0x00000112; // 2TDM, 1bit Rising edge INTERNAL FS, word
+ d) A3 | O! d- @1 _ mcasp->regs->ACLKXCTL = 0x000000AF; // ASYNC, Rising INTERNAL CLK, div-by-16. i# K* E" ^ R [. g* A
mcasp->regs->AHCLKXCTL = 0x00000000; // EXT CLK' G' x) E* s, h
mcasp->regs->XTDM = 0x00000003; // Slots 0,1/ n) _3 i* P' f- N( O9 \* h
mcasp->regs->XINTCTL = 0x00000020; // interrupt on transmit
# x. i7 L. e. D1 P: _ mcasp->regs->XCLKCHK = 0x00FF0008; // 255-MAX 0-MIN, div-by-256) x6 z* R/ t# |( e
# r. `5 M4 V# X! i
mcasp->regs->SRCTL5 = 0x000D; // MCASP1.AXR1[5] --> DIN
7 x# o1 D, e. I( X% P2 K mcasp->regs->SRCTL0 = 0x000E; // MCASP1.AXR1[0] <-- DOUT3 K' |0 Z; @! M$ A( ^3 x' X2 [. c
mcasp->regs->PFUNC = 0; // All MCASPs& C3 g1 E; z3 G) G+ g7 C
mcasp->regs->PDIR = 0x14000020; // All inputs except AXR0[5], ACLKX1, AFSX1
; W2 Q0 P7 h# R% s/ A7 h2 E. A1 W n# H6 F
mcasp->regs->DITCTL = 0x00000000; // Not used
0 @- s8 a; T. `& D5 V mcasp->regs->DLBCTL = 0x00000000; // Not used3 d. w1 w; f3 n3 P) V2 `: J* x2 U
mcasp->regs->AMUTE = 0x00000000; // Not used
! q( T9 b+ b) l: @7 @( ?/ N3 B3 p& r2 i8 u- r6 V* Z
/* Starting sections of the McASP*/
8 S; `& F5 ?4 p/ v% K' _. s! |( L mcasp->regs->XGBLCTL |= GBLCTL_XHCLKRST_ON; 6 p1 R L* v+ D" X. B) S
while ( ( mcasp->regs->XGBLCTL & GBLCTL_XHCLKRST_ON ) != GBLCTL_XHCLKRST_ON );
5 c6 P. N5 E1 f6 j6 L mcasp->regs->RGBLCTL |= GBLCTL_RHCLKRST_ON; % D1 @$ c* x) t
while ( ( mcasp->regs->RGBLCTL & GBLCTL_RHCLKRST_ON ) != GBLCTL_RHCLKRST_ON );5 a# G: Y0 u1 w) w, `; ]3 F% T1 h3 o
9 Y1 h0 b! g8 W/ i( |/ Z6 v mcasp->regs->XGBLCTL |= GBLCTL_XCLKRST_ON; 3 g/ S$ j& [9 e, w* x9 G
while ( ( mcasp->regs->XGBLCTL & GBLCTL_XCLKRST_ON ) != GBLCTL_XCLKRST_ON );
, j. l) d: W$ \4 p' E mcasp->regs->RGBLCTL |= GBLCTL_RCLKRST_ON;
% T. ~ `+ I- U while ( ( mcasp->regs->RGBLCTL & GBLCTL_RCLKRST_ON ) != GBLCTL_RCLKRST_ON );
9 _; ^9 r2 h+ d8 d( R" w
, I0 Z' L- N# k& k: A mcasp->regs->XSTAT = 0x0000ffff;
# z* p7 Y2 P% J+ @ mcasp->regs->RSTAT = 0x0000ffff; ) X+ ]* C0 J: i) H
: }0 b( {, g/ G* B0 [ z, N, b# j
mcasp->regs->XGBLCTL |= GBLCTL_XSRCLR_ON;$ g! D1 o6 l6 A1 Y1 M
while ( ( mcasp->regs->XGBLCTL & GBLCTL_XSRCLR_ON ) != GBLCTL_XSRCLR_ON );
$ n+ ~6 X0 Q( i- l mcasp->regs->RGBLCTL |= GBLCTL_RSRCLR_ON; % e$ \2 G+ m6 t! B: a' m
while ( ( mcasp->regs->RGBLCTL & GBLCTL_RSRCLR_ON ) != GBLCTL_RSRCLR_ON );
9 g# F$ ]! B6 n6 G* y4 o$ R9 }2 u' D- I8 u, `0 w
/* Write a 0, so that no underrun occurs after releasing the state machine */* t& Y, l% P5 y( {
mcasp->regs->XBUF5 = 0;5 r v, q& a" k: ]
mcasp->regs->RBUF0 = 0;
2 ]& w. C6 t; i! ^
6 D2 u5 S# [+ h4 C9 b. `9 v, \ mcasp->regs->XGBLCTL |= GBLCTL_XSMRST_ON;
7 q! n3 S' D6 M2 O while ( ( mcasp->regs->XGBLCTL & GBLCTL_XSMRST_ON ) != GBLCTL_XSMRST_ON );( m8 Z3 O4 f. M$ ~9 E- @
mcasp->regs->RGBLCTL |= GBLCTL_RSMRST_ON; / X: n, P! Y% ~6 ?9 z" ]1 Y# d: ?
while ( ( mcasp->regs->RGBLCTL & GBLCTL_RSMRST_ON ) != GBLCTL_RSMRST_ON );! ?! f1 P* a* X
+ C) R' W2 }8 Q/ `
mcasp->regs->XGBLCTL |= GBLCTL_XFRST_ON;
. w# l7 g$ C7 M! \! U while ( ( mcasp->regs->XGBLCTL & GBLCTL_XFRST_ON ) != GBLCTL_XFRST_ON );; {4 _; U- C+ o7 g
mcasp->regs->RGBLCTL |= GBLCTL_RFRST_ON; 3 y: d8 w& a2 z, X5 s% i3 J5 F
while ( ( mcasp->regs->RGBLCTL & GBLCTL_RFRST_ON ) != GBLCTL_RFRST_ON );
$ U7 Z# U' t. t5 B: O' X' ^, l: _/ h# Z
CSR = 0x0000;! E; ?) H+ J) A" w
INTC_INTMUX1 = 0x3d;
8 _9 U. h# F+ t4 A* w2 y0 v ISTP = (unsigned int)vectors;7 S" i% u/ w/ h# C7 a6 B
ICR = 0xFFF0;
7 J* M! n3 v/ z! ]" _4 j IER |= 0x12; 3 l1 O, Z* D+ b+ K/ u
CSR |= 0x01; 8 E9 A) L1 N7 }
" X: P; }4 ~: F" P+ x% g
( [; _7 @0 E6 v9 @+ k1 s" N- E" t& M
还有就是两个输入输出函数:
% F! M( W& | Mvoid output_sample(Int32 out_data): v2 e" ]9 F) N+ X+ u
{
+ x( [9 w. y& G: b AIC31_data.uint = out_data;
4 j( Y& [6 j9 X6 Z; t MCASP1_XBUF5_32BIT = AIC31_data.uint;3 |0 v) w7 K: Q: L& l- ]& g
}
, Q" P0 C/ p) ]$ `* {
5 L* ~3 f. P4 e9 G8 N1 ^Int32 input_sample(void)
+ q) {! ?9 l) Q3 v* ?, q{
5 [) Y) |3 b$ @' E3 E AIC31_data.uint = MCASP1_RBUF0_32BIT;
- F5 W) C4 C" `& N4 Z+ q return (AIC31_data.uint);( A. l! `) f. R$ _
}+ W( N7 T( J& C# D- @
$ M: n# {0 ]- ]! \8 [
|
|