|
|
C6747和C6748感觉差不多,我想实现McASP发送中断方式控制音频信号,在轮询的例程基础上改的,轮询程序可以实现,但是中断一直实现不了,也找不到错误,求大神帮忙!下边是主要程序:
" k. s2 c9 t# g- t, V) ?6 {main文件:
) X- S% `( r* v* ^ u E6 A$ Finterrupt void interrupt4(void) * J. x! a+ c6 O6 b- t
{
$ g2 [% z0 t* g2 w* j) q# c* ?6 W" D Uint32 sample;4 U! \% b0 R2 h) y1 E, Z/ ^
4 A* m. D0 H% a6 E& I4 ?% B sample = input_sample(); // read L + R samples from ADC
7 _( p9 C: C- o7 W output_sample(sample); // write L + R samples to DAC ' K% J& j) t* S7 V
return;( Y* x M# F& S9 G4 J) M3 N0 E
}
" p5 V5 i: X/ A. H
: y- {* B Q" m) d: H- Xint main( void )( j1 u) t F3 C3 c5 L* R: {
{
! u* u( Y' Q$ H% M' ~! \) E4 l! \6 h7 F( n/ {" Q
/* Initialize BSL */- C$ [# g: x4 E8 ^7 j
EVMC6747_init( );
9 k7 J1 c8 r: V* B1 {( V /* Call evmc6747_intr function */! T& s# u& u. @
aic3106_init( );8 i X8 O Y) ?) a1 z
while(1);
9 n$ ^1 N9 J/ [0 x/ y. G}
P+ a: A2 M2 {9 u. R
) |4 W" O& F. S2 _ l! F, U4 S5 R [% b$ H! n, i) r' H
aic3106_init文件的一部分,McASP配置部分,采用内部时钟,I2S方式,同步传输。音频芯片的配置应该没问题
4 r v- i* n, W! y% @$ M) [3 h4 p/* Initialize MCASP1 */
( M, C# d' F# ~& T3 [) Q0 D mcasp = &MCASP_MODULE_1;5 d! V' e! n# |
mcasp->regs->GBLCTL = 0; // Reset
6 }" T; @" A7 `, {1 n. v6 ]# ]' u4 T mcasp->regs->RGBLCTL = 0; // Reset RX! D. ^( k" e7 ~6 v3 F
mcasp->regs->XGBLCTL = 0; // Reset TX! U6 b& ~+ ]/ m' Z* p, ^# c
mcasp->regs->PWRDEMU = 1; // Free-running
, D( u8 c3 S0 k5 C$ T2 ~ // configure McASP0 receive registers
" L0 L9 Z1 S% ?1 W( n' f mcasp->regs->RMASK = 0xFFFFFFFF; // No padding used
7 s d! o4 }* q/ t; I7 r0 ` mcasp->regs->RFMT = 0x00018078; // MSB 16bit, 0-delay, no pad, CFGBus
- d+ T9 k8 T2 ]$ W9 {0 o0 c mcasp->regs->AFSRCTL = 0x00000112; // 2TDM, 1bit Falling, External FS, word
( l; ?9 R% {6 i1 _# L" H mcasp->regs->ACLKRCTL = 0x000000AF; // Rising INTERNAL CLK,(from tx side)
/ _9 p `0 Z6 e mcasp->regs->AHCLKRCTL = 0x00000000; // INT CLK (from tx side)
& J4 j) t+ i- I5 m0 L# M" }( \! P mcasp->regs->RTDM = 0x00000003; // Slots 0,1
- Y- r* V2 F& c* L7 ^ mcasp->regs->RINTCTL = 0x00000000; // Not used" S0 W# t3 v9 j5 D. |1 v6 _
mcasp->regs->RCLKCHK = 0x00FF0008; // 255-MAX 0-MIN, div-by-256
+ }/ F' V7 w7 K7 f" s% m+ ?' ^* {+ G
mcasp->regs->XMASK = 0xFFFFFFFF; // No padding used
; O& C M. A' c+ q5 J mcasp->regs->XFMT = 0x00018078; // MSB 16bit, 0-delay, no pad, CFGBus f. F4 Z6 E* c: \: R% o
mcasp->regs->AFSXCTL = 0x00000112; // 2TDM, 1bit Rising edge INTERNAL FS, word/ Q @9 i" }0 c( X# [% p9 e/ ~
mcasp->regs->ACLKXCTL = 0x000000AF; // ASYNC, Rising INTERNAL CLK, div-by-16
$ E/ }, Z' I, `8 c4 D mcasp->regs->AHCLKXCTL = 0x00000000; // EXT CLK- Z) ?' p4 o. t8 E" h& p, z
mcasp->regs->XTDM = 0x00000003; // Slots 0,15 a' n8 h( ?' f1 t2 z
mcasp->regs->XINTCTL = 0x00000020; // interrupt on transmit
9 s+ X# r/ t' h, T4 R mcasp->regs->XCLKCHK = 0x00FF0008; // 255-MAX 0-MIN, div-by-256! j3 F# R, ~4 x
7 V5 c+ `2 i E8 S% U/ J/ B7 g" P mcasp->regs->SRCTL5 = 0x000D; // MCASP1.AXR1[5] --> DIN
% _/ M! ], V3 h5 y- \ mcasp->regs->SRCTL0 = 0x000E; // MCASP1.AXR1[0] <-- DOUT
0 H9 y: q( h: a0 Q. @$ I5 G3 K2 U$ C" n mcasp->regs->PFUNC = 0; // All MCASPs
; p3 `0 K; M8 T8 k0 }) V mcasp->regs->PDIR = 0x14000020; // All inputs except AXR0[5], ACLKX1, AFSX1
2 U& x" _; \; I# l' m# ]- B
: m' h0 @) s1 X+ J# ~ mcasp->regs->DITCTL = 0x00000000; // Not used" Q; S4 a* C, w5 O; Q f( [! `! u
mcasp->regs->DLBCTL = 0x00000000; // Not used
+ j) K' f1 x: U$ }' T+ O mcasp->regs->AMUTE = 0x00000000; // Not used
& h5 c/ O6 j3 ]9 @) b. v7 R# t
$ ^$ c5 G+ B/ J( G# O7 K/* Starting sections of the McASP*/; d( L% t$ f+ z
mcasp->regs->XGBLCTL |= GBLCTL_XHCLKRST_ON;
& ]! w6 X2 a4 `" _" ~' `! B# z0 ? while ( ( mcasp->regs->XGBLCTL & GBLCTL_XHCLKRST_ON ) != GBLCTL_XHCLKRST_ON ); % W8 b. n: p( C& c0 D0 Y
mcasp->regs->RGBLCTL |= GBLCTL_RHCLKRST_ON;
! Z! V" U* M. _1 F while ( ( mcasp->regs->RGBLCTL & GBLCTL_RHCLKRST_ON ) != GBLCTL_RHCLKRST_ON );
7 B9 E% |0 B+ v. ]' d; ?3 T* n
t" O( O' K Y( D& I: I7 m mcasp->regs->XGBLCTL |= GBLCTL_XCLKRST_ON;
* i: W4 D! |: { n0 P# i while ( ( mcasp->regs->XGBLCTL & GBLCTL_XCLKRST_ON ) != GBLCTL_XCLKRST_ON );
) l5 d1 N1 R2 _8 {( b mcasp->regs->RGBLCTL |= GBLCTL_RCLKRST_ON; . O% Y- M6 |: @- r" J y/ U
while ( ( mcasp->regs->RGBLCTL & GBLCTL_RCLKRST_ON ) != GBLCTL_RCLKRST_ON );
) }* o0 _! w! C" h* z' u7 ~9 |/ P; I3 L: H2 L u0 S1 L( X
mcasp->regs->XSTAT = 0x0000ffff;
q3 h0 w7 l y mcasp->regs->RSTAT = 0x0000ffff;
( L9 _7 p' d V* [6 @2 N: ^5 {' K/ U
mcasp->regs->XGBLCTL |= GBLCTL_XSRCLR_ON;
) Y8 N* J' [$ H- k6 e D while ( ( mcasp->regs->XGBLCTL & GBLCTL_XSRCLR_ON ) != GBLCTL_XSRCLR_ON );/ c( i1 Q, T; P9 r) T L$ P5 i
mcasp->regs->RGBLCTL |= GBLCTL_RSRCLR_ON; 0 s/ f( D8 b' N
while ( ( mcasp->regs->RGBLCTL & GBLCTL_RSRCLR_ON ) != GBLCTL_RSRCLR_ON );3 ^: M$ G; M; D) o% A M1 Y
! E( h o1 S' _( [% D0 O /* Write a 0, so that no underrun occurs after releasing the state machine */
! X i; M/ G8 [0 X2 X! b mcasp->regs->XBUF5 = 0;
" K0 ~$ \' n2 y5 i7 w mcasp->regs->RBUF0 = 0;. i; T4 S6 s& d
: X! \$ u, E8 j- |+ s; f( s
mcasp->regs->XGBLCTL |= GBLCTL_XSMRST_ON; # i; f$ ~# d* @3 f8 k
while ( ( mcasp->regs->XGBLCTL & GBLCTL_XSMRST_ON ) != GBLCTL_XSMRST_ON );
5 W }3 c4 r! A. X$ a4 P mcasp->regs->RGBLCTL |= GBLCTL_RSMRST_ON;
2 U b& k' \7 |/ g* O( M' z while ( ( mcasp->regs->RGBLCTL & GBLCTL_RSMRST_ON ) != GBLCTL_RSMRST_ON );* Y7 a2 z/ S) e9 h5 f' c
/ J' a2 x# u' y0 J" j mcasp->regs->XGBLCTL |= GBLCTL_XFRST_ON; 2 V7 D, y8 I" G7 N% Q8 S" L
while ( ( mcasp->regs->XGBLCTL & GBLCTL_XFRST_ON ) != GBLCTL_XFRST_ON );
c9 N0 X+ B7 i# \5 n9 C mcasp->regs->RGBLCTL |= GBLCTL_RFRST_ON;
$ z2 w; Y7 ^# {- N) _! [ while ( ( mcasp->regs->RGBLCTL & GBLCTL_RFRST_ON ) != GBLCTL_RFRST_ON );
( a, r: q0 K4 M J* ]4 J8 _7 R2 M# e0 G9 G1 v0 z
CSR = 0x0000;3 d3 n$ @1 d/ `2 b+ q
INTC_INTMUX1 = 0x3d;2 H b: I; d: j- _, d L; p
ISTP = (unsigned int)vectors;/ l0 S" P1 v7 c
ICR = 0xFFF0;
' h2 Y, v- n. r# ?/ f4 ^ IER |= 0x12;
9 R( a5 x2 | d e/ |/ l% K% x' Y+ K/ Y CSR |= 0x01; 8 N* V% E$ y1 G
* C/ E8 I: Y/ u9 j$ D7 h6 I4 {- \7 w2 ?4 e3 y: j" [1 h+ F
: r9 B9 s2 T" y) ?4 Q+ H- L
还有就是两个输入输出函数:3 E1 B- O! Y+ O% U a" K" I
void output_sample(Int32 out_data)
4 o* U0 c: l% Q# N/ y @; }: x{
7 J# s1 e; Z5 y) v5 @7 M2 Y3 w6 S AIC31_data.uint = out_data; 1 P( P% c2 R9 P" y( F/ U X
MCASP1_XBUF5_32BIT = AIC31_data.uint;
1 d0 B0 y2 U9 u1 h4 K5 `% X1 M}! U4 Z+ E c9 D4 O7 E0 j7 h
7 Z3 M& R. Y. TInt32 input_sample(void)3 U7 ?7 _. L- k. e
{
0 M5 u, k# s* c: w& @7 F( @' d AIC31_data.uint = MCASP1_RBUF0_32BIT;* k, p) e" w# ]( f) l
return (AIC31_data.uint);4 g) U% I6 s+ c4 w- ? L$ T, Q, g
}5 C( h% y' }# {: a
g+ i. ?8 u4 z$ j/ r' D6 e- ` |
|