|
C6747和C6748感觉差不多,我想实现McASP发送中断方式控制音频信号,在轮询的例程基础上改的,轮询程序可以实现,但是中断一直实现不了,也找不到错误,求大神帮忙!下边是主要程序:
% G6 ^/ R6 a8 S9 Q* }% {6 b, p! z4 Q- Jmain文件:
% `# n+ [4 c: B! Cinterrupt void interrupt4(void) 2 x+ S' l$ l8 R! Q% r
{. N& `. q+ `- l6 t. v
Uint32 sample;
: E) Z8 b( H9 I$ D3 p' L! Y, Y/ X5 y! I1 v4 l8 u9 K5 Z
sample = input_sample(); // read L + R samples from ADC6 v6 e" c$ M+ z- W5 m
output_sample(sample); // write L + R samples to DAC
; c- R: j3 [: G5 O1 X( x3 h return;7 N$ e9 D0 {" s* L3 F
}/ Y9 ^4 i N* M% Y- H
) @' b/ P, K/ z$ X$ f6 ]int main( void )
' `' P3 U% {, j9 B$ B6 C{
& M k& ?' b* m2 t$ g( f9 p' W1 n5 e6 b
/* Initialize BSL */; A9 e2 {% w% @ ~! j
EVMC6747_init( );) d) S1 {; a# c9 N8 `; B. \
/* Call evmc6747_intr function */
7 i0 A& I5 y. z' _ aic3106_init( );: ^# p, G! _: B U
while(1);. L: {# f# V: B. o
}2 p" m. H/ t# ^8 G: h4 P1 S- q1 s- ^
* _6 I6 e* ~- g, u7 s# P" d: f1 N% r' k( }$ y
aic3106_init文件的一部分,McASP配置部分,采用内部时钟,I2S方式,同步传输。音频芯片的配置应该没问题
5 U9 T& n! T" X* x/* Initialize MCASP1 */
- _! H! ^2 @2 ?7 s mcasp = &MCASP_MODULE_1;
! j* q6 u- J) n2 E F, x. b& t mcasp->regs->GBLCTL = 0; // Reset
( S" F& z* J; L" c4 ^ mcasp->regs->RGBLCTL = 0; // Reset RX' Q9 O; v7 C5 r' ~
mcasp->regs->XGBLCTL = 0; // Reset TX
) D$ f, N0 f. [% ? mcasp->regs->PWRDEMU = 1; // Free-running
0 t, [% a* [/ E // configure McASP0 receive registers3 k! R( |8 V% \
mcasp->regs->RMASK = 0xFFFFFFFF; // No padding used
% X( N; M* x6 I, o$ [2 T mcasp->regs->RFMT = 0x00018078; // MSB 16bit, 0-delay, no pad, CFGBus
/ q1 C2 `* ?& u( E mcasp->regs->AFSRCTL = 0x00000112; // 2TDM, 1bit Falling, External FS, word; v! A& p4 }9 h; k1 u2 W
mcasp->regs->ACLKRCTL = 0x000000AF; // Rising INTERNAL CLK,(from tx side)
. y0 g8 X; g# [2 e8 n3 |8 u- W mcasp->regs->AHCLKRCTL = 0x00000000; // INT CLK (from tx side)
3 E, U# d: W' @7 g! F* \) l/ E mcasp->regs->RTDM = 0x00000003; // Slots 0,1$ o+ m) Z' F# Y" [3 y
mcasp->regs->RINTCTL = 0x00000000; // Not used
3 @5 Q+ h, T! s mcasp->regs->RCLKCHK = 0x00FF0008; // 255-MAX 0-MIN, div-by-256' x0 U! y/ C( _( g# ^( O
: G ]6 {. s* P8 q, W L
mcasp->regs->XMASK = 0xFFFFFFFF; // No padding used
; O; H4 y6 z. L7 O mcasp->regs->XFMT = 0x00018078; // MSB 16bit, 0-delay, no pad, CFGBus: _& V( c+ s, V8 X; Q
mcasp->regs->AFSXCTL = 0x00000112; // 2TDM, 1bit Rising edge INTERNAL FS, word! x0 y; L% p' e6 O! l. I
mcasp->regs->ACLKXCTL = 0x000000AF; // ASYNC, Rising INTERNAL CLK, div-by-16
3 @+ P. H7 m% [; @% ]: q mcasp->regs->AHCLKXCTL = 0x00000000; // EXT CLK0 o8 o- U1 j! u
mcasp->regs->XTDM = 0x00000003; // Slots 0,1
# z" W* i9 G3 S& Q' w" _ mcasp->regs->XINTCTL = 0x00000020; // interrupt on transmit
/ r' I; _% @3 ] Q mcasp->regs->XCLKCHK = 0x00FF0008; // 255-MAX 0-MIN, div-by-256
+ l; P# x8 J" L* v+ m6 U K* k
0 P+ I/ e) J, t" ?8 a* d' y mcasp->regs->SRCTL5 = 0x000D; // MCASP1.AXR1[5] --> DIN% a) ]) l4 w& m0 n& `
mcasp->regs->SRCTL0 = 0x000E; // MCASP1.AXR1[0] <-- DOUT
) r) `+ P8 w! Z# V3 n) K mcasp->regs->PFUNC = 0; // All MCASPs0 \% {7 e2 e; F1 v9 K8 a! l
mcasp->regs->PDIR = 0x14000020; // All inputs except AXR0[5], ACLKX1, AFSX1
* w& K( e, s) y# `% Q5 V: R9 M
* Y( `% e" I# m& C3 w mcasp->regs->DITCTL = 0x00000000; // Not used
: Q* V1 e+ c+ `# [* L4 j mcasp->regs->DLBCTL = 0x00000000; // Not used
2 P) f: B2 G3 t6 N; q mcasp->regs->AMUTE = 0x00000000; // Not used9 E/ N. m# U. g0 Y2 h& ^5 ~
' l# H8 A$ ]3 i' L1 ^) T/* Starting sections of the McASP*/& g9 Y7 z, E$ f5 d" R# L3 w
mcasp->regs->XGBLCTL |= GBLCTL_XHCLKRST_ON; & T( T" c. T$ C p# P8 d
while ( ( mcasp->regs->XGBLCTL & GBLCTL_XHCLKRST_ON ) != GBLCTL_XHCLKRST_ON );
# Z5 j1 U( ?+ v& v+ b( G3 @- H mcasp->regs->RGBLCTL |= GBLCTL_RHCLKRST_ON;
$ C& o# d5 S* _* i5 q. Z0 j0 S while ( ( mcasp->regs->RGBLCTL & GBLCTL_RHCLKRST_ON ) != GBLCTL_RHCLKRST_ON );
- F' {- y3 c; Z( i1 e6 L% z$ _& v M
mcasp->regs->XGBLCTL |= GBLCTL_XCLKRST_ON;
! j; J! F3 P. i: ?$ x) D0 C while ( ( mcasp->regs->XGBLCTL & GBLCTL_XCLKRST_ON ) != GBLCTL_XCLKRST_ON );
& F4 m4 ` @( Z; T9 P mcasp->regs->RGBLCTL |= GBLCTL_RCLKRST_ON; 3 b" r. z b( `/ q( |1 p4 g
while ( ( mcasp->regs->RGBLCTL & GBLCTL_RCLKRST_ON ) != GBLCTL_RCLKRST_ON );
% y0 t& F. x; }9 g
/ G5 K/ w) b' f" B* V! x+ D3 R mcasp->regs->XSTAT = 0x0000ffff; ) y, G3 c. y4 b9 e2 o+ Q" ?; u
mcasp->regs->RSTAT = 0x0000ffff;
& b% T& ^) Y9 r: s, M' w' @) W* z+ H$ R* P% w4 q/ j+ V/ b/ l. K" E) b
mcasp->regs->XGBLCTL |= GBLCTL_XSRCLR_ON;
9 h% o0 U2 A3 i* A. `9 b while ( ( mcasp->regs->XGBLCTL & GBLCTL_XSRCLR_ON ) != GBLCTL_XSRCLR_ON );
$ H5 b3 m+ u% L3 D: \ mcasp->regs->RGBLCTL |= GBLCTL_RSRCLR_ON; ; N# q1 W# u4 A% k+ b R
while ( ( mcasp->regs->RGBLCTL & GBLCTL_RSRCLR_ON ) != GBLCTL_RSRCLR_ON );
: K& m( j" J7 M% c9 L- A& m. A) m" O3 U& b
/* Write a 0, so that no underrun occurs after releasing the state machine */
* O- j2 y* \ r* i6 r mcasp->regs->XBUF5 = 0;; P- y. R! B# m$ p8 C6 o6 e9 o
mcasp->regs->RBUF0 = 0;
/ e2 \* E: z; a+ A6 ?9 [' R$ G% K! L9 w& {7 `
mcasp->regs->XGBLCTL |= GBLCTL_XSMRST_ON; + W, F0 I* m0 A2 i& ?# `$ @
while ( ( mcasp->regs->XGBLCTL & GBLCTL_XSMRST_ON ) != GBLCTL_XSMRST_ON );
+ H' ~& K- x" c9 a* Q4 Q mcasp->regs->RGBLCTL |= GBLCTL_RSMRST_ON;
+ b4 @& T) v9 i7 ?/ ?+ T! }7 O while ( ( mcasp->regs->RGBLCTL & GBLCTL_RSMRST_ON ) != GBLCTL_RSMRST_ON );) Z( `, P( a) k2 M4 q
/ T% n7 z7 E6 Q8 C
mcasp->regs->XGBLCTL |= GBLCTL_XFRST_ON;
( y8 m( K9 u* X( w: f& ~# Q3 N while ( ( mcasp->regs->XGBLCTL & GBLCTL_XFRST_ON ) != GBLCTL_XFRST_ON );
$ C( \. D* s$ F }+ R mcasp->regs->RGBLCTL |= GBLCTL_RFRST_ON;
9 E4 r/ {7 P5 y" C" z; b* s while ( ( mcasp->regs->RGBLCTL & GBLCTL_RFRST_ON ) != GBLCTL_RFRST_ON );) L( p/ h, h8 k9 Y) _7 K
1 D8 |- s: \/ n CSR = 0x0000;% |2 _9 X( [# }1 P, s( ~
INTC_INTMUX1 = 0x3d;
) t* p( C' f2 x4 J6 s1 g ISTP = (unsigned int)vectors;. t4 B4 |) h- n3 U$ T
ICR = 0xFFF0;
, @# G- a2 D% Z IER |= 0x12; / R u4 h& J4 i4 {$ {! @7 i; w
CSR |= 0x01; ) ?/ \3 y$ S' w. y/ N0 r! Q
1 v# X6 C( t7 P8 J1 x7 {6 X( [$ Y" _9 ^
/ b( I" L# `- i }! ~* d, m
还有就是两个输入输出函数:& h9 m! z8 }) E2 d
void output_sample(Int32 out_data)
+ }: v: l4 G7 g* u{
( |6 j r: U2 d4 D2 ~4 r& o AIC31_data.uint = out_data;
9 o# |' B% o+ ]( E MCASP1_XBUF5_32BIT = AIC31_data.uint;5 h3 f8 s+ \8 H+ u# w: u
}
& m! `6 U' t; `5 B- z' \$ w U; z2 p. j) b( ^" L5 J
Int32 input_sample(void): I" g" f3 E' x {% Q1 ? D- v/ [
{ 2 x$ w1 C8 W9 R T6 K- D
AIC31_data.uint = MCASP1_RBUF0_32BIT;
+ W9 Y% g, R9 ^. r2 w4 i- W- h J* ? return (AIC31_data.uint);, W; B2 A6 W, @; A7 Q5 K# }
}9 u+ H# h4 J+ n2 }
/ j6 Z0 ?5 A6 [9 Z- g, J H
|
|