|
|
C6747和C6748感觉差不多,我想实现McASP发送中断方式控制音频信号,在轮询的例程基础上改的,轮询程序可以实现,但是中断一直实现不了,也找不到错误,求大神帮忙!下边是主要程序:
6 J$ |8 {. {7 V7 g, k9 r' Fmain文件:4 Y7 W2 g+ B6 _# }6 Y
interrupt void interrupt4(void) 2 `2 m' R: l" ?0 f( v
{
s$ n9 A6 a' h" X2 J2 g Uint32 sample;2 A/ h& ?# N# E, H5 d: q7 c) |7 z
+ z0 p1 p1 T* O+ I- Y+ o3 @ sample = input_sample(); // read L + R samples from ADC/ O7 Y0 o3 U: ^1 W) z3 W
output_sample(sample); // write L + R samples to DAC
6 w: d8 \5 o+ i return;
5 e9 r1 A2 x* s- w}4 x; q f6 @! l+ p9 P$ F+ b4 \
$ A' F: X( |, e$ w# f$ O3 l0 [int main( void )
) Q+ r; N/ g( I5 [{
# \3 H R4 p7 a
2 L" L: {" n z" U /* Initialize BSL */% E% N5 J& |; K7 j0 y0 h# C; V
EVMC6747_init( );0 e0 V2 I7 b8 `; g! u5 f
/* Call evmc6747_intr function */
! \; s K0 i {! j7 f) U aic3106_init( );$ }, @; `4 h# T0 U
while(1);6 H2 h* h4 D0 M9 n/ l5 A' U! q
}
2 n# s& n# }* `8 P- V1 x
& p! `) N1 c) \5 N& M8 ^% I2 X# }
aic3106_init文件的一部分,McASP配置部分,采用内部时钟,I2S方式,同步传输。音频芯片的配置应该没问题0 `' _+ b" G: T
/* Initialize MCASP1 */% ?- F; x3 K8 V1 V) v
mcasp = &MCASP_MODULE_1;4 o6 t& P* F6 ?2 Z+ J+ X
mcasp->regs->GBLCTL = 0; // Reset2 J$ v& A# I1 y4 s, k. s7 S
mcasp->regs->RGBLCTL = 0; // Reset RX. W! [) I1 x. N! j$ O. ^, m& B
mcasp->regs->XGBLCTL = 0; // Reset TX
/ R4 l" O* P7 B d1 k( f7 n mcasp->regs->PWRDEMU = 1; // Free-running& C) X4 f* J6 z" {' ~& F! X
// configure McASP0 receive registers1 X# C2 O: M7 x5 X6 b
mcasp->regs->RMASK = 0xFFFFFFFF; // No padding used
9 v. B8 M7 k* M& { mcasp->regs->RFMT = 0x00018078; // MSB 16bit, 0-delay, no pad, CFGBus
x8 c) A% ` Q mcasp->regs->AFSRCTL = 0x00000112; // 2TDM, 1bit Falling, External FS, word
{! h0 B y6 M6 I mcasp->regs->ACLKRCTL = 0x000000AF; // Rising INTERNAL CLK,(from tx side)
& \2 U# \- c/ d$ }* e) R% I, q4 M mcasp->regs->AHCLKRCTL = 0x00000000; // INT CLK (from tx side)) m. h1 f3 X! Y2 \; e1 e
mcasp->regs->RTDM = 0x00000003; // Slots 0,1
& [' B, U/ W* A9 |( E; X/ K mcasp->regs->RINTCTL = 0x00000000; // Not used
D5 G) ?' y2 g0 G+ v4 t mcasp->regs->RCLKCHK = 0x00FF0008; // 255-MAX 0-MIN, div-by-256
0 o% r( \' G% ~/ E, s( b3 {5 S; X! B! T! V& P3 h- A: z# P
mcasp->regs->XMASK = 0xFFFFFFFF; // No padding used/ O2 D) k* l$ |- b$ T
mcasp->regs->XFMT = 0x00018078; // MSB 16bit, 0-delay, no pad, CFGBus
+ H( S# g6 Z5 I mcasp->regs->AFSXCTL = 0x00000112; // 2TDM, 1bit Rising edge INTERNAL FS, word+ M: s( u) H% s3 X( E
mcasp->regs->ACLKXCTL = 0x000000AF; // ASYNC, Rising INTERNAL CLK, div-by-16
( e! i, y! y% l6 e. q mcasp->regs->AHCLKXCTL = 0x00000000; // EXT CLK
7 F8 a, P- m( }8 o1 _5 ~3 w! D, [ n mcasp->regs->XTDM = 0x00000003; // Slots 0,1
8 T6 r! j8 @! |4 H9 ~0 | mcasp->regs->XINTCTL = 0x00000020; // interrupt on transmit* T4 Y5 @5 S0 n7 P5 ]+ l
mcasp->regs->XCLKCHK = 0x00FF0008; // 255-MAX 0-MIN, div-by-256# L, A ^3 P s) x, j
# y$ j2 ]& a; E, t" l1 I) n mcasp->regs->SRCTL5 = 0x000D; // MCASP1.AXR1[5] --> DIN( q5 J3 Q( o! P0 |& I& Q
mcasp->regs->SRCTL0 = 0x000E; // MCASP1.AXR1[0] <-- DOUT
7 X. k, `* m+ U mcasp->regs->PFUNC = 0; // All MCASPs
% P# u9 |2 G" |' t- B+ o7 x) m& y mcasp->regs->PDIR = 0x14000020; // All inputs except AXR0[5], ACLKX1, AFSX13 Y7 p: Z# F8 e' K9 @
% i1 F! M0 P( c) i! e. D- Y
mcasp->regs->DITCTL = 0x00000000; // Not used& t7 p) \# J/ s
mcasp->regs->DLBCTL = 0x00000000; // Not used
1 E8 h2 U5 y: v. {* b S+ z mcasp->regs->AMUTE = 0x00000000; // Not used0 @* `! T% r* w! m& t
8 a" n7 u4 L5 E, ?
/* Starting sections of the McASP*/
6 _0 a: ~0 c6 [0 Q3 q mcasp->regs->XGBLCTL |= GBLCTL_XHCLKRST_ON;
5 c- J3 y1 \! v* B& T, m while ( ( mcasp->regs->XGBLCTL & GBLCTL_XHCLKRST_ON ) != GBLCTL_XHCLKRST_ON );
! k- }( v" f- F mcasp->regs->RGBLCTL |= GBLCTL_RHCLKRST_ON; ( {- k% J2 ^, g7 s/ z
while ( ( mcasp->regs->RGBLCTL & GBLCTL_RHCLKRST_ON ) != GBLCTL_RHCLKRST_ON );
6 `- ]. g) n' p/ C( i9 c4 X5 _' u- Y2 I
mcasp->regs->XGBLCTL |= GBLCTL_XCLKRST_ON; - |" B! M7 s( p d, ~0 c
while ( ( mcasp->regs->XGBLCTL & GBLCTL_XCLKRST_ON ) != GBLCTL_XCLKRST_ON );5 T; _ S; m) ]7 N. w
mcasp->regs->RGBLCTL |= GBLCTL_RCLKRST_ON; 0 {" |4 E& @( k% ~0 Y' }. q
while ( ( mcasp->regs->RGBLCTL & GBLCTL_RCLKRST_ON ) != GBLCTL_RCLKRST_ON );
0 k8 u* S& d/ c3 N( T' m J D- \8 C+ f) y
mcasp->regs->XSTAT = 0x0000ffff; ; L/ n G" {7 l4 d! v
mcasp->regs->RSTAT = 0x0000ffff;
5 H4 a* H) c* c! U. H; V
! Z( S$ I0 `' H- P6 c; R- {$ ~ mcasp->regs->XGBLCTL |= GBLCTL_XSRCLR_ON;" J# W) r# Z: w( v: C
while ( ( mcasp->regs->XGBLCTL & GBLCTL_XSRCLR_ON ) != GBLCTL_XSRCLR_ON );4 G) a% v W$ U' D* d" n" B
mcasp->regs->RGBLCTL |= GBLCTL_RSRCLR_ON; 8 M3 L* x2 E; l" T2 g
while ( ( mcasp->regs->RGBLCTL & GBLCTL_RSRCLR_ON ) != GBLCTL_RSRCLR_ON );/ r c* `. F' o& W% R
7 d$ Y$ t+ `6 x6 ~5 L- W# C# F /* Write a 0, so that no underrun occurs after releasing the state machine */# c) d h6 k' ^$ H# I! y
mcasp->regs->XBUF5 = 0;4 [, q4 F0 K, X) o' L- `6 Z
mcasp->regs->RBUF0 = 0;
* U7 N. P3 n' y9 Y. c1 F" x
% ~0 y: K: T' v9 I) Y& C9 `4 x4 Q mcasp->regs->XGBLCTL |= GBLCTL_XSMRST_ON;
9 m1 L5 Y/ l P0 K& H8 D while ( ( mcasp->regs->XGBLCTL & GBLCTL_XSMRST_ON ) != GBLCTL_XSMRST_ON );
" R& J# S0 T8 x6 S: {( J( S mcasp->regs->RGBLCTL |= GBLCTL_RSMRST_ON; . V1 k9 H: b2 U! }' J
while ( ( mcasp->regs->RGBLCTL & GBLCTL_RSMRST_ON ) != GBLCTL_RSMRST_ON );8 ?3 R- k7 B+ ?. l& o5 M
|; p; c# D3 Z) l! r9 B0 i" z
mcasp->regs->XGBLCTL |= GBLCTL_XFRST_ON; 2 n* A9 A F/ k% r5 z( Y$ @2 q2 A. x
while ( ( mcasp->regs->XGBLCTL & GBLCTL_XFRST_ON ) != GBLCTL_XFRST_ON );
$ V; j( s; T9 O mcasp->regs->RGBLCTL |= GBLCTL_RFRST_ON;
9 g- w9 d5 H- \; A5 M$ d* G while ( ( mcasp->regs->RGBLCTL & GBLCTL_RFRST_ON ) != GBLCTL_RFRST_ON );
; N v7 L$ y! Z ~" z2 x8 `: X
1 ^7 h% _! y7 o/ d, ] CSR = 0x0000;! d7 N+ v) R. r2 d: P( a
INTC_INTMUX1 = 0x3d;. H% d8 d3 H& j# g6 K
ISTP = (unsigned int)vectors;
k( l: ]( o1 j# x0 O1 r7 W, h ICR = 0xFFF0;
3 q' n$ w+ s( T- C1 j IER |= 0x12; : e4 W' v& ]# i5 A, B
CSR |= 0x01; 8 l2 C. @( P5 p. u
3 l9 i3 W2 _( U8 a- g
8 m: ?0 K( O( g/ c1 U( j5 s5 c3 {3 c' s& s4 b
还有就是两个输入输出函数:$ a! b' O+ O& g- ?1 m4 J0 g7 `
void output_sample(Int32 out_data)2 _: x2 d5 O5 n6 @3 v- V; Q
{
7 _3 h) j t8 ?8 b: m: m" h3 L, V8 e AIC31_data.uint = out_data;
% P2 w% ^; I' `$ b* n1 a3 q6 c' ^ MCASP1_XBUF5_32BIT = AIC31_data.uint;
/ V: d# G" a( l ~$ z: ?}
% p7 \7 e- H# r+ `9 e5 s" J& ~& t- W5 G. ?1 |
Int32 input_sample(void)9 C- d4 N( `; `
{ ! {9 e5 {* o+ e9 V# E( Y9 h
AIC31_data.uint = MCASP1_RBUF0_32BIT;# \) `8 ]% E8 u) B6 y W: Q
return (AIC31_data.uint); Y4 A/ X# `, L( i8 r w* L
}& h* e+ r5 @! [9 _
* ^8 ~# B1 |* o: f9 S ?! p
|
|