|
|
C6747和C6748感觉差不多,我想实现McASP发送中断方式控制音频信号,在轮询的例程基础上改的,轮询程序可以实现,但是中断一直实现不了,也找不到错误,求大神帮忙!下边是主要程序:1 `9 E" X& k7 k& a
main文件:1 e$ o3 f' e% J! m
interrupt void interrupt4(void) 9 b" m% G+ E9 v* y% G& N0 {% v3 w9 L8 }
{
: W- b6 ?2 ? J C) y8 t Uint32 sample;
$ }3 u: O# a# O6 L$ i1 I- Q$ ~9 E2 A0 _7 j3 A6 H3 h0 s( ?
sample = input_sample(); // read L + R samples from ADC+ U9 x) h4 i1 P1 v; C
output_sample(sample); // write L + R samples to DAC 4 U; k/ G3 l& A: F
return;
2 M$ W2 E: V! |- J3 P" w) X}
% d( C1 a* O C s4 B+ V4 y! Y6 J* {$ I4 w8 F- j
int main( void )& h' ]* ~5 C; Q. o# B* C: ~
{8 l9 {4 U! x7 m1 K4 A
) r `0 n3 b0 ?7 w* T [ /* Initialize BSL */
2 D3 Z/ U; A8 l& p! c. n EVMC6747_init( );
( d7 O2 D9 x0 v S1 @* v /* Call evmc6747_intr function */2 E! N* Y! z# [" V. ]! T o- c
aic3106_init( );
" F5 ] Z4 c7 R7 m while(1);
1 H0 D* @/ I# {}0 Z0 f5 G# ~: ]- d6 g
3 w, l3 k& e; j* A# ?" E( F. N- V3 Z+ j1 o& H( [5 v/ l
aic3106_init文件的一部分,McASP配置部分,采用内部时钟,I2S方式,同步传输。音频芯片的配置应该没问题
" g5 k9 T& Z$ E1 r) W/* Initialize MCASP1 */3 C, M- V! b& u8 [# L' ?: n
mcasp = &MCASP_MODULE_1;
* A7 d& W, e5 S mcasp->regs->GBLCTL = 0; // Reset
% y! C3 c' v: C, n. z, y' O. j1 D mcasp->regs->RGBLCTL = 0; // Reset RX
( a4 N, N* c" ]7 q( b/ H mcasp->regs->XGBLCTL = 0; // Reset TX
$ I X8 r6 J' _: Q' L2 ^& z: | mcasp->regs->PWRDEMU = 1; // Free-running' `: L+ C* e7 y* }+ F4 H% z8 e
// configure McASP0 receive registers
% y3 I9 H5 \; t% k mcasp->regs->RMASK = 0xFFFFFFFF; // No padding used9 c o; j2 F8 U+ b
mcasp->regs->RFMT = 0x00018078; // MSB 16bit, 0-delay, no pad, CFGBus
7 ^9 G+ v6 l8 N* P S mcasp->regs->AFSRCTL = 0x00000112; // 2TDM, 1bit Falling, External FS, word
% Q6 g& U/ }0 B- O3 R" F4 H" e mcasp->regs->ACLKRCTL = 0x000000AF; // Rising INTERNAL CLK,(from tx side)
4 k' u. E& _) n9 H( G mcasp->regs->AHCLKRCTL = 0x00000000; // INT CLK (from tx side)5 D( D4 O. R6 C' Y3 `
mcasp->regs->RTDM = 0x00000003; // Slots 0,1! H2 ]# j0 D* k' f/ h N7 O" f
mcasp->regs->RINTCTL = 0x00000000; // Not used
( R7 O5 Z* v+ ]( r& a- t& V/ x mcasp->regs->RCLKCHK = 0x00FF0008; // 255-MAX 0-MIN, div-by-256
" C9 Q1 G5 k& C: { Z9 e `5 O- k* G* i
mcasp->regs->XMASK = 0xFFFFFFFF; // No padding used# j% v& N& s3 j' `
mcasp->regs->XFMT = 0x00018078; // MSB 16bit, 0-delay, no pad, CFGBus, E5 r3 i7 S4 _! Q/ b
mcasp->regs->AFSXCTL = 0x00000112; // 2TDM, 1bit Rising edge INTERNAL FS, word
+ R2 j% i/ E1 [ mcasp->regs->ACLKXCTL = 0x000000AF; // ASYNC, Rising INTERNAL CLK, div-by-16+ w3 x" u2 ^) x1 t' `* j" {
mcasp->regs->AHCLKXCTL = 0x00000000; // EXT CLK" ]/ _/ p9 L. E" x* b; B% p# C
mcasp->regs->XTDM = 0x00000003; // Slots 0,1
|) t z9 J" c9 y; [# w. Z mcasp->regs->XINTCTL = 0x00000020; // interrupt on transmit
9 K$ P% w: K9 y! p mcasp->regs->XCLKCHK = 0x00FF0008; // 255-MAX 0-MIN, div-by-2563 p8 K+ n! s/ T4 Q4 n
' N6 j6 p) J+ ~; W& q
mcasp->regs->SRCTL5 = 0x000D; // MCASP1.AXR1[5] --> DIN# t6 [1 Z) D6 ?2 ]& q6 {
mcasp->regs->SRCTL0 = 0x000E; // MCASP1.AXR1[0] <-- DOUT
. `5 N& n( m& Y/ Y mcasp->regs->PFUNC = 0; // All MCASPs
, }, a6 B E5 [( x mcasp->regs->PDIR = 0x14000020; // All inputs except AXR0[5], ACLKX1, AFSX1# h0 a; P+ h5 g% j7 x3 p
4 K8 S' `' I ~: l6 m% q
mcasp->regs->DITCTL = 0x00000000; // Not used
" S! m% k0 Q' k+ C6 W" R& X- h+ _ mcasp->regs->DLBCTL = 0x00000000; // Not used
$ V! n3 `# A b2 e mcasp->regs->AMUTE = 0x00000000; // Not used
3 f9 x* q6 u9 \5 b# G2 ]
3 z' z6 L. n# p0 K( t$ q5 @/* Starting sections of the McASP*/8 [8 q: R' H% Q6 F( Q( ?
mcasp->regs->XGBLCTL |= GBLCTL_XHCLKRST_ON;
! }! e5 F7 y* {6 l4 p1 k+ ?' T# l1 Q while ( ( mcasp->regs->XGBLCTL & GBLCTL_XHCLKRST_ON ) != GBLCTL_XHCLKRST_ON );
# e3 v3 `2 Q ^# G/ C$ ] mcasp->regs->RGBLCTL |= GBLCTL_RHCLKRST_ON;
. v) @. p/ c8 k) ~6 N( F while ( ( mcasp->regs->RGBLCTL & GBLCTL_RHCLKRST_ON ) != GBLCTL_RHCLKRST_ON );3 u5 W0 h0 L+ }' U- r
2 x8 x' H1 c) t. S( ~) u, G
mcasp->regs->XGBLCTL |= GBLCTL_XCLKRST_ON; 9 k, Y/ U. ^1 n6 Z3 r8 Q
while ( ( mcasp->regs->XGBLCTL & GBLCTL_XCLKRST_ON ) != GBLCTL_XCLKRST_ON );
6 I9 o' p5 } q: g0 g2 k5 r6 l mcasp->regs->RGBLCTL |= GBLCTL_RCLKRST_ON; . P8 j t: H5 ?5 R6 d/ B
while ( ( mcasp->regs->RGBLCTL & GBLCTL_RCLKRST_ON ) != GBLCTL_RCLKRST_ON );
; m1 A1 O, Y* j6 ?% V0 H" k- l& x; ]# O, B
mcasp->regs->XSTAT = 0x0000ffff; 1 m/ s4 B4 }9 Q! P" b1 D+ ^% D# |( ^
mcasp->regs->RSTAT = 0x0000ffff; - J/ D% t- ~2 {& C
! I" s- h& B- x
mcasp->regs->XGBLCTL |= GBLCTL_XSRCLR_ON;! t$ u: e& E9 Q# F. F- l2 I
while ( ( mcasp->regs->XGBLCTL & GBLCTL_XSRCLR_ON ) != GBLCTL_XSRCLR_ON );* D" }, f$ s3 w0 ?6 }* v a
mcasp->regs->RGBLCTL |= GBLCTL_RSRCLR_ON;
' _1 {$ U' V6 O& k% } while ( ( mcasp->regs->RGBLCTL & GBLCTL_RSRCLR_ON ) != GBLCTL_RSRCLR_ON );. b$ @6 S8 c: _4 n; W( p7 j# b! |
' ?0 m4 _! Z k
/* Write a 0, so that no underrun occurs after releasing the state machine */9 A/ w/ m4 Z! w& g
mcasp->regs->XBUF5 = 0;8 A$ q( t( }" w0 x7 j8 i6 [' c
mcasp->regs->RBUF0 = 0;
9 `7 ?# I7 q7 o6 ~0 h
$ ]* S3 J$ y# X/ a. T mcasp->regs->XGBLCTL |= GBLCTL_XSMRST_ON; * [3 ~5 b* I5 L0 w1 k7 R
while ( ( mcasp->regs->XGBLCTL & GBLCTL_XSMRST_ON ) != GBLCTL_XSMRST_ON );
6 c: @' o. x7 W5 M$ C+ x6 i mcasp->regs->RGBLCTL |= GBLCTL_RSMRST_ON;
4 m- H6 D) L4 i; L while ( ( mcasp->regs->RGBLCTL & GBLCTL_RSMRST_ON ) != GBLCTL_RSMRST_ON );
( t; N, }7 G3 U% m4 E _1 X" ]8 v+ `3 a5 P+ d1 y
mcasp->regs->XGBLCTL |= GBLCTL_XFRST_ON;
% b. @: B( [5 t while ( ( mcasp->regs->XGBLCTL & GBLCTL_XFRST_ON ) != GBLCTL_XFRST_ON );
( o" M) F4 K2 E, F2 R( h mcasp->regs->RGBLCTL |= GBLCTL_RFRST_ON; 6 B; V+ u/ w5 |" v
while ( ( mcasp->regs->RGBLCTL & GBLCTL_RFRST_ON ) != GBLCTL_RFRST_ON );
* {. r' R6 Z z- d( I0 p* \6 Z
; }$ [5 a/ N9 f/ b1 w CSR = 0x0000;
- p3 @0 o1 i8 a' k$ ^9 y. [ INTC_INTMUX1 = 0x3d;
' t: e: f, B( I$ Z2 z7 f g ISTP = (unsigned int)vectors;
' @" _# h h& U1 D1 X ICR = 0xFFF0; x; y! u) N1 N- }5 U: `. d9 E
IER |= 0x12;
4 X; Z% P P; I& q+ d CSR |= 0x01; 7 Z3 y3 q' K" `) H7 ?) Y: H
3 s! |! b1 V% w$ s+ C6 s0 r8 B1 l. M' a
2 ~; `- U, i T9 B% z) k* @还有就是两个输入输出函数:; `$ T6 p8 |. x# }( J( u
void output_sample(Int32 out_data)) B4 z; T( F% k
{
4 B. Q& R# g8 e8 U( r AIC31_data.uint = out_data; + d$ }. N, v7 _9 q$ ?. X1 q# j
MCASP1_XBUF5_32BIT = AIC31_data.uint;7 L; C2 _ A% @, S. | y. z. ?
}
+ W* ?1 j6 j/ R% k/ @+ {" o
2 T5 {1 c- g7 N3 {Int32 input_sample(void)
( E5 v, p5 a% L{
. I* E9 b% `0 L' `' T7 A! o* Q! A AIC31_data.uint = MCASP1_RBUF0_32BIT;6 [: E) T" f% N
return (AIC31_data.uint);
& Y% h7 f) q. ^7 i( F; V A}
2 U& J- Y. u, k0 {5 R% i2 k
3 \- T7 Q$ [8 b* h |
|