嵌入式开发者社区

标题: C6747利用McASP发送中断方式完成音频输入信号的直接输出 [打印本页]

作者: yusijiangchengm    时间: 2016-3-15 16:07
标题: C6747利用McASP发送中断方式完成音频输入信号的直接输出
C6747和C6748感觉差不多,我想实现McASP发送中断方式控制音频信号,在轮询的例程基础上改的,轮询程序可以实现,但是中断一直实现不了,也找不到错误,求大神帮忙!下边是主要程序:
" ^* k: b, X5 R& j% }" R/ Xmain文件:
2 |$ n0 l4 h9 \) `- vinterrupt void interrupt4(void)  + ^) l+ H7 ?& n- t6 s8 y
{$ R2 |) D" i/ W3 m4 Y' j$ j
  Uint32 sample;, Q1 v% o1 |2 {' J- ?
4 b. B- F' ^1 f
  sample = input_sample(); // read L + R samples from ADC
! R: S' e. h) C8 p% t  output_sample(sample);   // write L + R samples to DAC
) }/ V% K) t0 a1 d! X  return;% a1 s) _. T; D" C( k4 u6 _: q4 ]+ L
}: w5 D" n* T1 r( a& ~- [

3 Z9 I% U* @0 E3 Aint main( void )
5 l; I$ D, f8 j- d{! q& e, W0 Z- j; Z( O. {( p

. h7 [  s8 Z# y4 I( @    /* Initialize BSL */- ?' L" r7 ^6 W* \$ l4 ?
    EVMC6747_init( );' _$ R( U6 D8 V  u9 D# a
        /* Call evmc6747_intr function */
8 D& [: \& X. c    aic3106_init( );5 I( ^# e: N' c1 r' K
        while(1);% |; n( ?+ F+ V* z/ s: w( Y
}. z" Q% G2 w2 f4 A' U. _
3 n$ t- y& e; g' d; {4 A
+ A! W4 l9 F: j6 L: a$ g; E
aic3106_init文件的一部分,McASP配置部分,采用内部时钟,I2S方式,同步传输。音频芯片的配置应该没问题" g3 U: f1 u4 [8 q9 v$ x3 m
/* Initialize MCASP1 */
. M7 o1 H! p$ x3 j' N- T    mcasp = &MCASP_MODULE_1;7 F1 N; C3 C' Z; C7 S/ G( k
    mcasp->regs->GBLCTL  = 0;       // Reset
5 q0 j2 y. H+ u% v7 A0 G6 G$ o. }% P. n    mcasp->regs->RGBLCTL = 0;       // Reset RX3 a: e7 `4 I( y
    mcasp->regs->XGBLCTL = 0;       // Reset TX
! Z* d2 R2 o; y) I! x8 M/ s1 O    mcasp->regs->PWRDEMU = 1;       // Free-running
! _5 y2 ~! M/ P, m' |( Z1 @* W   // configure McASP0 receive registers1 j+ J; t2 b: N
    mcasp->regs->RMASK      = 0xFFFFFFFF; // No padding used
3 O& a" ~# o; [: m    mcasp->regs->RFMT       = 0x00018078; // MSB 16bit, 0-delay, no pad, CFGBus
6 l$ r: Y, V; s/ y    mcasp->regs->AFSRCTL    = 0x00000112; // 2TDM, 1bit Falling, External FS, word2 u1 e) D9 P- t
    mcasp->regs->ACLKRCTL   = 0x000000AF; // Rising INTERNAL CLK,(from tx side)
