|
|
C6747和C6748感觉差不多,我想实现McASP发送中断方式控制音频信号,在轮询的例程基础上改的,轮询程序可以实现,但是中断一直实现不了,也找不到错误,求大神帮忙!下边是主要程序:
7 b# q, @6 r' R& s3 amain文件:
8 i# a; _/ @+ h0 v$ U0 U6 Pinterrupt void interrupt4(void) % _$ Z( Q% L+ J+ p* i6 T* _- r1 V
{
" f5 J+ p6 c' B Uint32 sample;. E; U5 g. N& h& p2 [; r8 p/ h
* A. G3 q" D% U9 q, w! D/ a6 V0 a sample = input_sample(); // read L + R samples from ADC
5 l+ x' T" F3 N1 \ output_sample(sample); // write L + R samples to DAC
k, B2 S# j+ i5 \ return;
8 z+ _4 Z+ E5 G! r" T4 h8 |6 A}. {$ Q ~* w7 b% m& b
2 M% N) @2 J7 _; c& L5 rint main( void )/ O Z9 `- D6 o9 H5 {
{
* X; I. S: U" t' D; w$ N7 w8 A8 S. a1 Q. y3 Z1 {
/* Initialize BSL */+ U& G) v( p" C9 T4 V
EVMC6747_init( );
9 p5 q: A1 p0 b& a% |9 c5 E /* Call evmc6747_intr function */
# v( J$ {3 e! A- ?& W aic3106_init( );
/ s: E: \! `3 O6 t% w: j while(1);% X& m& |/ G1 b9 j: A7 D
}
- s( t* b! E# o7 A5 D9 M) n. M- f6 W' y5 A2 q" R
9 _7 [& G" a9 B: M9 A0 e4 r" U% z* Q/ ]
aic3106_init文件的一部分,McASP配置部分,采用内部时钟,I2S方式,同步传输。音频芯片的配置应该没问题$ i. a4 |' U; t7 a' b9 r! \
/* Initialize MCASP1 */. w, d# E. N0 C! \& p
mcasp = &MCASP_MODULE_1;
/ N1 y: M- p$ P7 X mcasp->regs->GBLCTL = 0; // Reset' ]1 ?* r6 b2 M: o( ~
mcasp->regs->RGBLCTL = 0; // Reset RX$ Q* m' ^" N7 F' Q o" B( L
mcasp->regs->XGBLCTL = 0; // Reset TX- ^( ^" x3 U% {' Y! j
mcasp->regs->PWRDEMU = 1; // Free-running; c9 S# ~0 r# M
// configure McASP0 receive registers
4 G! @* k: K$ a2 `4 L mcasp->regs->RMASK = 0xFFFFFFFF; // No padding used4 f- {9 O& J) } b
mcasp->regs->RFMT = 0x00018078; // MSB 16bit, 0-delay, no pad, CFGBus
8 f* @' }) ^8 S/ K5 K( o8 X3 b8 m2 | mcasp->regs->AFSRCTL = 0x00000112; // 2TDM, 1bit Falling, External FS, word. s8 U, d: ?0 `% j
mcasp->regs->ACLKRCTL = 0x000000AF; // Rising INTERNAL CLK,(from tx side); c4 Y3 k3 ?! {! C& G' b" Z! L
mcasp->regs->AHCLKRCTL = 0x00000000; // INT CLK (from tx side)$ I4 T' J- c* t
mcasp->regs->RTDM = 0x00000003; // Slots 0,15 }! P( b# |8 Y5 V/ ^
mcasp->regs->RINTCTL = 0x00000000; // Not used
4 d& Z5 ?6 d, H. @3 r mcasp->regs->RCLKCHK = 0x00FF0008; // 255-MAX 0-MIN, div-by-2561 K; }3 O# R" u8 x8 j* j
: j8 P7 E* |: b
mcasp->regs->XMASK = 0xFFFFFFFF; // No padding used! @ w5 a$ n, J
mcasp->regs->XFMT = 0x00018078; // MSB 16bit, 0-delay, no pad, CFGBus. G: t2 n1 d0 ^( ]
mcasp->regs->AFSXCTL = 0x00000112; // 2TDM, 1bit Rising edge INTERNAL FS, word5 ~4 U6 \" _- L' ?3 v
mcasp->regs->ACLKXCTL = 0x000000AF; // ASYNC, Rising INTERNAL CLK, div-by-16
8 `, q/ ~. a$ Y3 @! g mcasp->regs->AHCLKXCTL = 0x00000000; // EXT CLK
9 z: z, K8 ^- b/ s! U- s. C& Y3 ` mcasp->regs->XTDM = 0x00000003; // Slots 0,13 j6 h4 [/ V/ N7 \ m- K* p; b
mcasp->regs->XINTCTL = 0x00000020; // interrupt on transmit K, W' Z6 C' q0 @! Z- p
mcasp->regs->XCLKCHK = 0x00FF0008; // 255-MAX 0-MIN, div-by-256/ w" e1 ?8 X- L: \' O9 L
" e- J) _- D9 A" S1 N' o( D mcasp->regs->SRCTL5 = 0x000D; // MCASP1.AXR1[5] --> DIN
: }8 I" q& `6 x. r mcasp->regs->SRCTL0 = 0x000E; // MCASP1.AXR1[0] <-- DOUT/ K% a. H7 }7 D8 J+ G" Z7 A" b( V
mcasp->regs->PFUNC = 0; // All MCASPs
. ?" i0 k% i' ^. K" ? mcasp->regs->PDIR = 0x14000020; // All inputs except AXR0[5], ACLKX1, AFSX1
3 c" O1 r8 A0 N2 n' K+ ?5 N) h- d2 w e$ n) |( u5 j
mcasp->regs->DITCTL = 0x00000000; // Not used5 z6 m# Z! z7 q* q
mcasp->regs->DLBCTL = 0x00000000; // Not used& P: S8 V4 z; ~0 Z% m
mcasp->regs->AMUTE = 0x00000000; // Not used, x" s$ I, H3 K# p Q9 O2 j% V
$ b8 Y0 S; p% W% K3 V( U. ]$ u% w
/* Starting sections of the McASP*/
# K: D {1 d' {( O1 h* i1 T mcasp->regs->XGBLCTL |= GBLCTL_XHCLKRST_ON; * V* F* w3 X m6 @' f& r. F/ ^
while ( ( mcasp->regs->XGBLCTL & GBLCTL_XHCLKRST_ON ) != GBLCTL_XHCLKRST_ON );
& [$ o7 j6 f% y$ N mcasp->regs->RGBLCTL |= GBLCTL_RHCLKRST_ON; 8 Q: R7 e, Y% u5 N6 u
while ( ( mcasp->regs->RGBLCTL & GBLCTL_RHCLKRST_ON ) != GBLCTL_RHCLKRST_ON );
7 V* R; t. f1 l H2 b
, Q' T l* `5 H5 {( X& S" U. Q mcasp->regs->XGBLCTL |= GBLCTL_XCLKRST_ON;
Q( v% _: v* ?; v while ( ( mcasp->regs->XGBLCTL & GBLCTL_XCLKRST_ON ) != GBLCTL_XCLKRST_ON );
/ M# N3 s: W: }' r/ d" F: S mcasp->regs->RGBLCTL |= GBLCTL_RCLKRST_ON; 1 d0 G/ [# K" y
while ( ( mcasp->regs->RGBLCTL & GBLCTL_RCLKRST_ON ) != GBLCTL_RCLKRST_ON );
3 W) S- O g4 r T8 e+ w9 e/ x9 S: G$ k: A3 f( S
mcasp->regs->XSTAT = 0x0000ffff; 9 V5 F/ I4 g6 X$ b# g4 E1 U- n
mcasp->regs->RSTAT = 0x0000ffff; " s/ l+ f/ C$ P5 `6 P; g( M( U c
1 b! I; c0 U; n1 t mcasp->regs->XGBLCTL |= GBLCTL_XSRCLR_ON;
& B7 i7 B3 R' B3 G+ X- K while ( ( mcasp->regs->XGBLCTL & GBLCTL_XSRCLR_ON ) != GBLCTL_XSRCLR_ON );
: _5 }1 i3 L$ g$ j7 w mcasp->regs->RGBLCTL |= GBLCTL_RSRCLR_ON;
8 m I+ Z4 n8 H* i7 R while ( ( mcasp->regs->RGBLCTL & GBLCTL_RSRCLR_ON ) != GBLCTL_RSRCLR_ON );. w. @9 c9 P+ }2 x- z) W- I
D4 N) T5 X5 B9 @: W# }8 L /* Write a 0, so that no underrun occurs after releasing the state machine */
7 B8 l8 A! j) I( C9 i: S$ o mcasp->regs->XBUF5 = 0;+ S# v6 U$ b0 t& K$ t
mcasp->regs->RBUF0 = 0;" S$ g4 m) e) i: {) M; ^& F% D
% r1 t% d: _7 ~; L( z" F mcasp->regs->XGBLCTL |= GBLCTL_XSMRST_ON; b2 n4 z# t' Z* R
while ( ( mcasp->regs->XGBLCTL & GBLCTL_XSMRST_ON ) != GBLCTL_XSMRST_ON );
' _6 \1 w' c9 Z mcasp->regs->RGBLCTL |= GBLCTL_RSMRST_ON;
% H( G6 Z! _+ N4 g$ S% o% M while ( ( mcasp->regs->RGBLCTL & GBLCTL_RSMRST_ON ) != GBLCTL_RSMRST_ON );
{- L+ T/ V! L7 `' A4 }7 {1 R) A. e7 W1 l
mcasp->regs->XGBLCTL |= GBLCTL_XFRST_ON; " S5 j% G( o% D `! r$ i$ H: G4 X
while ( ( mcasp->regs->XGBLCTL & GBLCTL_XFRST_ON ) != GBLCTL_XFRST_ON );
2 ?7 t N, r2 K0 [, [ mcasp->regs->RGBLCTL |= GBLCTL_RFRST_ON; 4 o& l4 F# u ]) J+ s
while ( ( mcasp->regs->RGBLCTL & GBLCTL_RFRST_ON ) != GBLCTL_RFRST_ON );, E. r( n7 {' t! k8 s& c
3 }5 Y5 [$ I2 }, a) p
CSR = 0x0000;- u. P/ W6 o! i
INTC_INTMUX1 = 0x3d;" L" R& N# X1 j7 [4 Z
ISTP = (unsigned int)vectors;( s9 m) {0 h3 S, j$ M, c4 D" E
ICR = 0xFFF0; . @* f3 [0 I A
IER |= 0x12;
) h$ r+ z' [- S8 v6 Y CSR |= 0x01; ( S+ K& n9 h! I
' f1 X5 ~, b( n: E) Q5 ]0 \
' U+ E5 h! z$ S. p x* H) p/ h0 }8 y9 a2 p; o- v: b4 I8 Y
还有就是两个输入输出函数:
9 E- H7 c* l& w* ?/ v" }& P4 r) Qvoid output_sample(Int32 out_data)0 V$ E4 X+ |9 [- @/ R' E2 S+ o
{
2 x% a9 ~4 ^. g AIC31_data.uint = out_data; ( f, @) h1 u* e) j4 H" y. w+ ~
MCASP1_XBUF5_32BIT = AIC31_data.uint;8 x# r2 U! B, w0 S
}
9 c @0 p$ A1 U9 Q* V$ C" N2 T' B8 n9 e0 p
Int32 input_sample(void)) z6 h$ c Z3 n0 M o6 i
{
) t, f: E2 Y4 v9 C% L' N: } AIC31_data.uint = MCASP1_RBUF0_32BIT;
/ e$ k$ V$ {4 D( W return (AIC31_data.uint);* L: ?+ c9 i- s
}
x1 H9 Q9 E+ ?# L2 I z
* B, z! M! A) u |
|