|
|
C6747和C6748感觉差不多,我想实现McASP发送中断方式控制音频信号,在轮询的例程基础上改的,轮询程序可以实现,但是中断一直实现不了,也找不到错误,求大神帮忙!下边是主要程序:
6 O; F$ U, g0 F: Q! Vmain文件:
- ?9 }" ]- k6 h Pinterrupt void interrupt4(void) 0 K) Y* Z6 x) l0 d: p
{
/ B* ?' I# x4 Y% ^ Uint32 sample;
! e3 p3 d7 s9 o# m; F+ a5 R5 z& Z3 @8 |+ x9 ^5 i' Z4 V
sample = input_sample(); // read L + R samples from ADC, |0 \" O" }9 Q+ m6 M
output_sample(sample); // write L + R samples to DAC 4 ]2 Q3 a4 v6 j$ D* `% \, [( N" S8 f l
return;$ x, \; o6 b+ B/ f `, m y1 f4 u
}
) d X2 h* I. c- J: K1 j
K8 p' N6 d; ?! s/ n# [int main( void )
, m/ T4 y3 r# O2 d{
V8 K- V7 j, n
) i1 ^( ?9 `# S$ ]! t# v( L /* Initialize BSL */
6 o/ s* u6 W8 U6 w EVMC6747_init( );
$ e' N' | k. l /* Call evmc6747_intr function */
' m* X8 I0 @) O5 M9 k/ L aic3106_init( );
6 {& I: `: D& N7 F* n' J7 h while(1);! e7 i0 z4 y( }/ c7 ^. ~8 j. ^( {; y+ l3 U
}6 i/ O" H" }. J$ e) p8 v; M
, j9 C$ s8 V6 z, G, B3 i1 V) e
% A' q9 ?: ?3 W" F1 J
aic3106_init文件的一部分,McASP配置部分,采用内部时钟,I2S方式,同步传输。音频芯片的配置应该没问题
- [# h# _+ P5 Z/ C/* Initialize MCASP1 */* u( }, i' q; A+ N, N# x4 }
mcasp = &MCASP_MODULE_1;+ w! |9 b0 s& w+ K b" X
mcasp->regs->GBLCTL = 0; // Reset
+ \/ ^ V* W+ ? Z mcasp->regs->RGBLCTL = 0; // Reset RX( X+ R( Y u4 g0 E' R A; l
mcasp->regs->XGBLCTL = 0; // Reset TX
# v6 A4 w& L3 |' d! | mcasp->regs->PWRDEMU = 1; // Free-running e2 O% G3 @% w) G
// configure McASP0 receive registers1 ?; ^$ e3 \3 Q) q1 ?6 H5 K
mcasp->regs->RMASK = 0xFFFFFFFF; // No padding used- V, p6 r/ b( ^1 b! {$ U2 ?7 b5 z
mcasp->regs->RFMT = 0x00018078; // MSB 16bit, 0-delay, no pad, CFGBus
4 h. W6 o2 ~* j) Q) x; ~ mcasp->regs->AFSRCTL = 0x00000112; // 2TDM, 1bit Falling, External FS, word
! F: U: G" v, F e mcasp->regs->ACLKRCTL = 0x000000AF; // Rising INTERNAL CLK,(from tx side)' i* n# T0 _( l3 {( |
mcasp->regs->AHCLKRCTL = 0x00000000; // INT CLK (from tx side)
$ Z$ w) n) T! u1 P' L mcasp->regs->RTDM = 0x00000003; // Slots 0,10 I z% K& L( ^* Z
mcasp->regs->RINTCTL = 0x00000000; // Not used' ]# Z0 {/ |# A. _$ U, X) K+ \
mcasp->regs->RCLKCHK = 0x00FF0008; // 255-MAX 0-MIN, div-by-2562 e6 e- q. }+ ?3 j* E' G# r
w( v: N6 R" F* y; d1 x; r& `
mcasp->regs->XMASK = 0xFFFFFFFF; // No padding used
; c$ s- |/ z, @: V, z5 y3 a0 W mcasp->regs->XFMT = 0x00018078; // MSB 16bit, 0-delay, no pad, CFGBus/ t9 a3 o. Z- u: O
mcasp->regs->AFSXCTL = 0x00000112; // 2TDM, 1bit Rising edge INTERNAL FS, word- n: O: r: d: }: `0 ]
mcasp->regs->ACLKXCTL = 0x000000AF; // ASYNC, Rising INTERNAL CLK, div-by-16! g! s# V/ Y! D4 ]
mcasp->regs->AHCLKXCTL = 0x00000000; // EXT CLK* K9 H, {7 C) Y
mcasp->regs->XTDM = 0x00000003; // Slots 0,1
6 R. U4 w0 x+ x/ v% Q* \7 T mcasp->regs->XINTCTL = 0x00000020; // interrupt on transmit
: i# E/ ]& e. z7 I6 J( q' |: y mcasp->regs->XCLKCHK = 0x00FF0008; // 255-MAX 0-MIN, div-by-256
0 t+ Z4 o, \3 V8 A; V; M" W# Y6 u
mcasp->regs->SRCTL5 = 0x000D; // MCASP1.AXR1[5] --> DIN
! }' Q0 F2 c: `, s* q% ? mcasp->regs->SRCTL0 = 0x000E; // MCASP1.AXR1[0] <-- DOUT
! s d6 w1 ^) _7 ~& R1 h `$ o mcasp->regs->PFUNC = 0; // All MCASPs
- i/ W4 S# ^; ^. S8 L mcasp->regs->PDIR = 0x14000020; // All inputs except AXR0[5], ACLKX1, AFSX1& b# A. T% q) r5 Q h D% |, U
# x" b0 {0 b6 g* F# a7 s
mcasp->regs->DITCTL = 0x00000000; // Not used
- [/ e3 O4 R2 B+ N* s0 q0 p$ f& G mcasp->regs->DLBCTL = 0x00000000; // Not used
]# J7 J# U! U# {5 m" E. |2 f1 B: b mcasp->regs->AMUTE = 0x00000000; // Not used4 U" r& _0 q+ M+ D. a5 h2 x4 E
1 r S2 ^) z! f* b/* Starting sections of the McASP*/
0 j2 K; Q0 B5 h6 T mcasp->regs->XGBLCTL |= GBLCTL_XHCLKRST_ON; 1 q6 [, f( b- [* X7 \" A
while ( ( mcasp->regs->XGBLCTL & GBLCTL_XHCLKRST_ON ) != GBLCTL_XHCLKRST_ON ); * s6 J1 X E* s4 ~8 `4 q4 p; \) f+ |
mcasp->regs->RGBLCTL |= GBLCTL_RHCLKRST_ON; : u7 H: y5 z8 \, A0 e" M5 f
while ( ( mcasp->regs->RGBLCTL & GBLCTL_RHCLKRST_ON ) != GBLCTL_RHCLKRST_ON );8 f6 r* w2 r4 y7 @+ n+ C' M6 b
0 a* {' o% h, A2 ^# s7 H$ x mcasp->regs->XGBLCTL |= GBLCTL_XCLKRST_ON;
4 V4 m( O* @2 h h while ( ( mcasp->regs->XGBLCTL & GBLCTL_XCLKRST_ON ) != GBLCTL_XCLKRST_ON );
9 ]" v2 a9 \0 R" Q* f' y( h" a1 d mcasp->regs->RGBLCTL |= GBLCTL_RCLKRST_ON;
% T, F, @' j$ P6 U0 | while ( ( mcasp->regs->RGBLCTL & GBLCTL_RCLKRST_ON ) != GBLCTL_RCLKRST_ON );; |) V X5 M) A ]5 ~5 G
6 E6 Q& X( q. y" o" o" @2 X
mcasp->regs->XSTAT = 0x0000ffff; 7 o8 R1 M* h. e! Q, ]4 Y. u: V
mcasp->regs->RSTAT = 0x0000ffff;
L0 E/ p) X( f( Q3 Z. \9 C$ o! _0 \* R1 `
mcasp->regs->XGBLCTL |= GBLCTL_XSRCLR_ON;/ V! e# w* U& X" D1 O/ n7 B
while ( ( mcasp->regs->XGBLCTL & GBLCTL_XSRCLR_ON ) != GBLCTL_XSRCLR_ON );* M8 h; o4 b6 Z; {
mcasp->regs->RGBLCTL |= GBLCTL_RSRCLR_ON;
" ~0 m9 V, D) p# C* `9 d while ( ( mcasp->regs->RGBLCTL & GBLCTL_RSRCLR_ON ) != GBLCTL_RSRCLR_ON );' @; z. T! u2 B7 N2 C/ G
+ ?7 O5 _# a0 |' O2 t+ b- v3 S
/* Write a 0, so that no underrun occurs after releasing the state machine */" i$ v' ]7 g& P. x: O2 o$ O7 C: W
mcasp->regs->XBUF5 = 0;* c3 b6 U& U" S# H' s
mcasp->regs->RBUF0 = 0;$ b& ?0 \5 o a- M" ?1 K$ i
6 A& m# E3 S/ f mcasp->regs->XGBLCTL |= GBLCTL_XSMRST_ON;
7 Q1 x. v' k7 S- B+ j9 [5 a while ( ( mcasp->regs->XGBLCTL & GBLCTL_XSMRST_ON ) != GBLCTL_XSMRST_ON );. y. [$ v) O3 c, V* e$ d0 m
mcasp->regs->RGBLCTL |= GBLCTL_RSMRST_ON;
2 h% f" h8 @ N! |& H1 x" ]2 \8 l while ( ( mcasp->regs->RGBLCTL & GBLCTL_RSMRST_ON ) != GBLCTL_RSMRST_ON );& E9 P2 }4 n8 g/ t
6 h ^. P! ~9 X, S4 H5 b mcasp->regs->XGBLCTL |= GBLCTL_XFRST_ON; $ B0 A: K. J; M# Q
while ( ( mcasp->regs->XGBLCTL & GBLCTL_XFRST_ON ) != GBLCTL_XFRST_ON );
5 y$ k$ O) m% W+ | mcasp->regs->RGBLCTL |= GBLCTL_RFRST_ON; 1 t; C. L* S! h! r: S
while ( ( mcasp->regs->RGBLCTL & GBLCTL_RFRST_ON ) != GBLCTL_RFRST_ON );# `8 j+ g5 S" J1 N0 H5 H
. o) U- Q2 R/ i; A CSR = 0x0000;
0 ^7 e2 {+ x) `$ i. d& d) b' b/ v INTC_INTMUX1 = 0x3d;
; ]/ X0 X" ~! c. J ISTP = (unsigned int)vectors;
7 ^3 E [! R; q6 n* ]( t. G3 P' @ ICR = 0xFFF0; : ^7 Q5 }# {2 Y' I' }% i
IER |= 0x12; 5 l1 j4 \4 X, n _8 w3 {
CSR |= 0x01;
6 d0 S" _+ o. T, M7 o) O( S8 s
' d- J% J8 f) s1 k# X
. Z0 i3 S" k0 m! N# W- _/ Y. x; h0 G
8 R" R- q! \$ j- v% i5 ^& A还有就是两个输入输出函数:0 J* b+ Z7 w: u
void output_sample(Int32 out_data)* u) b) N& S5 T ~
{$ {$ f) v( ?% _+ L
AIC31_data.uint = out_data; # O W8 `& c u3 c- J2 T
MCASP1_XBUF5_32BIT = AIC31_data.uint;7 C B0 o1 f1 X2 h, y1 a
}2 S- N2 g6 L; U1 H, B7 `8 l
# J& q0 W! t0 i5 T" U+ T# F
Int32 input_sample(void)$ c. S. `' P) S f: l! w
{
8 _8 R9 x, k+ ^6 x3 ~& t0 J) v AIC31_data.uint = MCASP1_RBUF0_32BIT;
7 S, |6 x- k! Z1 e1 } return (AIC31_data.uint);4 T3 E8 A2 y: _( W1 s
}7 h& z6 o: ^6 @/ { t. `! J2 m: M
) P H. ?8 x7 F! O7 u
|
|