|
|
C6747和C6748感觉差不多,我想实现McASP发送中断方式控制音频信号,在轮询的例程基础上改的,轮询程序可以实现,但是中断一直实现不了,也找不到错误,求大神帮忙!下边是主要程序:+ i! T' V, |( t
main文件:
7 _+ G+ s* {' o2 m2 x: ainterrupt void interrupt4(void) $ t1 f! J( t3 A. n
{
- \( k0 E4 w, L' e Uint32 sample;
% C, V3 k. [- U3 R# C0 m/ _; m9 Q7 `! G4 v4 F0 b, Z; U
sample = input_sample(); // read L + R samples from ADC
( s! y0 N: i5 i2 _8 t output_sample(sample); // write L + R samples to DAC 2 n# x$ ~( H9 r
return;
( q" J [! C/ P2 h$ Q: C}3 W" ]/ | u9 r, G: u- L) X
/ K( N7 ?0 d; cint main( void )
' c. B& p* `7 q' A5 n" n |{. v" Y! H, h9 n" \' B
! o1 n8 q9 U( g; b/ S+ Q2 F; L! M
/* Initialize BSL */" X) y( e9 g: c; }( F/ G
EVMC6747_init( );
. q# L6 t9 e0 A# u /* Call evmc6747_intr function */* w% \' U* k, M# h* e) K
aic3106_init( );
1 d6 O5 D% o1 U while(1);+ j- F6 z( }' w9 R( d
}1 Z( w' a5 V$ l! p; q7 l
$ \5 s* E: v# h+ q! a8 v3 h C, a( Y- [( o1 S% N3 R) r
aic3106_init文件的一部分,McASP配置部分,采用内部时钟,I2S方式,同步传输。音频芯片的配置应该没问题4 X% j+ w$ W' j
/* Initialize MCASP1 */6 Y* T3 ~ r O6 L: s# Y( i8 d X
mcasp = &MCASP_MODULE_1;
, o) t- E9 g" {" M mcasp->regs->GBLCTL = 0; // Reset
+ d: B+ w- |8 i! U" W3 S mcasp->regs->RGBLCTL = 0; // Reset RX
$ p' a' J* K5 ^0 t1 I4 `4 W mcasp->regs->XGBLCTL = 0; // Reset TX
( ]* O. b3 O7 `. R' y3 G4 E mcasp->regs->PWRDEMU = 1; // Free-running
: ?5 j' P6 o' A2 J // configure McASP0 receive registers
S2 A4 E o- a5 f/ h" x mcasp->regs->RMASK = 0xFFFFFFFF; // No padding used
3 K4 m9 t5 }2 M; T mcasp->regs->RFMT = 0x00018078; // MSB 16bit, 0-delay, no pad, CFGBus) M* E! q- q$ s& ?
mcasp->regs->AFSRCTL = 0x00000112; // 2TDM, 1bit Falling, External FS, word0 {' u) Q V' R- B& ~3 r2 y4 S
mcasp->regs->ACLKRCTL = 0x000000AF; // Rising INTERNAL CLK,(from tx side)
$ C$ f, e+ Q2 R3 U9 Q* I/ V! M+ Y mcasp->regs->AHCLKRCTL = 0x00000000; // INT CLK (from tx side)
! w8 Y8 n6 J. d mcasp->regs->RTDM = 0x00000003; // Slots 0,14 |! {8 M* ~& p* B, I; b5 T( D$ z
mcasp->regs->RINTCTL = 0x00000000; // Not used- Q8 F9 B5 ]# {3 O9 y1 W
mcasp->regs->RCLKCHK = 0x00FF0008; // 255-MAX 0-MIN, div-by-256
0 k' q* C2 \& ~4 c: y0 |" X/ T" @7 d$ f- `
mcasp->regs->XMASK = 0xFFFFFFFF; // No padding used
4 m, I0 d% ]5 d/ R mcasp->regs->XFMT = 0x00018078; // MSB 16bit, 0-delay, no pad, CFGBus, m: f. g. i; s6 o7 [
mcasp->regs->AFSXCTL = 0x00000112; // 2TDM, 1bit Rising edge INTERNAL FS, word
, r/ u8 S% d9 n mcasp->regs->ACLKXCTL = 0x000000AF; // ASYNC, Rising INTERNAL CLK, div-by-167 g+ j- P% h; `! c; o
mcasp->regs->AHCLKXCTL = 0x00000000; // EXT CLK
4 v0 x( n: N1 j1 ~& @- C# e- W mcasp->regs->XTDM = 0x00000003; // Slots 0,1
+ q! ^6 l R* Z" K* i1 ] mcasp->regs->XINTCTL = 0x00000020; // interrupt on transmit
+ Z. \/ Q0 V: E+ | x( P mcasp->regs->XCLKCHK = 0x00FF0008; // 255-MAX 0-MIN, div-by-2566 F4 I) \+ n9 i; h+ Z1 p3 Z g/ n
8 b! Y, w* t4 R mcasp->regs->SRCTL5 = 0x000D; // MCASP1.AXR1[5] --> DIN
7 x3 k+ \2 }4 j2 S& I5 e mcasp->regs->SRCTL0 = 0x000E; // MCASP1.AXR1[0] <-- DOUT7 h6 V- h0 e( C" v+ H" M) c6 x& M
mcasp->regs->PFUNC = 0; // All MCASPs, a2 |: Z2 b! ]' G. s( n2 }( e" r
mcasp->regs->PDIR = 0x14000020; // All inputs except AXR0[5], ACLKX1, AFSX12 H3 u; {0 a2 N. E5 t# M
# _; T/ d6 O& |3 r, F) g3 k5 t x
mcasp->regs->DITCTL = 0x00000000; // Not used+ i d- N7 i6 s9 {4 O- [0 V+ d
mcasp->regs->DLBCTL = 0x00000000; // Not used
% w, [8 ~. g- [- j2 F8 |& O. x mcasp->regs->AMUTE = 0x00000000; // Not used- b( k4 \, ~5 R
' C8 h; h# F0 o& v* Q* S/* Starting sections of the McASP*/
3 d5 c! s2 b, X' [& c mcasp->regs->XGBLCTL |= GBLCTL_XHCLKRST_ON;
! B' H6 q& E# c9 P8 V while ( ( mcasp->regs->XGBLCTL & GBLCTL_XHCLKRST_ON ) != GBLCTL_XHCLKRST_ON ); , G6 @% }# ~7 q6 M7 q+ j9 t
mcasp->regs->RGBLCTL |= GBLCTL_RHCLKRST_ON;
; B( E$ i* I3 t8 L# S2 n: y while ( ( mcasp->regs->RGBLCTL & GBLCTL_RHCLKRST_ON ) != GBLCTL_RHCLKRST_ON );
; F! f! a8 D. w4 V0 J: `: f
" G @0 W9 `9 \ mcasp->regs->XGBLCTL |= GBLCTL_XCLKRST_ON;
& Q1 t: q4 M8 L [1 Y$ ?3 w while ( ( mcasp->regs->XGBLCTL & GBLCTL_XCLKRST_ON ) != GBLCTL_XCLKRST_ON );9 u5 [9 x5 H: Q4 v7 B x
mcasp->regs->RGBLCTL |= GBLCTL_RCLKRST_ON; 6 `' ?# p3 v/ j3 O) s0 b
while ( ( mcasp->regs->RGBLCTL & GBLCTL_RCLKRST_ON ) != GBLCTL_RCLKRST_ON );; U8 Q; X! a1 n/ n9 Y
# g2 x1 E! R* Z% a6 j; z
mcasp->regs->XSTAT = 0x0000ffff; 7 H+ H6 S1 f' C, ^, d
mcasp->regs->RSTAT = 0x0000ffff; 4 U" b4 W# O7 |+ h3 a) u
5 t# W0 @: B) E$ U+ h' E& e mcasp->regs->XGBLCTL |= GBLCTL_XSRCLR_ON;- S* n+ c G9 t$ P# J4 d; ]
while ( ( mcasp->regs->XGBLCTL & GBLCTL_XSRCLR_ON ) != GBLCTL_XSRCLR_ON );' t3 r6 w! A, U/ [7 z8 U
mcasp->regs->RGBLCTL |= GBLCTL_RSRCLR_ON; . x: H7 x8 o2 {; x! F$ u" D4 b6 P
while ( ( mcasp->regs->RGBLCTL & GBLCTL_RSRCLR_ON ) != GBLCTL_RSRCLR_ON );4 j& w0 |$ f! W
5 S, N6 q5 ^; F3 O
/* Write a 0, so that no underrun occurs after releasing the state machine */' { F# x- X6 i. x7 T
mcasp->regs->XBUF5 = 0;5 s8 G4 s5 B8 H3 y: `9 h2 p
mcasp->regs->RBUF0 = 0;/ i2 g! l0 Q1 v L0 w) k
; y& y8 Q; D8 ` mcasp->regs->XGBLCTL |= GBLCTL_XSMRST_ON;
) U- y) n4 c7 T* @( o while ( ( mcasp->regs->XGBLCTL & GBLCTL_XSMRST_ON ) != GBLCTL_XSMRST_ON );; P2 K$ [2 U }$ g6 i4 h
mcasp->regs->RGBLCTL |= GBLCTL_RSMRST_ON;
, I: `: P' H3 F; F/ ^5 P while ( ( mcasp->regs->RGBLCTL & GBLCTL_RSMRST_ON ) != GBLCTL_RSMRST_ON );
, G1 j7 {$ h# e( s2 u& }4 u+ N4 u0 a! h7 ]
mcasp->regs->XGBLCTL |= GBLCTL_XFRST_ON;
7 T- ?6 k; ]$ a5 ]8 a9 F while ( ( mcasp->regs->XGBLCTL & GBLCTL_XFRST_ON ) != GBLCTL_XFRST_ON );
! A: e3 F" ?4 ~' {3 @$ I0 W mcasp->regs->RGBLCTL |= GBLCTL_RFRST_ON;
" c% _: K0 l& |' l while ( ( mcasp->regs->RGBLCTL & GBLCTL_RFRST_ON ) != GBLCTL_RFRST_ON );, e5 e3 I5 @2 _* |* c* v- W/ m
' H# u( \5 N! G- ?- e* a Q
CSR = 0x0000;
3 ^* f1 F: C) [: o: }9 A; A" b. d- N INTC_INTMUX1 = 0x3d;
+ Z# `' A- l$ D ISTP = (unsigned int)vectors;$ H. E4 `: n; K
ICR = 0xFFF0;
0 u9 f: W5 P: j, g IER |= 0x12;
! t! q6 B' Y% V" A9 C$ Y CSR |= 0x01; . m2 t9 R6 w, O0 w, k+ q
7 J' i" o& z+ g- h+ P# S/ K2 i# M) E/ M4 X8 B" \
- d. [9 G+ B; Z3 t' l1 T4 S
还有就是两个输入输出函数:5 L [* c# k2 W: c) q! T$ h
void output_sample(Int32 out_data)- c X- r w# ]8 _$ g0 Q4 ^$ U# u+ u
{
$ P8 I2 U Q3 C8 @3 l+ x) o AIC31_data.uint = out_data;
0 w$ J/ o0 L) I( V- X' b' q MCASP1_XBUF5_32BIT = AIC31_data.uint;0 H7 ^4 X* O: v9 j( x$ Z- l
}
, O" y/ t @' h" b) y! @8 k9 Y
! v. |! t& h4 z& X( fInt32 input_sample(void)
( z7 J2 M' H$ n: q/ g+ C9 j{
. ?+ S7 G- |0 g) o8 o AIC31_data.uint = MCASP1_RBUF0_32BIT;
$ x; Q1 r- P1 ^ E" \2 A& U return (AIC31_data.uint);
! {5 a4 d, ^& s# e}
. a4 F+ ]* ]4 F# o" L, |! L% E" C, F9 J `
|
|