|
|
C6747和C6748感觉差不多,我想实现McASP发送中断方式控制音频信号,在轮询的例程基础上改的,轮询程序可以实现,但是中断一直实现不了,也找不到错误,求大神帮忙!下边是主要程序:% @* {' i$ }' [9 g" S, h
main文件:7 c( y ] p; C) m( k2 q
interrupt void interrupt4(void)
, A8 D. A4 F* z2 E. G2 n0 s& o$ f8 U{
2 b( l4 ^) E' J' L Uint32 sample;
$ h. r$ y; Q! J1 s/ d; v" E3 E
2 _& ]) K* t: j9 @6 N$ W sample = input_sample(); // read L + R samples from ADC" }$ u# w% v8 y. b% m! o3 N, Q
output_sample(sample); // write L + R samples to DAC 1 h- }5 R' v: B( @
return;9 C% j6 s. E) v6 q) s7 k- R
}# O! J* h: R2 O' T: p
/ y$ B0 B) N5 n9 v/ J$ t
int main( void )
; u, E( V4 @1 a; b& S- s8 m{
" _, r, a4 P: I A. k/ D* l% @$ s2 L @8 x
/* Initialize BSL */
* a+ J6 e" r3 S5 Y8 E; w2 _ EVMC6747_init( );" Y4 f7 C0 v# L
/* Call evmc6747_intr function */ k0 ^0 S3 A* r1 d: y# N3 e
aic3106_init( );" S1 m t, g4 ~- U. M `1 r/ R- z
while(1);7 v8 T" {: f) h
}
# N, c+ c" _7 Z& R( o3 k- O; n
# N( T* i0 M. k! t( D5 w1 M$ o# e T3 s z5 y8 [" @
aic3106_init文件的一部分,McASP配置部分,采用内部时钟,I2S方式,同步传输。音频芯片的配置应该没问题
' K8 a# G, t" o7 s" b3 L% n$ A/* Initialize MCASP1 */
3 t* n3 ^0 N! L* U mcasp = &MCASP_MODULE_1;
2 Y( G& p2 n! R$ N- W- o mcasp->regs->GBLCTL = 0; // Reset
4 E- O' i) j1 k! d3 Y mcasp->regs->RGBLCTL = 0; // Reset RX
' @) x8 h6 }* t, K1 n mcasp->regs->XGBLCTL = 0; // Reset TX
% U9 m9 i' z$ s& W+ h; A mcasp->regs->PWRDEMU = 1; // Free-running4 U w2 w3 ^, I! B
// configure McASP0 receive registers
( q8 z+ N* g n1 w1 N9 G0 S2 K mcasp->regs->RMASK = 0xFFFFFFFF; // No padding used
. z) z% O5 l) S1 K7 Y& s( w) A# ? mcasp->regs->RFMT = 0x00018078; // MSB 16bit, 0-delay, no pad, CFGBus
. a' l2 z W3 C0 K mcasp->regs->AFSRCTL = 0x00000112; // 2TDM, 1bit Falling, External FS, word9 ~' l* } C7 W( s/ A4 S
mcasp->regs->ACLKRCTL = 0x000000AF; // Rising INTERNAL CLK,(from tx side)
9 k8 j$ k2 H! R- n mcasp->regs->AHCLKRCTL = 0x00000000; // INT CLK (from tx side)
* {: M5 k/ i2 I' s* ~& T mcasp->regs->RTDM = 0x00000003; // Slots 0,1
8 L5 E; l7 s, P* u& V+ Y" J9 V mcasp->regs->RINTCTL = 0x00000000; // Not used
& u4 Y/ n. ^5 I mcasp->regs->RCLKCHK = 0x00FF0008; // 255-MAX 0-MIN, div-by-256( }9 z3 J2 m0 `
; \' F1 x, ^4 s+ Z. Z
mcasp->regs->XMASK = 0xFFFFFFFF; // No padding used
& D9 C' s6 E2 j+ F6 F' R mcasp->regs->XFMT = 0x00018078; // MSB 16bit, 0-delay, no pad, CFGBus6 u% Z2 m& z& F9 v0 P
mcasp->regs->AFSXCTL = 0x00000112; // 2TDM, 1bit Rising edge INTERNAL FS, word0 Q4 c# O2 M8 P3 k; Y. _
mcasp->regs->ACLKXCTL = 0x000000AF; // ASYNC, Rising INTERNAL CLK, div-by-16
% Z9 U6 ^/ ]' q/ s9 ^/ z! d mcasp->regs->AHCLKXCTL = 0x00000000; // EXT CLK8 x; Y8 s9 u* y0 z& s
mcasp->regs->XTDM = 0x00000003; // Slots 0,10 z B9 r3 X& n/ u* h' H
mcasp->regs->XINTCTL = 0x00000020; // interrupt on transmit
9 c% k9 r! ^6 P0 r mcasp->regs->XCLKCHK = 0x00FF0008; // 255-MAX 0-MIN, div-by-256
+ v& X+ h3 Y5 j6 E! u3 S$ p% N7 m3 s9 P+ d. F5 `- Q8 K7 o
mcasp->regs->SRCTL5 = 0x000D; // MCASP1.AXR1[5] --> DIN" n$ e5 D" [0 {) Z3 o6 U4 `
mcasp->regs->SRCTL0 = 0x000E; // MCASP1.AXR1[0] <-- DOUT5 c$ q$ c: u: a/ J" }, |+ V- y
mcasp->regs->PFUNC = 0; // All MCASPs
l; I+ I% }/ F9 ^ mcasp->regs->PDIR = 0x14000020; // All inputs except AXR0[5], ACLKX1, AFSX17 c: D8 W. ~( C8 O
% n0 U: S+ P' A4 q; B mcasp->regs->DITCTL = 0x00000000; // Not used
6 z$ w; b0 f1 }7 v. a mcasp->regs->DLBCTL = 0x00000000; // Not used
* o+ e& u( \) v, s, I" F- O mcasp->regs->AMUTE = 0x00000000; // Not used
2 Q# t* y2 n3 P5 n6 D( K5 A
/ u! Q) G( n2 B+ B1 V) @1 J/* Starting sections of the McASP*/
7 ?# r& P" L* M; I: d mcasp->regs->XGBLCTL |= GBLCTL_XHCLKRST_ON;
8 G& ?# W2 {5 Q* z1 E! }( w2 N while ( ( mcasp->regs->XGBLCTL & GBLCTL_XHCLKRST_ON ) != GBLCTL_XHCLKRST_ON );
6 s! F& G/ \% B4 X0 r" i( U1 C mcasp->regs->RGBLCTL |= GBLCTL_RHCLKRST_ON; 2 Q4 ?: R4 F- R/ I: @
while ( ( mcasp->regs->RGBLCTL & GBLCTL_RHCLKRST_ON ) != GBLCTL_RHCLKRST_ON );
& V- O0 s- ~% c( |3 W3 y% U5 M% r4 G' q) [2 J, X G) |" O
mcasp->regs->XGBLCTL |= GBLCTL_XCLKRST_ON;
; ]! a9 x. }' m) a# n while ( ( mcasp->regs->XGBLCTL & GBLCTL_XCLKRST_ON ) != GBLCTL_XCLKRST_ON );9 \1 l. o; L" ~; J2 R1 d
mcasp->regs->RGBLCTL |= GBLCTL_RCLKRST_ON;
) ` M _7 B- F while ( ( mcasp->regs->RGBLCTL & GBLCTL_RCLKRST_ON ) != GBLCTL_RCLKRST_ON );
2 W: C1 Q7 f9 U V k6 {5 S' [: S! v
mcasp->regs->XSTAT = 0x0000ffff; ; U D; A& n, q) ]9 {1 }
mcasp->regs->RSTAT = 0x0000ffff;
3 \1 ]- n" |( ]4 b F9 }6 i l' s. N7 X( C4 q7 M+ w
mcasp->regs->XGBLCTL |= GBLCTL_XSRCLR_ON;
/ a( S# \! ~" O while ( ( mcasp->regs->XGBLCTL & GBLCTL_XSRCLR_ON ) != GBLCTL_XSRCLR_ON );
% ?8 H" x9 Q7 W/ c. I' n& C mcasp->regs->RGBLCTL |= GBLCTL_RSRCLR_ON;
+ u& N- e6 E9 n& Q1 s9 X7 _- X while ( ( mcasp->regs->RGBLCTL & GBLCTL_RSRCLR_ON ) != GBLCTL_RSRCLR_ON );
9 l; M$ u' O" Y2 i, x8 T5 _. h: S# P5 q0 C- K7 |7 O `
/* Write a 0, so that no underrun occurs after releasing the state machine */
" j% Y9 J% E2 q) X- u) R, w( \9 |; F mcasp->regs->XBUF5 = 0;
- p% F" E, V. t9 Y" k6 x mcasp->regs->RBUF0 = 0;
4 l5 i! p/ x- X f8 L$ n3 d0 }/ ]
8 C2 f+ T. ^4 `- R mcasp->regs->XGBLCTL |= GBLCTL_XSMRST_ON;
1 N7 j8 _: \6 P; Y while ( ( mcasp->regs->XGBLCTL & GBLCTL_XSMRST_ON ) != GBLCTL_XSMRST_ON );+ T1 E! X% |! A5 c7 p( f3 l
mcasp->regs->RGBLCTL |= GBLCTL_RSMRST_ON; * R) U. Q t9 B7 c
while ( ( mcasp->regs->RGBLCTL & GBLCTL_RSMRST_ON ) != GBLCTL_RSMRST_ON );4 D) q- f/ R7 ^0 y& r L4 n+ D) F
. W& m; ]2 J9 K4 g+ W& t
mcasp->regs->XGBLCTL |= GBLCTL_XFRST_ON; & O" b# H8 `/ J4 T2 S( C$ k
while ( ( mcasp->regs->XGBLCTL & GBLCTL_XFRST_ON ) != GBLCTL_XFRST_ON );
; g# c6 I( R2 A; R- s. v+ D mcasp->regs->RGBLCTL |= GBLCTL_RFRST_ON;
" g, _: @: E& G while ( ( mcasp->regs->RGBLCTL & GBLCTL_RFRST_ON ) != GBLCTL_RFRST_ON );% w4 C* G: u" B+ O7 j8 o* ~
0 J1 Q7 T* {- U' k% A( ^
CSR = 0x0000;
% B/ F3 n9 S3 ]' B$ C INTC_INTMUX1 = 0x3d;. E* Q8 T& d" Z( s9 _5 I$ O
ISTP = (unsigned int)vectors;
: t8 h" W9 k: I U2 g0 Z% u ICR = 0xFFF0; $ k( M# J! `! n
IER |= 0x12; $ p# a2 W7 A1 S+ m( |- k
CSR |= 0x01;
" ?) Y- Y& F$ U* O i1 z6 n: P8 [1 B
( I7 m" N4 d# l: e9 @+ t7 x0 s8 T: ]3 J$ W" e! y( ?
4 ^9 c. J$ j- F! O5 k还有就是两个输入输出函数:
8 O+ M' x4 G( ?9 T: q2 e- o$ ?. Svoid output_sample(Int32 out_data)1 y& V _& q3 Y) j& K. q
{; H& m t7 l" t
AIC31_data.uint = out_data; 0 S8 S7 t" T8 L/ i+ V
MCASP1_XBUF5_32BIT = AIC31_data.uint;4 J6 c# P8 a6 J c2 u" w+ c5 j
}
4 [6 n" l- K: r; y, S
/ e# @8 T, ]/ N& C, x: vInt32 input_sample(void)
8 i5 G0 ]. a6 P; N8 l$ p$ k{
' x( a" } A1 z: m0 M AIC31_data.uint = MCASP1_RBUF0_32BIT;
4 {3 V$ ]+ R4 _+ { return (AIC31_data.uint);
/ ~# l6 C# z2 h% T2 }' a}/ V0 |3 ]5 {3 Q2 N. J
, D+ z7 A" |5 u$ s |
|