|
|
C6747和C6748感觉差不多,我想实现McASP发送中断方式控制音频信号,在轮询的例程基础上改的,轮询程序可以实现,但是中断一直实现不了,也找不到错误,求大神帮忙!下边是主要程序:
. H5 A1 K% x) E/ q! E8 _. Vmain文件:
8 R, ?* D3 s5 E2 l( {) q q: d+ xinterrupt void interrupt4(void) 3 s8 w, N- d) i; f: n& ^
{
1 w, d7 x: Y2 F1 { Uint32 sample;
( V a$ G1 X/ p! n' [. a/ j* N, q2 B/ f7 _0 I" O( W+ @4 O! h
sample = input_sample(); // read L + R samples from ADC6 Y: ~, [8 p& \" L- a" B
output_sample(sample); // write L + R samples to DAC ' X5 ~* M8 Y- g
return;( I m5 J" G! f
}$ }# N2 q8 U' f3 j& ]* N
5 M2 Q( k" l& P6 l, u9 M; f9 Pint main( void )# L. R7 i: s6 t$ f' P
{/ a, Q- f: q& ^2 x$ m' U' P
$ i8 |4 W9 V3 q2 W, e! h' q% _
/* Initialize BSL */" H8 L) ]; T- r8 t( W! _
EVMC6747_init( );# ~/ k. I* n3 Z2 h
/* Call evmc6747_intr function */
R# n/ n8 Q# m4 M aic3106_init( );7 D; u" F+ Q* d% Q
while(1);
- q" W5 X# l! @* c/ T: d+ x}
' j1 Q! l# y, q) g, B# P8 t
/ {; }- C3 t% U, {1 l$ B, }7 f
: l: p( \; v) g/ g7 A0 caic3106_init文件的一部分,McASP配置部分,采用内部时钟,I2S方式,同步传输。音频芯片的配置应该没问题
) I' a0 U( o7 a3 C/ T; j) n/* Initialize MCASP1 */
$ u. l+ ~9 l( ? mcasp = &MCASP_MODULE_1;
2 `" s W4 e) n) ~ p& p5 _9 A mcasp->regs->GBLCTL = 0; // Reset0 `4 }. S0 p! j$ L
mcasp->regs->RGBLCTL = 0; // Reset RX( [# D( u- r5 X
mcasp->regs->XGBLCTL = 0; // Reset TX5 h8 ^7 q# u6 g: t& V. a) V' z
mcasp->regs->PWRDEMU = 1; // Free-running
7 ]* U. Z, y% X& H // configure McASP0 receive registers
6 g# H6 }5 W2 Q8 m mcasp->regs->RMASK = 0xFFFFFFFF; // No padding used
" _; u+ s* k# N mcasp->regs->RFMT = 0x00018078; // MSB 16bit, 0-delay, no pad, CFGBus
; Q1 P" x" b1 E8 e2 l, z* g; d8 Z mcasp->regs->AFSRCTL = 0x00000112; // 2TDM, 1bit Falling, External FS, word& L1 G3 o( h& o3 g* L
mcasp->regs->ACLKRCTL = 0x000000AF; // Rising INTERNAL CLK,(from tx side)$ J& U# R* {7 q$ J4 R! i4 P
mcasp->regs->AHCLKRCTL = 0x00000000; // INT CLK (from tx side)
7 _4 z- ]$ Z5 R4 X mcasp->regs->RTDM = 0x00000003; // Slots 0,1' B) U6 e$ \9 B# k$ p1 q
mcasp->regs->RINTCTL = 0x00000000; // Not used
- X6 s& r" g* q- o mcasp->regs->RCLKCHK = 0x00FF0008; // 255-MAX 0-MIN, div-by-2563 X K9 Z" C, ]; f; i
# k" U" v; G4 n4 K/ x
mcasp->regs->XMASK = 0xFFFFFFFF; // No padding used
6 h$ Z- @- I6 Z3 W. i& D1 m mcasp->regs->XFMT = 0x00018078; // MSB 16bit, 0-delay, no pad, CFGBus6 F" C, ~3 y- B2 Y U' j- @& r
mcasp->regs->AFSXCTL = 0x00000112; // 2TDM, 1bit Rising edge INTERNAL FS, word" P9 h+ ]7 u6 j W+ t3 ^7 r
mcasp->regs->ACLKXCTL = 0x000000AF; // ASYNC, Rising INTERNAL CLK, div-by-16
% K% Z l8 c+ c- Q mcasp->regs->AHCLKXCTL = 0x00000000; // EXT CLK2 B4 ^7 I8 \3 l& P
mcasp->regs->XTDM = 0x00000003; // Slots 0,1/ a( M+ O9 I+ K
mcasp->regs->XINTCTL = 0x00000020; // interrupt on transmit: t( I2 y. l* |
mcasp->regs->XCLKCHK = 0x00FF0008; // 255-MAX 0-MIN, div-by-2569 \* B1 j1 [6 S( ~. q
4 Z/ w6 s: c6 B0 M7 e9 m
mcasp->regs->SRCTL5 = 0x000D; // MCASP1.AXR1[5] --> DIN
+ ~- Y4 p( F9 X+ W& n mcasp->regs->SRCTL0 = 0x000E; // MCASP1.AXR1[0] <-- DOUT
" @- e3 F) U) M6 F/ @1 u mcasp->regs->PFUNC = 0; // All MCASPs$ W+ j7 A- t% [5 {' z' v/ D
mcasp->regs->PDIR = 0x14000020; // All inputs except AXR0[5], ACLKX1, AFSX1; c/ T1 x& v! |2 Q6 [/ D& J) ~
7 w4 G9 J; P. h" I& q/ w% _ mcasp->regs->DITCTL = 0x00000000; // Not used# K7 t7 ~% W7 {; w
mcasp->regs->DLBCTL = 0x00000000; // Not used) d4 U4 t- X9 ^8 ?/ ~& T
mcasp->regs->AMUTE = 0x00000000; // Not used
% H6 |& U6 y/ k9 r+ ~2 }: `3 v: K* X* N1 K! N
/* Starting sections of the McASP*// q, t1 ?& Z" P' f- e
mcasp->regs->XGBLCTL |= GBLCTL_XHCLKRST_ON;
* G, A" h6 g& K7 _4 g while ( ( mcasp->regs->XGBLCTL & GBLCTL_XHCLKRST_ON ) != GBLCTL_XHCLKRST_ON ); # U: h( q' ]1 L+ Q8 n
mcasp->regs->RGBLCTL |= GBLCTL_RHCLKRST_ON; . W. ]/ k$ c( D, V
while ( ( mcasp->regs->RGBLCTL & GBLCTL_RHCLKRST_ON ) != GBLCTL_RHCLKRST_ON );
1 Q3 t! B' _: v4 |7 R( D( n+ C9 T. ]/ B
mcasp->regs->XGBLCTL |= GBLCTL_XCLKRST_ON;
: } |/ J( _" _6 F while ( ( mcasp->regs->XGBLCTL & GBLCTL_XCLKRST_ON ) != GBLCTL_XCLKRST_ON );
' o D) N2 |! z' J/ E7 L mcasp->regs->RGBLCTL |= GBLCTL_RCLKRST_ON;
, I; L8 g% g1 d' t0 { while ( ( mcasp->regs->RGBLCTL & GBLCTL_RCLKRST_ON ) != GBLCTL_RCLKRST_ON );
2 R! I' Y6 o; W# E3 n* o# |" k2 T; U r$ O& i: o$ v
mcasp->regs->XSTAT = 0x0000ffff;
7 M* q3 |9 w* F mcasp->regs->RSTAT = 0x0000ffff; 6 w' x4 i# K8 Q. O3 [- Q. F( q2 l1 V
9 a+ @- K/ r% H) V mcasp->regs->XGBLCTL |= GBLCTL_XSRCLR_ON;
% d+ b8 \4 k/ D" f while ( ( mcasp->regs->XGBLCTL & GBLCTL_XSRCLR_ON ) != GBLCTL_XSRCLR_ON );
7 u& V( d2 ~5 ` mcasp->regs->RGBLCTL |= GBLCTL_RSRCLR_ON;
- D3 E1 E: p6 X2 f& g- q8 u while ( ( mcasp->regs->RGBLCTL & GBLCTL_RSRCLR_ON ) != GBLCTL_RSRCLR_ON );
$ ?0 p0 Q5 |5 [8 m5 F* g! _, c, J9 _+ Q* |! W$ {+ @; P7 I9 u& V
/* Write a 0, so that no underrun occurs after releasing the state machine */- C1 M/ ?6 \, t
mcasp->regs->XBUF5 = 0;
1 n' s' H# V2 g# X3 m* I, a2 z mcasp->regs->RBUF0 = 0;
1 h4 l4 l* f( Q: I7 h
8 w1 Y1 ?/ e1 e; u0 J mcasp->regs->XGBLCTL |= GBLCTL_XSMRST_ON;
7 t8 R( |+ |8 Z, Y3 G1 T3 P while ( ( mcasp->regs->XGBLCTL & GBLCTL_XSMRST_ON ) != GBLCTL_XSMRST_ON );1 t8 [( c" L/ t# y* _( q
mcasp->regs->RGBLCTL |= GBLCTL_RSMRST_ON; & b. A1 n* a$ T0 A) Q0 D
while ( ( mcasp->regs->RGBLCTL & GBLCTL_RSMRST_ON ) != GBLCTL_RSMRST_ON );7 Q: H/ h$ J$ [2 u* L
/ d' z1 f+ U) u, n mcasp->regs->XGBLCTL |= GBLCTL_XFRST_ON;
- q$ W* M- v; j, k while ( ( mcasp->regs->XGBLCTL & GBLCTL_XFRST_ON ) != GBLCTL_XFRST_ON );
" s$ B9 j$ P% g- P, Q3 W mcasp->regs->RGBLCTL |= GBLCTL_RFRST_ON;
+ \ q# I+ v$ l4 ^: W while ( ( mcasp->regs->RGBLCTL & GBLCTL_RFRST_ON ) != GBLCTL_RFRST_ON );
7 Q: x" A' f! }4 V9 f0 x
) o6 ?6 Y5 G1 U7 p, A CSR = 0x0000;
7 i8 _: W( G3 @" }; G K INTC_INTMUX1 = 0x3d;
; E) u8 w5 {0 u; h ISTP = (unsigned int)vectors;
1 `( u7 T9 U2 I- _6 z5 D ICR = 0xFFF0; ) v' z! o" ]3 p
IER |= 0x12; ( j9 Z1 c8 |- h( [- N: {$ y- V
CSR |= 0x01;
; H" Z. |- H. k3 u
% j# i$ m- a) t( \
& s, ^8 G+ J) j( \+ r
7 A) e' c- R: ?5 {还有就是两个输入输出函数:
' ~1 c! V( s" `& ?/ N3 Jvoid output_sample(Int32 out_data)
! W2 \( B4 @: b c7 Y! j+ {9 W5 V{
7 j+ ?6 q1 s2 L8 h2 P5 ^3 t. s! R AIC31_data.uint = out_data; g {0 E7 v, `5 Z( r2 _& Q* P
MCASP1_XBUF5_32BIT = AIC31_data.uint;
8 b( i/ A! ^/ f9 G: r& Y% R}$ }* j4 X, O9 g d7 }& e
7 \) U: y7 W4 V' D7 c! C. ]: g! G5 iInt32 input_sample(void)
) r- F5 u* U z/ |8 r; u{
6 H1 F& B) k# F! W0 m. g8 l1 ]# x* A AIC31_data.uint = MCASP1_RBUF0_32BIT;8 S# `3 `% c$ [3 o8 o4 X
return (AIC31_data.uint);3 J+ d( S- m& |& t; x& t
}2 x! |4 ~5 M! c) L- N
6 M7 T1 b6 _" m9 {* r) ?3 [5 s
|
|