|
|
C6747和C6748感觉差不多,我想实现McASP发送中断方式控制音频信号,在轮询的例程基础上改的,轮询程序可以实现,但是中断一直实现不了,也找不到错误,求大神帮忙!下边是主要程序:/ x9 V0 c8 ~; H" D
main文件:5 Y- y8 I% l- q( ]1 J# N) ~7 ^
interrupt void interrupt4(void)
# Q4 ?3 j J& \{4 J9 ~( I% s4 M
Uint32 sample;
# m, z% R3 y. h% J6 H: f, y- J
1 }8 I; F$ C: V( m3 Z sample = input_sample(); // read L + R samples from ADC5 h' `! b$ P; ]. N4 P
output_sample(sample); // write L + R samples to DAC
' H* N+ G1 y7 w1 C# `, X4 Z return;( O. \. R; W5 C: A2 W' c
}
4 u8 x* E i4 f2 w. _6 d( _1 D6 v7 K
int main( void )8 M: O+ D% c7 Z. a, q
{* v: O) J: X, r* \2 T
3 i4 e# b- F4 R) @) O3 W
/* Initialize BSL */
4 p8 M$ P6 \$ E* D3 L+ n EVMC6747_init( );! L5 _8 M# W( j: `+ A& g# p
/* Call evmc6747_intr function */
0 a: K( Y) V4 [- a+ s L2 y0 e/ L aic3106_init( );$ V# y m+ G7 E' s
while(1);
3 ]& A' [0 ~+ E6 Z" B3 l; W: O}; h O- _ A8 T4 V& Y& c: W, W
/ c# Z1 H0 Y. C& s/ D0 i
2 T# L Y" p, _5 e' P
aic3106_init文件的一部分,McASP配置部分,采用内部时钟,I2S方式,同步传输。音频芯片的配置应该没问题
v( v7 K- w3 T# a4 w/* Initialize MCASP1 */8 j7 O) t) ^0 _% o
mcasp = &MCASP_MODULE_1;8 Y0 Z+ K7 M8 c( i
mcasp->regs->GBLCTL = 0; // Reset y5 C) w7 _1 u/ g, }6 Q
mcasp->regs->RGBLCTL = 0; // Reset RX
6 [. i5 x4 `! q; Z mcasp->regs->XGBLCTL = 0; // Reset TX8 e9 Z7 a5 O" T$ W3 w# V/ _+ e
mcasp->regs->PWRDEMU = 1; // Free-running
) z& d5 E r, H1 a // configure McASP0 receive registers! P: u2 }/ S" H; h
mcasp->regs->RMASK = 0xFFFFFFFF; // No padding used
5 R6 |9 K8 f) I5 s mcasp->regs->RFMT = 0x00018078; // MSB 16bit, 0-delay, no pad, CFGBus
) y; @* D- B7 \- k6 t. q mcasp->regs->AFSRCTL = 0x00000112; // 2TDM, 1bit Falling, External FS, word
/ `: w) K$ W0 |9 Q) g mcasp->regs->ACLKRCTL = 0x000000AF; // Rising INTERNAL CLK,(from tx side)
) C; j/ H6 r6 z$ C mcasp->regs->AHCLKRCTL = 0x00000000; // INT CLK (from tx side); r4 n4 V' [ V. V" |6 I: Q
mcasp->regs->RTDM = 0x00000003; // Slots 0,19 l- N/ n( X1 [/ e& ?; U2 [) M
mcasp->regs->RINTCTL = 0x00000000; // Not used
; H1 N, n9 ]! t& u3 [ D! ^ mcasp->regs->RCLKCHK = 0x00FF0008; // 255-MAX 0-MIN, div-by-256% f4 U! ^. E3 `% R
7 _( V x! s( {" d
mcasp->regs->XMASK = 0xFFFFFFFF; // No padding used# j7 n; s: F3 b# l9 p8 l$ U& V' f
mcasp->regs->XFMT = 0x00018078; // MSB 16bit, 0-delay, no pad, CFGBus1 `0 q- k+ \4 B4 Z2 e2 g
mcasp->regs->AFSXCTL = 0x00000112; // 2TDM, 1bit Rising edge INTERNAL FS, word( ^: c( h( h8 Q
mcasp->regs->ACLKXCTL = 0x000000AF; // ASYNC, Rising INTERNAL CLK, div-by-16
- z/ C3 f5 v# @* u, Y mcasp->regs->AHCLKXCTL = 0x00000000; // EXT CLK
" M$ k) F: r; U0 s# j2 i mcasp->regs->XTDM = 0x00000003; // Slots 0,1
' m# K* |# g4 u8 X; B! c! G mcasp->regs->XINTCTL = 0x00000020; // interrupt on transmit
K" z: r' v# m" x! K mcasp->regs->XCLKCHK = 0x00FF0008; // 255-MAX 0-MIN, div-by-2565 s/ e) z; t+ \' O8 Q Q# k, E
$ h! [1 g- \+ v" y% G# r mcasp->regs->SRCTL5 = 0x000D; // MCASP1.AXR1[5] --> DIN
, a* D+ u1 p; ~2 W mcasp->regs->SRCTL0 = 0x000E; // MCASP1.AXR1[0] <-- DOUT
7 y) \0 u, ]3 b& l3 _7 [, n mcasp->regs->PFUNC = 0; // All MCASPs
8 _9 I0 k5 Q! n) J. f mcasp->regs->PDIR = 0x14000020; // All inputs except AXR0[5], ACLKX1, AFSX1
# \5 l) w. v3 N7 G1 T0 |* y- M$ X: c8 o$ J# W
mcasp->regs->DITCTL = 0x00000000; // Not used
8 E, D, x! @ W mcasp->regs->DLBCTL = 0x00000000; // Not used9 y9 S$ ?4 o6 P
mcasp->regs->AMUTE = 0x00000000; // Not used
: X, q# s! L3 a, ~' C( E; M$ p! o/ r( X0 c
/* Starting sections of the McASP*/' V f, X5 \" Q) ^5 R
mcasp->regs->XGBLCTL |= GBLCTL_XHCLKRST_ON; 5 r$ v+ Y, z6 E: f3 t9 J7 g" N0 W
while ( ( mcasp->regs->XGBLCTL & GBLCTL_XHCLKRST_ON ) != GBLCTL_XHCLKRST_ON );
, V z9 Z. d$ ^3 f8 l6 Z mcasp->regs->RGBLCTL |= GBLCTL_RHCLKRST_ON;
* l* h6 q) z' ? N) m% j" d1 @- z while ( ( mcasp->regs->RGBLCTL & GBLCTL_RHCLKRST_ON ) != GBLCTL_RHCLKRST_ON );
; o U, Q3 x& R9 Y8 v8 ?
: b9 l1 Z' L) i$ e( G3 `% v. l mcasp->regs->XGBLCTL |= GBLCTL_XCLKRST_ON;
, C& v# p) v" J3 v' R while ( ( mcasp->regs->XGBLCTL & GBLCTL_XCLKRST_ON ) != GBLCTL_XCLKRST_ON );
' J0 S7 N3 e" m/ b* u, _' I: Y mcasp->regs->RGBLCTL |= GBLCTL_RCLKRST_ON;
9 K5 t' A% c4 i+ B2 d# f! G while ( ( mcasp->regs->RGBLCTL & GBLCTL_RCLKRST_ON ) != GBLCTL_RCLKRST_ON );! s1 U' F8 _. e! A b4 P% _
* b& D3 a* |( ?. [9 _' Q3 K
mcasp->regs->XSTAT = 0x0000ffff; # C. u8 P" k7 f3 O! Z
mcasp->regs->RSTAT = 0x0000ffff;
( u. m$ u1 V3 ~3 z3 x M: J) T0 I9 E8 Q) e5 r" n$ I. {% |
mcasp->regs->XGBLCTL |= GBLCTL_XSRCLR_ON;
! i A3 L$ a4 T4 H4 K) r while ( ( mcasp->regs->XGBLCTL & GBLCTL_XSRCLR_ON ) != GBLCTL_XSRCLR_ON );
. @7 o1 ^1 F, `" {7 V* F1 Y4 q mcasp->regs->RGBLCTL |= GBLCTL_RSRCLR_ON;
\% N C. g' ]* z; x while ( ( mcasp->regs->RGBLCTL & GBLCTL_RSRCLR_ON ) != GBLCTL_RSRCLR_ON );
: q' w1 h1 S. E6 y) [ R& e) _2 _7 a: H4 I# e
/* Write a 0, so that no underrun occurs after releasing the state machine */, S) y* o3 s0 y6 s' P: l
mcasp->regs->XBUF5 = 0;
, k+ o7 Z( e- u2 H$ o. | mcasp->regs->RBUF0 = 0;
9 F& h; j% }" \. p* ]# n
1 |4 V& Q0 X+ E8 c! Q/ Q mcasp->regs->XGBLCTL |= GBLCTL_XSMRST_ON; * N' a& C. h5 C, a1 w0 T
while ( ( mcasp->regs->XGBLCTL & GBLCTL_XSMRST_ON ) != GBLCTL_XSMRST_ON );' \8 m) x0 P4 a7 n+ H+ o$ j
mcasp->regs->RGBLCTL |= GBLCTL_RSMRST_ON;
6 z7 T* Y0 r* R* B2 [ while ( ( mcasp->regs->RGBLCTL & GBLCTL_RSMRST_ON ) != GBLCTL_RSMRST_ON );' V5 Z; W, _% f5 H9 u3 V
0 j" h" V" g& G$ b& f6 [ mcasp->regs->XGBLCTL |= GBLCTL_XFRST_ON; 2 b% T' I; Q! O5 K2 Z
while ( ( mcasp->regs->XGBLCTL & GBLCTL_XFRST_ON ) != GBLCTL_XFRST_ON );
, Z4 R, x( w7 w4 d5 O$ b' Z5 S mcasp->regs->RGBLCTL |= GBLCTL_RFRST_ON;
8 x1 u5 r# O9 ~ z while ( ( mcasp->regs->RGBLCTL & GBLCTL_RFRST_ON ) != GBLCTL_RFRST_ON );9 b: C1 h- k9 W! ]
( A7 s" N" a$ q6 j( k5 j4 K) p# @) o CSR = 0x0000;
3 H; J+ e4 r% e# R; I INTC_INTMUX1 = 0x3d;: ?; U, T' P$ n. m o
ISTP = (unsigned int)vectors;
2 r( P) _: p* B' J/ L ICR = 0xFFF0;
4 `3 ]* E; f. x. B7 g5 r' q IER |= 0x12; * j2 Y- [% ], h& K
CSR |= 0x01;
* R. [, N' h: X- T, T5 T8 d9 T; g, Y9 k8 @
: c8 V7 H. C: l! L' H$ z
) Z& _8 m; o) B- p: c$ ~还有就是两个输入输出函数:! u3 a* ^* H4 w* i5 Q
void output_sample(Int32 out_data)* M7 J: j5 u1 C7 O" q6 @
{" F! F# z* O; k/ {& G
AIC31_data.uint = out_data;
; `* G' M$ P6 a) N. @: W MCASP1_XBUF5_32BIT = AIC31_data.uint;
8 e9 U2 D$ k& f* p) _; p9 M! f7 I9 Y}
$ L- ?. X* Y. u% z7 M! I" v7 x! M2 ~- Q, b+ R& y
Int32 input_sample(void)' X- r" A6 ?* L) @- P" j/ H6 ^1 N; T
{ ?' O8 U9 ~, W. A
AIC31_data.uint = MCASP1_RBUF0_32BIT;
/ \7 I# f1 Z/ M% l q, V$ M, C Y return (AIC31_data.uint);+ P+ v% k$ N L+ L; X3 N
}
2 e+ Z! k' h: Y* V6 x" b8 ]. _! ^0 H5 d* E+ j. ^8 o* ?+ f; q, E
|
|