6 h3 l8 j4 ^* `, e sample = input_sample(); // read L + R samples from ADC* s z5 B5 H, @
output_sample(sample); // write L + R samples to DAC 7 E. `6 Z& g5 P1 ]+ c7 u0 F5 | return;4 r ]( \# j! P) z( S
}6 E- l0 S6 f' ], g1 o: m
7 X/ P" y8 U/ q7 g8 a( Qint main( void )6 b# J0 z* y8 ^% `; _7 @7 A# ~
{ 7 [& M3 W" a( F0 v T" Q# R5 ~1 D' R* _) s7 S( ^
/* Initialize BSL */$ X8 V5 u2 U3 z C$ }7 Q- t
EVMC6747_init( ); # Z/ n! X0 O* y a6 r /* Call evmc6747_intr function */ * X2 ` Y, H+ }3 \# z e# j2 y3 I aic3106_init( ); / p/ K: R' k; I, w2 G while(1);1 u5 W# ~' f& g! U. }
} - E4 o H0 }' T ! F5 g# _" L4 O* X5 {7 s+ \6 ^6 x( ^* v" O! z
aic3106_init文件的一部分,McASP配置部分,采用内部时钟,I2S方式,同步传输。音频芯片的配置应该没问题 i6 u" m1 m; q' \* }3 x% w+ G6 y5 A E
/* Initialize MCASP1 */ ( K% g" x' V! g* b, n mcasp = &MCASP_MODULE_1;. N2 r2 D: c. ]& W9 U) p, t
mcasp->regs->GBLCTL = 0; // Reset1 d+ Y2 W+ u( N4 s" p( }/ d& u6 S% C r
mcasp->regs->RGBLCTL = 0; // Reset RX; E( a0 k4 k( @: @. _# v& G
mcasp->regs->XGBLCTL = 0; // Reset TX $ |' u0 \1 m: i mcasp->regs->PWRDEMU = 1; // Free-running $ K; L, X+ c( C // configure McASP0 receive registers1 v n4 p8 }# g H8 Z
mcasp->regs->RMASK = 0xFFFFFFFF; // No padding used 9 h8 p. B5 l6 \" k$ { mcasp->regs->RFMT = 0x00018078; // MSB 16bit, 0-delay, no pad, CFGBus+ g6 C8 s( q, }4 X# i( e' b
mcasp->regs->AFSRCTL = 0x00000112; // 2TDM, 1bit Falling, External FS, word & c w0 c( J* v& } mcasp->regs->ACLKRCTL = 0x000000AF; // Rising INTERNAL CLK,(from tx side): ~8 C: q0 b4 p* Q- N
mcasp->regs->AHCLKRCTL = 0x00000000; // INT CLK (from tx side)/ J5 C- }' ^$ G( b
mcasp->regs->RTDM = 0x00000003; // Slots 0,1 1 k1 s, s& ~/ q x2 B mcasp->regs->RINTCTL = 0x00000000; // Not used0 [ ~7 U% C! m( V! o& a" l" b: r
mcasp->regs->RCLKCHK = 0x00FF0008; // 255-MAX 0-MIN, div-by-256" v" m* |! @& C+ H
$ I/ ~; |" O, M/ _6 b mcasp->regs->XMASK = 0xFFFFFFFF; // No padding used T; m* O& e4 Q, M' D mcasp->regs->XFMT = 0x00018078; // MSB 16bit, 0-delay, no pad, CFGBus e" j! o) Q- q) \& H; W! _* r7 ^9 s, S$ q3 b
mcasp->regs->AFSXCTL = 0x00000112; // 2TDM, 1bit Rising edge INTERNAL FS, word d9 Q$ d! G; q: M/ x8 \4 Q: t mcasp->regs->ACLKXCTL = 0x000000AF; // ASYNC, Rising INTERNAL CLK, div-by-161 [5 [9 y" q& j
mcasp->regs->AHCLKXCTL = 0x00000000; // EXT CLK8 k$ ]( d) o) o7 W
mcasp->regs->XTDM = 0x00000003; // Slots 0,1 ) }2 L- ]1 S4 b; P2 N% c+ x mcasp->regs->XINTCTL = 0x00000020; // interrupt on transmit - X% I' Y- w! N( u3 a. I mcasp->regs->XCLKCHK = 0x00FF0008; // 255-MAX 0-MIN, div-by-256 K: k; ~) Y- X4 M; u
6 L$ A+ R: S! K: _% @( Z' d9 B
mcasp->regs->SRCTL5 = 0x000D; // MCASP1.AXR1[5] --> DIN ( R9 W/ y4 b6 y) t+ n: A T mcasp->regs->SRCTL0 = 0x000E; // MCASP1.AXR1[0] <-- DOUT% d2 `/ [* _0 e+ @9 T5 @
mcasp->regs->PFUNC = 0; // All MCASPs ! t8 l4 ?1 ]# g mcasp->regs->PDIR = 0x14000020; // All inputs except AXR0[5], ACLKX1, AFSX1% A% _# Y. w, G0 \0 l/ m6 m
/ W( _- ^: O* o; V+ P mcasp->regs->DITCTL = 0x00000000; // Not used6 j/ e$ o+ Z. R! Z: h3 A5 J3 P% v e
mcasp->regs->DLBCTL = 0x00000000; // Not used( v9 N8 o" f3 F* U3 R4 p
mcasp->regs->AMUTE = 0x00000000; // Not used % Z9 _* A0 w9 j: Y. P6 J, X& Y: d$ V# c- i
/* Starting sections of the McASP*/, C# _" |) b( E9 }2 \
mcasp->regs->XGBLCTL |= GBLCTL_XHCLKRST_ON; & e0 S0 w: w' f4 g, D
while ( ( mcasp->regs->XGBLCTL & GBLCTL_XHCLKRST_ON ) != GBLCTL_XHCLKRST_ON ); * Q' C6 L1 q! X2 t
mcasp->regs->RGBLCTL |= GBLCTL_RHCLKRST_ON; ( r. ^' j8 Q: {8 {$ r8 B while ( ( mcasp->regs->RGBLCTL & GBLCTL_RHCLKRST_ON ) != GBLCTL_RHCLKRST_ON );! h0 }* L4 F' `4 a6 ]6 C& g8 Z1 O
$ O, R, P: \& T4 ~ mcasp->regs->XGBLCTL |= GBLCTL_XCLKRST_ON; # d. P* ~+ y0 F2 E0 ^ while ( ( mcasp->regs->XGBLCTL & GBLCTL_XCLKRST_ON ) != GBLCTL_XCLKRST_ON );# ?0 t; @7 f s/ I+ `/ U9 O
mcasp->regs->RGBLCTL |= GBLCTL_RCLKRST_ON; 8 p* G' T5 z, \8 Q/ w
while ( ( mcasp->regs->RGBLCTL & GBLCTL_RCLKRST_ON ) != GBLCTL_RCLKRST_ON );# Y; U4 Z! ^ y8 O, X, v
# W8 s$ m1 c; N3 Y6 L9 e; q3 Z
mcasp->regs->XSTAT = 0x0000ffff; & {: n: x/ e1 R$ ^4 J
mcasp->regs->RSTAT = 0x0000ffff; $ ^0 p0 e% x7 s9 \
5 h! A. f0 u9 Q3 b L
mcasp->regs->XGBLCTL |= GBLCTL_XSRCLR_ON; 3 }" v4 Y" u) Q# o9 I" O1 \5 t while ( ( mcasp->regs->XGBLCTL & GBLCTL_XSRCLR_ON ) != GBLCTL_XSRCLR_ON );6 J6 x3 Q- e/ ]
mcasp->regs->RGBLCTL |= GBLCTL_RSRCLR_ON; . |, |* T& W( f; T- q7 }# U while ( ( mcasp->regs->RGBLCTL & GBLCTL_RSRCLR_ON ) != GBLCTL_RSRCLR_ON ); # D4 J) S W. K7 i3 T5 Q. J# e : u- Q9 h; N) j8 H/ O% k /* Write a 0, so that no underrun occurs after releasing the state machine */ , u3 L# w. E! {, ~4 {& Y# @ mcasp->regs->XBUF5 = 0;% j$ w5 _; D# T8 ~% P0 M: J& {
mcasp->regs->RBUF0 = 0;$ o; f8 ~* s7 L3 v
' _3 U" \# h7 l
mcasp->regs->XGBLCTL |= GBLCTL_XSMRST_ON; $ S" w( L6 @! n$ u( w while ( ( mcasp->regs->XGBLCTL & GBLCTL_XSMRST_ON ) != GBLCTL_XSMRST_ON );, u8 H! M5 ^# s' q/ m3 f. S
mcasp->regs->RGBLCTL |= GBLCTL_RSMRST_ON; ' e0 ^1 a! X( | while ( ( mcasp->regs->RGBLCTL & GBLCTL_RSMRST_ON ) != GBLCTL_RSMRST_ON ); + g1 e) B9 j( z) O2 s" |7 x0 d# q/ f+ ~# ^0 q! P& S) `/ D
mcasp->regs->XGBLCTL |= GBLCTL_XFRST_ON; 3 U2 B, N L7 x; A0 t1 k
while ( ( mcasp->regs->XGBLCTL & GBLCTL_XFRST_ON ) != GBLCTL_XFRST_ON ); % [4 s0 Y2 z! {4 T# x8 u mcasp->regs->RGBLCTL |= GBLCTL_RFRST_ON; ' c( D$ P2 R# L- C+ D( `: _
while ( ( mcasp->regs->RGBLCTL & GBLCTL_RFRST_ON ) != GBLCTL_RFRST_ON );" I! N! h+ ?3 F
' z6 X) G& Q6 u W4 v4 V CSR = 0x0000;; ?) _! B s+ w% a
INTC_INTMUX1 = 0x3d; 2 ~6 b8 ]% A" u v1 l7 C8 W( Q0 V0 k ISTP = (unsigned int)vectors; ; Q: a6 `: g' e2 K* W% d ICR = 0xFFF0; ' q k# c$ C. u k x IER |= 0x12; , p [6 i6 q( n. B) H& C; w2 { CSR |= 0x01; # K9 n! N& S# Y5 {. c- o, G
4 l+ u P9 W9 M* f+ W + S# `) [, `8 P/ z9 M2 p4 W3 p' |4 y1 ^0 r! U/ P" p
还有就是两个输入输出函数:& X( g' z! |0 p; C/ W
void output_sample(Int32 out_data) : O) j9 G4 R# N& `/ \{& K+ |& i. ] F' g) H7 h1 S* R2 h u
AIC31_data.uint = out_data; $ L; s& G: T& R& i2 q* i9 w MCASP1_XBUF5_32BIT = AIC31_data.uint;6 V4 S6 U# C' U
}$ ?7 M2 D6 Q& K8 x: ^
9 b$ R P; O8 q. E& M" k+ TInt32 input_sample(void) 6 X; D0 ?# ]$ t, a( H' j{ " Z6 E% M& ^- j+ D AIC31_data.uint = MCASP1_RBUF0_32BIT;1 _5 }2 W7 U" Y; {0 e
return (AIC31_data.uint); t6 A" T& m4 e* \8 G, _- S. t" C} 5 ]$ Y2 |' N' i ' a4 P4 I4 {4 `3 R作者: human 时间: 2016-3-16 11:55
可以参看创龙提供的例程:AUDIO_LINE_OUT_INTR——Line Out 音频输出(中断方式)