|
|
C6747和C6748感觉差不多,我想实现McASP发送中断方式控制音频信号,在轮询的例程基础上改的,轮询程序可以实现,但是中断一直实现不了,也找不到错误,求大神帮忙!下边是主要程序:0 y8 S0 ?' e- y8 L0 A
main文件:; }) Z$ J; P( l; a9 `
interrupt void interrupt4(void) * i0 a! l8 b" k( q2 t% t
{
) Y. I; C1 w# e2 P Uint32 sample;1 W1 y$ e$ h1 M. U; Q
/ j. M, K5 l, V) |
sample = input_sample(); // read L + R samples from ADC
- t9 x, u# `+ t1 J! z output_sample(sample); // write L + R samples to DAC / B( V+ Q( i+ B! l5 D, t
return;
' @1 ?: J- m3 ?' }, d}6 L; m0 ^7 f3 U& h
& r Y! x+ ]1 i" Y% q) @int main( void )' v3 O, r$ T5 H# S+ G
{
$ Z+ i, m$ o0 Q% ?
; K1 m2 n$ H* B& K" F /* Initialize BSL */
" O; T8 X# F% t: L$ t( k EVMC6747_init( );
$ w1 g1 E# [' G% ?) o /* Call evmc6747_intr function */& b j: R7 c/ {, k2 ?4 ?! b
aic3106_init( );
; j6 g: P% }, a, E) G while(1);
5 F/ R( O5 l1 J; T! m}' L. k6 W, H( O
# @. ~& j) q8 h, f
: \' {4 ?1 d7 x; a U J! @. S% H+ O
aic3106_init文件的一部分,McASP配置部分,采用内部时钟,I2S方式,同步传输。音频芯片的配置应该没问题
5 W3 [+ ~& v; W6 Y( V/* Initialize MCASP1 */* U' w. f! v) M. Z) M$ t
mcasp = &MCASP_MODULE_1;; \2 R+ Z" J- S* o9 B; R$ ]
mcasp->regs->GBLCTL = 0; // Reset& ^" H6 @, j$ Q, o8 t9 h
mcasp->regs->RGBLCTL = 0; // Reset RX
$ ^: u: M A; c" o2 p mcasp->regs->XGBLCTL = 0; // Reset TX
7 g3 M" h7 Z1 Z4 }* l mcasp->regs->PWRDEMU = 1; // Free-running3 p% h; \7 _" A# e0 @& e
// configure McASP0 receive registers
& f- {+ z, H" F# _ mcasp->regs->RMASK = 0xFFFFFFFF; // No padding used
) p1 J% c9 i# c; S mcasp->regs->RFMT = 0x00018078; // MSB 16bit, 0-delay, no pad, CFGBus5 @/ D1 M. D1 F" k2 e7 L' \& A* s
mcasp->regs->AFSRCTL = 0x00000112; // 2TDM, 1bit Falling, External FS, word
7 v3 N5 o1 \+ P- {- _ mcasp->regs->ACLKRCTL = 0x000000AF; // Rising INTERNAL CLK,(from tx side)
& ]0 H, k% ]0 }7 R+ H mcasp->regs->AHCLKRCTL = 0x00000000; // INT CLK (from tx side)
* Y& l5 Q+ |, `- {+ W( r, Z# Y mcasp->regs->RTDM = 0x00000003; // Slots 0,1
# x; `4 Y/ T9 _/ b8 Q$ d4 E' d+ ` mcasp->regs->RINTCTL = 0x00000000; // Not used
$ H4 \) Z: T5 i' u' Q P5 O mcasp->regs->RCLKCHK = 0x00FF0008; // 255-MAX 0-MIN, div-by-256
7 {5 W2 \6 q) v3 W% w i. x2 R3 l
mcasp->regs->XMASK = 0xFFFFFFFF; // No padding used& E' {4 R ^, i) Y
mcasp->regs->XFMT = 0x00018078; // MSB 16bit, 0-delay, no pad, CFGBus/ c) h0 Y) y" {" Z
mcasp->regs->AFSXCTL = 0x00000112; // 2TDM, 1bit Rising edge INTERNAL FS, word
& C! G) e8 i* X1 j mcasp->regs->ACLKXCTL = 0x000000AF; // ASYNC, Rising INTERNAL CLK, div-by-16
3 i6 ]9 }. {9 G, c- {8 |) Q/ z mcasp->regs->AHCLKXCTL = 0x00000000; // EXT CLK
( m0 ?) y# z+ n- J0 ^# _; a mcasp->regs->XTDM = 0x00000003; // Slots 0,1
% f" ]8 b# A: c* h k* A mcasp->regs->XINTCTL = 0x00000020; // interrupt on transmit `8 O8 C! J' }
mcasp->regs->XCLKCHK = 0x00FF0008; // 255-MAX 0-MIN, div-by-256
; H9 z% ~4 S* |7 V- ^0 l3 r. b! j' N' k' E
mcasp->regs->SRCTL5 = 0x000D; // MCASP1.AXR1[5] --> DIN3 X* ]+ J4 ~/ K+ x" E
mcasp->regs->SRCTL0 = 0x000E; // MCASP1.AXR1[0] <-- DOUT
! i0 i( {" P9 S3 w$ d3 h, p; N mcasp->regs->PFUNC = 0; // All MCASPs$ m m/ Q, o% T3 O
mcasp->regs->PDIR = 0x14000020; // All inputs except AXR0[5], ACLKX1, AFSX1
' y. n3 P2 Q9 D: i3 Z8 x# V$ s" ~7 }. \4 p; r) h
mcasp->regs->DITCTL = 0x00000000; // Not used3 b& L2 J% u1 K2 r( y
mcasp->regs->DLBCTL = 0x00000000; // Not used
7 N8 p& b) ?7 W# T) u( d mcasp->regs->AMUTE = 0x00000000; // Not used
6 L$ X7 o& m+ y: c. P# A9 T8 |4 e. \ F; M$ N4 a& S/ E
/* Starting sections of the McASP*/& N# ?. S& P g- K
mcasp->regs->XGBLCTL |= GBLCTL_XHCLKRST_ON; 1 ]5 n; E3 I/ X2 d( r4 S
while ( ( mcasp->regs->XGBLCTL & GBLCTL_XHCLKRST_ON ) != GBLCTL_XHCLKRST_ON ); 7 g& i" B) G, J4 M
mcasp->regs->RGBLCTL |= GBLCTL_RHCLKRST_ON;
R ]7 q: v8 h) G7 Y while ( ( mcasp->regs->RGBLCTL & GBLCTL_RHCLKRST_ON ) != GBLCTL_RHCLKRST_ON );% @4 i8 H5 e. ]6 {- }# Y8 v4 u
1 |/ C7 t" u5 p, p) f mcasp->regs->XGBLCTL |= GBLCTL_XCLKRST_ON;
+ x! j; K1 r2 A1 ^9 Y9 h while ( ( mcasp->regs->XGBLCTL & GBLCTL_XCLKRST_ON ) != GBLCTL_XCLKRST_ON );
& H0 E8 i% h$ w+ r mcasp->regs->RGBLCTL |= GBLCTL_RCLKRST_ON;
; U9 L7 g4 U3 I8 d; q$ ^ while ( ( mcasp->regs->RGBLCTL & GBLCTL_RCLKRST_ON ) != GBLCTL_RCLKRST_ON );
1 T8 d! C- @" D5 H! S' @3 P# L& o/ D! @9 |# B8 Z6 a. k0 f
mcasp->regs->XSTAT = 0x0000ffff;
3 x( z5 b9 x; h8 n% H% P$ n3 J6 A mcasp->regs->RSTAT = 0x0000ffff;
( a9 V& ?$ J2 m4 _0 d. L) a
t4 i3 e) A7 X. P# M mcasp->regs->XGBLCTL |= GBLCTL_XSRCLR_ON;2 g1 H: L: O1 \9 t
while ( ( mcasp->regs->XGBLCTL & GBLCTL_XSRCLR_ON ) != GBLCTL_XSRCLR_ON );
: D! y2 o% z4 W* J6 \& p ` mcasp->regs->RGBLCTL |= GBLCTL_RSRCLR_ON; 0 A3 \5 x: w; ^5 _' O9 b" G: q
while ( ( mcasp->regs->RGBLCTL & GBLCTL_RSRCLR_ON ) != GBLCTL_RSRCLR_ON );$ x$ a) W1 h+ ]* f% v
/ m1 S7 [+ h# F) [ J, s' V7 @& P2 y
/* Write a 0, so that no underrun occurs after releasing the state machine */& j f9 ^8 F% w+ D2 Z; z+ u
mcasp->regs->XBUF5 = 0;$ }# p1 w9 J4 T! K" ]$ }
mcasp->regs->RBUF0 = 0;
% k7 I( I; z1 r, Z9 I! B, K1 R. n% p6 b V3 i, @
mcasp->regs->XGBLCTL |= GBLCTL_XSMRST_ON;
( J# {: Y; }' ^. q/ W( @ while ( ( mcasp->regs->XGBLCTL & GBLCTL_XSMRST_ON ) != GBLCTL_XSMRST_ON ); v7 g9 N8 s' n9 n# l. A
mcasp->regs->RGBLCTL |= GBLCTL_RSMRST_ON;
! V `! z/ ^& x! p* f% C& \$ J while ( ( mcasp->regs->RGBLCTL & GBLCTL_RSMRST_ON ) != GBLCTL_RSMRST_ON );2 c6 G. i" n$ b/ u E3 v6 [- W1 _& V
Z( W0 l7 E/ O% N D mcasp->regs->XGBLCTL |= GBLCTL_XFRST_ON;
9 L% ~4 |7 q3 P4 ]& o- b while ( ( mcasp->regs->XGBLCTL & GBLCTL_XFRST_ON ) != GBLCTL_XFRST_ON );
4 G% y4 v* V0 l8 R) T4 q9 g mcasp->regs->RGBLCTL |= GBLCTL_RFRST_ON;
8 M; b6 D _' }; [ while ( ( mcasp->regs->RGBLCTL & GBLCTL_RFRST_ON ) != GBLCTL_RFRST_ON );9 y9 v/ l) Y) \0 S4 a( G
4 t0 c% W( e( P; I/ q1 ~& J CSR = 0x0000;9 q9 z" F! M0 b8 v# P6 j3 P/ N
INTC_INTMUX1 = 0x3d;" \" |6 t' _, D, ]1 D+ O8 F
ISTP = (unsigned int)vectors;
, K5 t. K) ?$ H( k$ {' V% ?/ x ICR = 0xFFF0; # H8 U% r% N" d3 S0 _1 H- B
IER |= 0x12;
! Y" o+ N" S$ I CSR |= 0x01;
. X4 V8 @% C m
9 Y# l0 V* A4 c% L( C0 e8 V T7 s; R
& D( @4 s2 @" i; n2 U: `, @: H; s4 T
1 Q9 j4 [7 A8 x/ ]( z还有就是两个输入输出函数:
2 q1 @* j0 \9 k+ o' |2 d `% m3 hvoid output_sample(Int32 out_data)
% i0 j* S& G& L$ {{; X2 _# l4 J6 A
AIC31_data.uint = out_data; 6 o; J( c. H* V+ b
MCASP1_XBUF5_32BIT = AIC31_data.uint;
* j/ P( ~8 P) x5 X}/ ^3 N) e7 ]3 Q: [" f( a
8 F- i1 f; L: h( q
Int32 input_sample(void): v3 w, X V2 R! N6 k
{ ; m) P% C) g( }8 R: ^
AIC31_data.uint = MCASP1_RBUF0_32BIT;
# l, O8 D7 t" ^: l return (AIC31_data.uint); P# p c8 F z6 ]1 h0 j/ o
}/ H- `; l( Y" n! `$ O" X
8 p" q' I( ?, i
|
|