4 X1 i0 i: d, f4 C/ Z* O3 ?- u    mcasp->regs->AHCLKRCTL  = 0x00000000; // INT CLK (from tx side)
4 N+ s$ j2 P) ]' h5 Y    mcasp->regs->RTDM       = 0x00000003; // Slots 0,1
& S- Y) A& Q; t2 h; O    mcasp->regs->RINTCTL    = 0x00000000; // Not used
& Q% u' v# r9 s, M. }) n    mcasp->regs->RCLKCHK    = 0x00FF0008; // 255-MAX 0-MIN, div-by-256
6 |$ H9 {, K8 G& W& x/ o, L0 z. j0 J' S+ s$ Y8 D+ r
    mcasp->regs->XMASK      = 0xFFFFFFFF; // No padding used
  w# D& L$ r9 W( u. z    mcasp->regs->XFMT       = 0x00018078; // MSB 16bit, 0-delay, no pad, CFGBus
% L) _3 j" ?: S* y    mcasp->regs->AFSXCTL    = 0x00000112; // 2TDM, 1bit Rising edge INTERNAL FS, word
: u0 ^0 h- s, q' s    mcasp->regs->ACLKXCTL   = 0x000000AF; // ASYNC, Rising INTERNAL CLK, div-by-16
; d% G7 j6 B/ p' w, q7 t, L    mcasp->regs->AHCLKXCTL  = 0x00000000; // EXT CLK
/ h) h4 w) u) z* z' M% B- S+ [    mcasp->regs->XTDM       = 0x00000003; // Slots 0,1
7 E8 X  h, y" q' h    mcasp->regs->XINTCTL    = 0x00000020; // interrupt on transmit) R! R% B7 V1 \3 \( ?
    mcasp->regs->XCLKCHK    = 0x00FF0008; // 255-MAX 0-MIN, div-by-256
