|
|
C6747和C6748感觉差不多,我想实现McASP发送中断方式控制音频信号,在轮询的例程基础上改的,轮询程序可以实现,但是中断一直实现不了,也找不到错误,求大神帮忙!下边是主要程序:% {2 a' a( D# G* z& W$ w
main文件:
( |) B0 g! I. @% Pinterrupt void interrupt4(void)
+ b; e7 t% u/ @' d0 F3 t! a9 ^; ?/ O{- a6 A" q# S, ]& {) M
Uint32 sample;
, q6 ~: O8 u2 g d1 x+ u; E) B; ^0 y8 ^! ^" p! \1 Q
sample = input_sample(); // read L + R samples from ADC: ?4 `. ?+ G, o4 z, j' g6 M8 `
output_sample(sample); // write L + R samples to DAC ( u$ W3 f* M7 K
return;2 J: V3 w6 g1 K# ?$ H) d: i
}. p- V( x. T% l# E! X" R
! ~2 M3 o& C3 v) w4 Z6 hint main( void )2 d% ?1 D: Q% D- B6 b
{
! ^* J) H: P; V& }6 e
, V3 }& b1 K) P/ } H1 g) ] /* Initialize BSL */
/ |! ^- N. n& u. \ EVMC6747_init( );
. N& t, |: `# V5 Z7 M% B- q* i /* Call evmc6747_intr function */, U# y' m. N3 [* t; j6 U7 |' p. C* R
aic3106_init( );- S- _ v" b' T
while(1);3 V7 ?% w* u* { j
}$ F/ [6 Q: G' k. j2 D. g' T
0 V1 P4 S* ~9 y3 `+ ]2 d; t9 X/ z6 A& O2 F. y% {; Q
aic3106_init文件的一部分,McASP配置部分,采用内部时钟,I2S方式,同步传输。音频芯片的配置应该没问题
+ Q& Z; F. O1 N6 i/* Initialize MCASP1 */
2 @4 u E) t# R' z( @7 V mcasp = &MCASP_MODULE_1;6 x4 q$ r' P+ W: |
mcasp->regs->GBLCTL = 0; // Reset
. q7 o& w: Q6 U w3 e8 c3 b, D mcasp->regs->RGBLCTL = 0; // Reset RX5 a8 ?6 e7 E( f/ n7 `; m% j
mcasp->regs->XGBLCTL = 0; // Reset TX/ n4 ^7 @- q6 E* A* S3 v! w
mcasp->regs->PWRDEMU = 1; // Free-running6 h, Y5 J. L& O0 d6 N3 N
// configure McASP0 receive registers
8 v3 R+ _2 }' o7 o9 Q% ^* C mcasp->regs->RMASK = 0xFFFFFFFF; // No padding used/ v( E2 C# {0 N' v I: y- H: S2 o
mcasp->regs->RFMT = 0x00018078; // MSB 16bit, 0-delay, no pad, CFGBus* o# z# e# d7 M2 w
mcasp->regs->AFSRCTL = 0x00000112; // 2TDM, 1bit Falling, External FS, word
, Z0 M4 t" G! B7 c mcasp->regs->ACLKRCTL = 0x000000AF; // Rising INTERNAL CLK,(from tx side)
7 D$ x" M' D. e mcasp->regs->AHCLKRCTL = 0x00000000; // INT CLK (from tx side)1 ?. C3 }7 V% u7 ^% N9 D
mcasp->regs->RTDM = 0x00000003; // Slots 0,1/ r: y& H+ M* A, ~4 f& C" C
mcasp->regs->RINTCTL = 0x00000000; // Not used( Z! e ?5 |; _3 k4 q0 x* h2 {
mcasp->regs->RCLKCHK = 0x00FF0008; // 255-MAX 0-MIN, div-by-2566 r' i- ?5 \. Y8 ^
* d; p2 }2 E' p2 z s- p5 o mcasp->regs->XMASK = 0xFFFFFFFF; // No padding used
, u9 `& R9 E4 D* u1 n mcasp->regs->XFMT = 0x00018078; // MSB 16bit, 0-delay, no pad, CFGBus: y$ S9 C6 e5 C/ A2 G0 ~
mcasp->regs->AFSXCTL = 0x00000112; // 2TDM, 1bit Rising edge INTERNAL FS, word7 J3 z8 t) G4 h0 p. W$ Y' y7 t
mcasp->regs->ACLKXCTL = 0x000000AF; // ASYNC, Rising INTERNAL CLK, div-by-16
# [- g0 f9 f$ J V3 l. g mcasp->regs->AHCLKXCTL = 0x00000000; // EXT CLK: |5 V; Z. l6 p' }
mcasp->regs->XTDM = 0x00000003; // Slots 0,1$ N# U0 K# f. `9 n# ?" |4 M: U- c5 g
mcasp->regs->XINTCTL = 0x00000020; // interrupt on transmit
Q% _4 s. c. R: ] mcasp->regs->XCLKCHK = 0x00FF0008; // 255-MAX 0-MIN, div-by-2568 @4 X5 c- }4 Z3 c, ~% [
* L4 L. j: m/ R& ]$ E6 n3 M mcasp->regs->SRCTL5 = 0x000D; // MCASP1.AXR1[5] --> DIN
, B* E! \9 s* ~ mcasp->regs->SRCTL0 = 0x000E; // MCASP1.AXR1[0] <-- DOUT
: r( r) j( D7 l mcasp->regs->PFUNC = 0; // All MCASPs
% T2 i7 Q, `' h2 v mcasp->regs->PDIR = 0x14000020; // All inputs except AXR0[5], ACLKX1, AFSX1, k' E( x7 T* v# `
7 k Y8 H$ B$ G' ~; b/ N. h mcasp->regs->DITCTL = 0x00000000; // Not used. ] R# ^( X7 N& k' ]& l: f
mcasp->regs->DLBCTL = 0x00000000; // Not used$ G! P' d- J) Z# O8 ^: t) f; R! X7 Y
mcasp->regs->AMUTE = 0x00000000; // Not used1 p3 Z8 _; E* o
4 m; k3 n: u# f. `/* Starting sections of the McASP*/
' m/ S+ w' ^2 ` mcasp->regs->XGBLCTL |= GBLCTL_XHCLKRST_ON; o9 C* D5 x. s& ?. F! O
while ( ( mcasp->regs->XGBLCTL & GBLCTL_XHCLKRST_ON ) != GBLCTL_XHCLKRST_ON ); ) O% r: i: o8 F
mcasp->regs->RGBLCTL |= GBLCTL_RHCLKRST_ON; ' x2 U- c5 G; H
while ( ( mcasp->regs->RGBLCTL & GBLCTL_RHCLKRST_ON ) != GBLCTL_RHCLKRST_ON );
: l' H* K8 S, j: |- C. C2 J+ Q, T; p# U( G0 ~) A
mcasp->regs->XGBLCTL |= GBLCTL_XCLKRST_ON;
8 T2 A( c4 h3 E& W( l: d while ( ( mcasp->regs->XGBLCTL & GBLCTL_XCLKRST_ON ) != GBLCTL_XCLKRST_ON );
/ o# ^* T5 B$ |( x2 u2 c8 P! P& k mcasp->regs->RGBLCTL |= GBLCTL_RCLKRST_ON; : y# d, e2 |& d A
while ( ( mcasp->regs->RGBLCTL & GBLCTL_RCLKRST_ON ) != GBLCTL_RCLKRST_ON );
' i5 \7 \1 \; Z3 U6 Q# n ~, ~/ Z( w+ d8 \8 C, Q2 @3 Z3 k
mcasp->regs->XSTAT = 0x0000ffff; U/ `- [! G" K9 q. H2 F% i8 R
mcasp->regs->RSTAT = 0x0000ffff;
3 C: i% n Y7 M" J- \; j
4 ?7 K# T! \* a8 `. d" [7 b mcasp->regs->XGBLCTL |= GBLCTL_XSRCLR_ON;' A+ t- W- ]* Q+ t8 n1 j" y0 I
while ( ( mcasp->regs->XGBLCTL & GBLCTL_XSRCLR_ON ) != GBLCTL_XSRCLR_ON );
4 Z, l" P* _9 S1 }% I% H4 a mcasp->regs->RGBLCTL |= GBLCTL_RSRCLR_ON; 6 m( Z, l( i# O' T8 C* j& k T
while ( ( mcasp->regs->RGBLCTL & GBLCTL_RSRCLR_ON ) != GBLCTL_RSRCLR_ON );
: K+ t) l2 v! g3 E' @
; n- m; w. Q' [, x/ l7 C0 x: m: t /* Write a 0, so that no underrun occurs after releasing the state machine */4 c% h' s1 X. s" B$ Q$ ]
mcasp->regs->XBUF5 = 0;
* z2 Q/ U' O% C/ s4 |7 ] mcasp->regs->RBUF0 = 0;
: f( }0 g U5 o' r3 A8 T) W, Q4 P: h3 G \
mcasp->regs->XGBLCTL |= GBLCTL_XSMRST_ON; . l! K" ^; n4 K4 i- {+ |
while ( ( mcasp->regs->XGBLCTL & GBLCTL_XSMRST_ON ) != GBLCTL_XSMRST_ON );: B ?" u+ u0 t- `9 D. p0 `! h
mcasp->regs->RGBLCTL |= GBLCTL_RSMRST_ON; ) f8 d7 d, s5 A, T4 @% }
while ( ( mcasp->regs->RGBLCTL & GBLCTL_RSMRST_ON ) != GBLCTL_RSMRST_ON );
6 w ]% t4 @4 \1 t) P! l. M4 I( U2 ]
mcasp->regs->XGBLCTL |= GBLCTL_XFRST_ON;
# N6 D$ x# `1 r( }+ T while ( ( mcasp->regs->XGBLCTL & GBLCTL_XFRST_ON ) != GBLCTL_XFRST_ON );0 L; ?" q- N$ h) {
mcasp->regs->RGBLCTL |= GBLCTL_RFRST_ON; ; O: e$ I. b5 F; `
while ( ( mcasp->regs->RGBLCTL & GBLCTL_RFRST_ON ) != GBLCTL_RFRST_ON );
' E# w5 ? J. {1 Y
0 ]7 e6 j7 L3 B2 t S" D CSR = 0x0000;+ p$ k; k& D4 Z0 l( Y
INTC_INTMUX1 = 0x3d;- w# ~6 s+ a0 J X
ISTP = (unsigned int)vectors;5 ]1 C# \* }0 d0 x6 V
ICR = 0xFFF0;
# W, \: b! j/ x$ X% c IER |= 0x12;
4 i2 L0 Q0 B/ o0 k& K3 c" C CSR |= 0x01; . o9 @4 S1 w: d& d( q7 O8 \
9 J8 d# P6 `8 s
s p2 D# A, G( Y( k! y! l) W
" ]2 e& K/ Y( ]( x2 H( a4 k9 }
还有就是两个输入输出函数:! j5 u$ B. I! N- z
void output_sample(Int32 out_data)2 H% _! l( R% C4 o
{8 n$ y! m0 B5 H- h4 |
AIC31_data.uint = out_data;
- m1 v, [7 G' e3 b& A' }# k# D MCASP1_XBUF5_32BIT = AIC31_data.uint;0 i, I* U; P' {2 n( w' V, M
}
. M+ K2 l2 [" |. D& V6 _% Q/ c2 x9 h0 K2 k/ \/ Z
Int32 input_sample(void)
8 \8 j2 k( J# F8 Q& b b) Y{
8 ]3 @: `- k: P \ AIC31_data.uint = MCASP1_RBUF0_32BIT;
0 d! E4 J9 K+ R' Y1 E, [: `7 t return (AIC31_data.uint);
% e: n+ M5 \9 U/ l, l+ O8 e}$ @% R) h: h4 C5 p
- E* Z$ d6 m/ a; B2 W E |
|