|
|
C6747和C6748感觉差不多,我想实现McASP发送中断方式控制音频信号,在轮询的例程基础上改的,轮询程序可以实现,但是中断一直实现不了,也找不到错误,求大神帮忙!下边是主要程序:! E1 k9 E; `. Y0 C
main文件:& ?+ p6 N; M/ w/ o
interrupt void interrupt4(void) % B. P9 ~: Y& Y4 A: x2 Z. q
{# M: a0 t) ~ H$ r
Uint32 sample;
+ [% E) M2 \ [ N* |# T
G: q+ g8 S N( Y3 @. T sample = input_sample(); // read L + R samples from ADC
6 ~* n3 I4 W0 s- @ output_sample(sample); // write L + R samples to DAC 4 W8 b7 F6 x, h' L6 E: y" ~+ Z
return;
& N' R2 ~4 a7 J1 E}
! W0 M0 t6 t( x9 V% v6 @( P5 {% J& `% K
int main( void ): h. c1 z. c! |% x0 a' ^
{) ]5 `# M, @3 [3 c! s$ ?
]1 t! z0 x8 Y1 F( n V /* Initialize BSL */
- a1 h, z9 J; N/ S! Q1 n1 R) X EVMC6747_init( );
7 _0 ?0 q! p1 \. o! Y) z /* Call evmc6747_intr function */3 A0 J D( n# X5 F" v6 q. X
aic3106_init( );
# g) M3 e' I- g2 D while(1);
# L/ }5 I8 G& S2 `}. f/ Z5 \1 h8 B. d% W% I/ z
; L% C ? j; q! H- W# I
& k4 }2 d9 M( a+ X( z) t# n
aic3106_init文件的一部分,McASP配置部分,采用内部时钟,I2S方式,同步传输。音频芯片的配置应该没问题
5 H+ A7 n+ D) x2 e/* Initialize MCASP1 */9 m3 @0 ?% i4 o0 N& }
mcasp = &MCASP_MODULE_1;4 M# D! ?; t& b2 }3 M( K' j
mcasp->regs->GBLCTL = 0; // Reset% N4 f5 T0 b$ w7 @) ]. s
mcasp->regs->RGBLCTL = 0; // Reset RX
+ N7 P1 \/ s$ u" @& \ mcasp->regs->XGBLCTL = 0; // Reset TX
+ F& U0 x+ \1 A( _) h( x% h7 L4 W mcasp->regs->PWRDEMU = 1; // Free-running) x: _( X3 {5 c! s# y
// configure McASP0 receive registers
. Y- R- E& u) W% X! A mcasp->regs->RMASK = 0xFFFFFFFF; // No padding used: p% Q" U3 x: [4 d
mcasp->regs->RFMT = 0x00018078; // MSB 16bit, 0-delay, no pad, CFGBus
7 g" ]4 k. R( U. _ mcasp->regs->AFSRCTL = 0x00000112; // 2TDM, 1bit Falling, External FS, word( `: Y" l \; {. i) n. v
mcasp->regs->ACLKRCTL = 0x000000AF; // Rising INTERNAL CLK,(from tx side). V+ @0 G% L; O+ C- `$ c5 q
mcasp->regs->AHCLKRCTL = 0x00000000; // INT CLK (from tx side)# a! e: b; }6 ?/ H% \, Q
mcasp->regs->RTDM = 0x00000003; // Slots 0,11 Q3 n& L, o/ F* z0 }" G0 }
mcasp->regs->RINTCTL = 0x00000000; // Not used
% j( X. X2 N* z mcasp->regs->RCLKCHK = 0x00FF0008; // 255-MAX 0-MIN, div-by-256; E3 C/ {4 ^$ |( ~# a: X+ w8 E3 r
5 ~4 z' Y0 s J4 `" Z mcasp->regs->XMASK = 0xFFFFFFFF; // No padding used8 j6 v; ]8 w( e- c8 L* x
mcasp->regs->XFMT = 0x00018078; // MSB 16bit, 0-delay, no pad, CFGBus- ~7 d: A" U' R6 T# Q
mcasp->regs->AFSXCTL = 0x00000112; // 2TDM, 1bit Rising edge INTERNAL FS, word
/ `" I9 r2 |3 V0 G% m. j4 C& ?8 C mcasp->regs->ACLKXCTL = 0x000000AF; // ASYNC, Rising INTERNAL CLK, div-by-16
- a- G: a2 P4 B, q# v0 E mcasp->regs->AHCLKXCTL = 0x00000000; // EXT CLK
0 O A7 v( \) k8 B mcasp->regs->XTDM = 0x00000003; // Slots 0,1
5 l5 J- q$ c0 \7 R) H mcasp->regs->XINTCTL = 0x00000020; // interrupt on transmit
8 H0 E; Q# ^$ r; H3 S mcasp->regs->XCLKCHK = 0x00FF0008; // 255-MAX 0-MIN, div-by-2569 X/ d8 F# T' e% o8 e9 p
0 l: _ w' l; Y- F+ X7 x mcasp->regs->SRCTL5 = 0x000D; // MCASP1.AXR1[5] --> DIN
+ H4 B' n9 L; `% S2 z8 l, M8 o' l mcasp->regs->SRCTL0 = 0x000E; // MCASP1.AXR1[0] <-- DOUT. h" z* t7 R& T' G' U
mcasp->regs->PFUNC = 0; // All MCASPs- C( f' G. x$ G
mcasp->regs->PDIR = 0x14000020; // All inputs except AXR0[5], ACLKX1, AFSX1
3 r4 {5 J5 W) d, t# i1 g
+ `( w' |* I* H. e3 R7 x/ m mcasp->regs->DITCTL = 0x00000000; // Not used1 l2 N t5 k. k) K# X! L) I0 j
mcasp->regs->DLBCTL = 0x00000000; // Not used
1 \) \" W2 U' a7 p, W# o mcasp->regs->AMUTE = 0x00000000; // Not used* G6 G7 p% ]1 Y/ `
8 O3 v) } ~# W8 O, L# K; P
/* Starting sections of the McASP*/8 A0 M, P/ U4 x# N* [ `
mcasp->regs->XGBLCTL |= GBLCTL_XHCLKRST_ON; 4 l6 \7 b* G, k( B4 b3 ~( [$ d
while ( ( mcasp->regs->XGBLCTL & GBLCTL_XHCLKRST_ON ) != GBLCTL_XHCLKRST_ON );
) W; x+ y7 I2 @- {' I* D mcasp->regs->RGBLCTL |= GBLCTL_RHCLKRST_ON; $ C- |# |8 p! _4 X$ ^. i
while ( ( mcasp->regs->RGBLCTL & GBLCTL_RHCLKRST_ON ) != GBLCTL_RHCLKRST_ON );
) t7 R4 F# ~0 H7 ]4 x' Y
$ B0 g9 n, S' A" A& G& x/ Y( N& }4 e mcasp->regs->XGBLCTL |= GBLCTL_XCLKRST_ON;
5 M3 J. I- H d* E8 b0 S while ( ( mcasp->regs->XGBLCTL & GBLCTL_XCLKRST_ON ) != GBLCTL_XCLKRST_ON );
) _6 }8 @ P R$ O mcasp->regs->RGBLCTL |= GBLCTL_RCLKRST_ON; / P1 e' a( q- d& M
while ( ( mcasp->regs->RGBLCTL & GBLCTL_RCLKRST_ON ) != GBLCTL_RCLKRST_ON );
% A0 a0 d( f+ U* W1 t8 ~7 k5 n" K3 y( W3 I6 {, o( m1 v# Z5 e# \
mcasp->regs->XSTAT = 0x0000ffff;
0 K: D5 i; M" n8 I5 P5 ~5 { mcasp->regs->RSTAT = 0x0000ffff;
4 F0 r2 Y6 R3 x% A5 T: M7 z
7 h! z( O: j5 J8 J mcasp->regs->XGBLCTL |= GBLCTL_XSRCLR_ON;
' V- Z6 S# I$ l7 R& m3 k while ( ( mcasp->regs->XGBLCTL & GBLCTL_XSRCLR_ON ) != GBLCTL_XSRCLR_ON );
: d$ V9 A5 P4 z$ C4 O K mcasp->regs->RGBLCTL |= GBLCTL_RSRCLR_ON;
( x4 n# S' Y7 l0 m while ( ( mcasp->regs->RGBLCTL & GBLCTL_RSRCLR_ON ) != GBLCTL_RSRCLR_ON );
3 s' E! K1 \% W3 {2 L' n" N( j9 w* u, l$ W' h
/* Write a 0, so that no underrun occurs after releasing the state machine */6 g; v: V& c: ]4 s# O f9 [, b
mcasp->regs->XBUF5 = 0;# a, \& j5 M: |1 C9 p
mcasp->regs->RBUF0 = 0;
- d3 q' }+ F c. {) R2 [
: Y7 E) \ [/ ], X mcasp->regs->XGBLCTL |= GBLCTL_XSMRST_ON; " c [( J) G- y( {+ u& L! w
while ( ( mcasp->regs->XGBLCTL & GBLCTL_XSMRST_ON ) != GBLCTL_XSMRST_ON );" `: {/ F; ^2 F( Z
mcasp->regs->RGBLCTL |= GBLCTL_RSMRST_ON; - @* ]1 N& z' I2 a" [8 e
while ( ( mcasp->regs->RGBLCTL & GBLCTL_RSMRST_ON ) != GBLCTL_RSMRST_ON );
! c& E( z1 b5 o& j" a
5 u* @2 l }* s; K5 @# V# | mcasp->regs->XGBLCTL |= GBLCTL_XFRST_ON; ; g9 ^, k% P# g0 O8 ~: Q9 s
while ( ( mcasp->regs->XGBLCTL & GBLCTL_XFRST_ON ) != GBLCTL_XFRST_ON );. X" d( p- {$ Q: f, `) C( m
mcasp->regs->RGBLCTL |= GBLCTL_RFRST_ON; . n) U1 E0 d5 s x
while ( ( mcasp->regs->RGBLCTL & GBLCTL_RFRST_ON ) != GBLCTL_RFRST_ON );
?. q& p5 A9 M
+ {& d; T, }5 _' }6 H CSR = 0x0000;7 G1 s+ ?, w2 u/ q9 g1 i" a
INTC_INTMUX1 = 0x3d;
) H" z) \$ z9 w& G/ F# N" x ISTP = (unsigned int)vectors;+ G# c" E) t. F ^# z8 e
ICR = 0xFFF0;
' d5 c4 h( D, L# H6 B) S. } IER |= 0x12;
2 }- D4 [ Y& x! Y1 e1 o" P CSR |= 0x01;
7 i5 o2 w3 ?- z M4 f
0 q. q3 J6 Q; o9 A! S- e. @
0 G' k" I, p- B" q) n; O2 _$ K( |
还有就是两个输入输出函数:* a4 g) m+ Z) H; Y9 Z; s8 S
void output_sample(Int32 out_data)
+ a4 @! Q; k; K{
( V: s$ ^/ m% f AIC31_data.uint = out_data;
) ?/ O t7 P" X; }' e5 Y MCASP1_XBUF5_32BIT = AIC31_data.uint;
6 W- x0 Y9 C' G7 R" o}! g6 }- n6 f+ X5 ~$ o8 k* Z \" H
; c# n. j8 E0 \! aInt32 input_sample(void)
# J, k8 c! a" B7 c5 u{
1 u! B6 X& U# b/ w. H AIC31_data.uint = MCASP1_RBUF0_32BIT;) [2 c, g9 M& |1 t" s- ?
return (AIC31_data.uint);
% L/ t N; J) g. p! J3 r}5 M# j* @3 ^! c( s
7 D; Q5 f. g) a5 O7 `! } m
|
|