|
C6747和C6748感觉差不多,我想实现McASP发送中断方式控制音频信号,在轮询的例程基础上改的,轮询程序可以实现,但是中断一直实现不了,也找不到错误,求大神帮忙!下边是主要程序:( l2 M( D# G" c3 w, C! O
main文件:8 G# H: m! I- I; o
interrupt void interrupt4(void) / s% X N% ]$ W( l( w: @$ }
{
; X, P& i" a. z% p U7 ]! k1 Q, T Uint32 sample;
9 A) S4 }5 L7 Z+ U0 T) B' g$ k: U; Q
sample = input_sample(); // read L + R samples from ADC
$ Y% B# _7 Q# \1 T* a+ T output_sample(sample); // write L + R samples to DAC
! W6 \% M0 _8 }; {" ~ return;+ z3 a @; }6 M1 s) {% R
} K( e! B* l N5 K) @9 u
0 C* o2 e5 j% Q# @& w" wint main( void ); D8 G0 a9 f5 v
{
* V4 ?( D9 X. [2 T. C4 | M/ `9 y i2 D
/* Initialize BSL */& A" N) W, ^5 w
EVMC6747_init( );
6 P& T! Q+ m$ s /* Call evmc6747_intr function */9 i, {# O8 P- U* [6 g# L( ~3 T4 ~3 t
aic3106_init( );0 e; h* p( \6 m8 c: S
while(1);
+ o& N3 i( G1 e8 N8 Y}4 P% M- g0 H5 f& s
5 u( Z% `" N% I' n, a! |2 y
3 m5 R5 Q5 o7 k7 saic3106_init文件的一部分,McASP配置部分,采用内部时钟,I2S方式,同步传输。音频芯片的配置应该没问题
* @7 W- l/ |1 Q6 Y: B/* Initialize MCASP1 */2 N3 K! G) V; N& |
mcasp = &MCASP_MODULE_1;) j5 R4 {4 T* H2 \% p. z
mcasp->regs->GBLCTL = 0; // Reset7 K3 Z) O- I+ o
mcasp->regs->RGBLCTL = 0; // Reset RX
2 g8 V4 b; v- }/ C: S% }1 w& N mcasp->regs->XGBLCTL = 0; // Reset TX6 N& J' K8 \* w, Y
mcasp->regs->PWRDEMU = 1; // Free-running
7 s, b6 p5 h; _0 z // configure McASP0 receive registers
# B4 F+ D! [, x& a; a mcasp->regs->RMASK = 0xFFFFFFFF; // No padding used; W* y5 G2 ?$ e" L5 K3 ~5 v
mcasp->regs->RFMT = 0x00018078; // MSB 16bit, 0-delay, no pad, CFGBus" z# ~& {% H4 x2 s7 p
mcasp->regs->AFSRCTL = 0x00000112; // 2TDM, 1bit Falling, External FS, word: ?2 U& M+ Q1 e4 V3 `* _
mcasp->regs->ACLKRCTL = 0x000000AF; // Rising INTERNAL CLK,(from tx side)# p, s* t5 L5 o8 V' @
mcasp->regs->AHCLKRCTL = 0x00000000; // INT CLK (from tx side)
) b5 S, w% @0 M3 z% {2 Q( @ mcasp->regs->RTDM = 0x00000003; // Slots 0,1, C( R7 k! ^. r8 o% a6 n
mcasp->regs->RINTCTL = 0x00000000; // Not used
: ]9 k5 a; R9 \8 g- [ mcasp->regs->RCLKCHK = 0x00FF0008; // 255-MAX 0-MIN, div-by-256
5 H: A, Z5 U- _, _) |2 S6 ?% Z [ E
4 p- N" k3 ]$ e2 T- M mcasp->regs->XMASK = 0xFFFFFFFF; // No padding used
! W2 p' V: c3 R% V# K# @ mcasp->regs->XFMT = 0x00018078; // MSB 16bit, 0-delay, no pad, CFGBus
) j$ O P4 ^6 _$ o7 @" a- a$ F mcasp->regs->AFSXCTL = 0x00000112; // 2TDM, 1bit Rising edge INTERNAL FS, word g; }% u6 ^$ c! s6 W
mcasp->regs->ACLKXCTL = 0x000000AF; // ASYNC, Rising INTERNAL CLK, div-by-16) j+ T, Z: N2 }5 X2 X$ w& a
mcasp->regs->AHCLKXCTL = 0x00000000; // EXT CLK
* g7 g7 h& k ]3 H3 }& D5 \ mcasp->regs->XTDM = 0x00000003; // Slots 0,1
$ B* f" O0 d; F% e mcasp->regs->XINTCTL = 0x00000020; // interrupt on transmit
0 ~3 S( b4 L) M; V7 v K mcasp->regs->XCLKCHK = 0x00FF0008; // 255-MAX 0-MIN, div-by-256
; z. y4 z' S3 A X0 ?/ K- a7 ^6 d, L( [- j) G4 G& i
mcasp->regs->SRCTL5 = 0x000D; // MCASP1.AXR1[5] --> DIN
; L5 y) c! s; y1 Y5 R8 Y9 i3 {' r mcasp->regs->SRCTL0 = 0x000E; // MCASP1.AXR1[0] <-- DOUT
3 z$ w4 v+ L: y& i3 S3 l t mcasp->regs->PFUNC = 0; // All MCASPs0 g6 d+ I3 g$ c$ j
mcasp->regs->PDIR = 0x14000020; // All inputs except AXR0[5], ACLKX1, AFSX1
, i0 K0 n) i e' J+ E. _4 X9 h$ w/ z/ \! X: {
mcasp->regs->DITCTL = 0x00000000; // Not used
* m. M1 k8 r% V5 j# Y q2 }6 t mcasp->regs->DLBCTL = 0x00000000; // Not used
+ f3 o! \6 n0 n9 ~8 j mcasp->regs->AMUTE = 0x00000000; // Not used
( t7 F& f) A/ P) q7 [" z1 M
$ [$ v9 L G) N4 ?" d/* Starting sections of the McASP*/( U; z* k8 h# K/ O4 l' m
mcasp->regs->XGBLCTL |= GBLCTL_XHCLKRST_ON; ' ~- R, o. R. q- U
while ( ( mcasp->regs->XGBLCTL & GBLCTL_XHCLKRST_ON ) != GBLCTL_XHCLKRST_ON );
& j- M. F. B% l# | mcasp->regs->RGBLCTL |= GBLCTL_RHCLKRST_ON;
7 k$ ]0 w) w# [( t- q while ( ( mcasp->regs->RGBLCTL & GBLCTL_RHCLKRST_ON ) != GBLCTL_RHCLKRST_ON ); Y$ h# g- {+ S+ X1 {/ {
& V/ B% x" t+ ~ U1 S5 i8 C: W: B mcasp->regs->XGBLCTL |= GBLCTL_XCLKRST_ON; ! {7 X, D( h% B, l# B& Z2 U
while ( ( mcasp->regs->XGBLCTL & GBLCTL_XCLKRST_ON ) != GBLCTL_XCLKRST_ON );
2 r) t# F' E/ g5 D+ d7 C% @ mcasp->regs->RGBLCTL |= GBLCTL_RCLKRST_ON;
6 u* _$ S0 s( v. K5 @, h( r while ( ( mcasp->regs->RGBLCTL & GBLCTL_RCLKRST_ON ) != GBLCTL_RCLKRST_ON );% M/ E8 @6 F$ S7 E' T( p, T1 R" `& ^7 b0 T
1 t# S9 M, Q6 _2 A
mcasp->regs->XSTAT = 0x0000ffff;
8 \& D% H0 y3 O( l mcasp->regs->RSTAT = 0x0000ffff; $ w, `8 B1 E9 L$ x" m: o9 W& S
, G* X4 C& g0 @6 _ mcasp->regs->XGBLCTL |= GBLCTL_XSRCLR_ON;
+ \0 T% l9 R5 Z9 V0 @6 k& ~$ F while ( ( mcasp->regs->XGBLCTL & GBLCTL_XSRCLR_ON ) != GBLCTL_XSRCLR_ON );
: k# M! N7 Y2 f, m4 F( a mcasp->regs->RGBLCTL |= GBLCTL_RSRCLR_ON; 4 I. l$ [* m$ i( X# c2 E. n! U
while ( ( mcasp->regs->RGBLCTL & GBLCTL_RSRCLR_ON ) != GBLCTL_RSRCLR_ON );# u- @. e u9 M% n& U9 T, D6 p
# u/ g! v9 x0 J" X
/* Write a 0, so that no underrun occurs after releasing the state machine */. @& Q( [! I* D8 ~3 Y
mcasp->regs->XBUF5 = 0;
6 a- t+ X! H, S& c' N) O7 R mcasp->regs->RBUF0 = 0;' k9 f5 L) H2 ?0 i
' d j9 j" [+ e' |" i
mcasp->regs->XGBLCTL |= GBLCTL_XSMRST_ON;
- c3 N& w' |" V/ N4 t1 z) O. w while ( ( mcasp->regs->XGBLCTL & GBLCTL_XSMRST_ON ) != GBLCTL_XSMRST_ON );% U7 W* T& R/ k2 l
mcasp->regs->RGBLCTL |= GBLCTL_RSMRST_ON;
8 J; V8 `0 \0 L1 k4 @1 Q while ( ( mcasp->regs->RGBLCTL & GBLCTL_RSMRST_ON ) != GBLCTL_RSMRST_ON );1 d$ m$ N2 B! S& \8 }
! [2 f& r6 K" s, S j' @ mcasp->regs->XGBLCTL |= GBLCTL_XFRST_ON;
1 a5 ]" T/ N+ j. S, D& P while ( ( mcasp->regs->XGBLCTL & GBLCTL_XFRST_ON ) != GBLCTL_XFRST_ON );" E3 e( E* E! V/ V- ^
mcasp->regs->RGBLCTL |= GBLCTL_RFRST_ON;
9 x1 X8 m2 F- j$ Z4 g+ V while ( ( mcasp->regs->RGBLCTL & GBLCTL_RFRST_ON ) != GBLCTL_RFRST_ON );* h3 X* y" y1 p# w- K b% T6 W. R% u3 @
& m B) F8 @( g1 m# o5 X1 Z; w
CSR = 0x0000;
' Q# |- a2 e0 K INTC_INTMUX1 = 0x3d;, h1 s* r @$ F; _0 u* ]8 f
ISTP = (unsigned int)vectors;) C" A& k o4 X! y- N \7 b3 A4 a
ICR = 0xFFF0; 1 U) q7 j$ ?5 k* w1 N. T
IER |= 0x12; ! n( O1 }4 B, M8 c! Q: P" O
CSR |= 0x01;
Q, W |7 T& m8 F
+ A; [/ Z: ]6 ~# m0 y6 l% t
1 Z$ h5 ~0 C8 n) r
1 B! E1 p$ j1 B m! t; t还有就是两个输入输出函数:
" G$ j* f9 }% S1 v1 I$ \void output_sample(Int32 out_data)
" `6 y$ Q0 h- B! l4 O, `{
1 R6 Q' I" q2 p4 i/ `" e AIC31_data.uint = out_data; * \7 m( x- s. s- f# ?, X' g: k
MCASP1_XBUF5_32BIT = AIC31_data.uint;
3 @; g* }. ^' N8 I% Z}! a2 h" j( U* o; M. f
) {, D+ i( e7 G3 M6 m2 OInt32 input_sample(void)4 e8 I2 Z( v) R5 j
{ 4 n6 m! U9 Q% @
AIC31_data.uint = MCASP1_RBUF0_32BIT;
1 P, H% r9 R0 D; N9 F2 c return (AIC31_data.uint);+ k6 Q+ a* N1 _- Z3 \6 g
}+ X O, i5 y1 U+ c$ h3 X8 X
' X4 y' Y/ W0 M5 O |
|