|
|
C6747和C6748感觉差不多,我想实现McASP发送中断方式控制音频信号,在轮询的例程基础上改的,轮询程序可以实现,但是中断一直实现不了,也找不到错误,求大神帮忙!下边是主要程序:
: ^& R3 X/ W* z K" J. s0 Wmain文件:" C- j# C+ x1 I4 n
interrupt void interrupt4(void)
3 q1 m# w* S" ?% \& n$ ~{
* e1 z9 S3 _# V, ?& I; l6 f Uint32 sample;
7 Y; B7 T6 M) d& I+ w! K
, |7 s/ n; _ s6 E sample = input_sample(); // read L + R samples from ADC" P: D8 T: r" h: |$ j% L+ L
output_sample(sample); // write L + R samples to DAC 8 E& p' N9 o7 `5 ~
return;
4 `0 N. ~* G+ `* o5 L2 v7 q}; J+ I( y7 ~0 g; v \" ?( E' a+ C
+ B) ~' O; t9 J* M4 U mint main( void )
. i1 N8 B* R9 k# |/ d3 s! v{
$ ^+ W9 M6 C; d% \
5 b2 l5 r1 c9 t- d/ z2 o+ M /* Initialize BSL */9 w" ]& ]( X! J6 f5 O0 j6 i# i
EVMC6747_init( );. `3 }' ]1 R2 a! m' g
/* Call evmc6747_intr function */
/ C% o# \' J/ j7 m! |+ w' { aic3106_init( ); E" V- ^! l* `6 m- C* u! z* c
while(1);% x; s7 R+ _3 y4 I
}
8 J. _6 c& r4 l% P3 L' K
2 _+ Y9 w1 X4 j4 }8 x- n Z3 f( m: C( E# K
aic3106_init文件的一部分,McASP配置部分,采用内部时钟,I2S方式,同步传输。音频芯片的配置应该没问题
+ @+ h" L4 {8 B0 e/* Initialize MCASP1 */4 Q3 y$ ^6 y6 B
mcasp = &MCASP_MODULE_1;
- ^1 ~$ J# @" Z0 B+ @+ q mcasp->regs->GBLCTL = 0; // Reset; W s, C3 \3 N; L* ? A% @' ~) [
mcasp->regs->RGBLCTL = 0; // Reset RX
+ r7 @0 H$ m2 [% P/ u9 n mcasp->regs->XGBLCTL = 0; // Reset TX
. b6 _! A e" Y3 x% L- Z H# v mcasp->regs->PWRDEMU = 1; // Free-running7 T1 }6 p9 C4 k% d
// configure McASP0 receive registers: U. s6 t0 z0 ?* C+ [ j3 d, c
mcasp->regs->RMASK = 0xFFFFFFFF; // No padding used4 ^* w1 N! C" S7 W6 l/ c
mcasp->regs->RFMT = 0x00018078; // MSB 16bit, 0-delay, no pad, CFGBus4 ^- o# O& @! o- m6 W5 ^# t
mcasp->regs->AFSRCTL = 0x00000112; // 2TDM, 1bit Falling, External FS, word6 L1 N9 K4 t5 f
mcasp->regs->ACLKRCTL = 0x000000AF; // Rising INTERNAL CLK,(from tx side)5 L6 w4 S+ g9 S, ~! F
mcasp->regs->AHCLKRCTL = 0x00000000; // INT CLK (from tx side)
9 @; S0 Y/ k1 d- o, `2 O! l ] mcasp->regs->RTDM = 0x00000003; // Slots 0,1/ V! a/ y" z# \# x6 ~6 |, n
mcasp->regs->RINTCTL = 0x00000000; // Not used
{, @) {, U$ h$ `- l+ d; V# Q- s mcasp->regs->RCLKCHK = 0x00FF0008; // 255-MAX 0-MIN, div-by-256
" S+ ~/ y; F/ @0 e P! t
& ]$ `: ~0 ]9 C5 a4 z% n3 W mcasp->regs->XMASK = 0xFFFFFFFF; // No padding used
" n% N- V8 T1 Z+ G% S' h mcasp->regs->XFMT = 0x00018078; // MSB 16bit, 0-delay, no pad, CFGBus
$ Y6 r" A8 V8 G& i9 t7 V, W" ] mcasp->regs->AFSXCTL = 0x00000112; // 2TDM, 1bit Rising edge INTERNAL FS, word
* I7 y) Y# J% Y+ j. G mcasp->regs->ACLKXCTL = 0x000000AF; // ASYNC, Rising INTERNAL CLK, div-by-169 p' l5 Q/ U2 Y, M1 V$ `
mcasp->regs->AHCLKXCTL = 0x00000000; // EXT CLK; O; K. ?% Y: L( N% i) X1 M1 m$ ]
mcasp->regs->XTDM = 0x00000003; // Slots 0,1: d1 K8 C. g. E" Z& ~6 R. j
mcasp->regs->XINTCTL = 0x00000020; // interrupt on transmit2 @! }2 i8 y% `9 H7 ?+ R, u
mcasp->regs->XCLKCHK = 0x00FF0008; // 255-MAX 0-MIN, div-by-256# @+ T& u2 D8 l! l
6 i5 Y# f0 Y6 v mcasp->regs->SRCTL5 = 0x000D; // MCASP1.AXR1[5] --> DIN/ m2 M0 b% A# [9 o
mcasp->regs->SRCTL0 = 0x000E; // MCASP1.AXR1[0] <-- DOUT. h2 c, d/ k Q) G7 B
mcasp->regs->PFUNC = 0; // All MCASPs! r8 K% C% Q- E! Z
mcasp->regs->PDIR = 0x14000020; // All inputs except AXR0[5], ACLKX1, AFSX1
& _% s& l4 o R* m9 s, |
& d% ^ [% d7 Z mcasp->regs->DITCTL = 0x00000000; // Not used: L& }' q3 L# ]
mcasp->regs->DLBCTL = 0x00000000; // Not used. G3 i f" M7 q9 X& D2 h
mcasp->regs->AMUTE = 0x00000000; // Not used
0 u' n' r: |) Y/ v# m) h
) s& J0 c6 ` B$ ~# `4 R/* Starting sections of the McASP*/8 p5 n9 ` Z( G- E3 A! j
mcasp->regs->XGBLCTL |= GBLCTL_XHCLKRST_ON; 9 |& a8 I+ j2 N6 a5 d
while ( ( mcasp->regs->XGBLCTL & GBLCTL_XHCLKRST_ON ) != GBLCTL_XHCLKRST_ON ); 7 Z, ^6 {1 F# b/ @* r
mcasp->regs->RGBLCTL |= GBLCTL_RHCLKRST_ON; : Y7 z! ?0 Y) Q Q2 T9 b1 |& D: P
while ( ( mcasp->regs->RGBLCTL & GBLCTL_RHCLKRST_ON ) != GBLCTL_RHCLKRST_ON );! ~! I0 n- a8 f& r) P) U
, A5 O t7 [4 F mcasp->regs->XGBLCTL |= GBLCTL_XCLKRST_ON; / }: t% h/ F5 O6 J# Z# N! N
while ( ( mcasp->regs->XGBLCTL & GBLCTL_XCLKRST_ON ) != GBLCTL_XCLKRST_ON );
" k5 _% L! l" E% z1 |( z! U% C- l mcasp->regs->RGBLCTL |= GBLCTL_RCLKRST_ON; ; P, _% H! [; t6 b
while ( ( mcasp->regs->RGBLCTL & GBLCTL_RCLKRST_ON ) != GBLCTL_RCLKRST_ON );
1 M" Y& K8 m2 o& i8 S( A
0 w1 h* `& O; V+ R! W mcasp->regs->XSTAT = 0x0000ffff; ; {' S$ v! D- R2 | d+ t B
mcasp->regs->RSTAT = 0x0000ffff; 5 g& m. S6 |# D9 }
6 j9 f+ U9 l# [) h- r% u mcasp->regs->XGBLCTL |= GBLCTL_XSRCLR_ON;
& p" n' U/ K9 B" V" p. A) ] while ( ( mcasp->regs->XGBLCTL & GBLCTL_XSRCLR_ON ) != GBLCTL_XSRCLR_ON );, l2 l. p1 Q5 R1 a8 k' T
mcasp->regs->RGBLCTL |= GBLCTL_RSRCLR_ON;
- z2 B% ?, k6 l1 ^ while ( ( mcasp->regs->RGBLCTL & GBLCTL_RSRCLR_ON ) != GBLCTL_RSRCLR_ON );
1 O8 F0 ]' s- q7 T9 ~3 q; M: [2 R Z5 Z# d! ~8 b
/* Write a 0, so that no underrun occurs after releasing the state machine */
* D+ p2 Y# V$ W3 m mcasp->regs->XBUF5 = 0;/ n, o6 E. I2 p# S
mcasp->regs->RBUF0 = 0;
( d. M1 N& [6 F1 D$ U% V0 y# o h1 d4 z4 A7 X. B
mcasp->regs->XGBLCTL |= GBLCTL_XSMRST_ON;
" r9 C$ u7 Q$ Y0 ^0 o7 w while ( ( mcasp->regs->XGBLCTL & GBLCTL_XSMRST_ON ) != GBLCTL_XSMRST_ON );. I7 j# [# R# F" N
mcasp->regs->RGBLCTL |= GBLCTL_RSMRST_ON; % p8 _ ^9 E- [6 {; r6 _* E4 @
while ( ( mcasp->regs->RGBLCTL & GBLCTL_RSMRST_ON ) != GBLCTL_RSMRST_ON );
) M# {, M7 j' y" t* l" B" w
1 t! b2 s, x/ ]3 r& F) N9 s mcasp->regs->XGBLCTL |= GBLCTL_XFRST_ON; # O8 I! N' D) E- h m5 p
while ( ( mcasp->regs->XGBLCTL & GBLCTL_XFRST_ON ) != GBLCTL_XFRST_ON );7 h8 i+ ~$ e" l/ ]$ \' [
mcasp->regs->RGBLCTL |= GBLCTL_RFRST_ON; ! J/ b% V& A/ y+ |& }; i# j7 A" F
while ( ( mcasp->regs->RGBLCTL & GBLCTL_RFRST_ON ) != GBLCTL_RFRST_ON );. S# N) c/ k6 {5 E
5 a* w: b# `' J4 U9 S8 z
CSR = 0x0000;
2 |; ?9 P: ^3 y0 \9 ]$ E" v1 r9 W INTC_INTMUX1 = 0x3d;
( X" s8 `# f( q* _+ @ ISTP = (unsigned int)vectors;% S* p. L' y* U
ICR = 0xFFF0; - C9 d2 m1 g! o7 A9 Y' `* u" P, i$ W
IER |= 0x12;
1 |9 d# Q" |' j! F3 S5 \ CSR |= 0x01; : n* m0 @) x- R) g3 i |1 C7 I
9 Q! `) l- v- b+ S
% @" L# ~" |, s/ M- ^9 b
' Z: v5 d; Z% U1 A
还有就是两个输入输出函数:( [% h/ {" l' b/ x. B1 ^
void output_sample(Int32 out_data)# d% d8 b2 |. B) U- r# U. o W
{
1 `) l4 w% R1 C4 l+ q8 V( C8 l AIC31_data.uint = out_data;
' }+ K/ q1 l1 g4 ?; m7 [; D. I; S+ J MCASP1_XBUF5_32BIT = AIC31_data.uint;3 L/ y) \ y+ M2 U7 \/ q, H% G8 w) a& N& t' j
}' q: f$ @5 Y7 {( v. f7 K
1 E( h% v# I9 N' @! P3 aInt32 input_sample(void)
$ G& F7 N1 S. t: n* K- r8 f{ / O& H; p6 j* j- \; |- s
AIC31_data.uint = MCASP1_RBUF0_32BIT;, r: ~) g4 U( ]% E2 j
return (AIC31_data.uint);% e3 P) e% D: }, X3 _! B3 f& E0 ]. `
}
$ a" H* R6 x7 K
& f, `3 r" V1 N( c |
|