|
|
C6747和C6748感觉差不多,我想实现McASP发送中断方式控制音频信号,在轮询的例程基础上改的,轮询程序可以实现,但是中断一直实现不了,也找不到错误,求大神帮忙!下边是主要程序:+ f0 U! ?& x5 K6 c1 T% z$ Y2 X
main文件:+ I& a0 D, L4 o: L
interrupt void interrupt4(void) * D/ ^2 `9 j( T8 o6 y0 `& t0 ?
{4 Z! F" X+ ?( B( h- o
Uint32 sample;
8 Q4 k& J, S/ \6 b1 R: {" [! X5 N6 ?' Q
sample = input_sample(); // read L + R samples from ADC& U- s% `, N6 h) L) U4 J7 Q( v" L
output_sample(sample); // write L + R samples to DAC 9 n+ x& X. ^$ _) L' X1 B
return;/ i1 x7 q7 J& r1 j I
}
0 a9 G# P8 A. q6 {; R! f3 K5 n! V6 l6 V+ {+ ?2 i) {4 v& Q
int main( void )- H, M+ P9 a. q8 e6 B$ D( c9 K* }
{- Z: e' u* y: \$ p
, p3 b8 L- ^1 h8 t& S4 I2 f( ]
/* Initialize BSL */9 _" j& e) s1 }# v% p& x% D5 P
EVMC6747_init( );
y& D7 ^; \2 q3 u /* Call evmc6747_intr function */, M3 t& P. C; {3 B3 W \8 u
aic3106_init( );
' M7 o" m8 U. k) K, E while(1);
& W* S1 q- |6 w/ @. l}
: ]* d/ B; ?' l K. |, H
) n6 c% Z4 ^/ g# N; G& V, T+ s- T
8 n/ t$ z: j |: c) t& W" `aic3106_init文件的一部分,McASP配置部分,采用内部时钟,I2S方式,同步传输。音频芯片的配置应该没问题
! u0 y0 E3 @; C+ x/ v: c/ }* @/* Initialize MCASP1 */4 Y" k: Q' s6 R) a. O
mcasp = &MCASP_MODULE_1;- ^ p$ ]; x* w8 r
mcasp->regs->GBLCTL = 0; // Reset0 O- @# e/ a Z% m( A6 {9 }' ^3 m
mcasp->regs->RGBLCTL = 0; // Reset RX# l6 X6 B% \7 j T/ |2 r
mcasp->regs->XGBLCTL = 0; // Reset TX* I# S$ O4 Y8 q( N0 C
mcasp->regs->PWRDEMU = 1; // Free-running
6 M3 u0 X7 C4 D& ~! E5 B // configure McASP0 receive registers$ y% K; w& Z' H3 T) O
mcasp->regs->RMASK = 0xFFFFFFFF; // No padding used
0 T% o {$ f( Z6 n# |$ C& W, [2 ~ mcasp->regs->RFMT = 0x00018078; // MSB 16bit, 0-delay, no pad, CFGBus
! [* c* I, T, \1 V& b mcasp->regs->AFSRCTL = 0x00000112; // 2TDM, 1bit Falling, External FS, word3 y# b0 Z% @) F
mcasp->regs->ACLKRCTL = 0x000000AF; // Rising INTERNAL CLK,(from tx side)0 ]! `; l, F$ \
mcasp->regs->AHCLKRCTL = 0x00000000; // INT CLK (from tx side)# n% I- y( [' ^% h' c: t9 |
mcasp->regs->RTDM = 0x00000003; // Slots 0,15 s, Y* I1 Z6 G9 P8 _" h
mcasp->regs->RINTCTL = 0x00000000; // Not used
. O. s! h- } E6 G/ V9 B+ K mcasp->regs->RCLKCHK = 0x00FF0008; // 255-MAX 0-MIN, div-by-256
, h# t1 ~6 }; [$ g" N- Z, ?
& P/ u1 k- m% Z6 K" W; v0 [ mcasp->regs->XMASK = 0xFFFFFFFF; // No padding used; S7 [5 d0 v- }6 }( L Q
mcasp->regs->XFMT = 0x00018078; // MSB 16bit, 0-delay, no pad, CFGBus3 a( x& b& Q- m3 k q6 i; G
mcasp->regs->AFSXCTL = 0x00000112; // 2TDM, 1bit Rising edge INTERNAL FS, word- g$ e1 ]1 M" o/ F4 }) T! R" ^
mcasp->regs->ACLKXCTL = 0x000000AF; // ASYNC, Rising INTERNAL CLK, div-by-16& Y0 b d/ d. U* |0 i( `6 c
mcasp->regs->AHCLKXCTL = 0x00000000; // EXT CLK# I# v& N+ A& E9 [2 j8 Q
mcasp->regs->XTDM = 0x00000003; // Slots 0,1
9 S6 I8 w( }+ G9 B mcasp->regs->XINTCTL = 0x00000020; // interrupt on transmit1 T& ?/ ^% d4 D. S- p
mcasp->regs->XCLKCHK = 0x00FF0008; // 255-MAX 0-MIN, div-by-256
* O" [* x( ?) e* z
9 r) g, c1 `0 s9 _4 X* W mcasp->regs->SRCTL5 = 0x000D; // MCASP1.AXR1[5] --> DIN
+ V* s5 F- S; p7 F) J mcasp->regs->SRCTL0 = 0x000E; // MCASP1.AXR1[0] <-- DOUT
2 O3 m! y( \% k0 d- @# G0 P mcasp->regs->PFUNC = 0; // All MCASPs+ E$ N% E- Q2 U& b2 C7 b
mcasp->regs->PDIR = 0x14000020; // All inputs except AXR0[5], ACLKX1, AFSX13 D8 m/ F B. O, g3 a& R t* _, Y
0 e2 y% ^& g; R2 I
mcasp->regs->DITCTL = 0x00000000; // Not used" m/ F: \# A4 _! \+ o/ ?9 n7 S
mcasp->regs->DLBCTL = 0x00000000; // Not used
) \) V) x5 j+ G mcasp->regs->AMUTE = 0x00000000; // Not used
% t* `3 y; @% e9 h2 k% U) K: g) i; r2 ^0 f& q
/* Starting sections of the McASP*/
: W" T+ Q( C" z mcasp->regs->XGBLCTL |= GBLCTL_XHCLKRST_ON; + Q; }1 A; f/ I& d d! D3 c' X
while ( ( mcasp->regs->XGBLCTL & GBLCTL_XHCLKRST_ON ) != GBLCTL_XHCLKRST_ON );
0 E4 f0 I* Z+ e9 k( l, _7 c+ y mcasp->regs->RGBLCTL |= GBLCTL_RHCLKRST_ON;
6 ^, O% x2 J$ }: @0 \$ z* f while ( ( mcasp->regs->RGBLCTL & GBLCTL_RHCLKRST_ON ) != GBLCTL_RHCLKRST_ON );/ |4 h# R) d4 f0 O. n
& v- J* y: X! s: ^8 Q" e9 y9 R
mcasp->regs->XGBLCTL |= GBLCTL_XCLKRST_ON;
: z6 h' c: B( C/ o3 ^ while ( ( mcasp->regs->XGBLCTL & GBLCTL_XCLKRST_ON ) != GBLCTL_XCLKRST_ON );2 X9 J- x1 p$ M d, p9 F+ L3 R
mcasp->regs->RGBLCTL |= GBLCTL_RCLKRST_ON;
& J+ f4 W" Y& i1 q" ^2 D while ( ( mcasp->regs->RGBLCTL & GBLCTL_RCLKRST_ON ) != GBLCTL_RCLKRST_ON );
; V- d8 z# |6 }2 ]4 Q# F& M# l5 u7 a
mcasp->regs->XSTAT = 0x0000ffff;
- h. O8 s M: @: E mcasp->regs->RSTAT = 0x0000ffff;
( Q) x' ^0 t4 @
3 O$ V* `. l$ x* d/ K: [3 ?2 J mcasp->regs->XGBLCTL |= GBLCTL_XSRCLR_ON;
4 B3 F! n- k' H5 G: ~ while ( ( mcasp->regs->XGBLCTL & GBLCTL_XSRCLR_ON ) != GBLCTL_XSRCLR_ON );# N: e4 h$ B w- c5 W0 I
mcasp->regs->RGBLCTL |= GBLCTL_RSRCLR_ON;
0 c* B. D7 F3 V& p6 A while ( ( mcasp->regs->RGBLCTL & GBLCTL_RSRCLR_ON ) != GBLCTL_RSRCLR_ON );
" M9 m1 w- c- F! a5 ]- K( V9 ]) L. X C. \
/* Write a 0, so that no underrun occurs after releasing the state machine */) ~6 Q. L1 Q. C1 Z) M
mcasp->regs->XBUF5 = 0;4 g0 x* g5 x$ U8 d7 T) K7 _/ N
mcasp->regs->RBUF0 = 0;! A; p1 I" ]9 v! W
2 h. Z) E ]% H; M
mcasp->regs->XGBLCTL |= GBLCTL_XSMRST_ON;
5 W5 x1 z* R7 U8 X2 ^ while ( ( mcasp->regs->XGBLCTL & GBLCTL_XSMRST_ON ) != GBLCTL_XSMRST_ON );
* p: V2 I" p$ W- B mcasp->regs->RGBLCTL |= GBLCTL_RSMRST_ON; . b3 b& Z' [& S W0 P1 p- b9 C+ S
while ( ( mcasp->regs->RGBLCTL & GBLCTL_RSMRST_ON ) != GBLCTL_RSMRST_ON );
$ @4 ?5 |0 l3 B+ ~
; ?. [5 F6 I& a# @# D( i mcasp->regs->XGBLCTL |= GBLCTL_XFRST_ON; 5 ]4 m1 ]2 v) s6 B
while ( ( mcasp->regs->XGBLCTL & GBLCTL_XFRST_ON ) != GBLCTL_XFRST_ON );& Z; u8 [' O& d: B( z3 Q: d
mcasp->regs->RGBLCTL |= GBLCTL_RFRST_ON;
9 \6 G7 Q3 V/ y/ r5 `3 F while ( ( mcasp->regs->RGBLCTL & GBLCTL_RFRST_ON ) != GBLCTL_RFRST_ON );
! q0 J! v4 Z% b5 ]2 U. M, p, C7 o/ R0 V& [& C
CSR = 0x0000;
! q3 Z+ K) O$ U) Z8 x" {* _& ] INTC_INTMUX1 = 0x3d;
* E+ t1 X6 p& |' a& V' u3 e1 W D ISTP = (unsigned int)vectors;
3 ?; S o* s6 |% T ICR = 0xFFF0; & m3 g6 v$ _# z. b( g
IER |= 0x12;
7 v) S' P! ^) a9 O CSR |= 0x01;
: }( X" ~4 h% [( n, D. w9 v
) l" _% O, u/ s- q- {+ V* W$ b' X
0 O1 {: K4 ^5 |
k$ |/ p$ ?3 K( d4 A6 \, ^. N还有就是两个输入输出函数:& |7 a) u. R8 @! [( i) e p3 N
void output_sample(Int32 out_data). Q! S6 W( t- U# n2 _+ l6 l6 x
{' `# u4 p# ~: o: W) d
AIC31_data.uint = out_data;
8 q b) N5 y- M! F* r# E MCASP1_XBUF5_32BIT = AIC31_data.uint;8 d; ~( \! Z' T. X1 z' U
}' Z/ L% d) Q! b
; \; Y9 E. a: g+ J+ z
Int32 input_sample(void)
5 N* \' {1 z. W- b{ 3 @. E, |0 _& s# l* d
AIC31_data.uint = MCASP1_RBUF0_32BIT;, z4 B5 `0 z* e6 x$ C& R+ h
return (AIC31_data.uint);( ~2 S, @0 T( H$ ?: @4 P1 R% a5 W
}0 a( K& D6 `# p) p* R; d4 J6 E6 |6 z: k
# O) ]0 R0 ?/ ?* e3 n |
|