|
|
C6747和C6748感觉差不多,我想实现McASP发送中断方式控制音频信号,在轮询的例程基础上改的,轮询程序可以实现,但是中断一直实现不了,也找不到错误,求大神帮忙!下边是主要程序:, ? T H- L" v( }/ V
main文件:
' A( y* ?, O8 s& pinterrupt void interrupt4(void)
a* L6 M7 d6 }: y{2 R: Y; U4 l( z: y- I
Uint32 sample;+ k# P8 Q* X4 Q/ P5 }
4 P4 ^+ x0 }0 F& T
sample = input_sample(); // read L + R samples from ADC/ e2 o1 i3 n. h. J6 o8 {' {
output_sample(sample); // write L + R samples to DAC , {+ N8 U9 s# x* p6 l
return;
t$ t! j7 g {8 o' |8 O, e}" \5 b, c1 E. W8 C. U( U
2 i7 r+ `1 }+ {: p: q; n* O
int main( void )
7 u' Q ]: C9 ~& y2 f$ r{
( u! W" d! j; b R6 w1 V7 `+ S" m& F5 y: t
/* Initialize BSL */1 T0 b' I, x( t9 e0 I* \; s' d
EVMC6747_init( );3 o$ f% r, x3 |+ I% t, l* r
/* Call evmc6747_intr function */, o y; Y( Y4 N* I) W7 c
aic3106_init( );4 g# o6 |2 @; b' o f
while(1);& T' r# {& l5 u
}; a) J# \8 b! `4 G2 Y9 J9 r; {" \
6 a2 v9 m0 `" [$ o# @6 T
$ \2 b" j) ?' s P% U [0 W0 raic3106_init文件的一部分,McASP配置部分,采用内部时钟,I2S方式,同步传输。音频芯片的配置应该没问题' f9 n% a; A" J1 k* l
/* Initialize MCASP1 */
0 \* A+ P8 S/ n! p* z8 Z' I P mcasp = &MCASP_MODULE_1;
2 L- Y4 I0 r B- \+ F4 q mcasp->regs->GBLCTL = 0; // Reset
% r/ }5 }8 v$ E6 H; K mcasp->regs->RGBLCTL = 0; // Reset RX
0 i5 l( y/ I& Q8 |& k4 u6 V- d mcasp->regs->XGBLCTL = 0; // Reset TX. |7 C) g8 }0 b) t, D9 g
mcasp->regs->PWRDEMU = 1; // Free-running
. ^0 D, W" {2 D: _* o // configure McASP0 receive registers
\8 |8 P. M% g: d mcasp->regs->RMASK = 0xFFFFFFFF; // No padding used
; G6 Z5 K# e. g& l mcasp->regs->RFMT = 0x00018078; // MSB 16bit, 0-delay, no pad, CFGBus F3 W! c w$ {" B% y
mcasp->regs->AFSRCTL = 0x00000112; // 2TDM, 1bit Falling, External FS, word4 @# v3 f6 ?/ n* h# c* e3 q
mcasp->regs->ACLKRCTL = 0x000000AF; // Rising INTERNAL CLK,(from tx side)9 K2 ], d( l& M2 g
mcasp->regs->AHCLKRCTL = 0x00000000; // INT CLK (from tx side)) R( k0 e- A5 O4 \0 _
mcasp->regs->RTDM = 0x00000003; // Slots 0,1
/ P0 i( T# ?* L3 x( `2 _5 u/ c mcasp->regs->RINTCTL = 0x00000000; // Not used0 h3 }- @1 \- V9 |8 m* M' U
mcasp->regs->RCLKCHK = 0x00FF0008; // 255-MAX 0-MIN, div-by-256' j& h, @6 V8 [$ I
5 V( d, u- p! n mcasp->regs->XMASK = 0xFFFFFFFF; // No padding used
9 G" i; I: G1 I7 P% C; R. n mcasp->regs->XFMT = 0x00018078; // MSB 16bit, 0-delay, no pad, CFGBus
8 A# ]/ U0 b2 I mcasp->regs->AFSXCTL = 0x00000112; // 2TDM, 1bit Rising edge INTERNAL FS, word
! l/ M: ?; E' u/ v6 L9 u mcasp->regs->ACLKXCTL = 0x000000AF; // ASYNC, Rising INTERNAL CLK, div-by-16
M0 L) D% S, Q& B! O3 O mcasp->regs->AHCLKXCTL = 0x00000000; // EXT CLK
8 c) z) e3 d3 A& {7 \; h mcasp->regs->XTDM = 0x00000003; // Slots 0,1
) m8 S. @3 p" P' ~* _9 Z# D# q mcasp->regs->XINTCTL = 0x00000020; // interrupt on transmit
# W; S# h. t1 \ mcasp->regs->XCLKCHK = 0x00FF0008; // 255-MAX 0-MIN, div-by-256
9 l1 W" H7 ?2 j( }8 p* m! l C1 x3 H% h4 A4 B* s2 \' x
mcasp->regs->SRCTL5 = 0x000D; // MCASP1.AXR1[5] --> DIN
! Q& p) Q* y! r* P$ }! | mcasp->regs->SRCTL0 = 0x000E; // MCASP1.AXR1[0] <-- DOUT
R, Y" f X/ K mcasp->regs->PFUNC = 0; // All MCASPs" ^% q. c' k! f* p+ x+ m6 b9 r W
mcasp->regs->PDIR = 0x14000020; // All inputs except AXR0[5], ACLKX1, AFSX1+ G7 t3 L" O U9 z- q
1 m% f" U) y. F) l; S mcasp->regs->DITCTL = 0x00000000; // Not used
9 ^, q3 c; M, {% a mcasp->regs->DLBCTL = 0x00000000; // Not used/ b' b! d$ S, |- z( g. d
mcasp->regs->AMUTE = 0x00000000; // Not used
* @. S2 K/ N% l, m8 O- I. m8 }) G+ A8 ^( h/ ?
/* Starting sections of the McASP*/
- N3 b) n4 W- L! b/ X3 { mcasp->regs->XGBLCTL |= GBLCTL_XHCLKRST_ON;
2 z2 R3 i3 v3 g! n+ l! U while ( ( mcasp->regs->XGBLCTL & GBLCTL_XHCLKRST_ON ) != GBLCTL_XHCLKRST_ON ); 9 u+ \' J" D9 X% L {; ?2 D8 x" }2 m, @
mcasp->regs->RGBLCTL |= GBLCTL_RHCLKRST_ON; $ l: u/ M6 \( {! r( l# ?- J! S/ }
while ( ( mcasp->regs->RGBLCTL & GBLCTL_RHCLKRST_ON ) != GBLCTL_RHCLKRST_ON );
" V$ @! v# a( ~$ ^1 i% d9 S! K
! g d, d, K% _ mcasp->regs->XGBLCTL |= GBLCTL_XCLKRST_ON;
5 a! o9 j- _) ~4 ] while ( ( mcasp->regs->XGBLCTL & GBLCTL_XCLKRST_ON ) != GBLCTL_XCLKRST_ON );
- [+ x# n' E& e8 [+ Q mcasp->regs->RGBLCTL |= GBLCTL_RCLKRST_ON;
1 A8 G9 W4 n3 k- v+ q- S( S/ y while ( ( mcasp->regs->RGBLCTL & GBLCTL_RCLKRST_ON ) != GBLCTL_RCLKRST_ON );, o, I d$ ^1 h1 ?5 C
n% q; {$ Z' k& n: C4 s
mcasp->regs->XSTAT = 0x0000ffff;
. q; C/ q* h2 r" d mcasp->regs->RSTAT = 0x0000ffff; , h0 F# x' T& V) c8 |: J. }
) j8 z, `2 T& }
mcasp->regs->XGBLCTL |= GBLCTL_XSRCLR_ON;, d2 Q! V/ `3 W% [
while ( ( mcasp->regs->XGBLCTL & GBLCTL_XSRCLR_ON ) != GBLCTL_XSRCLR_ON );
/ Q n8 }# Q% Q* c" E+ Y5 n) O: ` s6 J mcasp->regs->RGBLCTL |= GBLCTL_RSRCLR_ON;
) y. j, V: Q- s while ( ( mcasp->regs->RGBLCTL & GBLCTL_RSRCLR_ON ) != GBLCTL_RSRCLR_ON );0 U) \4 k ]* W/ A
- c% w' d( b! p p
/* Write a 0, so that no underrun occurs after releasing the state machine */ _" V. t! t9 c5 V5 U1 Y/ f
mcasp->regs->XBUF5 = 0;4 u% ` P- K" i
mcasp->regs->RBUF0 = 0;
9 v4 X4 _3 N" s4 z2 W
/ s# e) x# W: {' {5 ]. Q; v. X( M1 W mcasp->regs->XGBLCTL |= GBLCTL_XSMRST_ON;
! V( e5 A4 W$ \5 w4 ]& l9 C while ( ( mcasp->regs->XGBLCTL & GBLCTL_XSMRST_ON ) != GBLCTL_XSMRST_ON );
, q: Y5 C( j; { S mcasp->regs->RGBLCTL |= GBLCTL_RSMRST_ON;
X7 q& b0 I0 l$ `1 C" p while ( ( mcasp->regs->RGBLCTL & GBLCTL_RSMRST_ON ) != GBLCTL_RSMRST_ON );
2 [3 K" X' z+ E( b3 l% q! y0 b# L
mcasp->regs->XGBLCTL |= GBLCTL_XFRST_ON;
' S, x9 Q0 E5 P+ u# r, y while ( ( mcasp->regs->XGBLCTL & GBLCTL_XFRST_ON ) != GBLCTL_XFRST_ON );
( i. v9 T" C6 L- D* k9 a' C mcasp->regs->RGBLCTL |= GBLCTL_RFRST_ON; 6 Y5 N$ w' G' S; \
while ( ( mcasp->regs->RGBLCTL & GBLCTL_RFRST_ON ) != GBLCTL_RFRST_ON );
/ A8 l2 Z8 w0 k# n( f g
: O. r. q2 H8 _3 k7 M CSR = 0x0000;
0 J& O7 j0 |1 E$ m& e3 K- A. D INTC_INTMUX1 = 0x3d;
& U+ g5 K9 t* S6 E( Z ISTP = (unsigned int)vectors;# j2 ^. R8 A, k$ o7 F* `
ICR = 0xFFF0;
! s. b6 M: E e$ E7 s( f& @! F& Q IER |= 0x12;
6 E4 p6 I7 ]! h+ ~* x ~ CSR |= 0x01;
) o# D" w6 {2 h! q5 Y9 j7 {
8 D! l- [: l3 j8 v, ?, L
$ l3 ?1 S+ E7 _+ d. P
! { n" n# @; V1 z, {还有就是两个输入输出函数:; \8 [) }7 i `/ j; _$ Q
void output_sample(Int32 out_data): y% |% b1 ^6 c" ~- T' K
{6 H8 [" n" d" G& }2 Y/ {; t
AIC31_data.uint = out_data;
1 Q% e$ @' Y b/ q! |% q MCASP1_XBUF5_32BIT = AIC31_data.uint;
+ P1 r i" S6 ]' G9 S' }+ J, O+ {4 Y}
# Z9 h; J. b6 [8 Y3 e4 w5 m- R3 v" u
Int32 input_sample(void)$ \+ P+ h, Y1 }: m/ t8 x3 ]
{ # Y3 ?8 |; U# Y
AIC31_data.uint = MCASP1_RBUF0_32BIT; g, D8 b) T, ^, c8 w
return (AIC31_data.uint);
5 s/ t/ g- c! @5 O} t& p# u1 v2 Z0 j! o
3 \7 W, C- Z- {* m- }
|
|