|
|
C6747和C6748感觉差不多,我想实现McASP发送中断方式控制音频信号,在轮询的例程基础上改的,轮询程序可以实现,但是中断一直实现不了,也找不到错误,求大神帮忙!下边是主要程序:
, j' O; M W; Ymain文件:* H8 X1 ]. ?0 y$ W
interrupt void interrupt4(void) : Q7 J. v$ b4 x/ }! ]9 m% N4 }
{& M% P6 H/ y* z- l
Uint32 sample;
@6 }+ ?+ _* _( G) |* c' s) x
4 h" a% |) k, a+ y& O2 _3 p sample = input_sample(); // read L + R samples from ADC: G, L# a( Y/ k; p: Q9 L2 S
output_sample(sample); // write L + R samples to DAC
; C3 [+ C& N/ {2 o4 F return;$ t1 V* Z1 R6 |$ ~5 N, c
}, j* f, h: M- N5 _: b P. a1 G. b" z
& o! c- ~3 X* Q( kint main( void )0 Q* ~6 j9 m# c* W) U0 w
{
. ?) p& `" ~0 j: r
2 L; s+ C* U% W /* Initialize BSL */6 e9 {4 K6 u Y4 G7 B
EVMC6747_init( );9 S6 e, }: q* i7 [
/* Call evmc6747_intr function */2 @+ d, w7 x8 i2 F0 t( h) \& E* P+ M% S
aic3106_init( );$ ^2 s: D$ H- D: z1 D' n
while(1);
: A+ e! O$ U8 C9 f# `' n}
2 v- k4 ?# D/ b7 o% Y) p1 [+ Y0 _: D2 ~
; w; D* i7 o8 Saic3106_init文件的一部分,McASP配置部分,采用内部时钟,I2S方式,同步传输。音频芯片的配置应该没问题
5 K- V" w3 G; L# C/* Initialize MCASP1 */- u+ q- D O2 @4 d8 x
mcasp = &MCASP_MODULE_1;9 G/ T/ W# T; m$ N
mcasp->regs->GBLCTL = 0; // Reset
& k* s* c! V% d" ]5 ~$ I- R mcasp->regs->RGBLCTL = 0; // Reset RX( O/ r7 f0 p( G# Z9 {
mcasp->regs->XGBLCTL = 0; // Reset TX/ z5 {: I$ a5 m6 |
mcasp->regs->PWRDEMU = 1; // Free-running
- f; a: e( ^; a: r/ g6 r2 C // configure McASP0 receive registers
) E) k3 R) k8 t' F/ d mcasp->regs->RMASK = 0xFFFFFFFF; // No padding used
. o4 P' j& Q7 O9 U mcasp->regs->RFMT = 0x00018078; // MSB 16bit, 0-delay, no pad, CFGBus7 {) A; ]9 Y6 _. W! [
mcasp->regs->AFSRCTL = 0x00000112; // 2TDM, 1bit Falling, External FS, word
$ w! M. _. ~* I$ V mcasp->regs->ACLKRCTL = 0x000000AF; // Rising INTERNAL CLK,(from tx side)) `- R& o% l; r1 l1 f# [
mcasp->regs->AHCLKRCTL = 0x00000000; // INT CLK (from tx side)
& a. A) @; ?; l, O4 c3 \4 S mcasp->regs->RTDM = 0x00000003; // Slots 0,1; c% \. v) [1 e5 s. [$ u
mcasp->regs->RINTCTL = 0x00000000; // Not used
% ^$ `1 F$ T( g! N/ M' ]) k, g. P2 h) e( D mcasp->regs->RCLKCHK = 0x00FF0008; // 255-MAX 0-MIN, div-by-256
% N0 F7 z$ X' A8 N: K& ~* r6 ?/ ]% D) T6 E+ Y
mcasp->regs->XMASK = 0xFFFFFFFF; // No padding used* t- G/ B9 s* x9 Y9 ?
mcasp->regs->XFMT = 0x00018078; // MSB 16bit, 0-delay, no pad, CFGBus
0 h6 L# w J! I mcasp->regs->AFSXCTL = 0x00000112; // 2TDM, 1bit Rising edge INTERNAL FS, word& R+ c* E; U7 V; i; t/ S; t. Z
mcasp->regs->ACLKXCTL = 0x000000AF; // ASYNC, Rising INTERNAL CLK, div-by-16
' U$ d p# c( D6 u/ |$ b4 j mcasp->regs->AHCLKXCTL = 0x00000000; // EXT CLK
& @ ^0 \3 Y6 y( b. F8 o; f! D mcasp->regs->XTDM = 0x00000003; // Slots 0,17 s& q+ w' I4 i$ `- | _ y
mcasp->regs->XINTCTL = 0x00000020; // interrupt on transmit. k: _/ Y2 J9 s% }( z
mcasp->regs->XCLKCHK = 0x00FF0008; // 255-MAX 0-MIN, div-by-256
' G G G; |7 v! a- c% `. G! i4 R7 Q+ u: s
mcasp->regs->SRCTL5 = 0x000D; // MCASP1.AXR1[5] --> DIN0 ]* }- P6 g$ G1 ~* Q$ b
mcasp->regs->SRCTL0 = 0x000E; // MCASP1.AXR1[0] <-- DOUT1 S4 }! c6 l2 I+ h! Y+ L1 r# D
mcasp->regs->PFUNC = 0; // All MCASPs
' e6 S% N t9 { mcasp->regs->PDIR = 0x14000020; // All inputs except AXR0[5], ACLKX1, AFSX1) b8 h, Y- s' p; ? }7 h7 _/ y) [
: M, n+ J/ K( F* Y6 `, r5 ?9 { mcasp->regs->DITCTL = 0x00000000; // Not used Q2 X, {. m6 m5 M$ u# i! {
mcasp->regs->DLBCTL = 0x00000000; // Not used5 W8 O: H# F5 y7 i* V% S
mcasp->regs->AMUTE = 0x00000000; // Not used9 W# e+ e$ Y9 D4 ]. ^' F
' T. A/ E, j9 ~: u
/* Starting sections of the McASP*/
4 G2 Y- \ u8 l* L4 r( ]! y mcasp->regs->XGBLCTL |= GBLCTL_XHCLKRST_ON; , v, n2 M% T5 D0 u/ {
while ( ( mcasp->regs->XGBLCTL & GBLCTL_XHCLKRST_ON ) != GBLCTL_XHCLKRST_ON );
# M/ x0 F6 g+ } G& c" |# m3 m mcasp->regs->RGBLCTL |= GBLCTL_RHCLKRST_ON;
- y2 g5 m6 d3 ?6 i3 z8 j- t8 D while ( ( mcasp->regs->RGBLCTL & GBLCTL_RHCLKRST_ON ) != GBLCTL_RHCLKRST_ON );
1 X, T+ Q5 ?/ z9 |9 i% v; O" e/ p
" L; Z7 l8 N" e- L3 u/ P2 @ mcasp->regs->XGBLCTL |= GBLCTL_XCLKRST_ON; 4 D3 M2 J4 x T7 i& o
while ( ( mcasp->regs->XGBLCTL & GBLCTL_XCLKRST_ON ) != GBLCTL_XCLKRST_ON );7 I9 k3 Z& _: x7 A8 P# x8 O0 G3 d
mcasp->regs->RGBLCTL |= GBLCTL_RCLKRST_ON; . ~7 A/ q1 G, s3 H% o4 i% D
while ( ( mcasp->regs->RGBLCTL & GBLCTL_RCLKRST_ON ) != GBLCTL_RCLKRST_ON );, \5 W1 u+ Q: i. a) D: p
$ k: n8 p' [! g" `( [" b+ ~2 A) b mcasp->regs->XSTAT = 0x0000ffff;
" N& ?1 r7 H2 B( v, _ mcasp->regs->RSTAT = 0x0000ffff;
* J7 U) q+ z/ ?* ~6 X, l3 ?/ q* U- f& K
mcasp->regs->XGBLCTL |= GBLCTL_XSRCLR_ON;1 V5 |: W. C4 j: s. n5 k$ M
while ( ( mcasp->regs->XGBLCTL & GBLCTL_XSRCLR_ON ) != GBLCTL_XSRCLR_ON );
0 F9 @4 w/ S D6 _) o9 I. D. e9 D mcasp->regs->RGBLCTL |= GBLCTL_RSRCLR_ON;
7 U0 ^. e# }+ N* e3 P& ` while ( ( mcasp->regs->RGBLCTL & GBLCTL_RSRCLR_ON ) != GBLCTL_RSRCLR_ON );3 G* K8 f' b4 i% F
' e+ k* }) G, @2 v5 e
/* Write a 0, so that no underrun occurs after releasing the state machine */
8 d6 s4 r! k* ?2 Y mcasp->regs->XBUF5 = 0;
$ @1 \* v, m, H: h( Y/ U6 Q: F mcasp->regs->RBUF0 = 0;
. Y. m$ z% [1 W) _
) A. o" \# Y/ W0 Z" @4 T! u$ h" | mcasp->regs->XGBLCTL |= GBLCTL_XSMRST_ON; " D7 {9 D8 N; |8 N4 ^3 s6 Y
while ( ( mcasp->regs->XGBLCTL & GBLCTL_XSMRST_ON ) != GBLCTL_XSMRST_ON );5 i( k* w8 E+ }- w# K# k
mcasp->regs->RGBLCTL |= GBLCTL_RSMRST_ON;
0 _; g3 i% l2 J+ u( K while ( ( mcasp->regs->RGBLCTL & GBLCTL_RSMRST_ON ) != GBLCTL_RSMRST_ON );
# L7 c, s7 i s; Q$ @& A) W; n: J
" m' M$ Z8 m5 O' n7 m4 e7 |. `. O" |. F mcasp->regs->XGBLCTL |= GBLCTL_XFRST_ON; ) G9 p, c9 n: w% `
while ( ( mcasp->regs->XGBLCTL & GBLCTL_XFRST_ON ) != GBLCTL_XFRST_ON );
6 K2 E$ h0 Z( Y$ f; X& `/ F mcasp->regs->RGBLCTL |= GBLCTL_RFRST_ON; 8 Q+ H$ s4 q3 x. r2 S
while ( ( mcasp->regs->RGBLCTL & GBLCTL_RFRST_ON ) != GBLCTL_RFRST_ON );% ~1 y' N+ S3 o# r; {
& F* ^0 j' S t! z0 k d: I
CSR = 0x0000;
) a( D8 N+ |6 L( N3 ^ INTC_INTMUX1 = 0x3d;( K/ w0 M. h( |- D( Z
ISTP = (unsigned int)vectors;5 b, G; W5 h% U
ICR = 0xFFF0;
$ c$ t/ D: G% i+ ? N IER |= 0x12; 5 f0 n% B" J7 e5 {! b
CSR |= 0x01;
6 e' }4 V% T3 }1 W" F% z$ n& P4 Z
6 n- r @& b% X# X$ h" A( ^7 c# k
4 j$ K+ i' g. f4 \% y+ e7 a; F
还有就是两个输入输出函数: T8 |. j4 T4 k2 v, p
void output_sample(Int32 out_data)
/ \- Z$ \! W0 X" c1 D6 X" R9 ^+ d8 s{
2 r1 i1 i" W7 @: b6 L7 \+ j AIC31_data.uint = out_data;
; @: X( d- E! m9 s4 I: y" z4 \- `$ T MCASP1_XBUF5_32BIT = AIC31_data.uint;) ~* ]6 R# l* v* a; o$ _
}6 v5 B: j0 B1 ~' M, t* n
" ? {" ]- E# X! x& ^" f$ n
Int32 input_sample(void)
( \, G. k1 e) c' `4 J! d2 x* ?+ w{ # `8 S0 r4 l% W; t& }) C* v( F2 d
AIC31_data.uint = MCASP1_RBUF0_32BIT;
. n B+ S+ Z& ^ return (AIC31_data.uint);* e; x9 N% o! J' H! h' }! I T- p
}# a! @8 m4 a8 u _4 w
/ y7 F4 Z8 W" J x- n |
|