|
|
C6747和C6748感觉差不多,我想实现McASP发送中断方式控制音频信号,在轮询的例程基础上改的,轮询程序可以实现,但是中断一直实现不了,也找不到错误,求大神帮忙!下边是主要程序:
! q- r e+ ]& n2 R n1 ^0 F* p! Nmain文件:
: U- p$ Z" Z& i7 n4 r! |/ ^, binterrupt void interrupt4(void) 4 c8 I/ r: R; y6 F) v. t& X% |
{# n, T' r0 b6 s+ L4 L- s# L
Uint32 sample;
! B8 I% m8 d0 h) \9 G+ }$ Z* t
* L0 J: i) m; B4 n" X sample = input_sample(); // read L + R samples from ADC. k3 w/ h( M8 f' Y; _ f2 M
output_sample(sample); // write L + R samples to DAC + N f ?+ L L7 z* ?
return;3 x. u( }$ G' t) h, x
}% w( P; s8 c: Q4 c* \( `
! n# [# f" J5 {2 C
int main( void )
( { d' Z; U/ |/ K S& {) s{' h- V8 s5 i9 b
3 G/ H: i- K2 ?' M& e" Z1 l3 i
/* Initialize BSL */- ?7 |; u9 g2 O, b# Z% T4 y
EVMC6747_init( );/ [. g5 j+ i) t- O6 Y) j
/* Call evmc6747_intr function */- _* M6 m" P, C/ f
aic3106_init( );: t, z5 g/ {) H; `, D% a$ D
while(1);9 P) l W2 b. K" r+ Q* ^) v
}
- }0 Q. \/ Z. [0 @! G! |: Z# S$ l2 g$ }2 z: a0 n* Y7 C, }. ?' g2 ^
, N$ Q/ {* K; ?7 d& q. A; Y
aic3106_init文件的一部分,McASP配置部分,采用内部时钟,I2S方式,同步传输。音频芯片的配置应该没问题
; s4 z" O% O% d" C( q8 z/* Initialize MCASP1 */
& I) Z8 T) u, ^8 V9 e i$ _ mcasp = &MCASP_MODULE_1;+ B+ i4 Q4 W `) l/ q3 V2 U9 Q
mcasp->regs->GBLCTL = 0; // Reset% ^4 ^+ o: |! y t0 k7 c. z
mcasp->regs->RGBLCTL = 0; // Reset RX& N3 T2 _7 b8 s- t0 U# l
mcasp->regs->XGBLCTL = 0; // Reset TX \! l% o. G3 o9 F7 N! u/ H2 M
mcasp->regs->PWRDEMU = 1; // Free-running7 Q6 @5 R" U' ~* Z
// configure McASP0 receive registers3 w4 q1 ~* h) k9 ?2 q* r% X, {" X
mcasp->regs->RMASK = 0xFFFFFFFF; // No padding used
5 o( @& k" m5 Z* T% r& u mcasp->regs->RFMT = 0x00018078; // MSB 16bit, 0-delay, no pad, CFGBus
9 z& ^. v( \, ~# U/ ~ mcasp->regs->AFSRCTL = 0x00000112; // 2TDM, 1bit Falling, External FS, word$ r1 A. r Z' W/ B" L
mcasp->regs->ACLKRCTL = 0x000000AF; // Rising INTERNAL CLK,(from tx side)
( N; p2 s ^* j# m mcasp->regs->AHCLKRCTL = 0x00000000; // INT CLK (from tx side)9 s2 q; @+ R+ I* m
mcasp->regs->RTDM = 0x00000003; // Slots 0,1
% B. K: v% C: l, N; n# S" U- q mcasp->regs->RINTCTL = 0x00000000; // Not used
5 W% N8 k# i5 R$ [ mcasp->regs->RCLKCHK = 0x00FF0008; // 255-MAX 0-MIN, div-by-256' o! P* z6 U' j8 {4 I
( U. g$ V# Q* x$ K* n
mcasp->regs->XMASK = 0xFFFFFFFF; // No padding used
0 Z2 S# A, R- ~ mcasp->regs->XFMT = 0x00018078; // MSB 16bit, 0-delay, no pad, CFGBus
& |! d% Q2 M) d% `: H mcasp->regs->AFSXCTL = 0x00000112; // 2TDM, 1bit Rising edge INTERNAL FS, word
+ I9 r$ a8 s- ]4 p6 ? mcasp->regs->ACLKXCTL = 0x000000AF; // ASYNC, Rising INTERNAL CLK, div-by-166 F: `% P# r, L H3 R0 h
mcasp->regs->AHCLKXCTL = 0x00000000; // EXT CLK) N4 ]! a0 b6 A! b& I2 p) v
mcasp->regs->XTDM = 0x00000003; // Slots 0,1/ [9 O: F* G; ?. d% U; k' g3 Y- j/ y* m% Y
mcasp->regs->XINTCTL = 0x00000020; // interrupt on transmit
. j2 }6 G1 h! j, k mcasp->regs->XCLKCHK = 0x00FF0008; // 255-MAX 0-MIN, div-by-256
# {8 N, [5 o0 W/ Y/ b# r( K' M2 H/ i; w2 o. ]) Q, X
mcasp->regs->SRCTL5 = 0x000D; // MCASP1.AXR1[5] --> DIN$ _5 x$ c8 c1 U7 W& r) j4 e3 _
mcasp->regs->SRCTL0 = 0x000E; // MCASP1.AXR1[0] <-- DOUT0 m y) n# l- U+ u5 L4 S4 j* U
mcasp->regs->PFUNC = 0; // All MCASPs
4 H" t$ m7 @: S) ? X0 e# q$ s mcasp->regs->PDIR = 0x14000020; // All inputs except AXR0[5], ACLKX1, AFSX11 S2 ~; J& H% \4 K. ]
4 O2 F( F+ Y: w0 Q% t
mcasp->regs->DITCTL = 0x00000000; // Not used6 _" U) h) O' ^
mcasp->regs->DLBCTL = 0x00000000; // Not used v3 O2 ^6 U$ u0 j/ Q4 e# Y
mcasp->regs->AMUTE = 0x00000000; // Not used
8 h9 P- A+ n& y5 Z8 w/ B, r5 q! T
( P, Z# l/ D& ]7 p( [7 c; [9 N/* Starting sections of the McASP*/1 v9 ?& Q! a/ J1 Q+ e
mcasp->regs->XGBLCTL |= GBLCTL_XHCLKRST_ON;
& Q" Z# j8 R, o# y* \ while ( ( mcasp->regs->XGBLCTL & GBLCTL_XHCLKRST_ON ) != GBLCTL_XHCLKRST_ON );
- z d3 r' k% Q8 l& H mcasp->regs->RGBLCTL |= GBLCTL_RHCLKRST_ON; ! \: e! U9 C& V2 ^. T
while ( ( mcasp->regs->RGBLCTL & GBLCTL_RHCLKRST_ON ) != GBLCTL_RHCLKRST_ON );9 T# X( ^% S9 j& q4 G
$ k4 d) K( u6 T$ [. I J( m6 X. r5 g mcasp->regs->XGBLCTL |= GBLCTL_XCLKRST_ON;
5 A/ n: {4 s' X# _* O6 X while ( ( mcasp->regs->XGBLCTL & GBLCTL_XCLKRST_ON ) != GBLCTL_XCLKRST_ON );
7 D& z4 x9 w G! p mcasp->regs->RGBLCTL |= GBLCTL_RCLKRST_ON; % {8 m# H W+ |) v9 v/ r* G
while ( ( mcasp->regs->RGBLCTL & GBLCTL_RCLKRST_ON ) != GBLCTL_RCLKRST_ON );, v; K& f) v$ y' F& L/ |1 F
* b% j [2 e S! G8 |" Z mcasp->regs->XSTAT = 0x0000ffff; ( x9 T# y8 C' B: r6 b
mcasp->regs->RSTAT = 0x0000ffff;
9 f2 b1 \0 l' q4 h9 d3 C! m! F' i! m4 ?' v8 j" ~( W' S
mcasp->regs->XGBLCTL |= GBLCTL_XSRCLR_ON;. A( C; O; P3 q0 |
while ( ( mcasp->regs->XGBLCTL & GBLCTL_XSRCLR_ON ) != GBLCTL_XSRCLR_ON );
! F3 b$ i4 k* g$ k, `/ K: N9 ~5 X mcasp->regs->RGBLCTL |= GBLCTL_RSRCLR_ON;
0 {) W6 W/ z% M% G) o( V while ( ( mcasp->regs->RGBLCTL & GBLCTL_RSRCLR_ON ) != GBLCTL_RSRCLR_ON );
2 x8 a# H. ]+ O4 s8 o5 u- t! M0 ]% n$ l/ y* _9 D+ F
/* Write a 0, so that no underrun occurs after releasing the state machine */
( y; j- d2 _) p6 n/ Y0 L mcasp->regs->XBUF5 = 0;& p; ]' x) \- {$ j. ~
mcasp->regs->RBUF0 = 0;% u: r2 ]& p, i. h
. \. D/ c+ G$ B- m; Q: B7 l# i
mcasp->regs->XGBLCTL |= GBLCTL_XSMRST_ON;
" Q2 J5 o/ a7 z" T5 v( f while ( ( mcasp->regs->XGBLCTL & GBLCTL_XSMRST_ON ) != GBLCTL_XSMRST_ON );
8 D& j+ c3 R a, W& E mcasp->regs->RGBLCTL |= GBLCTL_RSMRST_ON;
, e! w& T6 ^0 _; j I6 d! `- s while ( ( mcasp->regs->RGBLCTL & GBLCTL_RSMRST_ON ) != GBLCTL_RSMRST_ON );
5 _- g, c6 W6 L: @3 H4 v2 u o# s6 o7 b3 p1 [" `) q
mcasp->regs->XGBLCTL |= GBLCTL_XFRST_ON; I- @2 B: d7 M
while ( ( mcasp->regs->XGBLCTL & GBLCTL_XFRST_ON ) != GBLCTL_XFRST_ON );
% |& e& b6 v. \ mcasp->regs->RGBLCTL |= GBLCTL_RFRST_ON;
7 x# s* v# n! e5 X. A$ ]7 C$ f+ p while ( ( mcasp->regs->RGBLCTL & GBLCTL_RFRST_ON ) != GBLCTL_RFRST_ON );
% h& r( Y& x+ g7 G& ^9 r' X0 y r' S7 `) {8 H
CSR = 0x0000;( E" _% u: B: b O+ ? @2 k
INTC_INTMUX1 = 0x3d;
8 _3 c) \7 L# q ISTP = (unsigned int)vectors;
% |( d# T. O9 q ICR = 0xFFF0; 1 q C- ?% o: |+ U6 i
IER |= 0x12;
2 a, F) {/ ? }+ W5 e CSR |= 0x01; ( T: g G/ Z. e! ~
) m4 `$ E! p* j5 z% `! E2 Z+ |" D M
6 I# V c, n" _" x6 h6 y2 A1 v还有就是两个输入输出函数:
; M1 z* b, f+ w# Kvoid output_sample(Int32 out_data)' _0 ?; V6 l5 t+ i
{
( u P7 ^) G K" P0 _$ ` q3 s! Y: u AIC31_data.uint = out_data; % u9 J+ K U- L0 }) Y! N/ r% s
MCASP1_XBUF5_32BIT = AIC31_data.uint;
% |$ L& V" i, m4 P0 S4 T; X} E7 j) W0 D) _0 ^! j8 N+ j
: x9 n" V6 w) C& J' }Int32 input_sample(void)# Q( L4 B+ d8 ~8 N0 ~" W& P
{ b; p. {7 P8 V4 d' `5 L
AIC31_data.uint = MCASP1_RBUF0_32BIT;) k2 C# [& j0 z5 y3 ]) f. K, x0 w
return (AIC31_data.uint);8 v0 a- m& R! f: o" j* n0 ~
}
$ x3 y" h* g1 r5 w+ q) W$ k- ` _6 R$ _
|
|