|
|
C6747和C6748感觉差不多,我想实现McASP发送中断方式控制音频信号,在轮询的例程基础上改的,轮询程序可以实现,但是中断一直实现不了,也找不到错误,求大神帮忙!下边是主要程序:
5 v; [9 A" v" J) I; H9 vmain文件:
$ o% J' `, N) ?" l: \$ ^6 Sinterrupt void interrupt4(void)
5 u: y+ g/ M3 f3 s! `& O9 g{
$ S3 p& J6 w R( {! | Uint32 sample;" |0 M N; H# u1 W( G5 H
6 A3 q$ F# D4 r8 ]
sample = input_sample(); // read L + R samples from ADC
; S: }" _* ?- w7 V% Z output_sample(sample); // write L + R samples to DAC
0 h$ _& J. g: r% t. ~$ k7 a return;8 U C& o) w5 H2 W- F
}# R. ]3 G9 {' T6 b
% |& k/ |% v( V# H
int main( void )0 l1 q3 z+ p8 i: y+ {9 W- v
{
4 b, `( Z3 E/ ~1 S! T, v8 X
8 i9 A3 M0 i8 S- c /* Initialize BSL */: F/ ?) a6 |. v1 i
EVMC6747_init( );. X) S5 _/ v# q/ J) k/ A
/* Call evmc6747_intr function */
! B2 `/ N7 S% n! N5 C; f$ I& U aic3106_init( );
. q$ b! o v4 ?! X2 g5 `) a while(1);7 S- u X; L" {
}' q5 b9 p/ T# ~: M$ p/ H" A
# r9 m" }* v% {" w
4 {' _/ ? g, o; V# F/ S" Aaic3106_init文件的一部分,McASP配置部分,采用内部时钟,I2S方式,同步传输。音频芯片的配置应该没问题
7 l7 u, I- J5 L" N4 P1 ]! H4 ^& ?* ~/* Initialize MCASP1 */( }1 g, b1 z' m" [/ }7 ]4 U
mcasp = &MCASP_MODULE_1;
" B5 S& B( u+ n( Z9 P2 X8 u6 b mcasp->regs->GBLCTL = 0; // Reset
0 D, }' `$ E& D3 p5 G9 A3 M mcasp->regs->RGBLCTL = 0; // Reset RX6 M L$ f7 i/ X& z6 c: i
mcasp->regs->XGBLCTL = 0; // Reset TX5 J! L/ P7 {; s; E, f% r0 @
mcasp->regs->PWRDEMU = 1; // Free-running
( P' j" d* R7 t; p0 w ? // configure McASP0 receive registers. P; E% f# j3 b! J8 |* ~
mcasp->regs->RMASK = 0xFFFFFFFF; // No padding used0 x' t3 A$ T/ {4 J) ]
mcasp->regs->RFMT = 0x00018078; // MSB 16bit, 0-delay, no pad, CFGBus L1 }8 U5 Y' h2 l5 G- g3 L( D8 O
mcasp->regs->AFSRCTL = 0x00000112; // 2TDM, 1bit Falling, External FS, word
! C7 p6 f6 V5 U2 L% U& O6 E mcasp->regs->ACLKRCTL = 0x000000AF; // Rising INTERNAL CLK,(from tx side). U7 N3 ?+ Y& _6 @
mcasp->regs->AHCLKRCTL = 0x00000000; // INT CLK (from tx side)
: V. Y% t S+ Y) ^$ a& h mcasp->regs->RTDM = 0x00000003; // Slots 0,1
9 r6 L6 Z: B% j* I. V/ o0 Z mcasp->regs->RINTCTL = 0x00000000; // Not used8 i3 q9 @$ E; q2 y8 E, \: n
mcasp->regs->RCLKCHK = 0x00FF0008; // 255-MAX 0-MIN, div-by-2561 T4 S4 ~% [+ Q( z7 ~8 J
+ }" f4 o5 J F& \3 x
mcasp->regs->XMASK = 0xFFFFFFFF; // No padding used
( K# v1 \+ W9 b- `& O mcasp->regs->XFMT = 0x00018078; // MSB 16bit, 0-delay, no pad, CFGBus, e5 o3 ?" x2 ~1 m1 x
mcasp->regs->AFSXCTL = 0x00000112; // 2TDM, 1bit Rising edge INTERNAL FS, word, p+ `' `7 V. i# x
mcasp->regs->ACLKXCTL = 0x000000AF; // ASYNC, Rising INTERNAL CLK, div-by-16" _+ b, a! h4 I# M* z$ m
mcasp->regs->AHCLKXCTL = 0x00000000; // EXT CLK1 j e" O0 _- m, ]5 `1 ~2 d1 C
mcasp->regs->XTDM = 0x00000003; // Slots 0,1
) [0 N' t8 d' B5 [; ~) Q8 h mcasp->regs->XINTCTL = 0x00000020; // interrupt on transmit* G \4 N% X* }, |, }
mcasp->regs->XCLKCHK = 0x00FF0008; // 255-MAX 0-MIN, div-by-2569 L. a% K- J7 F! w0 K) }! H1 z
- K4 H( w- G* A9 K8 I8 Z4 K
mcasp->regs->SRCTL5 = 0x000D; // MCASP1.AXR1[5] --> DIN$ ^* e# ~5 r& T% K% f% C2 {
mcasp->regs->SRCTL0 = 0x000E; // MCASP1.AXR1[0] <-- DOUT
* a. i- x; T# \8 w mcasp->regs->PFUNC = 0; // All MCASPs
# Q, w* r% N* H4 t# o2 w3 B mcasp->regs->PDIR = 0x14000020; // All inputs except AXR0[5], ACLKX1, AFSX15 Q# N3 W; k8 ?# O
' M: `* r2 Z1 @7 _6 E8 ] mcasp->regs->DITCTL = 0x00000000; // Not used
4 @* Y/ f. F. _ mcasp->regs->DLBCTL = 0x00000000; // Not used( t h: t1 r* x* _ Z0 Q; g4 ]( o
mcasp->regs->AMUTE = 0x00000000; // Not used
; x$ x S# a: X/ ?* o9 `7 w. @5 U; S3 m( c/ x& d
/* Starting sections of the McASP*/& g* U$ B/ n% j7 {* D. t) |
mcasp->regs->XGBLCTL |= GBLCTL_XHCLKRST_ON; 8 `( I+ b, b3 z4 I; `" e; X: m
while ( ( mcasp->regs->XGBLCTL & GBLCTL_XHCLKRST_ON ) != GBLCTL_XHCLKRST_ON );
L# h7 T- @3 Y } mcasp->regs->RGBLCTL |= GBLCTL_RHCLKRST_ON; , q0 }( @; k) m# n8 `
while ( ( mcasp->regs->RGBLCTL & GBLCTL_RHCLKRST_ON ) != GBLCTL_RHCLKRST_ON );
p) |! Y* p. l& K$ Q
5 l) a2 m/ k; X+ G; R" ~2 T mcasp->regs->XGBLCTL |= GBLCTL_XCLKRST_ON; + X8 M% }& P: h% m& R) N" X
while ( ( mcasp->regs->XGBLCTL & GBLCTL_XCLKRST_ON ) != GBLCTL_XCLKRST_ON );& p% y9 {& l1 |6 Z. j( l
mcasp->regs->RGBLCTL |= GBLCTL_RCLKRST_ON;
# r$ V8 f( S3 |7 k I# r while ( ( mcasp->regs->RGBLCTL & GBLCTL_RCLKRST_ON ) != GBLCTL_RCLKRST_ON );% N- q! r% H K9 L$ ~; ]/ n
* n; ?: M; ]! f) }7 R
mcasp->regs->XSTAT = 0x0000ffff;
- @5 M% A' E! y7 b0 Q. P mcasp->regs->RSTAT = 0x0000ffff; ' N; [# ]" ?6 T9 |! d1 n
, P9 L; u* s& i" p3 a/ d6 R! Q mcasp->regs->XGBLCTL |= GBLCTL_XSRCLR_ON;
5 C8 t# X" d, N2 _; a while ( ( mcasp->regs->XGBLCTL & GBLCTL_XSRCLR_ON ) != GBLCTL_XSRCLR_ON );
7 N) R r3 ^4 v3 [* W# r mcasp->regs->RGBLCTL |= GBLCTL_RSRCLR_ON;
0 w) ^" m7 T [1 L while ( ( mcasp->regs->RGBLCTL & GBLCTL_RSRCLR_ON ) != GBLCTL_RSRCLR_ON );! T6 _) v& _. ]8 j
3 Q3 y9 \$ {( j7 R4 n$ g! ?' U
/* Write a 0, so that no underrun occurs after releasing the state machine */. M7 L' c' ~* v& n( @/ l: a1 E
mcasp->regs->XBUF5 = 0;2 L9 m3 S' t- f0 L
mcasp->regs->RBUF0 = 0;0 n/ V' A! _# ^. Q
# M, |2 a3 o6 Y4 {1 `3 c$ H
mcasp->regs->XGBLCTL |= GBLCTL_XSMRST_ON;
4 {4 i5 o, [5 _- \, b while ( ( mcasp->regs->XGBLCTL & GBLCTL_XSMRST_ON ) != GBLCTL_XSMRST_ON );
# s( G k" Z4 u( u( x8 X mcasp->regs->RGBLCTL |= GBLCTL_RSMRST_ON; / W# s2 R5 B% p# H
while ( ( mcasp->regs->RGBLCTL & GBLCTL_RSMRST_ON ) != GBLCTL_RSMRST_ON );( X3 v$ H6 V# R( C. ]% H& C0 o
7 x& Q1 R# i& D3 G! Z: l7 ^
mcasp->regs->XGBLCTL |= GBLCTL_XFRST_ON;
6 P$ ~6 }! d1 e while ( ( mcasp->regs->XGBLCTL & GBLCTL_XFRST_ON ) != GBLCTL_XFRST_ON );
+ P; b4 h ?$ O( ` mcasp->regs->RGBLCTL |= GBLCTL_RFRST_ON; * d$ _: g- z! K' b2 y' l
while ( ( mcasp->regs->RGBLCTL & GBLCTL_RFRST_ON ) != GBLCTL_RFRST_ON );4 d' f7 {4 |/ r
, |2 [ F: S: H2 N/ z2 S2 x" j
CSR = 0x0000;
# P: X3 W u, \# X4 t7 u INTC_INTMUX1 = 0x3d;
0 m( O3 d% g' r2 Y: w ISTP = (unsigned int)vectors;
# s4 ~3 O- o" |" Z8 N, ?* T ICR = 0xFFF0; % N1 S* n" F% t6 Y
IER |= 0x12; 2 [" S0 s0 i; h. N- R1 @
CSR |= 0x01;
+ f1 M+ ~2 h" U# `0 y
# U/ I7 t1 {( g) a5 i/ J. q7 _0 e7 E! F4 Z6 |1 W
' ]7 ?$ g: @9 K! m+ Q还有就是两个输入输出函数:2 c: M! X; A9 R: Z7 ~& Y8 r# @
void output_sample(Int32 out_data)
( c8 F3 L& _; ]8 i/ ~{; t" p, q. f1 j0 z( N6 F; I Q
AIC31_data.uint = out_data; 0 E1 \& ?; D6 T6 B) o
MCASP1_XBUF5_32BIT = AIC31_data.uint;
$ I# p0 c& L1 L- [* \* o# C}
. G" B) o; U. K- J! G
; g, d7 X6 ~% L9 SInt32 input_sample(void)
: P9 e- _# h' O1 r; o- t{
- D1 ^+ z+ s* F. O2 O AIC31_data.uint = MCASP1_RBUF0_32BIT;
/ i& o7 l; D1 ^% X* O1 L: L! e# s, @ return (AIC31_data.uint);- S9 A/ u+ ?+ y+ E- l. N6 F5 p
}) x# M+ I6 o/ T* `% e3 M1 @4 V3 h
" G- l& z# R0 J* n! R
|
|