|
|
C6747和C6748感觉差不多,我想实现McASP发送中断方式控制音频信号,在轮询的例程基础上改的,轮询程序可以实现,但是中断一直实现不了,也找不到错误,求大神帮忙!下边是主要程序:# X3 K7 z; z8 _4 j
main文件:" @. K6 y. G" {0 V
interrupt void interrupt4(void)
' M5 o# J, E b: g+ ? T4 N! m{) h! \- U9 D; v
Uint32 sample;* Z4 P* v) }, K3 M% g9 e
- ]. T5 v& |2 W% }( d0 y8 m* l sample = input_sample(); // read L + R samples from ADC) [, o2 H u* r% ^' N* ^
output_sample(sample); // write L + R samples to DAC
6 K7 @/ P2 d! B* h2 V5 r return;
, o$ ^" a6 C5 I% m1 j}* X0 V1 w# S0 B8 t6 b( n) Q
3 ^9 d0 y1 p) f- e6 S% Z4 ^int main( void )
3 N5 ~. }! a1 G& ^4 G/ c{. J5 T1 U+ P2 ~) T
0 U: w. i4 W m/ ]7 Y) q
/* Initialize BSL */0 x6 l0 W1 E; O8 Z0 n Q% f
EVMC6747_init( );. A! ?# ]: c. `" G
/* Call evmc6747_intr function */$ _% h5 v; o$ ~: U9 v" \: C$ U
aic3106_init( );
. R& o* u- S+ T1 v while(1);
( n: U/ w9 t& n0 I6 Y% z& w% m}. S) Y' j, w l5 l
. \; n# D& ]# `& b! X: {/ l
- d8 l' s4 O7 a3 w) R/ |1 uaic3106_init文件的一部分,McASP配置部分,采用内部时钟,I2S方式,同步传输。音频芯片的配置应该没问题
, b6 k9 }" Z% u a/* Initialize MCASP1 */
. J1 ]7 |* L9 K3 n$ U$ H4 U mcasp = &MCASP_MODULE_1;( T) _& i% |) q5 O
mcasp->regs->GBLCTL = 0; // Reset
% X. _9 r" b. W8 y- C3 w mcasp->regs->RGBLCTL = 0; // Reset RX5 Z1 ?2 F# U7 L/ Z2 ?
mcasp->regs->XGBLCTL = 0; // Reset TX0 Y" ]& F8 P7 r) A- q2 ^) {: U
mcasp->regs->PWRDEMU = 1; // Free-running3 ?- g4 U \9 K* L! l
// configure McASP0 receive registers
/ I* r$ ?- |6 C2 u, b mcasp->regs->RMASK = 0xFFFFFFFF; // No padding used
h0 S% v0 U( n; l6 }" O& y* g8 b mcasp->regs->RFMT = 0x00018078; // MSB 16bit, 0-delay, no pad, CFGBus+ {( y8 Z# Q- E- X
mcasp->regs->AFSRCTL = 0x00000112; // 2TDM, 1bit Falling, External FS, word. i4 f& b/ R0 \% c: _
mcasp->regs->ACLKRCTL = 0x000000AF; // Rising INTERNAL CLK,(from tx side)( }0 u$ q2 V( z3 @+ m
mcasp->regs->AHCLKRCTL = 0x00000000; // INT CLK (from tx side)
S9 V% ? x6 [- Z' Z8 j mcasp->regs->RTDM = 0x00000003; // Slots 0,1
& v' c+ |0 J! I/ a mcasp->regs->RINTCTL = 0x00000000; // Not used
2 A1 a+ V5 Y$ F" o1 r. R mcasp->regs->RCLKCHK = 0x00FF0008; // 255-MAX 0-MIN, div-by-256. z' b* }3 @% H) R" |* Z$ K- X$ ]
/ ]: }. L; z. V5 x mcasp->regs->XMASK = 0xFFFFFFFF; // No padding used
% {# I; v6 z3 u$ y& @; p mcasp->regs->XFMT = 0x00018078; // MSB 16bit, 0-delay, no pad, CFGBus% O% F) y) L3 l9 W# o- z
mcasp->regs->AFSXCTL = 0x00000112; // 2TDM, 1bit Rising edge INTERNAL FS, word) I1 l$ Q3 z) Q: I; U
mcasp->regs->ACLKXCTL = 0x000000AF; // ASYNC, Rising INTERNAL CLK, div-by-16
& A; H: j7 }: { mcasp->regs->AHCLKXCTL = 0x00000000; // EXT CLK. k4 M% [( @# T4 F x. O$ _ k
mcasp->regs->XTDM = 0x00000003; // Slots 0,1
8 S) A, B8 B. k4 Z% E) [/ l$ l mcasp->regs->XINTCTL = 0x00000020; // interrupt on transmit( |3 l' {/ E$ B' C
mcasp->regs->XCLKCHK = 0x00FF0008; // 255-MAX 0-MIN, div-by-256* p d+ V& G: m
# p0 J8 N$ |- F$ K" V3 A
mcasp->regs->SRCTL5 = 0x000D; // MCASP1.AXR1[5] --> DIN$ J. K# a" i* J1 q# n _# W
mcasp->regs->SRCTL0 = 0x000E; // MCASP1.AXR1[0] <-- DOUT
2 q* Y. h u( r1 @/ x mcasp->regs->PFUNC = 0; // All MCASPs
& i7 T2 V# _4 I5 N( K) h2 r mcasp->regs->PDIR = 0x14000020; // All inputs except AXR0[5], ACLKX1, AFSX1
; W4 `: |5 M/ e; _' w l- f
( l1 |$ i" y. R; [, U( G- v/ o, z mcasp->regs->DITCTL = 0x00000000; // Not used
- M" m: N* L( h! c. z J& ?4 D mcasp->regs->DLBCTL = 0x00000000; // Not used
5 c5 B, Q/ t( G% q9 r5 H mcasp->regs->AMUTE = 0x00000000; // Not used
1 y. ?9 q$ m6 g$ w% l! r
% p( s4 S1 g& b R* i v4 B. q* o; F/* Starting sections of the McASP*/5 V& g- t0 |7 @( e7 ?
mcasp->regs->XGBLCTL |= GBLCTL_XHCLKRST_ON;
5 `7 n& Q& {) D7 |2 { while ( ( mcasp->regs->XGBLCTL & GBLCTL_XHCLKRST_ON ) != GBLCTL_XHCLKRST_ON ); ) f, N! J0 v& F3 Y& M3 _8 l, ^
mcasp->regs->RGBLCTL |= GBLCTL_RHCLKRST_ON;
' ^/ W- r7 ^5 J; b4 w" c* `6 p* U while ( ( mcasp->regs->RGBLCTL & GBLCTL_RHCLKRST_ON ) != GBLCTL_RHCLKRST_ON );" k& \) E' P: B' ?# i5 U- i* y: c3 c
; m! ?5 @' z7 J- P9 C3 D) i
mcasp->regs->XGBLCTL |= GBLCTL_XCLKRST_ON;
3 t: V* c+ \7 a0 T0 ` while ( ( mcasp->regs->XGBLCTL & GBLCTL_XCLKRST_ON ) != GBLCTL_XCLKRST_ON );2 e n7 b& @; A! w( M
mcasp->regs->RGBLCTL |= GBLCTL_RCLKRST_ON; . D6 O4 }7 P) s5 J
while ( ( mcasp->regs->RGBLCTL & GBLCTL_RCLKRST_ON ) != GBLCTL_RCLKRST_ON );& _4 h2 j* M! S" I
6 e5 i4 B0 o$ l; b( { mcasp->regs->XSTAT = 0x0000ffff;
8 [! ~, ?* E9 \* Z mcasp->regs->RSTAT = 0x0000ffff; ( l* X1 Q) ]) ?& U
; H0 U; Y' N- a3 G5 k1 m
mcasp->regs->XGBLCTL |= GBLCTL_XSRCLR_ON;
# }! h9 ]$ B7 N+ Q7 Z+ C while ( ( mcasp->regs->XGBLCTL & GBLCTL_XSRCLR_ON ) != GBLCTL_XSRCLR_ON );6 [& W% o% [! E. z( l/ G
mcasp->regs->RGBLCTL |= GBLCTL_RSRCLR_ON; 1 R! Z- n' x1 _$ S
while ( ( mcasp->regs->RGBLCTL & GBLCTL_RSRCLR_ON ) != GBLCTL_RSRCLR_ON );
3 }8 L! l( _1 K4 E' K
0 O) X& E- M5 S /* Write a 0, so that no underrun occurs after releasing the state machine */
2 w6 B5 Q. ?! |" r mcasp->regs->XBUF5 = 0;
5 b; l6 j0 M* Q mcasp->regs->RBUF0 = 0;
3 `2 [2 O9 e9 Q% K& h+ P' K! }- ] @! E! P
mcasp->regs->XGBLCTL |= GBLCTL_XSMRST_ON; / R7 q, }% n, F1 n! \1 c- ^
while ( ( mcasp->regs->XGBLCTL & GBLCTL_XSMRST_ON ) != GBLCTL_XSMRST_ON );
* }+ { ~8 m# j6 P: f5 J$ ? mcasp->regs->RGBLCTL |= GBLCTL_RSMRST_ON; 4 Q+ _& s' q, u1 m. @
while ( ( mcasp->regs->RGBLCTL & GBLCTL_RSMRST_ON ) != GBLCTL_RSMRST_ON );
: Z/ \6 s6 Z+ k" b% m
0 @. v6 v+ t4 [ mcasp->regs->XGBLCTL |= GBLCTL_XFRST_ON; Z9 D1 l' [7 r4 I
while ( ( mcasp->regs->XGBLCTL & GBLCTL_XFRST_ON ) != GBLCTL_XFRST_ON );6 _* H9 G3 R: t1 c% P8 \- w9 G2 C/ o
mcasp->regs->RGBLCTL |= GBLCTL_RFRST_ON;
. h: w$ x+ {6 ]/ Z. Z+ K( d: H while ( ( mcasp->regs->RGBLCTL & GBLCTL_RFRST_ON ) != GBLCTL_RFRST_ON );
9 i# m$ I0 T! c8 a3 h0 p( S6 f' ?
# B2 ]7 U$ N1 L! x7 l CSR = 0x0000;
! l. b3 e" P' m. A INTC_INTMUX1 = 0x3d;, o% i1 {( p$ B( p! ]; j7 u
ISTP = (unsigned int)vectors;# k/ `" d8 f6 m+ e( e7 t1 M+ A" T! D
ICR = 0xFFF0; 4 \: K( j+ V. d3 {6 Q% x1 E
IER |= 0x12;
0 K0 f: r9 u! a; U# P. F( F; ]0 b CSR |= 0x01; 9 M" R+ m: ~# N& ~/ y/ ^! {2 N
' d# Y2 n$ u* O: c5 B% {! W
# e+ d4 ]# w9 u9 r% N; V$ {
+ K a: {2 Z( \& g) g* } P还有就是两个输入输出函数:* ]+ P4 ?% C2 t* `
void output_sample(Int32 out_data)8 J8 T' z$ g6 \
{
6 m& w& {, p0 j6 G AIC31_data.uint = out_data;
% S( T$ ?& X- S$ X: _& O/ l% a MCASP1_XBUF5_32BIT = AIC31_data.uint;2 |6 h' H9 r6 y4 f! P3 B D
}
+ X) i# t# J7 P) q& j) E7 x' v$ r# D1 ?4 u- D+ B; ^# h
Int32 input_sample(void)" F2 Z( p# |& W( {
{ - Z7 E, f9 Y, l0 K( x
AIC31_data.uint = MCASP1_RBUF0_32BIT;* F$ b R! u, Y. n& f: O1 U
return (AIC31_data.uint);
( t; p& O! P. C8 H! M- i}6 ]3 e& ~5 _- m7 E6 I" d6 Q5 Y
4 [* B& C% E- r |
|