|
|
C6747和C6748感觉差不多,我想实现McASP发送中断方式控制音频信号,在轮询的例程基础上改的,轮询程序可以实现,但是中断一直实现不了,也找不到错误,求大神帮忙!下边是主要程序:
; u. y9 w4 N. `% u& ?. L, wmain文件:
6 q m' ~& N0 F5 s9 c3 V9 Iinterrupt void interrupt4(void) 5 F; m. a$ ^6 y1 ^+ x
{1 {' T6 X: M/ h5 i; m3 z6 X
Uint32 sample;
; t% L% P% y! z( m1 c6 i; Q
8 N1 I( ]$ C0 `1 Q7 l9 } sample = input_sample(); // read L + R samples from ADC: E+ R, T- K, x
output_sample(sample); // write L + R samples to DAC 6 ^" O. s/ h- Z% X
return;6 t( Z1 ~3 A$ L4 ]; `# g
}# g" c; }3 q G( }2 k- i; y
4 z, w& F; p! F$ {! o
int main( void )
% P. t1 }! G' n3 n& o S{$ h( o V S/ c% z0 M! z7 J7 z
4 @6 R4 F2 M( {' G! F
/* Initialize BSL */
, r* |7 _* q& n; e EVMC6747_init( );
. A& K1 Y, f3 {' y4 V: b /* Call evmc6747_intr function *// t1 x7 i! n8 F, j4 B. a
aic3106_init( );
% A+ ]7 Y% T \+ k: h while(1);4 N/ u" p( A+ x) \1 Q4 V% S
}
- V+ t0 R* k4 _+ n( d/ O* O5 \* |* l
& z, P: z6 B3 X k1 X& p8 {" P' c, ^4 l
aic3106_init文件的一部分,McASP配置部分,采用内部时钟,I2S方式,同步传输。音频芯片的配置应该没问题
) ?. M4 B# y7 c+ n/* Initialize MCASP1 */! e- g" S4 n" z$ v% n
mcasp = &MCASP_MODULE_1;
1 d* O% Z6 W# w- M8 N0 \) h mcasp->regs->GBLCTL = 0; // Reset9 H' u- l$ i# y9 j7 z' h
mcasp->regs->RGBLCTL = 0; // Reset RX
1 }2 S }& n; J mcasp->regs->XGBLCTL = 0; // Reset TX
& X: v0 K/ D, I, U/ {; s! ? mcasp->regs->PWRDEMU = 1; // Free-running8 U: U0 F- ]& N5 Q
// configure McASP0 receive registers$ D0 ^5 H; x+ q! Q, Z
mcasp->regs->RMASK = 0xFFFFFFFF; // No padding used
# u r( D9 r ^/ i" o/ \, ` mcasp->regs->RFMT = 0x00018078; // MSB 16bit, 0-delay, no pad, CFGBus7 O4 P& R9 l R$ n
mcasp->regs->AFSRCTL = 0x00000112; // 2TDM, 1bit Falling, External FS, word& G* X+ ?2 x( Y
mcasp->regs->ACLKRCTL = 0x000000AF; // Rising INTERNAL CLK,(from tx side)
z% d% h P' s% u1 `* }$ _7 s mcasp->regs->AHCLKRCTL = 0x00000000; // INT CLK (from tx side). x, ]% X# Q1 t& ~% a" m, S
mcasp->regs->RTDM = 0x00000003; // Slots 0,1
, w9 ?& r/ u$ S: f3 C mcasp->regs->RINTCTL = 0x00000000; // Not used, O% l& x" Z; s, V* y& K4 B
mcasp->regs->RCLKCHK = 0x00FF0008; // 255-MAX 0-MIN, div-by-256
; y- {% G2 w+ F- T6 r- |9 U5 N1 j' U2 I9 u9 X/ G5 Q8 T' s
mcasp->regs->XMASK = 0xFFFFFFFF; // No padding used G6 `7 n7 b3 _2 n3 L) k- V: ]
mcasp->regs->XFMT = 0x00018078; // MSB 16bit, 0-delay, no pad, CFGBus& J; H9 a. b% N; _0 j; v5 E
mcasp->regs->AFSXCTL = 0x00000112; // 2TDM, 1bit Rising edge INTERNAL FS, word
' _" {/ t, M. y4 j mcasp->regs->ACLKXCTL = 0x000000AF; // ASYNC, Rising INTERNAL CLK, div-by-16) @# }: d2 x/ ?3 Q9 s
mcasp->regs->AHCLKXCTL = 0x00000000; // EXT CLK
# t% P( ^1 }. |7 w mcasp->regs->XTDM = 0x00000003; // Slots 0,1$ z3 g1 W( D# G9 k% V. u$ `
mcasp->regs->XINTCTL = 0x00000020; // interrupt on transmit% x9 O6 x+ t& e- F6 N; g; e
mcasp->regs->XCLKCHK = 0x00FF0008; // 255-MAX 0-MIN, div-by-256
6 S( T: b7 k% l( R- ^, V
$ ^5 v2 u( b9 A4 x. ^# E0 \ mcasp->regs->SRCTL5 = 0x000D; // MCASP1.AXR1[5] --> DIN- M8 X. J( V. Y; e
mcasp->regs->SRCTL0 = 0x000E; // MCASP1.AXR1[0] <-- DOUT
]! a3 N/ @' i6 _6 p5 Z mcasp->regs->PFUNC = 0; // All MCASPs
$ k9 @6 O0 C" l/ z mcasp->regs->PDIR = 0x14000020; // All inputs except AXR0[5], ACLKX1, AFSX15 t5 Q0 L( l5 v, H
2 Q* q/ j( O7 r: F+ ]5 |) T mcasp->regs->DITCTL = 0x00000000; // Not used
& T3 U q" }' H+ f% g. Z/ a& Y mcasp->regs->DLBCTL = 0x00000000; // Not used
$ X9 v( p9 D" Z( n" w mcasp->regs->AMUTE = 0x00000000; // Not used
: b- X) J, h' Y8 `2 H9 R) v
4 D- s( C; I, Q/* Starting sections of the McASP*/! X$ t) k2 ~2 l2 l9 y
mcasp->regs->XGBLCTL |= GBLCTL_XHCLKRST_ON;
, {# H" f, F5 }2 j1 f while ( ( mcasp->regs->XGBLCTL & GBLCTL_XHCLKRST_ON ) != GBLCTL_XHCLKRST_ON );
`; z" w. x4 {3 ?- O mcasp->regs->RGBLCTL |= GBLCTL_RHCLKRST_ON; " L+ K0 L; b" @1 A: k) K) C, `
while ( ( mcasp->regs->RGBLCTL & GBLCTL_RHCLKRST_ON ) != GBLCTL_RHCLKRST_ON );
' L" p* T9 K* i! m3 U% d1 s2 r7 X; F; B$ z1 }
mcasp->regs->XGBLCTL |= GBLCTL_XCLKRST_ON;
( H" Y& ?" [9 [* m- R/ J* w/ p while ( ( mcasp->regs->XGBLCTL & GBLCTL_XCLKRST_ON ) != GBLCTL_XCLKRST_ON );
" o( r2 [3 T8 R/ W+ B mcasp->regs->RGBLCTL |= GBLCTL_RCLKRST_ON; ) E0 G1 \! Z5 r: k0 [, d2 L
while ( ( mcasp->regs->RGBLCTL & GBLCTL_RCLKRST_ON ) != GBLCTL_RCLKRST_ON );! ~9 i2 c) X5 p$ p A
2 a. J7 K J2 S( ]; V) q$ @, K
mcasp->regs->XSTAT = 0x0000ffff;
0 P, o; r( R* T) \ mcasp->regs->RSTAT = 0x0000ffff;
' W0 |- }& @2 u M, `. \& Y; |7 u) [, n4 I9 i1 w
mcasp->regs->XGBLCTL |= GBLCTL_XSRCLR_ON;
# L8 n+ R8 d% @6 b while ( ( mcasp->regs->XGBLCTL & GBLCTL_XSRCLR_ON ) != GBLCTL_XSRCLR_ON );; {3 q% b9 `& `; M$ t/ }' m3 q
mcasp->regs->RGBLCTL |= GBLCTL_RSRCLR_ON; # l& N1 k: w, Q# Y
while ( ( mcasp->regs->RGBLCTL & GBLCTL_RSRCLR_ON ) != GBLCTL_RSRCLR_ON );
6 K3 n. {+ V, o6 c6 T O6 e' z4 s) m6 k& \0 P
/* Write a 0, so that no underrun occurs after releasing the state machine */
1 p: m$ f( H" A mcasp->regs->XBUF5 = 0;' N" F, `: z. t6 `$ ~
mcasp->regs->RBUF0 = 0;
' H, f( g$ U7 j. ~1 `
& Z! E8 g! `6 c w D mcasp->regs->XGBLCTL |= GBLCTL_XSMRST_ON;
: `" Z$ Y3 i6 X3 `4 s- { while ( ( mcasp->regs->XGBLCTL & GBLCTL_XSMRST_ON ) != GBLCTL_XSMRST_ON );# k# Q9 [4 Z: y7 a! z2 O8 `
mcasp->regs->RGBLCTL |= GBLCTL_RSMRST_ON; + h' S/ W8 ?6 O. _0 n; n
while ( ( mcasp->regs->RGBLCTL & GBLCTL_RSMRST_ON ) != GBLCTL_RSMRST_ON );
2 m- D8 C+ s3 t% K, R$ B8 I' T
^, `: v; r9 H$ y5 r, u mcasp->regs->XGBLCTL |= GBLCTL_XFRST_ON; 9 }. b# v+ I( |+ N3 {1 N$ D$ A/ B
while ( ( mcasp->regs->XGBLCTL & GBLCTL_XFRST_ON ) != GBLCTL_XFRST_ON );8 n% u4 d* T2 r5 `# H8 t7 G
mcasp->regs->RGBLCTL |= GBLCTL_RFRST_ON;
# K2 F; R7 o4 N- ^8 y: l while ( ( mcasp->regs->RGBLCTL & GBLCTL_RFRST_ON ) != GBLCTL_RFRST_ON );
$ n2 E& V4 H& [" x/ n8 U2 I8 d6 `1 l& S5 K2 |0 j' e
CSR = 0x0000;
$ Q! Y2 X+ G, a: U3 Z9 S5 ~4 W+ T INTC_INTMUX1 = 0x3d;
8 d7 J( l# L- b( q6 u, t; y ISTP = (unsigned int)vectors;2 {. U1 ]$ ?% |6 E+ p$ H6 b
ICR = 0xFFF0;
* j# \0 v! c! d7 K2 y IER |= 0x12;
1 N1 H, q0 Y0 ~7 M8 ]2 P CSR |= 0x01; - G: x$ {& y0 u& k: Y+ h
* P) e0 @& a: O; b- v
5 E9 d7 }6 W! R7 ?
! [1 {3 H' s D还有就是两个输入输出函数:, p4 S' n! q# o& I& U2 g0 R
void output_sample(Int32 out_data)3 r. E2 O- E8 W' {
{
m, R6 M9 U& N* S AIC31_data.uint = out_data;
2 A7 R3 ~" y! Z$ c4 g: A7 V MCASP1_XBUF5_32BIT = AIC31_data.uint;
# |% G0 H$ S6 b! F4 c}
7 H; E5 P. V" i* U# J; \. X' j, C. U: d3 q* w$ [) f4 F4 @2 H
Int32 input_sample(void) w8 W2 l0 [! |4 s. i9 ?( x
{
. H. x& u/ M: B8 m4 } AIC31_data.uint = MCASP1_RBUF0_32BIT;( ]1 r2 G! E# x6 J
return (AIC31_data.uint);
1 ?3 ?3 A* o$ |" h9 N}
7 F5 Q& {9 `9 {; I& A! n: M' [
" I% K4 b/ H( } |
|