|
|
C6747和C6748感觉差不多,我想实现McASP发送中断方式控制音频信号,在轮询的例程基础上改的,轮询程序可以实现,但是中断一直实现不了,也找不到错误,求大神帮忙!下边是主要程序:
5 q. Z: Z/ f2 Smain文件:
, h3 ?! f/ n9 a$ u9 I8 v. Z zinterrupt void interrupt4(void) & q! w' x: G3 R* H
{6 d1 W4 K- J# n/ g# H7 H# @5 S
Uint32 sample;
9 \: N. v3 M$ G6 ^% S/ }9 \
+ P7 r9 l% S" x sample = input_sample(); // read L + R samples from ADC r$ a! V5 d, x- o
output_sample(sample); // write L + R samples to DAC 3 u7 r- t5 a/ s, K" H2 k, J
return;
1 d. {9 a! f+ W7 B5 t1 ?2 ^}
6 [! S8 h; C" ~6 ^
4 Q8 k+ J* p/ I$ L! Z/ U! Kint main( void )7 k: O& G! U4 a/ r$ S; V9 t
{, b( W Y+ W8 o# z1 V( g0 r& [
5 D# K3 r, @) v. D+ r1 J6 e) S; K6 Z8 \
/* Initialize BSL */
9 V$ M9 C8 p* Z8 w' `/ L `8 r& O1 ? EVMC6747_init( );
1 D( v6 r! d8 i /* Call evmc6747_intr function */9 Y( }- d% M8 e2 `7 U9 `* a
aic3106_init( );
7 f; M( v9 `* d while(1);3 n3 Y- }8 o) D- z7 \" g- X, P3 k" I
}! a, u+ `$ ~. k" b3 d# d
6 Q/ _% n! Y7 C& E
. E/ }- C% O2 `0 _" v0 F9 Yaic3106_init文件的一部分,McASP配置部分,采用内部时钟,I2S方式,同步传输。音频芯片的配置应该没问题8 U7 B& Q' |/ D! Y: ^
/* Initialize MCASP1 */
' _) f6 o+ c7 j( F mcasp = &MCASP_MODULE_1;
) @ U& l6 z5 }0 K8 B, l mcasp->regs->GBLCTL = 0; // Reset M7 y/ U. Z( F- H& Y8 I
mcasp->regs->RGBLCTL = 0; // Reset RX
3 F0 u$ Y( k' }+ q mcasp->regs->XGBLCTL = 0; // Reset TX( R7 o& Z& i1 l; b+ e& g' b
mcasp->regs->PWRDEMU = 1; // Free-running
' a L2 A2 e! H! [: e$ E // configure McASP0 receive registers
t7 b4 b1 k |9 m; q mcasp->regs->RMASK = 0xFFFFFFFF; // No padding used
% Z9 m! q1 V% J& I mcasp->regs->RFMT = 0x00018078; // MSB 16bit, 0-delay, no pad, CFGBus3 P9 w* \: N8 E& c2 Q
mcasp->regs->AFSRCTL = 0x00000112; // 2TDM, 1bit Falling, External FS, word' B' W3 g% @+ b
mcasp->regs->ACLKRCTL = 0x000000AF; // Rising INTERNAL CLK,(from tx side)
, E$ X- e; A) C* J& o mcasp->regs->AHCLKRCTL = 0x00000000; // INT CLK (from tx side)
" b( _6 Y) H' j) x; k6 u' _ mcasp->regs->RTDM = 0x00000003; // Slots 0,1
# Q1 a( y8 T* K) ~4 O$ I4 X* J mcasp->regs->RINTCTL = 0x00000000; // Not used( f8 n2 C+ s: b# ~3 S. P
mcasp->regs->RCLKCHK = 0x00FF0008; // 255-MAX 0-MIN, div-by-2560 }0 W- g. f# T
6 S- M3 h8 r# h% U( {5 T1 D
mcasp->regs->XMASK = 0xFFFFFFFF; // No padding used! ^& ?1 O! G1 q3 q1 ~5 g2 F7 M) N
mcasp->regs->XFMT = 0x00018078; // MSB 16bit, 0-delay, no pad, CFGBus+ B8 w. C4 s3 B/ S8 }1 I
mcasp->regs->AFSXCTL = 0x00000112; // 2TDM, 1bit Rising edge INTERNAL FS, word
, {' A# l; M' d% W9 I8 \0 R+ ` mcasp->regs->ACLKXCTL = 0x000000AF; // ASYNC, Rising INTERNAL CLK, div-by-16" v! H7 B8 i% i3 d# q% i
mcasp->regs->AHCLKXCTL = 0x00000000; // EXT CLK4 g& Y5 I$ y( f: `) n( U
mcasp->regs->XTDM = 0x00000003; // Slots 0,1+ C" N5 ?* G9 C$ f% b
mcasp->regs->XINTCTL = 0x00000020; // interrupt on transmit3 k, [# h1 ?) y* g, l7 \
mcasp->regs->XCLKCHK = 0x00FF0008; // 255-MAX 0-MIN, div-by-2560 v% V d2 o. H# m
. [* k3 j& e) O" V. U mcasp->regs->SRCTL5 = 0x000D; // MCASP1.AXR1[5] --> DIN
$ B# X; n' }0 @ mcasp->regs->SRCTL0 = 0x000E; // MCASP1.AXR1[0] <-- DOUT
0 }1 l$ |* q/ U5 ~5 k mcasp->regs->PFUNC = 0; // All MCASPs
( L" J0 f* d% W" T mcasp->regs->PDIR = 0x14000020; // All inputs except AXR0[5], ACLKX1, AFSX1
* k) N& x% k7 m
3 z% W* }+ x2 D mcasp->regs->DITCTL = 0x00000000; // Not used
) N x. X, f2 a2 l: b+ P mcasp->regs->DLBCTL = 0x00000000; // Not used
* n5 G. V0 Q0 K" ? mcasp->regs->AMUTE = 0x00000000; // Not used
) c. \; T( u4 a7 I; ^% ]3 j6 U, K1 M; A! V$ z7 C! D
/* Starting sections of the McASP*/
3 n0 b) K$ E- ]. k mcasp->regs->XGBLCTL |= GBLCTL_XHCLKRST_ON;
; _5 A: b, w7 f. T while ( ( mcasp->regs->XGBLCTL & GBLCTL_XHCLKRST_ON ) != GBLCTL_XHCLKRST_ON );
1 x6 ?5 e" ^2 h `& w& ~( Z mcasp->regs->RGBLCTL |= GBLCTL_RHCLKRST_ON; ; |+ o/ f7 L2 t1 G% C4 i: R3 K) b
while ( ( mcasp->regs->RGBLCTL & GBLCTL_RHCLKRST_ON ) != GBLCTL_RHCLKRST_ON );2 s0 e! y# |0 i# V0 C3 B& D4 T
0 C6 y2 l/ k3 T) ?+ i mcasp->regs->XGBLCTL |= GBLCTL_XCLKRST_ON;
Z$ u, ~: }+ c& l- L while ( ( mcasp->regs->XGBLCTL & GBLCTL_XCLKRST_ON ) != GBLCTL_XCLKRST_ON );) t1 G, t0 g. x6 y
mcasp->regs->RGBLCTL |= GBLCTL_RCLKRST_ON; - d) r8 m6 \- X9 j" k# D. C$ B; q
while ( ( mcasp->regs->RGBLCTL & GBLCTL_RCLKRST_ON ) != GBLCTL_RCLKRST_ON );/ H4 H a6 p% s' n/ ]* ^
: D4 n g& ^( E7 c4 Y
mcasp->regs->XSTAT = 0x0000ffff; : S2 q" @ C% |$ E
mcasp->regs->RSTAT = 0x0000ffff;
( X a6 w& E; }. K2 ]! g7 I" t
) B1 K/ }3 B- {# F* a mcasp->regs->XGBLCTL |= GBLCTL_XSRCLR_ON;
: `0 r. v# H4 Q; ~! D3 n while ( ( mcasp->regs->XGBLCTL & GBLCTL_XSRCLR_ON ) != GBLCTL_XSRCLR_ON );
) Y) o2 y3 Q+ }' K& n) w! f mcasp->regs->RGBLCTL |= GBLCTL_RSRCLR_ON; 7 r4 }8 `1 g* F; U
while ( ( mcasp->regs->RGBLCTL & GBLCTL_RSRCLR_ON ) != GBLCTL_RSRCLR_ON );
& Y# B7 y" a1 u. O% U- B
5 J+ M" v) U9 k% w( [9 E /* Write a 0, so that no underrun occurs after releasing the state machine */ b$ V! r; E9 O9 T' S3 }
mcasp->regs->XBUF5 = 0;
# ? _ \9 ?4 G4 J mcasp->regs->RBUF0 = 0;
& w; y0 \5 M: p6 N7 q0 K0 B5 J
$ V3 q+ G8 a) ^$ r |, Q; P6 E" X mcasp->regs->XGBLCTL |= GBLCTL_XSMRST_ON; / x4 b! U$ J. B, n
while ( ( mcasp->regs->XGBLCTL & GBLCTL_XSMRST_ON ) != GBLCTL_XSMRST_ON );
6 K; q% Y$ h2 ? O- _& ` mcasp->regs->RGBLCTL |= GBLCTL_RSMRST_ON;
# i8 v! W3 Y. `3 C' u' C7 } while ( ( mcasp->regs->RGBLCTL & GBLCTL_RSMRST_ON ) != GBLCTL_RSMRST_ON );
" \9 C$ K: b% t' F4 c0 G$ o0 @; a
9 B- x$ Q' ~+ G E6 A W mcasp->regs->XGBLCTL |= GBLCTL_XFRST_ON;
8 k; D V& ?4 A0 ? L7 v2 \* S while ( ( mcasp->regs->XGBLCTL & GBLCTL_XFRST_ON ) != GBLCTL_XFRST_ON );
$ O+ c& A3 Q' \" q mcasp->regs->RGBLCTL |= GBLCTL_RFRST_ON;
$ @ v' n0 `' `' a7 E while ( ( mcasp->regs->RGBLCTL & GBLCTL_RFRST_ON ) != GBLCTL_RFRST_ON );
+ ?* z5 @1 _2 ]+ s+ ~
# [8 E* S; Y( b1 Z CSR = 0x0000;8 r! E8 L! s3 z5 a& n! ~
INTC_INTMUX1 = 0x3d;
$ l9 ~0 o: G Q ISTP = (unsigned int)vectors;- Y$ b8 o0 t& y: T6 J7 p1 t' M* |
ICR = 0xFFF0;
& V$ c# J- S9 Y& _$ v+ n% q( h4 B IER |= 0x12;
9 ~4 v5 v5 k6 O8 i CSR |= 0x01;
: u5 N" W/ h) x; p: d
2 S. S/ ^$ Q4 m! U; ~9 P' B! V! W. r: c# A0 x4 `- j
! \. Q/ S1 Q4 n& h
还有就是两个输入输出函数:5 s) V2 B6 L% U; M
void output_sample(Int32 out_data); K: A, s/ A- F2 Z+ G5 f' h$ f
{( _$ ~1 v1 l' A2 H" v, S* m2 g
AIC31_data.uint = out_data; 9 Y3 `1 a4 C- |. m8 m0 @9 j O) a. E0 H+ [
MCASP1_XBUF5_32BIT = AIC31_data.uint;7 l, N# n# d. H. [! ~( H1 p
}2 I7 ^( O7 }% Z) G+ t6 d" s2 x; g" J
& q( S5 Q0 q: Y% wInt32 input_sample(void)$ W! y* s$ y+ d6 d& ~, a" ^
{
: a# t( w% `) q7 X' K% _" {9 ~+ C AIC31_data.uint = MCASP1_RBUF0_32BIT;% `( _5 p& p" J+ p7 A- V! ~0 H- y1 i
return (AIC31_data.uint);6 ?, Q7 D5 O0 n# S9 H! K, _$ J
}7 d6 x" H L* g
4 k( ~9 v& p" J- D' c1 Z1 d |
|