|
|
C6747和C6748感觉差不多,我想实现McASP发送中断方式控制音频信号,在轮询的例程基础上改的,轮询程序可以实现,但是中断一直实现不了,也找不到错误,求大神帮忙!下边是主要程序:
) Q: z9 J% p9 Z$ K; E C; Hmain文件:
# r! y+ ~2 C3 d; b7 pinterrupt void interrupt4(void) 1 A( w, a0 P" @+ K) l0 `8 I: a& |
{" @$ `, h5 D6 o W* ~% K
Uint32 sample;1 P7 j- Y% O! n! L
) j6 K3 b0 F# A. |! {* a& Y5 N sample = input_sample(); // read L + R samples from ADC8 J# w* H& J% `, l& O0 Q- f: R
output_sample(sample); // write L + R samples to DAC
. h/ k" f% p% Q2 o7 `* I9 Q6 X return;
% _1 I. M0 F! B. {4 V6 h$ W}8 B9 u0 Y% d3 @; t' W! W2 v/ z
$ W4 x/ b$ E$ E4 L6 |7 V3 Mint main( void )
4 X3 n: ?/ E$ i# O{
2 B, Z- f" {9 b6 S+ N" K m+ t2 G9 _. ]. T& T& T( K. p2 L
/* Initialize BSL */
/ d; c$ [$ h0 B" e% ~ EVMC6747_init( );5 \0 F" U% r; K! i$ K% Y& V# H, ?
/* Call evmc6747_intr function */! w' F/ V1 v* C& f- J& h0 y' P, X- e
aic3106_init( );
* |" P$ u$ Y1 j1 K U while(1);* ~" h2 U% o7 I! f: h6 F6 q, L5 X
}6 ?4 `% M8 s- U! C8 z) R" X$ G
% x* v, g# B" Z- K1 j, R
3 A5 l: _; W9 @* e; P# B' _0 Z/ daic3106_init文件的一部分,McASP配置部分,采用内部时钟,I2S方式,同步传输。音频芯片的配置应该没问题3 s8 }$ p0 ^* r/ a! P. A* |
/* Initialize MCASP1 */
9 s% I" g/ H5 B, v/ q: a% e mcasp = &MCASP_MODULE_1;! k8 j5 c9 `6 J5 W
mcasp->regs->GBLCTL = 0; // Reset
3 q" O% m3 \# F- d% a mcasp->regs->RGBLCTL = 0; // Reset RX
3 f$ V( x5 q1 {) x# o3 U mcasp->regs->XGBLCTL = 0; // Reset TX0 c" b8 m8 m/ o$ A1 B
mcasp->regs->PWRDEMU = 1; // Free-running
4 ?2 S' o4 N' g) @ // configure McASP0 receive registers2 V; t1 m, H- [' H2 \; o+ z, B; r
mcasp->regs->RMASK = 0xFFFFFFFF; // No padding used4 ^. X( i9 s6 w A& j- c
mcasp->regs->RFMT = 0x00018078; // MSB 16bit, 0-delay, no pad, CFGBus9 p( w& s" X( k
mcasp->regs->AFSRCTL = 0x00000112; // 2TDM, 1bit Falling, External FS, word! `/ q! |: ^2 S1 J. h5 |
mcasp->regs->ACLKRCTL = 0x000000AF; // Rising INTERNAL CLK,(from tx side)
% p' r4 N. C6 D& y mcasp->regs->AHCLKRCTL = 0x00000000; // INT CLK (from tx side)2 O0 K9 |% \% S) d
mcasp->regs->RTDM = 0x00000003; // Slots 0,1
' G; @/ M9 G# M$ { mcasp->regs->RINTCTL = 0x00000000; // Not used4 F+ L Y3 a5 M* }' ?9 @
mcasp->regs->RCLKCHK = 0x00FF0008; // 255-MAX 0-MIN, div-by-256/ B& l4 s+ u, Z
$ d# G) a% h$ ]# L D
mcasp->regs->XMASK = 0xFFFFFFFF; // No padding used
) _3 B1 u+ B7 O4 P) ~ mcasp->regs->XFMT = 0x00018078; // MSB 16bit, 0-delay, no pad, CFGBus! j- S, C) z; c5 S% |8 l2 Y
mcasp->regs->AFSXCTL = 0x00000112; // 2TDM, 1bit Rising edge INTERNAL FS, word
0 E, Z( }1 f/ y6 p mcasp->regs->ACLKXCTL = 0x000000AF; // ASYNC, Rising INTERNAL CLK, div-by-16
8 R( h. A' c8 L( n' v3 q; N( r mcasp->regs->AHCLKXCTL = 0x00000000; // EXT CLK
) Z5 X7 t5 t0 r7 p; \ mcasp->regs->XTDM = 0x00000003; // Slots 0,1
^0 ^5 j/ l) u* |6 ]/ Q6 o mcasp->regs->XINTCTL = 0x00000020; // interrupt on transmit- H! y/ R6 W1 n% C
mcasp->regs->XCLKCHK = 0x00FF0008; // 255-MAX 0-MIN, div-by-256: C' r \6 D! i; i/ e, }6 L
& ?# q/ z. Z" L0 m. y) z# c( Z5 H: g
mcasp->regs->SRCTL5 = 0x000D; // MCASP1.AXR1[5] --> DIN! F s/ `& ?7 b* s. {3 J# }
mcasp->regs->SRCTL0 = 0x000E; // MCASP1.AXR1[0] <-- DOUT. {8 y" B1 f- C2 X# W" m' ~
mcasp->regs->PFUNC = 0; // All MCASPs
4 o3 U! D( o% e$ m. l$ \ mcasp->regs->PDIR = 0x14000020; // All inputs except AXR0[5], ACLKX1, AFSX1; m" R+ P% p; K
6 \; b) Q4 p+ Y' d. t$ ^% T: w mcasp->regs->DITCTL = 0x00000000; // Not used
: s- U* [& V8 Z2 v- C# a' ? mcasp->regs->DLBCTL = 0x00000000; // Not used
" ~, n% z9 ~9 ~) m0 c* o mcasp->regs->AMUTE = 0x00000000; // Not used& M$ \3 y% v2 F
1 H- U0 ~( l/ w1 r$ c0 `
/* Starting sections of the McASP*/
! y* A. x/ l9 _; I6 Q4 X* ] mcasp->regs->XGBLCTL |= GBLCTL_XHCLKRST_ON;
5 X/ F. \, ~, W" y while ( ( mcasp->regs->XGBLCTL & GBLCTL_XHCLKRST_ON ) != GBLCTL_XHCLKRST_ON );
( U. u/ }% v( I1 @ mcasp->regs->RGBLCTL |= GBLCTL_RHCLKRST_ON;
$ X. I) V4 P" C9 E# Q" d6 v while ( ( mcasp->regs->RGBLCTL & GBLCTL_RHCLKRST_ON ) != GBLCTL_RHCLKRST_ON );
5 s9 y' \4 ^: q3 F7 i1 i# T, }, [ U/ P x/ J% v5 |. V
mcasp->regs->XGBLCTL |= GBLCTL_XCLKRST_ON; : |" Q7 s( `; P/ n( S7 y1 V
while ( ( mcasp->regs->XGBLCTL & GBLCTL_XCLKRST_ON ) != GBLCTL_XCLKRST_ON );
: n5 Z. }/ E. t mcasp->regs->RGBLCTL |= GBLCTL_RCLKRST_ON; ! \/ g& H: P7 e! T* X2 c
while ( ( mcasp->regs->RGBLCTL & GBLCTL_RCLKRST_ON ) != GBLCTL_RCLKRST_ON );* s/ T& S6 w3 z0 {
6 C& Y# ]: `+ _( k
mcasp->regs->XSTAT = 0x0000ffff; * P5 C% {) ]2 ]4 S( g! T3 g4 j/ z( U
mcasp->regs->RSTAT = 0x0000ffff; . I- C% G* _9 r
5 e$ }3 }1 C; n' k- `$ u
mcasp->regs->XGBLCTL |= GBLCTL_XSRCLR_ON;
! K( B" v e; t I+ h while ( ( mcasp->regs->XGBLCTL & GBLCTL_XSRCLR_ON ) != GBLCTL_XSRCLR_ON );
& U8 p/ l7 L8 Z5 U( }. G4 G% r mcasp->regs->RGBLCTL |= GBLCTL_RSRCLR_ON;
) S5 k8 k; m: y) D while ( ( mcasp->regs->RGBLCTL & GBLCTL_RSRCLR_ON ) != GBLCTL_RSRCLR_ON );2 p5 r# x) F6 a6 w
8 C) I/ l5 {% H4 |' V7 f ?9 u /* Write a 0, so that no underrun occurs after releasing the state machine */
) ?& x$ Y3 Q6 ~7 {6 ~" d mcasp->regs->XBUF5 = 0; L/ k9 k# N: \3 ^& Y
mcasp->regs->RBUF0 = 0;
% [! k; d$ U Q! g. c" p0 ~ Y# @) d+ W+ c2 }
mcasp->regs->XGBLCTL |= GBLCTL_XSMRST_ON; / L2 j4 u2 [+ T h0 u9 Y+ q* V
while ( ( mcasp->regs->XGBLCTL & GBLCTL_XSMRST_ON ) != GBLCTL_XSMRST_ON );
. q8 o* N8 L/ @5 P2 J- V: T& ? mcasp->regs->RGBLCTL |= GBLCTL_RSMRST_ON; 5 P2 `9 p+ X8 m# _- r' ^
while ( ( mcasp->regs->RGBLCTL & GBLCTL_RSMRST_ON ) != GBLCTL_RSMRST_ON );2 |1 `$ u- h+ a
3 u& l2 {8 |5 W+ w' }. \: M
mcasp->regs->XGBLCTL |= GBLCTL_XFRST_ON; 8 M3 T- ^7 o0 B
while ( ( mcasp->regs->XGBLCTL & GBLCTL_XFRST_ON ) != GBLCTL_XFRST_ON );
! B8 t8 B1 S u' c! B) C' J mcasp->regs->RGBLCTL |= GBLCTL_RFRST_ON; # Y- _/ k/ E4 ] _: x7 v
while ( ( mcasp->regs->RGBLCTL & GBLCTL_RFRST_ON ) != GBLCTL_RFRST_ON );3 T; O: m$ x/ t0 s* u
`3 O3 O9 F, x% A- n" U CSR = 0x0000;) e3 J$ ~( p3 [0 n6 [) b. R
INTC_INTMUX1 = 0x3d;
% F% \6 [% u5 p; ?5 u* R/ H" [9 ]3 l, R ISTP = (unsigned int)vectors;. n$ c7 D# s7 ?) e/ p' s) s8 |
ICR = 0xFFF0;
$ s2 A0 p* n6 b2 `+ x9 Y IER |= 0x12;
2 Z9 |9 X/ v4 o) N4 y CSR |= 0x01;
- L2 f* B# ^& q6 c& \" S5 f
! b0 M' h# T2 E/ C3 M9 Y3 q% m7 m/ U3 Q- V% P, Z$ U; J
! N# ~& h* D- X! n& [: Y) k7 g! H
还有就是两个输入输出函数:) C! }" s0 x2 F
void output_sample(Int32 out_data)
5 F$ O. T, G" ]5 k" \# X4 T& k& z{
; e4 U4 K6 x2 Z4 Q! E4 r& p AIC31_data.uint = out_data;
1 S! G5 D5 H2 _ MCASP1_XBUF5_32BIT = AIC31_data.uint;- a: n9 q5 W, n9 c, v" S
}
5 W% b7 D3 z' A+ b6 M
, u k! c, r e2 }' L/ E" [/ ZInt32 input_sample(void)" n' x9 K6 @5 g- \
{ ' l: G$ n: m5 }6 W5 Z4 G
AIC31_data.uint = MCASP1_RBUF0_32BIT;
* _) F: z) [" }+ s; D7 N0 M: K$ ] return (AIC31_data.uint);+ p$ K; D, I5 [; z
}
9 \' p/ n# O$ y# _5 l2 p: q, r) H0 B2 S6 t
|
|