+ h1 _5 Z# H  C& o
, t9 `( l$ L( e' \7 w0 C+ I) ~, P    mcasp->regs->SRCTL5     = 0x000D;     // MCASP1.AXR1[5] --> DIN# D2 L1 m. A) P3 P- j; c6 a% c
    mcasp->regs->SRCTL0     = 0x000E;     // MCASP1.AXR1[0] <-- DOUT
- \: m: Q2 G( @# `& j% [% g    mcasp->regs->PFUNC      = 0;          // All MCASPs
$ u- T4 E; b4 P; N+ m$ O0 K    mcasp->regs->PDIR       = 0x14000020; // All inputs except AXR0[5], ACLKX1, AFSX1
+ ?0 T4 `1 y: u- r6 X7 ]3 D! F  ^1 |+ O" r' \) |  c8 k
    mcasp->regs->DITCTL     = 0x00000000; // Not used' z, g& @1 ^: G, }* \: {
    mcasp->regs->DLBCTL     = 0x00000000; // Not used
1 V% j+ [. }$ I; y+ m6 B    mcasp->regs->AMUTE      = 0x00000000; // Not used/ K; P# p5 Z4 `
2 g2 H, y9 Y$ @/ N( e; E3 y( Y
/* Starting sections of the McASP*/- S  b3 j* s$ S5 J/ ^* l
    mcasp->regs->XGBLCTL |= GBLCTL_XHCLKRST_ON; 7 C# ^  `' v) C1 q5 y
    while ( ( mcasp->regs->XGBLCTL & GBLCTL_XHCLKRST_ON ) != GBLCTL_XHCLKRST_ON );  
& J; G/ R' t' W# K    mcasp->regs->RGBLCTL |= GBLCTL_RHCLKRST_ON; . G+ w+ d6 x& Z9 {8 w+ M
    while ( ( mcasp->regs->RGBLCTL & GBLCTL_RHCLKRST_ON ) != GBLCTL_RHCLKRST_ON );
- k$ O5 ~( J2 Z8 G6 g' e
  l. {% s, ^/ K' I5 ?$ B( j+ ^    mcasp->regs->XGBLCTL |= GBLCTL_XCLKRST_ON;
& @+ \; `. G& l& {) \, {    while ( ( mcasp->regs->XGBLCTL & GBLCTL_XCLKRST_ON ) != GBLCTL_XCLKRST_ON );
; G7 x6 X! b" U# W. B4 w2 I    mcasp->regs->RGBLCTL |= GBLCTL_RCLKRST_ON;
4 t) j: }( B. \    while ( ( mcasp->regs->RGBLCTL & GBLCTL_RCLKRST_ON ) != GBLCTL_RCLKRST_ON );
( k4 n+ t5 u( A4 e. M
) O" e8 j$ }3 `4 n, ^  u    mcasp->regs->XSTAT = 0x0000ffff;
: x6 d, H* U9 G4 l    mcasp->regs->RSTAT = 0x0000ffff; - T) y3 E" ?3 M
- g1 w( O% n+ O* J3 g( ^" p: T
    mcasp->regs->XGBLCTL |= GBLCTL_XSRCLR_ON;8 b1 X% h" {( @
    while ( ( mcasp->regs->XGBLCTL & GBLCTL_XSRCLR_ON ) != GBLCTL_XSRCLR_ON );9 g4 }; z' Z1 ~
    mcasp->regs->RGBLCTL |= GBLCTL_RSRCLR_ON;
% |3 y+ `# }3 q: C    while ( ( mcasp->regs->RGBLCTL & GBLCTL_RSRCLR_ON ) != GBLCTL_RSRCLR_ON );1 y5 T- Q( W7 `, {7 W

: D) T) y( ~5 \# j/ C    /* Write a 0, so that no underrun occurs after releasing the state machine */
; H* J( X+ Q: D    mcasp->regs->XBUF5 = 0;
# T# n; K' p; p/ r6 E    mcasp->regs->RBUF0 = 0;* X& H# {' J1 H. ]. z6 H3 [+ b
% A' e0 Q0 q- V6 {( ^& N. J7 j
    mcasp->regs->XGBLCTL |= GBLCTL_XSMRST_ON; ! g0 L! A9 o" j* p7 x( r6 ~. D+ i3 q0 F
    while ( ( mcasp->regs->XGBLCTL & GBLCTL_XSMRST_ON ) != GBLCTL_XSMRST_ON );- s7 A' ~: c0 M# N" q0 M1 K
    mcasp->regs->RGBLCTL |= GBLCTL_RSMRST_ON; 9 q/ Z3 q( F8 u; @& X. E& a' \: M
    while ( ( mcasp->regs->RGBLCTL & GBLCTL_RSMRST_ON ) != GBLCTL_RSMRST_ON );
/ S' j' Q( j( J; q8 S& Q# R" c# q0 ?
9 _$ W* D- F7 _! S+ P    mcasp->regs->XGBLCTL |= GBLCTL_XFRST_ON;
/ I6 _. Y+ p( t2 {; D    while ( ( mcasp->regs->XGBLCTL & GBLCTL_XFRST_ON ) != GBLCTL_XFRST_ON );
9 X3 [# `, y7 C    mcasp->regs->RGBLCTL |= GBLCTL_RFRST_ON;
* Q" ~* ^& Z; R    while ( ( mcasp->regs->RGBLCTL & GBLCTL_RFRST_ON ) != GBLCTL_RFRST_ON );
$ c, M2 }1 A6 `1 n" s- o- A9 ~% ], |  R/ Z
    CSR = 0x0000;6 \# ~# L% S5 ]* |' Z% m# w3 p
    INTC_INTMUX1 = 0x3d;
" E, x2 s( g5 [8 m5 ~4 G    ISTP = (unsigned int)vectors;' h* P( }9 C& Y9 D: O
    ICR = 0xFFF0;  
3 L$ K) U5 Q7 x' E6 C. Q2 R/ K# x    IER |= 0x12;  
6 _, @9 q0 ^% K  V6 P) n* B    CSR |= 0x01;  ) r- m% M1 m# L1 |. J, J) q: A. `
, o* `: y- K5 w9 n; h6 G

0 s8 `) C0 F. l% D- y" l/ p% q$ p7 R& b# m+ H: b* A
还有就是两个输入输出函数:
! j0 j: H# o" Y$ i1 T, a1 [- evoid output_sample(Int32 out_data)2 b9 ~8 _& z% y& Y& N2 d+ Y9 ]: {
{9 I0 [" J- @0 Z) H7 Y: I  D7 W* ~
  AIC31_data.uint = out_data;  ) K1 O& e: V3 u) L3 _. \- J
  MCASP1_XBUF5_32BIT = AIC31_data.uint;2 n# L, Q) D0 V/ p
}
+ B; F6 U' C) H
; A- [* P& ~8 j3 u/ }+ B8 oInt32 input_sample(void)
9 S( f+ [/ ~0 R/ d- |) b) l7 k{  ' T' H  h( I+ X% _' g
  AIC31_data.uint = MCASP1_RBUF0_32BIT;+ {$ ?& h# R, \& @! ?" k' Y
  return (AIC31_data.uint);
$ y, T; g3 ]& e6 Y2 G7 [( ], m}9 C' ]0 V: e' ]& v4 N: _/ Y/ n( e

* v9 i" z8 Z- b& C
作者: human    时间: 2016-3-16 11:55
可以参看创龙提供的例程:AUDIO_LINE_OUT_INTR——Line Out 音频输出(中断方式)




欢迎光临 嵌入式开发者社区 (https://www.51ele.net/) Powered by Discuz! X3.4