|
|
C6747和C6748感觉差不多,我想实现McASP发送中断方式控制音频信号,在轮询的例程基础上改的,轮询程序可以实现,但是中断一直实现不了,也找不到错误,求大神帮忙!下边是主要程序:+ q8 ~" P( f1 {! y! ^" ~3 M/ r. t
main文件:- q5 s+ |8 r& [: j2 A( d
interrupt void interrupt4(void)
1 P1 g# X4 @9 x* ~6 Y+ t7 a a{
$ R! |& q5 a# l+ ] Uint32 sample;
) `: v7 j: r1 l: r7 Z* g8 P3 M+ w* p
5 [3 E; ?9 C3 d% v2 H+ ]2 l sample = input_sample(); // read L + R samples from ADC; o0 x2 }0 i: w
output_sample(sample); // write L + R samples to DAC
! K8 B6 M9 ~) s: X& ?# }- r& @+ C1 Y return;! z' Z! ?1 w) C7 e6 Y
}/ j! Q, g/ n+ m3 z
% O2 W# S# Z2 l. U
int main( void )8 v# P8 m9 I) D4 g: x
{8 S" _: }1 C o6 `' K7 E1 B
* E; e4 g2 Y# A, e( t2 X' B/ k
/* Initialize BSL */
1 [# w- E& S' T$ c EVMC6747_init( );% _+ r8 x) }& H' m
/* Call evmc6747_intr function */. w1 j9 f9 g; [% c" |8 w
aic3106_init( );% [# m; I; p2 l: o" `% {' L
while(1);9 T. B& S9 k$ w5 P' k! ^
}! A. _5 j$ t/ x9 y* B
3 @' p7 j% l5 N/ ]
# U# r7 q8 l) N) U
aic3106_init文件的一部分,McASP配置部分,采用内部时钟,I2S方式,同步传输。音频芯片的配置应该没问题
4 H3 l/ m* P6 r3 \7 {7 L) V8 L0 X/* Initialize MCASP1 */8 K+ w; w" }* K2 O, g" ~+ e
mcasp = &MCASP_MODULE_1;2 p" G Z; m! H( \! x
mcasp->regs->GBLCTL = 0; // Reset. T5 e3 i. F: C' E
mcasp->regs->RGBLCTL = 0; // Reset RX
% J, _+ u5 h+ ^8 x. l8 Y* t mcasp->regs->XGBLCTL = 0; // Reset TX+ Z$ `0 r2 |9 |7 R
mcasp->regs->PWRDEMU = 1; // Free-running# p# B$ P+ q! ?0 w# V4 u
// configure McASP0 receive registers1 ?/ U7 N; }& \* O! y i! o1 O
mcasp->regs->RMASK = 0xFFFFFFFF; // No padding used
9 S( F; A1 R7 e8 C mcasp->regs->RFMT = 0x00018078; // MSB 16bit, 0-delay, no pad, CFGBus
% ^& k- l$ t% V- j% x mcasp->regs->AFSRCTL = 0x00000112; // 2TDM, 1bit Falling, External FS, word5 L7 z' v0 N: R- k6 K
mcasp->regs->ACLKRCTL = 0x000000AF; // Rising INTERNAL CLK,(from tx side)
, {9 Z! E) t! u+ X2 ~" d" E* Z ~ mcasp->regs->AHCLKRCTL = 0x00000000; // INT CLK (from tx side)
! d$ W1 c& H+ E9 C( \& @+ } mcasp->regs->RTDM = 0x00000003; // Slots 0,1+ U9 s5 G( D' `1 m, N* u: ?
mcasp->regs->RINTCTL = 0x00000000; // Not used5 l% ^+ ~/ e7 {, _) B
mcasp->regs->RCLKCHK = 0x00FF0008; // 255-MAX 0-MIN, div-by-256& b% n- B9 E1 D1 B# X9 i1 y
& b1 |- Y) p) G; u4 d& u7 L
mcasp->regs->XMASK = 0xFFFFFFFF; // No padding used" V! R- s9 Z- b5 G
mcasp->regs->XFMT = 0x00018078; // MSB 16bit, 0-delay, no pad, CFGBus
8 P! V* q% h. [ mcasp->regs->AFSXCTL = 0x00000112; // 2TDM, 1bit Rising edge INTERNAL FS, word# z! W, f, _; B) l" w9 z; F: T4 G+ K: G
mcasp->regs->ACLKXCTL = 0x000000AF; // ASYNC, Rising INTERNAL CLK, div-by-16
- D7 l- m4 v( O) j4 s mcasp->regs->AHCLKXCTL = 0x00000000; // EXT CLK% W8 D0 @. H" e
mcasp->regs->XTDM = 0x00000003; // Slots 0,18 }% c9 v1 W9 h- m* O! e6 s
mcasp->regs->XINTCTL = 0x00000020; // interrupt on transmit
/ c X! N% P& z( W0 q- ^ mcasp->regs->XCLKCHK = 0x00FF0008; // 255-MAX 0-MIN, div-by-2566 J/ }+ x+ ]5 o/ V- l
5 c! s5 u: y- g# K% X V8 N
mcasp->regs->SRCTL5 = 0x000D; // MCASP1.AXR1[5] --> DIN: v, @ b/ v u6 D6 c2 V9 N0 V
mcasp->regs->SRCTL0 = 0x000E; // MCASP1.AXR1[0] <-- DOUT9 s. K/ U* q, N+ O c! d( ~8 j' a# Y
mcasp->regs->PFUNC = 0; // All MCASPs
& p2 W5 l6 e) _, _0 L/ s. a mcasp->regs->PDIR = 0x14000020; // All inputs except AXR0[5], ACLKX1, AFSX17 s4 a m/ X; m ]9 o
`% r1 |. [. Z0 M' ^' E- r, x mcasp->regs->DITCTL = 0x00000000; // Not used: L5 v7 c# Y2 c/ U. ]
mcasp->regs->DLBCTL = 0x00000000; // Not used
5 q' N5 S, L6 V) b3 ` X mcasp->regs->AMUTE = 0x00000000; // Not used
3 t G& e I( S. _1 o
7 M0 e# O; N' K' y3 i/* Starting sections of the McASP*/' d5 ]# d4 `$ R9 l& e
mcasp->regs->XGBLCTL |= GBLCTL_XHCLKRST_ON; ( b. J1 ~' a5 r: s5 f
while ( ( mcasp->regs->XGBLCTL & GBLCTL_XHCLKRST_ON ) != GBLCTL_XHCLKRST_ON ); 2 P* g3 {# W% ?# _/ Y
mcasp->regs->RGBLCTL |= GBLCTL_RHCLKRST_ON;
9 Q5 f5 c2 X% h, d3 g3 ^: W2 L while ( ( mcasp->regs->RGBLCTL & GBLCTL_RHCLKRST_ON ) != GBLCTL_RHCLKRST_ON );0 d- F! K, j9 h2 y% s# ?1 [ ~
6 {" T' s# b# f# F
mcasp->regs->XGBLCTL |= GBLCTL_XCLKRST_ON;
: r" ^+ e, H, B3 w* w while ( ( mcasp->regs->XGBLCTL & GBLCTL_XCLKRST_ON ) != GBLCTL_XCLKRST_ON );
' e" k+ S! A x2 H; c g mcasp->regs->RGBLCTL |= GBLCTL_RCLKRST_ON;
. h) E" {/ a4 p+ i8 F& A: { while ( ( mcasp->regs->RGBLCTL & GBLCTL_RCLKRST_ON ) != GBLCTL_RCLKRST_ON );2 k+ G/ \3 W& V- k4 i* C
1 Z0 m6 V' c+ u. e, l mcasp->regs->XSTAT = 0x0000ffff; 8 H$ d/ k/ z. q) K9 ? o2 n
mcasp->regs->RSTAT = 0x0000ffff; % j" F5 N, R' m, G5 P, Y
3 w% I9 `; q! h+ r. S
mcasp->regs->XGBLCTL |= GBLCTL_XSRCLR_ON;: E; B! E# E! a: U/ S" q; l/ ^
while ( ( mcasp->regs->XGBLCTL & GBLCTL_XSRCLR_ON ) != GBLCTL_XSRCLR_ON );
8 ]8 y! M* P- b; ~. H3 P1 y mcasp->regs->RGBLCTL |= GBLCTL_RSRCLR_ON; 5 S t4 R% v: P# g2 x4 g8 s2 E! [2 \
while ( ( mcasp->regs->RGBLCTL & GBLCTL_RSRCLR_ON ) != GBLCTL_RSRCLR_ON );$ p/ z& O$ a1 k0 f* i2 V# i3 P/ u
# ]( e+ j. o) @" {! p8 F; x
/* Write a 0, so that no underrun occurs after releasing the state machine */
; z- V+ L$ M& }1 Z: ? mcasp->regs->XBUF5 = 0;; N- E( j6 I; T4 b$ y
mcasp->regs->RBUF0 = 0;+ U$ y- x: ?" o3 R6 |, I
: R) h' S7 p# T. @1 ?8 q
mcasp->regs->XGBLCTL |= GBLCTL_XSMRST_ON; , U: V9 ~9 [) v
while ( ( mcasp->regs->XGBLCTL & GBLCTL_XSMRST_ON ) != GBLCTL_XSMRST_ON );1 G7 E+ b/ B' s
mcasp->regs->RGBLCTL |= GBLCTL_RSMRST_ON;
t2 I9 i! ? L P$ M! [ while ( ( mcasp->regs->RGBLCTL & GBLCTL_RSMRST_ON ) != GBLCTL_RSMRST_ON );
. g1 m1 x7 d4 W) X+ H Z$ K w( V( s; a0 R% ?. {
mcasp->regs->XGBLCTL |= GBLCTL_XFRST_ON; 4 q) R; E/ R# n$ X' c% |2 ^
while ( ( mcasp->regs->XGBLCTL & GBLCTL_XFRST_ON ) != GBLCTL_XFRST_ON );
2 h+ f. E$ x1 h& M3 @+ X% [ mcasp->regs->RGBLCTL |= GBLCTL_RFRST_ON; + M4 C- Y+ g l. w
while ( ( mcasp->regs->RGBLCTL & GBLCTL_RFRST_ON ) != GBLCTL_RFRST_ON );$ L7 T( o2 n5 Q: S/ ~2 P7 H
' P! \% W# \1 K
CSR = 0x0000;/ U1 y, C% n3 C# x
INTC_INTMUX1 = 0x3d; r! B9 C+ Q( Z: I7 w
ISTP = (unsigned int)vectors;+ R3 X9 K% p( ]4 W3 @5 `' b
ICR = 0xFFF0; ! Q0 g: Y' }9 e9 [6 {
IER |= 0x12;
# ?4 l5 Y% r3 j7 f$ [ CSR |= 0x01; " D8 n& |8 z( l4 F% t* {' j5 W
+ e$ L- K+ `9 p- Y* H/ s- ?; y
- m6 p. i0 d' r: h# ~/ L+ k! z+ ?/ C% m! o* A4 i
还有就是两个输入输出函数:& Q; _4 Q! F! f, F
void output_sample(Int32 out_data)
3 L1 {& m6 s P0 A: K7 ?{" K1 U5 Y7 g7 v' h. h" u, R% D I& H
AIC31_data.uint = out_data; + s/ e3 }) O- D9 R8 L9 ^
MCASP1_XBUF5_32BIT = AIC31_data.uint;4 k3 N6 K" l/ w2 r$ l* w
}
5 R( O0 k. u; ^1 c' g
2 B8 l5 w- Y5 N$ E' H$ D. |Int32 input_sample(void)3 w/ A, Q$ o6 t6 h$ L! C& s8 F
{ : a* \9 ^* u& R# q, h$ h' T& n% s
AIC31_data.uint = MCASP1_RBUF0_32BIT;! a$ h5 O% }) o$ Q" X6 m- I4 j1 g
return (AIC31_data.uint);
+ W+ g, I0 Y/ B E}
" T" }5 P1 P) [8 M
1 s9 _( I. r2 s1 U$ [! [; d |
|