|
C6747和C6748感觉差不多,我想实现McASP发送中断方式控制音频信号,在轮询的例程基础上改的,轮询程序可以实现,但是中断一直实现不了,也找不到错误,求大神帮忙!下边是主要程序:" O" s) u) y( g9 K' I4 m
main文件:
7 O4 b+ {( D3 n3 e, \- dinterrupt void interrupt4(void)
1 w! C& R2 y' J4 ?{
+ R: ~; G, ~6 @3 I: G; W* ?) |! U Uint32 sample;
4 d5 N% c: p" P0 m* u- E9 g% V) _0 U8 V5 `: w6 w# H$ ?
sample = input_sample(); // read L + R samples from ADC
5 V( t- T3 p' i# {7 I output_sample(sample); // write L + R samples to DAC
& w$ {" O/ E1 B, n9 S$ h return;
8 h" q+ j- I& M( Z; r}0 ^" ~0 P! M* l# u& \& \* L! z% w1 {
/ i! f5 r7 r1 ^' G ^" Cint main( void ). S( w# @" B! g% {8 T+ |& V
{
6 ^5 H- f* K$ w% A: {8 L r+ X; v H5 B {3 h
/* Initialize BSL */
8 N$ K( Q8 j3 a EVMC6747_init( );" G& P2 H3 S3 y$ _ o; J. m, e) ]) p
/* Call evmc6747_intr function */
' r7 k" q% x: F' g h: |' E- G% ] aic3106_init( );
1 K6 H4 y U C( \- E# d while(1);2 \- `& l* w q; B. \7 u
}
9 f2 W }, u2 e8 t L
) _( [2 X+ q- }& c% }) x' Y* k, J( `/ {$ z- d
aic3106_init文件的一部分,McASP配置部分,采用内部时钟,I2S方式,同步传输。音频芯片的配置应该没问题' h6 }/ C- ~- T- Y, P
/* Initialize MCASP1 */
, i) I! ?$ e$ @+ I mcasp = &MCASP_MODULE_1;7 w/ b, b- x3 H/ J% H1 x$ z
mcasp->regs->GBLCTL = 0; // Reset
+ |5 Q& q: L }$ @ mcasp->regs->RGBLCTL = 0; // Reset RX
6 a$ f: ]6 M( [ mcasp->regs->XGBLCTL = 0; // Reset TX
. W, a/ j9 Q. ^0 v) x S' j( W8 S mcasp->regs->PWRDEMU = 1; // Free-running
& X4 N$ L& v& ~ f( @! v9 ]" [% A9 T // configure McASP0 receive registers6 m2 K& R. V6 \7 [
mcasp->regs->RMASK = 0xFFFFFFFF; // No padding used
- X( [" x8 m% y1 U1 G4 _+ v- ^ mcasp->regs->RFMT = 0x00018078; // MSB 16bit, 0-delay, no pad, CFGBus8 x5 `7 Y" B, F; h! y
mcasp->regs->AFSRCTL = 0x00000112; // 2TDM, 1bit Falling, External FS, word
: W0 |8 ]% b, z7 L9 ~+ A) I mcasp->regs->ACLKRCTL = 0x000000AF; // Rising INTERNAL CLK,(from tx side)- K6 ?6 A) _0 _4 h& P( p4 S
mcasp->regs->AHCLKRCTL = 0x00000000; // INT CLK (from tx side)
A0 ]" ?+ l1 Z: I, F! g0 q7 s# d mcasp->regs->RTDM = 0x00000003; // Slots 0,1
; |/ `1 F3 ], W; h0 T mcasp->regs->RINTCTL = 0x00000000; // Not used
( q" Q) F+ Q% ^& W' _ mcasp->regs->RCLKCHK = 0x00FF0008; // 255-MAX 0-MIN, div-by-256$ D w( l4 n+ n6 {, d+ o
5 f- ~ d4 F: G! H mcasp->regs->XMASK = 0xFFFFFFFF; // No padding used( z ?* K8 @% T' f0 v" Z) T6 |
mcasp->regs->XFMT = 0x00018078; // MSB 16bit, 0-delay, no pad, CFGBus
8 L7 a6 M. {$ z6 s) d mcasp->regs->AFSXCTL = 0x00000112; // 2TDM, 1bit Rising edge INTERNAL FS, word
$ ?% S b- @; N; i2 w. ? mcasp->regs->ACLKXCTL = 0x000000AF; // ASYNC, Rising INTERNAL CLK, div-by-16
3 c7 i! S1 k; e( U0 E/ U i mcasp->regs->AHCLKXCTL = 0x00000000; // EXT CLK3 Q) E+ R% q# k
mcasp->regs->XTDM = 0x00000003; // Slots 0,1
# m0 B7 q9 Y8 g! }6 t& K! O# a mcasp->regs->XINTCTL = 0x00000020; // interrupt on transmit
x9 Z* v9 e+ ~- y mcasp->regs->XCLKCHK = 0x00FF0008; // 255-MAX 0-MIN, div-by-256
6 G3 o' T$ P, }+ f! e' b2 A' ~+ v2 G* c, i2 f9 Y k
mcasp->regs->SRCTL5 = 0x000D; // MCASP1.AXR1[5] --> DIN$ i1 Q9 S6 H: b5 T
mcasp->regs->SRCTL0 = 0x000E; // MCASP1.AXR1[0] <-- DOUT
- r. [* h; M1 Q mcasp->regs->PFUNC = 0; // All MCASPs; V1 l& n. j0 Q& J- H/ b0 }7 O
mcasp->regs->PDIR = 0x14000020; // All inputs except AXR0[5], ACLKX1, AFSX1
4 y% G* K4 D# p4 O/ n. P
, w) p7 s# ~8 D7 h8 b mcasp->regs->DITCTL = 0x00000000; // Not used* |9 v& S4 M2 d& E' t
mcasp->regs->DLBCTL = 0x00000000; // Not used6 Q# [ W5 ~. O& C2 u9 f$ y
mcasp->regs->AMUTE = 0x00000000; // Not used. I3 B0 n7 d% L3 t \
' I( O- n: Q# H/ z! U5 ~' _0 w/* Starting sections of the McASP*/3 |7 o* w& o6 _3 _1 ]
mcasp->regs->XGBLCTL |= GBLCTL_XHCLKRST_ON;
) f$ U7 v7 Z u! |; k1 t5 B while ( ( mcasp->regs->XGBLCTL & GBLCTL_XHCLKRST_ON ) != GBLCTL_XHCLKRST_ON );
" q/ |5 A6 H# \. r, W mcasp->regs->RGBLCTL |= GBLCTL_RHCLKRST_ON;
6 ]: D9 X6 P' @7 i$ o while ( ( mcasp->regs->RGBLCTL & GBLCTL_RHCLKRST_ON ) != GBLCTL_RHCLKRST_ON );1 m/ T U/ m1 T
( F* `! p/ a- ]& s8 Z" g! T mcasp->regs->XGBLCTL |= GBLCTL_XCLKRST_ON; ( M4 {$ b9 D2 w. l) U# K9 g
while ( ( mcasp->regs->XGBLCTL & GBLCTL_XCLKRST_ON ) != GBLCTL_XCLKRST_ON );4 O% }' M$ ~7 ?8 ?9 Y
mcasp->regs->RGBLCTL |= GBLCTL_RCLKRST_ON; $ `9 k& j% S% I& k
while ( ( mcasp->regs->RGBLCTL & GBLCTL_RCLKRST_ON ) != GBLCTL_RCLKRST_ON );( x% m# ] d/ ~0 p, Q
$ b8 o* j4 B" J- H. @6 f6 i6 s. ~ mcasp->regs->XSTAT = 0x0000ffff; 8 w8 m) T- {- v3 @5 ]
mcasp->regs->RSTAT = 0x0000ffff; 2 F# C- o+ N6 ^3 \+ v3 ]3 f
0 y, w# {) h6 O" z# p% S mcasp->regs->XGBLCTL |= GBLCTL_XSRCLR_ON;! p& X/ `+ ?* ~
while ( ( mcasp->regs->XGBLCTL & GBLCTL_XSRCLR_ON ) != GBLCTL_XSRCLR_ON );
. g" c! y F2 Z$ e' A3 s mcasp->regs->RGBLCTL |= GBLCTL_RSRCLR_ON; 3 c+ u8 q+ M& x F
while ( ( mcasp->regs->RGBLCTL & GBLCTL_RSRCLR_ON ) != GBLCTL_RSRCLR_ON );6 u4 V+ J3 }* Y3 y9 ?$ L/ O
; f o6 a7 B0 P: n% @3 p0 _8 m3 e /* Write a 0, so that no underrun occurs after releasing the state machine */4 x1 G+ D! O* Y
mcasp->regs->XBUF5 = 0;
/ X8 ?1 [0 O; v- }4 }4 y: ` mcasp->regs->RBUF0 = 0; f) J1 Y9 s& A) j& X
% f& T. l) m* A$ H! I+ S! s1 W mcasp->regs->XGBLCTL |= GBLCTL_XSMRST_ON; 8 @- h( a9 ^) [8 ]. T
while ( ( mcasp->regs->XGBLCTL & GBLCTL_XSMRST_ON ) != GBLCTL_XSMRST_ON );3 {$ o8 ^5 x. a3 \9 }8 v
mcasp->regs->RGBLCTL |= GBLCTL_RSMRST_ON;
# f' o& X4 s# F$ A while ( ( mcasp->regs->RGBLCTL & GBLCTL_RSMRST_ON ) != GBLCTL_RSMRST_ON );
4 K% J/ I: c! \, v; K: ?/ _' r
3 R$ N4 ~, m8 J' N/ m mcasp->regs->XGBLCTL |= GBLCTL_XFRST_ON;
+ k4 R& e8 v! i+ C8 g while ( ( mcasp->regs->XGBLCTL & GBLCTL_XFRST_ON ) != GBLCTL_XFRST_ON );. I& l/ r5 i: L
mcasp->regs->RGBLCTL |= GBLCTL_RFRST_ON;
3 m+ J( O5 E2 N% \; x d G4 e while ( ( mcasp->regs->RGBLCTL & GBLCTL_RFRST_ON ) != GBLCTL_RFRST_ON );
4 Q% U: i" Q6 y \( @, j: M/ [
; u4 Q/ K9 n6 v9 s% ? CSR = 0x0000;
+ m! @! R1 q8 ^ INTC_INTMUX1 = 0x3d;
! u; q* r S+ ?- n1 R ISTP = (unsigned int)vectors;: @, k9 J2 S& t6 h$ Q
ICR = 0xFFF0; - y) E z) l1 h, h$ v
IER |= 0x12; : |- L- V8 Y1 I3 p- D; H, L) I( S% F5 T5 m
CSR |= 0x01; 1 T: y" E/ S0 V1 ?9 _8 h
" d/ n1 L3 F& p1 s! w/ {% r+ Q
/ y# i+ c7 M- W: K; \6 B- c" \
' R4 r: G" H, N( U还有就是两个输入输出函数:5 t$ t& p9 p& a; I' N' F+ D
void output_sample(Int32 out_data)
$ o6 S4 Q4 U: v7 A% g# f; K, T{. |( ]- j. L. b6 f4 N; N- r( n( q3 `
AIC31_data.uint = out_data; 1 ~2 o; n' @9 ^$ Y2 p6 e
MCASP1_XBUF5_32BIT = AIC31_data.uint;
2 N& Z% ^! o8 c; Z. ?3 w}% G4 j* K) \6 \* A( p& c
% C' [7 [1 J6 e7 V2 |$ E
Int32 input_sample(void)
: E3 N, a+ A0 B9 s{ 7 l- Z3 W% C: c6 _- U# E3 ~
AIC31_data.uint = MCASP1_RBUF0_32BIT;
9 O- Q8 X3 O% n2 r return (AIC31_data.uint);0 A2 F. y! B( D+ K8 D
}
: M; L4 ^6 q6 B6 Z
6 }0 j" U) Z9 Q$ d6 A0 Y- k, q |
|