|
|
C6747和C6748感觉差不多,我想实现McASP发送中断方式控制音频信号,在轮询的例程基础上改的,轮询程序可以实现,但是中断一直实现不了,也找不到错误,求大神帮忙!下边是主要程序:
. s' @& D/ p+ |! Smain文件:) V7 ^' E% N5 V3 _, }& [7 l
interrupt void interrupt4(void)
9 {1 h, k3 j% }- b0 M{1 ?0 c) s0 b9 R% R( A& G$ [
Uint32 sample;
3 `+ h2 y5 X9 W( r2 Z, B1 @: a! Q
- l8 U& A o$ |. |8 _ A sample = input_sample(); // read L + R samples from ADC
2 ]3 R* p& R! [# w output_sample(sample); // write L + R samples to DAC
2 k3 V4 b! b) } return;
' D' L$ K' Z" t3 }0 O}
1 |% Z9 Y2 a B; _4 B) x
0 ?1 G" ~ a3 Q, f; z4 P6 Rint main( void )- p& y- j* A( J7 X8 v. o
{# R+ j. a$ q/ \% q. E6 z# |
5 L+ n4 [- J+ [% h8 P0 y3 v: |
/* Initialize BSL */' N2 ]/ \) b4 `' q1 A0 L" _
EVMC6747_init( );1 S( r) @' G2 C- c" b$ ?( z" r
/* Call evmc6747_intr function */
Z2 ^" @+ I# h' h0 r7 F+ g aic3106_init( );! a, d* T7 @; _* C! Y
while(1);
h, Y5 C# e) ~4 ~0 {9 s5 I}1 g& o) g6 N* w" w/ b
8 b7 g% }' a" \/ C% e
3 V; {- x" a. Q* L) x" Z- G4 G
aic3106_init文件的一部分,McASP配置部分,采用内部时钟,I2S方式,同步传输。音频芯片的配置应该没问题- h$ g& i! N0 z, T# @, p
/* Initialize MCASP1 */7 a% h/ ?4 w# k$ {
mcasp = &MCASP_MODULE_1;( g% ]& G. M) J# [6 \2 M: W
mcasp->regs->GBLCTL = 0; // Reset2 N0 @/ y" E2 [9 P* M! E
mcasp->regs->RGBLCTL = 0; // Reset RX
: P. V) n$ U( l8 f& L; i mcasp->regs->XGBLCTL = 0; // Reset TX9 _+ {# T; W7 ^4 O# n" d$ n
mcasp->regs->PWRDEMU = 1; // Free-running- v: B/ V7 ?! C! {2 M) I
// configure McASP0 receive registers9 S% z- J) q' K( d4 J
mcasp->regs->RMASK = 0xFFFFFFFF; // No padding used# C2 V9 o4 D, s f: \6 s
mcasp->regs->RFMT = 0x00018078; // MSB 16bit, 0-delay, no pad, CFGBus9 i- q# v' H: h* u4 @5 H+ _
mcasp->regs->AFSRCTL = 0x00000112; // 2TDM, 1bit Falling, External FS, word
* d7 `, i6 D4 b M mcasp->regs->ACLKRCTL = 0x000000AF; // Rising INTERNAL CLK,(from tx side)
3 R3 n) k& d- J0 A9 w* [* Z2 w mcasp->regs->AHCLKRCTL = 0x00000000; // INT CLK (from tx side)
, \0 G8 `6 B5 e- T5 Z5 z+ b mcasp->regs->RTDM = 0x00000003; // Slots 0,1
$ O2 y9 G# L: S# O' N! A1 `2 `6 S mcasp->regs->RINTCTL = 0x00000000; // Not used
( g5 F* K, W5 g% s$ ~1 Q mcasp->regs->RCLKCHK = 0x00FF0008; // 255-MAX 0-MIN, div-by-2567 ?9 N; ^( g6 V3 i
6 g$ y3 e2 c) g/ L, C, R4 b mcasp->regs->XMASK = 0xFFFFFFFF; // No padding used _. d8 Z7 m3 n/ x0 k
mcasp->regs->XFMT = 0x00018078; // MSB 16bit, 0-delay, no pad, CFGBus9 ~" M! h& j* r, A: S, ?
mcasp->regs->AFSXCTL = 0x00000112; // 2TDM, 1bit Rising edge INTERNAL FS, word) f) w0 f1 E" u4 ^
mcasp->regs->ACLKXCTL = 0x000000AF; // ASYNC, Rising INTERNAL CLK, div-by-16
# _# d4 x1 s5 }7 A. g) s# Y$ m: P mcasp->regs->AHCLKXCTL = 0x00000000; // EXT CLK
+ W0 }0 t# r6 d! T3 ]1 q mcasp->regs->XTDM = 0x00000003; // Slots 0,1
& }, C+ F4 M: X' | l% C( t mcasp->regs->XINTCTL = 0x00000020; // interrupt on transmit/ t p# V+ O5 j6 x5 |7 l
mcasp->regs->XCLKCHK = 0x00FF0008; // 255-MAX 0-MIN, div-by-256- r5 Y& J3 w! Y. Z0 m" r
* n+ `8 H- o4 _6 p' O mcasp->regs->SRCTL5 = 0x000D; // MCASP1.AXR1[5] --> DIN" E# f4 |! \9 j' G
mcasp->regs->SRCTL0 = 0x000E; // MCASP1.AXR1[0] <-- DOUT
) e' s6 ]' X+ H4 l: _$ o) H+ E3 D mcasp->regs->PFUNC = 0; // All MCASPs
2 r2 E) k' p( o, t3 ? mcasp->regs->PDIR = 0x14000020; // All inputs except AXR0[5], ACLKX1, AFSX1
9 g$ h3 u- _3 _7 f n( P- `$ s5 Y% m( S
mcasp->regs->DITCTL = 0x00000000; // Not used& X( N! y! \, L5 E6 y- t
mcasp->regs->DLBCTL = 0x00000000; // Not used' W0 d9 ~' T! p A
mcasp->regs->AMUTE = 0x00000000; // Not used
( ^* t5 f( u O$ Y. R7 a( G- C! G6 n* x8 b6 z) L
/* Starting sections of the McASP*/, ] Q4 E1 W' Y6 L2 F Z# m# \
mcasp->regs->XGBLCTL |= GBLCTL_XHCLKRST_ON;
7 l( O. Z) A! @ while ( ( mcasp->regs->XGBLCTL & GBLCTL_XHCLKRST_ON ) != GBLCTL_XHCLKRST_ON ); 6 l2 Z6 R9 N$ \; {1 ]% x& V
mcasp->regs->RGBLCTL |= GBLCTL_RHCLKRST_ON;
& h+ q: E- [6 E% G* ^& \0 k while ( ( mcasp->regs->RGBLCTL & GBLCTL_RHCLKRST_ON ) != GBLCTL_RHCLKRST_ON );5 Z8 U4 x' p6 U
/ p6 v+ o& F ]: d- H5 P& R mcasp->regs->XGBLCTL |= GBLCTL_XCLKRST_ON; " k1 {4 N2 u1 H& v: |0 j
while ( ( mcasp->regs->XGBLCTL & GBLCTL_XCLKRST_ON ) != GBLCTL_XCLKRST_ON );
1 H+ F+ i' L" E" N2 [4 U s' B mcasp->regs->RGBLCTL |= GBLCTL_RCLKRST_ON;
8 }2 T' |) z( c- u7 ?: p2 \9 v while ( ( mcasp->regs->RGBLCTL & GBLCTL_RCLKRST_ON ) != GBLCTL_RCLKRST_ON );# E" e* R" T; `( P! y+ m
/ \1 _! h$ s, S: H8 [ mcasp->regs->XSTAT = 0x0000ffff;
, i6 F+ K4 V# d2 k* s% Q$ G mcasp->regs->RSTAT = 0x0000ffff;
. A2 P1 w f* o" c2 x( O* |3 b5 u; R- z: x
mcasp->regs->XGBLCTL |= GBLCTL_XSRCLR_ON;
- V# w7 g) Z9 L+ t6 a while ( ( mcasp->regs->XGBLCTL & GBLCTL_XSRCLR_ON ) != GBLCTL_XSRCLR_ON );
& R* z0 I" V0 c) k6 [7 m$ x mcasp->regs->RGBLCTL |= GBLCTL_RSRCLR_ON;
+ k o- x1 k0 K6 q/ g while ( ( mcasp->regs->RGBLCTL & GBLCTL_RSRCLR_ON ) != GBLCTL_RSRCLR_ON );
, h, h3 c4 ]( j5 @' u0 ^; _& ?) p0 u# T+ a# M/ R' T
/* Write a 0, so that no underrun occurs after releasing the state machine */
+ @( q! R5 Z$ V, n- ~, O# m mcasp->regs->XBUF5 = 0;+ ~8 y9 N4 s7 P% ^' n
mcasp->regs->RBUF0 = 0;
/ ? W X( A9 H0 J; {4 u! B3 N6 L) }" n9 ^2 v0 N2 Z
mcasp->regs->XGBLCTL |= GBLCTL_XSMRST_ON; O4 m% S% n7 b
while ( ( mcasp->regs->XGBLCTL & GBLCTL_XSMRST_ON ) != GBLCTL_XSMRST_ON );$ }8 |6 _2 @2 ?. g- s) K
mcasp->regs->RGBLCTL |= GBLCTL_RSMRST_ON;
$ x: T/ g9 ^7 U# s% ? while ( ( mcasp->regs->RGBLCTL & GBLCTL_RSMRST_ON ) != GBLCTL_RSMRST_ON );2 x4 a8 H/ d9 f5 S1 _
9 V% p9 [0 F' K& a
mcasp->regs->XGBLCTL |= GBLCTL_XFRST_ON;
7 z1 q/ i$ b7 `: e; {* T while ( ( mcasp->regs->XGBLCTL & GBLCTL_XFRST_ON ) != GBLCTL_XFRST_ON );: V0 |9 D2 T0 s* F& x
mcasp->regs->RGBLCTL |= GBLCTL_RFRST_ON; # {1 Z& J. Z2 P; ]$ V- l
while ( ( mcasp->regs->RGBLCTL & GBLCTL_RFRST_ON ) != GBLCTL_RFRST_ON );
" y6 t$ p4 I2 N/ Q2 O
0 _& {7 r& d' o3 X9 B- S CSR = 0x0000;3 o1 l: _. k0 G! f/ N* B1 v/ s
INTC_INTMUX1 = 0x3d;. E% ?6 {1 [+ J. F# k0 e7 ^
ISTP = (unsigned int)vectors;4 \, I N% C5 j5 G4 r$ `9 C* X
ICR = 0xFFF0;
6 \ L0 I! P8 B& ^# ~ IER |= 0x12; ) g, i! T1 j. K) z9 X
CSR |= 0x01; 7 r! {$ `" \1 V: U F5 d0 ]6 q5 a2 X& q
* S- y2 e W9 L. Z2 o+ B
' ~! j0 c7 ?3 X9 V* h* [7 ]2 p3 H6 f) o
还有就是两个输入输出函数: u1 W; x8 k) j% h
void output_sample(Int32 out_data)5 g. W0 a% F1 Q* J+ A' Q
{
( j( ]2 x5 O9 a: f AIC31_data.uint = out_data; ; C- T# P: H) V' `
MCASP1_XBUF5_32BIT = AIC31_data.uint;
& C1 p l) L3 P9 f; O3 h2 r* M0 }}; m# \- z! M0 A" B4 q1 n2 ^
! P8 U: ?) c: I$ k% x( c
Int32 input_sample(void)
; W+ l/ F- p; R2 l{
: O$ [: k# x9 X( ]3 Y7 ~ AIC31_data.uint = MCASP1_RBUF0_32BIT;
2 |. j# l3 l6 Q, E return (AIC31_data.uint);
& ~, T+ _' R. A( I% z" C0 m}
) R2 f; O/ I2 P& d% k
- X+ p- F6 ^3 l/ g e |
|