|
|
C6747和C6748感觉差不多,我想实现McASP发送中断方式控制音频信号,在轮询的例程基础上改的,轮询程序可以实现,但是中断一直实现不了,也找不到错误,求大神帮忙!下边是主要程序:
/ O+ W+ g) K" w w6 z Amain文件:
; W# ]* w5 R3 T1 v; P$ o1 Pinterrupt void interrupt4(void)
- W* _% [+ t6 W. ?* ~% q( q{: S9 O7 Q! v6 R
Uint32 sample;4 ~' E' R/ h6 r+ i! x
: ~, w! {3 h# h" i) U K
sample = input_sample(); // read L + R samples from ADC
& a7 P0 G K2 q) d$ z( v output_sample(sample); // write L + R samples to DAC
, c/ \( S0 k- b" X return;
, g6 \; j$ E( F G/ M* U3 L& p; T}
2 C4 ?1 t* k1 X# U, ^& \; H
' I9 J# k O+ g5 Pint main( void )5 b+ U- L4 a+ r
{0 z/ t( r- F8 W) k) z
" c! S4 \. P2 j /* Initialize BSL */. m/ t8 b2 a6 u3 U! L" s, f. S% i
EVMC6747_init( );- Z1 S% j7 \2 o) g
/* Call evmc6747_intr function */# N, Z' L/ v: Z, K8 m5 i7 m. O* v
aic3106_init( );
; j( a' {* F( P while(1);
* |1 v9 r" ^2 S4 C, D}) I9 Z- h+ [6 j- s7 A0 F
( t. ~' m9 ^0 Z u: b1 F/ J! x1 U( {6 Y" k! U
aic3106_init文件的一部分,McASP配置部分,采用内部时钟,I2S方式,同步传输。音频芯片的配置应该没问题
' n$ H* V/ f: V- C& [. W8 C+ s: l/* Initialize MCASP1 */
* w0 j1 r5 s! j! t4 I9 ^ mcasp = &MCASP_MODULE_1;
9 k* d* P% W" P. Q4 a mcasp->regs->GBLCTL = 0; // Reset
/ K1 M/ j" a' @ ^6 n9 Q mcasp->regs->RGBLCTL = 0; // Reset RX
& y8 D" B7 p8 `' Z% A0 t. v4 w& N mcasp->regs->XGBLCTL = 0; // Reset TX) p( _" W: ^8 `
mcasp->regs->PWRDEMU = 1; // Free-running, \- z% n8 |6 N/ v0 Z- P
// configure McASP0 receive registers& F9 K8 P3 {% k, F; L
mcasp->regs->RMASK = 0xFFFFFFFF; // No padding used' n K2 ]: e+ |+ i* y# s% t
mcasp->regs->RFMT = 0x00018078; // MSB 16bit, 0-delay, no pad, CFGBus0 B, k) B+ T1 C+ N9 H
mcasp->regs->AFSRCTL = 0x00000112; // 2TDM, 1bit Falling, External FS, word- `, I+ m, I% T1 s! W- b" [) S3 z
mcasp->regs->ACLKRCTL = 0x000000AF; // Rising INTERNAL CLK,(from tx side)2 U. r. e. l0 ]3 E3 g6 Y, S
mcasp->regs->AHCLKRCTL = 0x00000000; // INT CLK (from tx side)
$ A3 u" _) ~- o mcasp->regs->RTDM = 0x00000003; // Slots 0,1: S. j2 b" n! n( R- a" D+ X
mcasp->regs->RINTCTL = 0x00000000; // Not used
5 _8 D2 r9 K( p9 j2 c5 O" N mcasp->regs->RCLKCHK = 0x00FF0008; // 255-MAX 0-MIN, div-by-256
6 G/ Q3 \) o( O9 v+ {
5 U3 F4 S7 m+ B: |! @ mcasp->regs->XMASK = 0xFFFFFFFF; // No padding used
2 w- n4 t& b7 |2 G7 U; ^2 C mcasp->regs->XFMT = 0x00018078; // MSB 16bit, 0-delay, no pad, CFGBus E8 L6 W3 W& y1 W
mcasp->regs->AFSXCTL = 0x00000112; // 2TDM, 1bit Rising edge INTERNAL FS, word
9 U9 R+ j$ q: L/ r& w# [ mcasp->regs->ACLKXCTL = 0x000000AF; // ASYNC, Rising INTERNAL CLK, div-by-16! d5 Y' W4 g2 N) }* F4 J% V+ _2 w' H7 i
mcasp->regs->AHCLKXCTL = 0x00000000; // EXT CLK
5 W- s- x9 H2 n0 } mcasp->regs->XTDM = 0x00000003; // Slots 0,1
8 w2 z9 S3 v! q+ ]9 Z |; M mcasp->regs->XINTCTL = 0x00000020; // interrupt on transmit; ]0 N8 ^( f) Z% v0 r. ~
mcasp->regs->XCLKCHK = 0x00FF0008; // 255-MAX 0-MIN, div-by-2566 O# A! ~/ t% `% o( b
- e2 o$ u( |- v# D5 F! Z5 M mcasp->regs->SRCTL5 = 0x000D; // MCASP1.AXR1[5] --> DIN
& q0 M7 R/ l$ S, h8 g mcasp->regs->SRCTL0 = 0x000E; // MCASP1.AXR1[0] <-- DOUT: k( C: d1 ~ x0 H7 A$ [
mcasp->regs->PFUNC = 0; // All MCASPs
$ G- n* n3 w) S* F. B mcasp->regs->PDIR = 0x14000020; // All inputs except AXR0[5], ACLKX1, AFSX1! @9 }% z: @1 ^9 G* |
4 h) X. k4 n( a& o6 X- z mcasp->regs->DITCTL = 0x00000000; // Not used
6 t& ?4 z L& Q2 Z" ~' _7 D mcasp->regs->DLBCTL = 0x00000000; // Not used
2 x$ }* F0 @. f$ F mcasp->regs->AMUTE = 0x00000000; // Not used
`. G1 y7 y0 G0 q3 I, M& l; p" s& @' u" j( U
/* Starting sections of the McASP*/
. L/ M% G; P2 R/ ^9 O3 m, c- H- V mcasp->regs->XGBLCTL |= GBLCTL_XHCLKRST_ON;
9 |" G+ j8 S9 w7 S* j# Z while ( ( mcasp->regs->XGBLCTL & GBLCTL_XHCLKRST_ON ) != GBLCTL_XHCLKRST_ON );
# A6 e: G6 N" X' L7 M2 F8 `! p mcasp->regs->RGBLCTL |= GBLCTL_RHCLKRST_ON; ! g; U0 i7 x( V0 o) e
while ( ( mcasp->regs->RGBLCTL & GBLCTL_RHCLKRST_ON ) != GBLCTL_RHCLKRST_ON );$ N. v; T m& Z4 p" z
+ i$ @- g/ Y! L7 {! L; m" l. ^* M mcasp->regs->XGBLCTL |= GBLCTL_XCLKRST_ON; 9 b, h& \. h# q2 {3 l
while ( ( mcasp->regs->XGBLCTL & GBLCTL_XCLKRST_ON ) != GBLCTL_XCLKRST_ON );
7 v7 j) J; Y: J- m6 k6 ? mcasp->regs->RGBLCTL |= GBLCTL_RCLKRST_ON;
8 k2 A& t' W8 ~6 t while ( ( mcasp->regs->RGBLCTL & GBLCTL_RCLKRST_ON ) != GBLCTL_RCLKRST_ON );
/ {" Q6 j% o* B7 G9 a9 G7 @: Z6 h! i, {# Y
mcasp->regs->XSTAT = 0x0000ffff; " V2 W( a0 F6 E% f
mcasp->regs->RSTAT = 0x0000ffff;
0 |4 j, F! ~, ?/ O- |! m' S
* [0 p! @% t# B mcasp->regs->XGBLCTL |= GBLCTL_XSRCLR_ON;, t# ?4 f2 O0 H, d* g
while ( ( mcasp->regs->XGBLCTL & GBLCTL_XSRCLR_ON ) != GBLCTL_XSRCLR_ON );
# \0 F+ _: W( }) d2 J4 c1 G' r mcasp->regs->RGBLCTL |= GBLCTL_RSRCLR_ON; # ~, S8 }! b, E5 Z. N X
while ( ( mcasp->regs->RGBLCTL & GBLCTL_RSRCLR_ON ) != GBLCTL_RSRCLR_ON );& k, d. \# a$ v" P. t
. h s8 h' i: ~0 R' C
/* Write a 0, so that no underrun occurs after releasing the state machine */
6 u9 Z$ ^9 s( L' h3 l9 _ mcasp->regs->XBUF5 = 0;( q- o4 f2 z- V' ^# |
mcasp->regs->RBUF0 = 0;
# K: l9 P% R( c# x! A$ |- J% U9 C2 ~4 k
mcasp->regs->XGBLCTL |= GBLCTL_XSMRST_ON; 3 a8 @7 @% J+ q' J5 J6 W% f
while ( ( mcasp->regs->XGBLCTL & GBLCTL_XSMRST_ON ) != GBLCTL_XSMRST_ON );
, x& U6 i3 O) ^ mcasp->regs->RGBLCTL |= GBLCTL_RSMRST_ON;
; h1 X; |- l* U" u while ( ( mcasp->regs->RGBLCTL & GBLCTL_RSMRST_ON ) != GBLCTL_RSMRST_ON );
" M4 M" l, K) C3 M4 j1 B* k. j
3 f, X) A+ P% [( J mcasp->regs->XGBLCTL |= GBLCTL_XFRST_ON; 3 S5 T8 k# z9 |! n8 r& B
while ( ( mcasp->regs->XGBLCTL & GBLCTL_XFRST_ON ) != GBLCTL_XFRST_ON );& D4 ]6 o4 ]& |7 F, l
mcasp->regs->RGBLCTL |= GBLCTL_RFRST_ON; + d0 M2 l. h) A
while ( ( mcasp->regs->RGBLCTL & GBLCTL_RFRST_ON ) != GBLCTL_RFRST_ON );
( v ]7 L- ^- l# k6 G
- k. M2 Z2 b) e; _, I6 |' F6 a CSR = 0x0000;. e) s9 u' R1 f: |! `/ q& r8 w
INTC_INTMUX1 = 0x3d;
; s# ^; V: g" W4 \% H7 }6 D ISTP = (unsigned int)vectors;
) w& s+ m# Y) C) H5 o' k1 { ICR = 0xFFF0; ' c) b& I7 H; W# X( o
IER |= 0x12;
2 N' U7 ^6 I2 _7 Z3 P6 G f' Y CSR |= 0x01; ; H# u0 f7 m. p: Q1 p. ^
: j0 N: H0 p% }3 j% I$ _, J$ h: T% W, b* V
9 E1 S# e% C7 A9 Z" H2 V2 V' O还有就是两个输入输出函数:
4 @/ D* u3 ~: v5 l# _9 z1 D- ^void output_sample(Int32 out_data)+ O- F5 _7 I: L9 B/ z1 @
{
* g) r1 ~3 A, L$ Q: T& z6 b AIC31_data.uint = out_data; ) o2 @7 ^ b6 H
MCASP1_XBUF5_32BIT = AIC31_data.uint;
. Z3 v4 U% ~) k7 S% \! x6 y}) Y0 ^( y. a+ h% n% [( t' u7 U# m
( K3 A1 N) o, O" a& z, e+ U4 vInt32 input_sample(void)3 o& N& ~) }: M9 G( l/ k
{ / q0 h0 n1 ~& i
AIC31_data.uint = MCASP1_RBUF0_32BIT;
5 l5 ?) I9 U- t& i Q3 x4 ~ return (AIC31_data.uint);
' S/ `; q; s3 z% i5 E9 S( r}8 ?8 M( U' r3 @7 R1 G. k4 u- e0 D
1 I) W- R% @% ^! e) o% i; S
|
|