|
|
C6747和C6748感觉差不多,我想实现McASP发送中断方式控制音频信号,在轮询的例程基础上改的,轮询程序可以实现,但是中断一直实现不了,也找不到错误,求大神帮忙!下边是主要程序:! ~7 H R4 g- {0 D
main文件:# ?6 @% x& @: F' h" B* {1 y
interrupt void interrupt4(void) 6 R' R. ^0 l$ B- V
{
( Y+ Q+ B/ U. F+ r+ ` Uint32 sample;
: P1 S) e6 b7 ~/ g# T: f! _; k
* D$ ?$ \) q ?* q. Y sample = input_sample(); // read L + R samples from ADC
[7 A* }- a d& X/ i3 k- j output_sample(sample); // write L + R samples to DAC . ~; g G* Z( X+ E
return;7 r9 g% z: X# ^' g/ ?
} D, x* O# @- F6 o0 i
1 l/ Q/ S5 W& V) P1 a
int main( void )
! B8 A# K/ G. O- C1 ~{
$ K- e- l0 b5 Z( Y% d5 H0 n/ W6 I8 t" S M0 E+ K1 L/ ?
/* Initialize BSL */6 C5 b% z/ G2 L* C# C
EVMC6747_init( );
: q* P$ D) `( I: Y/ x, R /* Call evmc6747_intr function */
2 `, G4 i8 r1 w7 r aic3106_init( );
+ d3 W* a* `0 B+ b8 s8 G while(1);
4 K2 z4 k$ G5 T$ G# t}
" B, h! T7 y5 {& b: \6 f: S$ m& i7 _# r& h- f# S5 B" A
3 O& L* R! _% L/ Aaic3106_init文件的一部分,McASP配置部分,采用内部时钟,I2S方式,同步传输。音频芯片的配置应该没问题
9 o& f, t: V! _) y/ m$ n b7 t/* Initialize MCASP1 */
/ K. s4 V: e* `# V! q' \, |5 V& k n mcasp = &MCASP_MODULE_1;
2 |6 y+ C# C; Z' x" l9 F mcasp->regs->GBLCTL = 0; // Reset
' o V7 F" E3 m. I6 s3 O mcasp->regs->RGBLCTL = 0; // Reset RX
+ s7 ?+ G: z4 w# y mcasp->regs->XGBLCTL = 0; // Reset TX. r0 J' t, o9 I4 f( y
mcasp->regs->PWRDEMU = 1; // Free-running! _8 x; e7 i# v* S: l
// configure McASP0 receive registers
2 y( r4 e+ B* A3 a9 t9 B mcasp->regs->RMASK = 0xFFFFFFFF; // No padding used
( g: j0 y$ v; J1 h) D; @4 i) g ` mcasp->regs->RFMT = 0x00018078; // MSB 16bit, 0-delay, no pad, CFGBus
) d2 c7 ~9 z- N1 d& R7 S; U mcasp->regs->AFSRCTL = 0x00000112; // 2TDM, 1bit Falling, External FS, word& S+ @/ M7 H$ p7 d- T
mcasp->regs->ACLKRCTL = 0x000000AF; // Rising INTERNAL CLK,(from tx side)
5 a+ r( J' D: _/ } mcasp->regs->AHCLKRCTL = 0x00000000; // INT CLK (from tx side)
9 X* l8 n. ]# P$ C( j! }% W mcasp->regs->RTDM = 0x00000003; // Slots 0,1
5 {: q4 }+ ~; ^9 Z5 K* k3 m mcasp->regs->RINTCTL = 0x00000000; // Not used3 ^. X0 A' u8 H9 S. f, r0 N
mcasp->regs->RCLKCHK = 0x00FF0008; // 255-MAX 0-MIN, div-by-256( p$ C: {! k8 a1 W9 |
+ r3 T+ I. @, Y/ q- _6 e mcasp->regs->XMASK = 0xFFFFFFFF; // No padding used4 f- V! z1 g" u
mcasp->regs->XFMT = 0x00018078; // MSB 16bit, 0-delay, no pad, CFGBus
$ T6 E4 a0 k: U9 b% ^ P mcasp->regs->AFSXCTL = 0x00000112; // 2TDM, 1bit Rising edge INTERNAL FS, word c5 z" q. N. A7 f) T! Y
mcasp->regs->ACLKXCTL = 0x000000AF; // ASYNC, Rising INTERNAL CLK, div-by-16
& ? E6 h* |& E1 ]9 Q mcasp->regs->AHCLKXCTL = 0x00000000; // EXT CLK
* E2 G9 H5 I, Q* D% H mcasp->regs->XTDM = 0x00000003; // Slots 0,1
0 [% i, w/ G, t: o" I mcasp->regs->XINTCTL = 0x00000020; // interrupt on transmit
$ [* T# e3 \8 w0 n+ e mcasp->regs->XCLKCHK = 0x00FF0008; // 255-MAX 0-MIN, div-by-2563 \' y% v, N# c* F5 _0 E
2 o' V* W; J5 s+ n4 k
mcasp->regs->SRCTL5 = 0x000D; // MCASP1.AXR1[5] --> DIN5 R2 G& }, }, F$ y3 q# y
mcasp->regs->SRCTL0 = 0x000E; // MCASP1.AXR1[0] <-- DOUT
5 u' @; v2 G5 H' i" S) B$ Z( b. _ mcasp->regs->PFUNC = 0; // All MCASPs: g; U, C; W! o( Y8 j
mcasp->regs->PDIR = 0x14000020; // All inputs except AXR0[5], ACLKX1, AFSX1
h* q1 R0 Q2 S; l/ A9 d8 a
/ C/ j! H% T/ ~! `/ O mcasp->regs->DITCTL = 0x00000000; // Not used
7 a" E- R# W4 H8 n0 \5 \* F mcasp->regs->DLBCTL = 0x00000000; // Not used
; ?+ k E" w( n! O. |0 A m, y4 ^1 R mcasp->regs->AMUTE = 0x00000000; // Not used
; t* z& ~* L: @! H, O; T8 g& @; E4 e" X+ D
/* Starting sections of the McASP*/
+ q' `3 S3 G; { mcasp->regs->XGBLCTL |= GBLCTL_XHCLKRST_ON;
, {* V: T+ C5 g. p2 y) ` while ( ( mcasp->regs->XGBLCTL & GBLCTL_XHCLKRST_ON ) != GBLCTL_XHCLKRST_ON ); 3 V0 S, A* y4 a- M2 x( c
mcasp->regs->RGBLCTL |= GBLCTL_RHCLKRST_ON; * n# ^2 D1 B0 o4 W5 E$ ?5 r
while ( ( mcasp->regs->RGBLCTL & GBLCTL_RHCLKRST_ON ) != GBLCTL_RHCLKRST_ON );: C2 I, V) R6 K7 _5 F) [
7 s! F1 Z2 e# s! s' \$ m- P mcasp->regs->XGBLCTL |= GBLCTL_XCLKRST_ON;
& }; y. E6 m9 c! E6 s' m while ( ( mcasp->regs->XGBLCTL & GBLCTL_XCLKRST_ON ) != GBLCTL_XCLKRST_ON );
% i8 I' L* U$ r( \ mcasp->regs->RGBLCTL |= GBLCTL_RCLKRST_ON; ; c5 a% @& J6 E0 D+ ]
while ( ( mcasp->regs->RGBLCTL & GBLCTL_RCLKRST_ON ) != GBLCTL_RCLKRST_ON );7 u- V" q4 S, z% R7 N+ c
4 z ]+ \# o& H4 R; D* S5 Y mcasp->regs->XSTAT = 0x0000ffff;
, I; T& V% |+ ], c5 x mcasp->regs->RSTAT = 0x0000ffff; ' l5 T3 G6 {: \& H
* O. M% z; \" c y$ { mcasp->regs->XGBLCTL |= GBLCTL_XSRCLR_ON;* T- K+ \0 [1 |
while ( ( mcasp->regs->XGBLCTL & GBLCTL_XSRCLR_ON ) != GBLCTL_XSRCLR_ON );
. X1 K' T% e& B3 L mcasp->regs->RGBLCTL |= GBLCTL_RSRCLR_ON; ( X0 S! ^. Q( f0 A5 Y: A( i
while ( ( mcasp->regs->RGBLCTL & GBLCTL_RSRCLR_ON ) != GBLCTL_RSRCLR_ON );
* m) u3 S, f$ X6 O& P
" ]2 J: A7 \( A2 \" v( e/ J( v /* Write a 0, so that no underrun occurs after releasing the state machine */
& B9 r+ A! P, ^( u& }/ v) e mcasp->regs->XBUF5 = 0;
c4 {: w- ]2 H mcasp->regs->RBUF0 = 0;
/ N' j Z" h+ r- m# }# B0 T, c$ I2 c4 `' s
mcasp->regs->XGBLCTL |= GBLCTL_XSMRST_ON; + t% U, ]6 H) t, {0 K
while ( ( mcasp->regs->XGBLCTL & GBLCTL_XSMRST_ON ) != GBLCTL_XSMRST_ON );
1 g, E8 l b! u3 w, r) K mcasp->regs->RGBLCTL |= GBLCTL_RSMRST_ON; 4 l5 q' `# B. ]7 J1 y
while ( ( mcasp->regs->RGBLCTL & GBLCTL_RSMRST_ON ) != GBLCTL_RSMRST_ON );8 ]' H. H1 S8 N( h
( K; [# t, v2 J9 G
mcasp->regs->XGBLCTL |= GBLCTL_XFRST_ON; 8 i- r* }. d% t+ Z) v9 A+ a
while ( ( mcasp->regs->XGBLCTL & GBLCTL_XFRST_ON ) != GBLCTL_XFRST_ON );$ J0 ~1 E+ U" V# s* X/ P c
mcasp->regs->RGBLCTL |= GBLCTL_RFRST_ON; " F6 Z* I: I3 `6 B0 \
while ( ( mcasp->regs->RGBLCTL & GBLCTL_RFRST_ON ) != GBLCTL_RFRST_ON );
' w8 b6 ~- h& P# T: f0 I
, j& _0 N/ ^+ x CSR = 0x0000;
) T% O& X9 g2 y* B INTC_INTMUX1 = 0x3d;
5 l6 H: x; G; i$ M3 x+ w# J: F3 y ISTP = (unsigned int)vectors;4 K" b2 C5 z3 g4 B! B
ICR = 0xFFF0;
0 W h2 D8 p( M* t& q IER |= 0x12; 4 E7 | G& t& ?5 i. ^2 l
CSR |= 0x01;
, I; S& }# E" O; B7 V; y2 E' E) J8 w) p/ g% m3 d h0 E
R" i: C8 A. @& U2 u
, `; v% w% m: Q2 L& B
还有就是两个输入输出函数: u5 |$ j) {! |- p4 E3 h
void output_sample(Int32 out_data)! ]6 e) r3 h1 s0 b: v
{
% C6 x" {4 V- x AIC31_data.uint = out_data;
+ ?. v" b/ X2 v* Z, E MCASP1_XBUF5_32BIT = AIC31_data.uint;
4 l8 R6 e% i' u" ~}" Y3 S, c/ e6 i) w
, I' h0 R3 B. ]( L3 C3 `2 C3 }
Int32 input_sample(void)
' i. L4 H/ V8 r" t( k$ }- O{ $ t* k5 v% u7 K, B$ u1 B9 a
AIC31_data.uint = MCASP1_RBUF0_32BIT;
) o8 [, ]' K7 y8 I2 n% `4 Y return (AIC31_data.uint);+ R1 Z! N/ f& z8 W
}
9 ?- M5 S& N! y$ R1 t! u1 F& s. n& U' N
|
|