|
|
C6747和C6748感觉差不多,我想实现McASP发送中断方式控制音频信号,在轮询的例程基础上改的,轮询程序可以实现,但是中断一直实现不了,也找不到错误,求大神帮忙!下边是主要程序:
* _& U+ ]) c) U E0 b( x: i9 `main文件:
# ?6 |# z) C( _! [2 e6 Kinterrupt void interrupt4(void)
+ P9 E0 o& S0 E{
' ?' E! \2 z3 I6 ]$ T8 }8 F Uint32 sample;
5 R& O) K4 K) g; { f* a& O
f/ l5 @7 b4 p. |( v$ V$ J sample = input_sample(); // read L + R samples from ADC
- ?1 O0 s) h6 [1 c5 H7 ?- g output_sample(sample); // write L + R samples to DAC
3 u8 _( H* @: I) u j: H return;# X7 u6 H* z2 N! o
}
+ o1 B; Q6 D* f/ u, g, G; R' L6 t8 ]& F/ T) G
int main( void )% ?5 r+ d' w: ^% `& A: ~4 X. K
{
$ p* a. @/ o N# w9 m: u% p% }6 x* Z2 w" j1 ~. j( j9 K
/* Initialize BSL */
$ T3 D3 M3 C3 r EVMC6747_init( );8 A ]! o6 i, v+ S% d8 `/ J2 k
/* Call evmc6747_intr function */7 B9 r0 A. k) H, s/ r$ m, @6 y
aic3106_init( );
9 w+ I; ?& W, H1 j0 a+ W while(1);
) o) f! \. w9 z, M h0 S9 q0 V}
; d' z/ ~- M/ h* n9 e$ r& D9 B! I2 y4 v# o: Y* q/ o3 D
5 P; d: [7 E1 S6 E8 Q% }7 Caic3106_init文件的一部分,McASP配置部分,采用内部时钟,I2S方式,同步传输。音频芯片的配置应该没问题/ d: E5 R: v, N9 E L( I: Y6 @; {
/* Initialize MCASP1 */
! W. b6 d; G7 I6 W: B4 c* L8 a+ T mcasp = &MCASP_MODULE_1;
8 q) r) d$ {& G& u; ]1 @6 H, Y mcasp->regs->GBLCTL = 0; // Reset. O- J% U7 s3 I3 R8 y. P
mcasp->regs->RGBLCTL = 0; // Reset RX' f8 Q8 H$ S4 q* C3 h! g, f
mcasp->regs->XGBLCTL = 0; // Reset TX
' `; J) d1 g5 i0 h2 h mcasp->regs->PWRDEMU = 1; // Free-running1 G7 F! n5 a, M. F* ~
// configure McASP0 receive registers
! N7 X# B H# [ mcasp->regs->RMASK = 0xFFFFFFFF; // No padding used: q* @, ]1 \3 j$ U/ D3 H
mcasp->regs->RFMT = 0x00018078; // MSB 16bit, 0-delay, no pad, CFGBus( v4 ?: M5 \' R
mcasp->regs->AFSRCTL = 0x00000112; // 2TDM, 1bit Falling, External FS, word6 ?( q o. {' N7 [* _! R H; M
mcasp->regs->ACLKRCTL = 0x000000AF; // Rising INTERNAL CLK,(from tx side)) {8 @4 x2 R/ ~4 Z, n
mcasp->regs->AHCLKRCTL = 0x00000000; // INT CLK (from tx side)
) N. _0 ^4 W, u& T mcasp->regs->RTDM = 0x00000003; // Slots 0,1
/ u% k0 ?0 Y' e5 u$ c8 e! t3 X1 f1 a mcasp->regs->RINTCTL = 0x00000000; // Not used
* |; R& [2 U4 n& ^0 Z' \ mcasp->regs->RCLKCHK = 0x00FF0008; // 255-MAX 0-MIN, div-by-256
( @: |- h# _4 s9 A7 n6 n
; n* J3 q- @ |4 k: {. F0 B mcasp->regs->XMASK = 0xFFFFFFFF; // No padding used% i7 |+ T$ [! H2 F
mcasp->regs->XFMT = 0x00018078; // MSB 16bit, 0-delay, no pad, CFGBus
( g. P+ m) h) O$ x5 y: B2 s mcasp->regs->AFSXCTL = 0x00000112; // 2TDM, 1bit Rising edge INTERNAL FS, word! g& q$ L% r: n9 `0 b e
mcasp->regs->ACLKXCTL = 0x000000AF; // ASYNC, Rising INTERNAL CLK, div-by-16: Y! v. f8 R, U" `! i
mcasp->regs->AHCLKXCTL = 0x00000000; // EXT CLK- H4 x6 W, E/ d; l
mcasp->regs->XTDM = 0x00000003; // Slots 0,1
: h1 [& W' k: `6 G6 v mcasp->regs->XINTCTL = 0x00000020; // interrupt on transmit
& m U( S( I, ?2 K# ]. Z mcasp->regs->XCLKCHK = 0x00FF0008; // 255-MAX 0-MIN, div-by-2566 K( P2 u9 `' X! d+ K; n* S
* r8 Z1 y; t; d7 `
mcasp->regs->SRCTL5 = 0x000D; // MCASP1.AXR1[5] --> DIN1 o( L9 s7 F* a/ w$ K! g
mcasp->regs->SRCTL0 = 0x000E; // MCASP1.AXR1[0] <-- DOUT
' C9 K! z# O7 K- W' U mcasp->regs->PFUNC = 0; // All MCASPs
& Z0 n1 k- u. B3 e- ]- I mcasp->regs->PDIR = 0x14000020; // All inputs except AXR0[5], ACLKX1, AFSX1
9 y, `8 {6 d a: }& Y# D4 e. o- R8 B
mcasp->regs->DITCTL = 0x00000000; // Not used: D* A6 B9 M. w I, ^, t" {1 Z
mcasp->regs->DLBCTL = 0x00000000; // Not used+ }+ d- a- D8 [5 e
mcasp->regs->AMUTE = 0x00000000; // Not used
0 J4 u/ ~! C" N6 t/ O% @4 P, E/ X, Q2 L0 D3 |
/* Starting sections of the McASP*/' f' B6 Z, N. F, Q- [- q: \
mcasp->regs->XGBLCTL |= GBLCTL_XHCLKRST_ON;
* L1 A, i# W7 W0 r$ z. B while ( ( mcasp->regs->XGBLCTL & GBLCTL_XHCLKRST_ON ) != GBLCTL_XHCLKRST_ON ); % a" U; P. |4 i" A1 W. X2 b
mcasp->regs->RGBLCTL |= GBLCTL_RHCLKRST_ON;
& y, Z9 L" L! V* m while ( ( mcasp->regs->RGBLCTL & GBLCTL_RHCLKRST_ON ) != GBLCTL_RHCLKRST_ON );
5 b2 N! a! O' @" E$ A T7 k
$ r4 W+ h, {( B9 e1 E mcasp->regs->XGBLCTL |= GBLCTL_XCLKRST_ON; + u0 p( y; a% I2 R6 o
while ( ( mcasp->regs->XGBLCTL & GBLCTL_XCLKRST_ON ) != GBLCTL_XCLKRST_ON );& K+ S* u9 W( i4 |3 u/ X
mcasp->regs->RGBLCTL |= GBLCTL_RCLKRST_ON; 1 _ i+ j6 N6 F& c/ `, c
while ( ( mcasp->regs->RGBLCTL & GBLCTL_RCLKRST_ON ) != GBLCTL_RCLKRST_ON );0 o0 w% J; l* |
$ k T6 D+ V( x$ J2 E1 q( f
mcasp->regs->XSTAT = 0x0000ffff; : T, p; H4 l. q) r& h
mcasp->regs->RSTAT = 0x0000ffff; + E1 R) T* [( K8 U$ {
1 g- N2 d! o# e2 Q) u mcasp->regs->XGBLCTL |= GBLCTL_XSRCLR_ON;7 m4 [% }& E6 U2 x. i& e* d1 X5 x
while ( ( mcasp->regs->XGBLCTL & GBLCTL_XSRCLR_ON ) != GBLCTL_XSRCLR_ON );1 ~! g* S2 e2 ^+ T
mcasp->regs->RGBLCTL |= GBLCTL_RSRCLR_ON;
) v, X- A" ?' E; f2 q8 e while ( ( mcasp->regs->RGBLCTL & GBLCTL_RSRCLR_ON ) != GBLCTL_RSRCLR_ON );" r% `! W" X- O D/ Q
: [$ `6 M& P: Q /* Write a 0, so that no underrun occurs after releasing the state machine */
; H# t0 {' y) G& D mcasp->regs->XBUF5 = 0;4 h& w0 E& Y! P; n* _4 f
mcasp->regs->RBUF0 = 0;$ e# O' z7 O+ D- F7 h3 G# P
% _/ \% |& Q% c6 Y" n* @. N mcasp->regs->XGBLCTL |= GBLCTL_XSMRST_ON;
) d6 n1 X* f5 Z0 M) }) ]6 p2 E G% y while ( ( mcasp->regs->XGBLCTL & GBLCTL_XSMRST_ON ) != GBLCTL_XSMRST_ON );
& t: Y U( t/ `. F9 } mcasp->regs->RGBLCTL |= GBLCTL_RSMRST_ON;
( n# I) V! {: r; X while ( ( mcasp->regs->RGBLCTL & GBLCTL_RSMRST_ON ) != GBLCTL_RSMRST_ON );
2 i# k1 ?" J1 K! [( w" w. g
# E8 i0 f% @$ ?4 P. | mcasp->regs->XGBLCTL |= GBLCTL_XFRST_ON;
* d4 ?0 P! r+ y9 g+ a while ( ( mcasp->regs->XGBLCTL & GBLCTL_XFRST_ON ) != GBLCTL_XFRST_ON );8 m+ |, J# S' r: ]0 b
mcasp->regs->RGBLCTL |= GBLCTL_RFRST_ON;
7 _, @: m" A: C( {; c" @( ` while ( ( mcasp->regs->RGBLCTL & GBLCTL_RFRST_ON ) != GBLCTL_RFRST_ON );) Y8 C& x; D& ~+ G$ P" F
3 ]( Z/ ?) f. z7 F
CSR = 0x0000;
( ?0 V9 A, w/ \- s0 Y INTC_INTMUX1 = 0x3d;
) _% F4 l' @8 u1 |2 U9 u ISTP = (unsigned int)vectors;0 I; N+ C& r% N" p
ICR = 0xFFF0;
; V9 G9 ^9 P3 S2 c v4 T6 z IER |= 0x12;
$ i; r6 m7 I5 X1 t! ^5 B. o# ~ CSR |= 0x01; ( ^- y( k( Y' U; {( c2 ]
, R2 q4 O2 d/ \9 w; B% k3 D0 l5 I" U0 n$ Z
; G5 V/ j; B) L$ Y' y
% e1 C* ?0 ]# b1 w/ B6 g还有就是两个输入输出函数:
: O2 q6 u, V2 [1 i4 L1 qvoid output_sample(Int32 out_data)
1 _$ {. {. K! c# O{9 U. y/ z$ W1 @/ U4 |2 G
AIC31_data.uint = out_data;
0 y' n. E3 W1 t: N4 ^! [! o MCASP1_XBUF5_32BIT = AIC31_data.uint;
' Y% k# |+ x3 M+ W& E f7 _3 E- J}
9 u% Z" \/ C: U* N9 U6 D2 O5 J4 i0 X3 Q2 x; Z/ \ B4 q
Int32 input_sample(void)
* |/ Q0 x, M9 h6 t{ 5 ]' s o1 r0 k" L$ @9 A- I
AIC31_data.uint = MCASP1_RBUF0_32BIT;
- N% x. q/ T# A return (AIC31_data.uint);
* E: T9 r! x0 T$ ?& i$ h}
" J' D& g& G7 q# E4 c7 Y& b, z0 n6 x: C
|
|