|
|
C6747和C6748感觉差不多,我想实现McASP发送中断方式控制音频信号,在轮询的例程基础上改的,轮询程序可以实现,但是中断一直实现不了,也找不到错误,求大神帮忙!下边是主要程序:2 Q1 _3 r5 T# E$ {3 x1 }
main文件:9 Y" a; m- _$ Z+ l% n1 v
interrupt void interrupt4(void)
* z( U1 R8 w" j5 ~{: h. @4 y) c3 i) f9 F" {, C
Uint32 sample;1 {! N, P7 w" P
3 f7 p! M9 {1 \
sample = input_sample(); // read L + R samples from ADC4 _% d W+ B/ `; W. P% |
output_sample(sample); // write L + R samples to DAC
: s: z1 K8 U& _- h1 X9 B5 k return;
6 w9 p; E' D1 ]/ u* w: u0 ?* j}
+ l- k; M# ?* W9 i$ U Z
+ O! z4 C1 @& P# ?int main( void ): _+ v. P! |4 y9 j1 S
{
! {8 E' h5 x! F! @2 a* h* _( H
- z5 C) L" ]4 k$ Q) V7 } /* Initialize BSL */
9 ]& B1 v# \/ s) V: G EVMC6747_init( );2 w5 U8 Q4 W& f! Q4 Y; u `
/* Call evmc6747_intr function */
% u1 O. k# A9 W aic3106_init( );
, t& {5 e' U# K) l while(1);
8 |- p* G6 G% Q}2 k: P, S0 g+ ?9 ~" V, W
" z) E, X( T; K9 ^% x) i% b; E4 S- P# G
aic3106_init文件的一部分,McASP配置部分,采用内部时钟,I2S方式,同步传输。音频芯片的配置应该没问题* o# R3 [. I' }9 b Q
/* Initialize MCASP1 */ i$ ?% s9 ? X+ y( g
mcasp = &MCASP_MODULE_1;
0 w3 O3 b* X, y3 c7 W* b mcasp->regs->GBLCTL = 0; // Reset
6 k3 z8 }9 {: ~) M mcasp->regs->RGBLCTL = 0; // Reset RX- V$ t1 \- s7 T. a; m: O5 t$ O
mcasp->regs->XGBLCTL = 0; // Reset TX! I$ h) M9 e' c; Q1 S
mcasp->regs->PWRDEMU = 1; // Free-running
7 K( W. _/ v: ]' X // configure McASP0 receive registers- u3 ]2 @. m& z9 I4 V0 x- F: P
mcasp->regs->RMASK = 0xFFFFFFFF; // No padding used4 g2 L* x" C& v4 Q5 J
mcasp->regs->RFMT = 0x00018078; // MSB 16bit, 0-delay, no pad, CFGBus2 l0 V1 @" W5 L4 N, `- P, R
mcasp->regs->AFSRCTL = 0x00000112; // 2TDM, 1bit Falling, External FS, word
# S/ j( y& @+ |4 i- F mcasp->regs->ACLKRCTL = 0x000000AF; // Rising INTERNAL CLK,(from tx side)! U/ c5 `/ K& J' s' Q- t ^, u/ G$ a1 e
mcasp->regs->AHCLKRCTL = 0x00000000; // INT CLK (from tx side), u+ m6 ?* Z0 e+ P/ p) ~7 Q6 H
mcasp->regs->RTDM = 0x00000003; // Slots 0,1+ _; o% `. _" d1 u1 `
mcasp->regs->RINTCTL = 0x00000000; // Not used
( e, y& o0 |2 m3 P! i/ Z6 { mcasp->regs->RCLKCHK = 0x00FF0008; // 255-MAX 0-MIN, div-by-256
: s# f, y) S/ e' W2 ~' n
- F2 \( @6 X% N" [" ~3 y mcasp->regs->XMASK = 0xFFFFFFFF; // No padding used* C/ M! p4 b) c
mcasp->regs->XFMT = 0x00018078; // MSB 16bit, 0-delay, no pad, CFGBus5 c+ F- C5 }; P( b" `( l
mcasp->regs->AFSXCTL = 0x00000112; // 2TDM, 1bit Rising edge INTERNAL FS, word# m4 l0 a) _6 ]
mcasp->regs->ACLKXCTL = 0x000000AF; // ASYNC, Rising INTERNAL CLK, div-by-16
% M8 V! K* w8 N0 m mcasp->regs->AHCLKXCTL = 0x00000000; // EXT CLK' M% _) b, n. \; M# i" P
mcasp->regs->XTDM = 0x00000003; // Slots 0,1
. Y5 ~( h* H# j: B mcasp->regs->XINTCTL = 0x00000020; // interrupt on transmit
% J$ ^4 g3 \& y( T1 K+ u9 s mcasp->regs->XCLKCHK = 0x00FF0008; // 255-MAX 0-MIN, div-by-256$ ?; w% ?0 e) w
' n4 ?9 ]. N5 P
mcasp->regs->SRCTL5 = 0x000D; // MCASP1.AXR1[5] --> DIN' ^& d! h y5 H6 q2 s9 C
mcasp->regs->SRCTL0 = 0x000E; // MCASP1.AXR1[0] <-- DOUT
/ Q B; H6 ?8 H mcasp->regs->PFUNC = 0; // All MCASPs
. m4 g6 R3 }2 A/ q" R1 i' O7 O mcasp->regs->PDIR = 0x14000020; // All inputs except AXR0[5], ACLKX1, AFSX1
9 H3 j% v& B1 }4 z9 y: Q6 @$ t
& y6 T" k+ L$ n. P mcasp->regs->DITCTL = 0x00000000; // Not used
8 E5 z- u& p# k+ D mcasp->regs->DLBCTL = 0x00000000; // Not used& a; _3 f4 o) l* W: k# l4 y0 w) Q
mcasp->regs->AMUTE = 0x00000000; // Not used2 V5 O/ Z3 L z5 P9 X. d! r- K; e- W
, P7 k0 O0 M2 e8 n8 x3 o& b2 t% F9 n/* Starting sections of the McASP*/
; l1 n6 _" Z, I& o/ h" ] mcasp->regs->XGBLCTL |= GBLCTL_XHCLKRST_ON; $ M3 Y* W8 W% J" A) s$ o, W& y
while ( ( mcasp->regs->XGBLCTL & GBLCTL_XHCLKRST_ON ) != GBLCTL_XHCLKRST_ON );
- w! M* q) z$ L: z { mcasp->regs->RGBLCTL |= GBLCTL_RHCLKRST_ON;
5 X) B k2 V5 N B- ]7 s, ~ while ( ( mcasp->regs->RGBLCTL & GBLCTL_RHCLKRST_ON ) != GBLCTL_RHCLKRST_ON );- f( ~1 n, [3 c) H6 n) \( j
* H% R1 {0 n! |6 w: L7 L, l
mcasp->regs->XGBLCTL |= GBLCTL_XCLKRST_ON; ' y! `5 P* y6 @9 X. F0 b2 z
while ( ( mcasp->regs->XGBLCTL & GBLCTL_XCLKRST_ON ) != GBLCTL_XCLKRST_ON );
' Z) h% y N$ b% R mcasp->regs->RGBLCTL |= GBLCTL_RCLKRST_ON; % \7 ]( x& @' h3 a( O0 M# n
while ( ( mcasp->regs->RGBLCTL & GBLCTL_RCLKRST_ON ) != GBLCTL_RCLKRST_ON );
# }" e4 C; E. ~% i* j7 }
6 N7 m6 D& { x5 f mcasp->regs->XSTAT = 0x0000ffff; N" C. m2 r, h$ f6 Z" X6 `
mcasp->regs->RSTAT = 0x0000ffff; " l% I) ]) A# n" m0 t
$ L9 f; @5 r4 X# s. O mcasp->regs->XGBLCTL |= GBLCTL_XSRCLR_ON;+ M6 f0 ^) ^ N+ Z) Q
while ( ( mcasp->regs->XGBLCTL & GBLCTL_XSRCLR_ON ) != GBLCTL_XSRCLR_ON );
+ n. } s& l6 l7 a mcasp->regs->RGBLCTL |= GBLCTL_RSRCLR_ON; 5 J' Q' v8 J" w
while ( ( mcasp->regs->RGBLCTL & GBLCTL_RSRCLR_ON ) != GBLCTL_RSRCLR_ON );
: }8 R& s& p& y; k( } _8 h& i q7 N8 t8 Z; i$ g2 c& v" H. s
/* Write a 0, so that no underrun occurs after releasing the state machine */
2 P7 q) w7 Z3 R/ h$ z. ^8 P: y) F mcasp->regs->XBUF5 = 0;
+ [0 K: C6 y* j& i2 I8 p mcasp->regs->RBUF0 = 0;" S3 L& B9 h' [% _& [
, N( z$ w6 m. A" M7 x
mcasp->regs->XGBLCTL |= GBLCTL_XSMRST_ON;
3 M: D, t1 R y/ s$ x3 r* t0 |2 m while ( ( mcasp->regs->XGBLCTL & GBLCTL_XSMRST_ON ) != GBLCTL_XSMRST_ON );# Z* p7 V; Z9 K/ L
mcasp->regs->RGBLCTL |= GBLCTL_RSMRST_ON; + R. u8 |4 b- K% ^. J/ X
while ( ( mcasp->regs->RGBLCTL & GBLCTL_RSMRST_ON ) != GBLCTL_RSMRST_ON );& R2 Y7 |: g/ s4 A t; @; C- m
$ g% d7 ?1 I% @9 r
mcasp->regs->XGBLCTL |= GBLCTL_XFRST_ON;
& N9 E- Y: S9 g6 i) Z2 q$ K while ( ( mcasp->regs->XGBLCTL & GBLCTL_XFRST_ON ) != GBLCTL_XFRST_ON );9 W4 ?& {. I; I
mcasp->regs->RGBLCTL |= GBLCTL_RFRST_ON;
( F; b$ e) ~! c* q; P. P* D5 b while ( ( mcasp->regs->RGBLCTL & GBLCTL_RFRST_ON ) != GBLCTL_RFRST_ON );
& B& C- S( D' _ k1 R8 P8 ~0 O+ t6 H ]+ @( ~7 [7 l$ a4 X9 |2 }1 j
CSR = 0x0000;5 ?& C4 T8 K. h( c4 |; c2 X
INTC_INTMUX1 = 0x3d;
1 x' B$ ]* L! R3 ~4 i ISTP = (unsigned int)vectors;: _' M9 g7 X" R9 k
ICR = 0xFFF0; $ C+ t" O7 m& _/ B
IER |= 0x12; % }8 }3 A% A8 y" j
CSR |= 0x01;
% n) A, E" g$ |4 ^5 t5 l; e- y. Q/ f, Z# s
' N ^3 `- s7 L6 ^' A/ ?
) h# d7 J. p7 c* y; ~* y还有就是两个输入输出函数:
: O1 B5 N) A- n, } A- `9 yvoid output_sample(Int32 out_data)
5 \; ~- v$ M0 B3 ]{
5 f) Z. y$ Y4 J$ D& U AIC31_data.uint = out_data; * c3 E# f- J" b$ u/ \: r4 ]- H
MCASP1_XBUF5_32BIT = AIC31_data.uint;
: P w4 m& I2 C) r1 d& |7 n}
6 [- U4 [9 d# e/ ~# \$ w- \6 `# w: s5 B# m1 G7 R
Int32 input_sample(void)3 M: r+ V# l6 G
{
8 b3 n/ K% V" @6 W M; j AIC31_data.uint = MCASP1_RBUF0_32BIT;
; p0 T6 a: Q- B return (AIC31_data.uint);
+ P, a* ~/ D/ T/ F}
0 Z& }( m6 P7 q8 s4 }2 \0 V5 x& @) V m( _; A8 M4 ^6 c) r
|
|