|
|
C6747和C6748感觉差不多,我想实现McASP发送中断方式控制音频信号,在轮询的例程基础上改的,轮询程序可以实现,但是中断一直实现不了,也找不到错误,求大神帮忙!下边是主要程序:: ~/ Y/ s; [( L N% B
main文件:$ ?/ y. K" e! E, I
interrupt void interrupt4(void)
+ j% [# d* j; f! ]& y4 Q) l: {{
) {6 [! E& A, c( H4 x5 p Uint32 sample;" Y6 M# f! C6 ?1 Q/ H
$ w$ g+ y# @0 o' _3 I6 y2 l+ a sample = input_sample(); // read L + R samples from ADC
; L4 [3 @) h3 O9 e# }8 k) Q output_sample(sample); // write L + R samples to DAC 5 @7 w+ J3 F1 w# ]4 O) i
return;
* O1 D1 c( p9 O) m}
# v% p1 I) }4 y' _* \! h7 K! X! U3 D7 g, g* _4 \2 ]% C
int main( void )
5 B4 N- {! c! L8 h% p{
$ o( M* s z- Z. \- n4 R4 |( I1 ]4 } H, k0 ]4 ?6 f4 i# q
/* Initialize BSL */2 e- G d- o* [ Y: w0 D
EVMC6747_init( );
! P1 ^/ M3 B: G5 G% [* e /* Call evmc6747_intr function */
+ U2 n) p6 m' s! G/ A% X aic3106_init( );! J# s) {8 M+ c+ |9 c7 P
while(1);3 @; {! E% D3 f' @: ?$ f
}0 ^$ T- m6 t' H7 k. v0 c
, {# }8 I7 h5 o$ J* O; B5 i7 g9 m/ z7 v; K4 O7 Q1 S
aic3106_init文件的一部分,McASP配置部分,采用内部时钟,I2S方式,同步传输。音频芯片的配置应该没问题2 t% k4 j+ X+ p
/* Initialize MCASP1 */
) j, ^$ D8 `7 W1 G, O, t mcasp = &MCASP_MODULE_1;. D7 {. E" \, z9 P: T; \
mcasp->regs->GBLCTL = 0; // Reset
6 z7 W' A. _' ]9 q- Y9 n% { mcasp->regs->RGBLCTL = 0; // Reset RX% G: p6 \. Y# A; U5 W2 K4 [6 u* Y
mcasp->regs->XGBLCTL = 0; // Reset TX
8 X2 l K) {' L+ }8 C mcasp->regs->PWRDEMU = 1; // Free-running0 y. Z( B4 {2 G: \
// configure McASP0 receive registers8 M" [' B7 }7 ?8 H: W
mcasp->regs->RMASK = 0xFFFFFFFF; // No padding used
$ z7 @; K0 T7 S) x- n* c7 g mcasp->regs->RFMT = 0x00018078; // MSB 16bit, 0-delay, no pad, CFGBus
$ p# b( t. M; R' K mcasp->regs->AFSRCTL = 0x00000112; // 2TDM, 1bit Falling, External FS, word
! ]% q4 U* l- p- p1 k mcasp->regs->ACLKRCTL = 0x000000AF; // Rising INTERNAL CLK,(from tx side)
+ ?9 C" y7 v9 y Y# `5 j6 d mcasp->regs->AHCLKRCTL = 0x00000000; // INT CLK (from tx side): W+ P0 a! x! a$ O R
mcasp->regs->RTDM = 0x00000003; // Slots 0,18 f# N2 W* E% Z( B
mcasp->regs->RINTCTL = 0x00000000; // Not used' t# e1 q; a* R8 f: `4 y# _
mcasp->regs->RCLKCHK = 0x00FF0008; // 255-MAX 0-MIN, div-by-2568 {4 N5 O: M6 H: W+ L! i' ?
6 g& h3 d* N9 ]9 a6 |$ X7 `& p1 Q2 t
mcasp->regs->XMASK = 0xFFFFFFFF; // No padding used
) ]0 |: g# J7 r4 V mcasp->regs->XFMT = 0x00018078; // MSB 16bit, 0-delay, no pad, CFGBus0 a1 T5 w) g/ A+ U$ x* ?
mcasp->regs->AFSXCTL = 0x00000112; // 2TDM, 1bit Rising edge INTERNAL FS, word ?: A: f4 [. O) Q. x
mcasp->regs->ACLKXCTL = 0x000000AF; // ASYNC, Rising INTERNAL CLK, div-by-16. v, _' p1 ^0 N/ n
mcasp->regs->AHCLKXCTL = 0x00000000; // EXT CLK
9 T1 i& l" |4 ^* M' A mcasp->regs->XTDM = 0x00000003; // Slots 0,1
6 h( b0 n0 } M' e" u mcasp->regs->XINTCTL = 0x00000020; // interrupt on transmit5 u/ a6 Q r$ y, ?, }
mcasp->regs->XCLKCHK = 0x00FF0008; // 255-MAX 0-MIN, div-by-256
; q1 m" W% T& {+ Q* B! [( ~' S$ Q4 V( G
mcasp->regs->SRCTL5 = 0x000D; // MCASP1.AXR1[5] --> DIN
* x: l! N% F) y. B8 s6 j; P mcasp->regs->SRCTL0 = 0x000E; // MCASP1.AXR1[0] <-- DOUT
, i: I) F V5 J* J mcasp->regs->PFUNC = 0; // All MCASPs! f* j7 e3 T. e% M# _) q
mcasp->regs->PDIR = 0x14000020; // All inputs except AXR0[5], ACLKX1, AFSX1% G9 {0 e8 g4 I% M
2 ^: P! J D; [: m8 h- C1 \
mcasp->regs->DITCTL = 0x00000000; // Not used8 ]9 X0 B% d: M/ Q
mcasp->regs->DLBCTL = 0x00000000; // Not used3 v% o8 N" r$ @- @ S2 Y! V
mcasp->regs->AMUTE = 0x00000000; // Not used
2 h4 N5 p: k8 u# G1 ^+ a
: Z9 Z" Z) b5 ]* P8 K [7 ~/* Starting sections of the McASP*/
; n* h- K0 F2 _0 q8 M1 v# _ mcasp->regs->XGBLCTL |= GBLCTL_XHCLKRST_ON;
8 W! C% i" A4 L7 K, F while ( ( mcasp->regs->XGBLCTL & GBLCTL_XHCLKRST_ON ) != GBLCTL_XHCLKRST_ON ); 7 O, o4 [0 Y0 C/ F3 N" U3 l
mcasp->regs->RGBLCTL |= GBLCTL_RHCLKRST_ON;
, V" u- P) F3 ?' J" G- O7 C; c while ( ( mcasp->regs->RGBLCTL & GBLCTL_RHCLKRST_ON ) != GBLCTL_RHCLKRST_ON );
7 _1 c# O8 c4 f& V
7 v7 Z5 ~4 G2 |6 x9 q5 Z3 o mcasp->regs->XGBLCTL |= GBLCTL_XCLKRST_ON;
# y6 u/ b9 u5 C0 q" a7 e' S- a) N while ( ( mcasp->regs->XGBLCTL & GBLCTL_XCLKRST_ON ) != GBLCTL_XCLKRST_ON );
) n! u5 v9 K3 Z& o0 a, { mcasp->regs->RGBLCTL |= GBLCTL_RCLKRST_ON;
3 H% Q& ?) W2 e while ( ( mcasp->regs->RGBLCTL & GBLCTL_RCLKRST_ON ) != GBLCTL_RCLKRST_ON );
8 I r% ]0 Z% Y3 x) k2 }% _7 G' M1 q- U t
mcasp->regs->XSTAT = 0x0000ffff; ) w$ Z r1 K, y8 q6 Z7 _# ^
mcasp->regs->RSTAT = 0x0000ffff;
4 H7 c8 {7 u! S5 `
4 b$ c0 _- N! b0 D. L o0 G mcasp->regs->XGBLCTL |= GBLCTL_XSRCLR_ON; f1 ]2 g; O( O. j. @9 v" n
while ( ( mcasp->regs->XGBLCTL & GBLCTL_XSRCLR_ON ) != GBLCTL_XSRCLR_ON );/ |& C! k3 y( d& }
mcasp->regs->RGBLCTL |= GBLCTL_RSRCLR_ON; 9 L7 v4 N2 _( ]) C* x
while ( ( mcasp->regs->RGBLCTL & GBLCTL_RSRCLR_ON ) != GBLCTL_RSRCLR_ON );
! V5 ^% T) o& v' B3 x# [8 w8 S8 G( h. z% J7 r* F% ]
/* Write a 0, so that no underrun occurs after releasing the state machine */
; p, z8 m, H! Q4 Q/ L mcasp->regs->XBUF5 = 0;6 l- Y1 F$ f, G' S6 W
mcasp->regs->RBUF0 = 0;% t* t& C7 f) T5 ~( q4 R% i
4 Q" u1 f4 A$ T, h$ M mcasp->regs->XGBLCTL |= GBLCTL_XSMRST_ON; * n6 c$ G% }' U1 S" [& x' d
while ( ( mcasp->regs->XGBLCTL & GBLCTL_XSMRST_ON ) != GBLCTL_XSMRST_ON );
- M* L% c$ V' H% m! g9 I Q mcasp->regs->RGBLCTL |= GBLCTL_RSMRST_ON;
; ?' h5 l9 ?' J+ p$ s* j3 j while ( ( mcasp->regs->RGBLCTL & GBLCTL_RSMRST_ON ) != GBLCTL_RSMRST_ON );! B) } l; s# g
5 N. q4 E* `4 {+ Z9 R: o. k$ D
mcasp->regs->XGBLCTL |= GBLCTL_XFRST_ON;
0 V& J' _/ F) t- D% n while ( ( mcasp->regs->XGBLCTL & GBLCTL_XFRST_ON ) != GBLCTL_XFRST_ON );: Q6 W0 G% x" V& x1 _4 p: L
mcasp->regs->RGBLCTL |= GBLCTL_RFRST_ON; - B2 \: Z' B9 B# g- n3 Y
while ( ( mcasp->regs->RGBLCTL & GBLCTL_RFRST_ON ) != GBLCTL_RFRST_ON );
9 I$ D) n* E/ \0 [/ H8 U% O% b! j- R% D7 g5 @
CSR = 0x0000;# q/ ?2 e8 |* U/ c5 H2 Q5 i/ p
INTC_INTMUX1 = 0x3d;+ C7 c- ?5 o* @# c
ISTP = (unsigned int)vectors;
7 s7 L/ _9 ~' y! X ICR = 0xFFF0;
1 p+ G* v6 \6 `0 F, H9 O IER |= 0x12; 8 X. c2 H% G% ]7 w* ?0 k
CSR |= 0x01; 3 W) x( g$ {% l1 X0 b& ]! I
5 P# e( }2 p" d6 m" X7 {9 c2 g$ H6 q% o
: K$ M/ P4 L/ c0 z1 h4 X2 N7 Q: F还有就是两个输入输出函数:! w+ O- v0 y/ k- u. l; W
void output_sample(Int32 out_data)8 z/ R3 H/ H8 E9 G/ i( W3 [
{+ j0 p* j# ~+ g, A8 N
AIC31_data.uint = out_data; ' u d! u) n+ S- ]" L+ y7 B
MCASP1_XBUF5_32BIT = AIC31_data.uint;
* o Q8 @/ t1 T}
$ T+ b9 ^: y+ x
! ~* v7 i) B% yInt32 input_sample(void)
5 c, V$ [* U# {" v' W2 m% h, G* F{ $ x) V; Q: q/ V7 ^3 `: k
AIC31_data.uint = MCASP1_RBUF0_32BIT;7 ~6 }2 n D2 g/ E3 {3 w
return (AIC31_data.uint);; q, C' F$ Z( S/ |2 F( f, J5 V8 h( H
}4 d5 ] O f+ V P7 \$ O& K
1 c7 D3 o. P- O' ?8 H: \: e V" P9 e |
|