|
|
C6747和C6748感觉差不多,我想实现McASP发送中断方式控制音频信号,在轮询的例程基础上改的,轮询程序可以实现,但是中断一直实现不了,也找不到错误,求大神帮忙!下边是主要程序:
; M, v) J. {9 O1 W2 s: K+ Bmain文件:: z# X1 p1 o2 x+ L
interrupt void interrupt4(void)
. N! c: r/ O3 \# d{
+ W2 T$ D/ P9 x8 O Uint32 sample;: q0 l5 D) u/ \0 Q: L, T3 P* ~
/ i7 p8 [0 l3 ?! ^+ o0 M+ p sample = input_sample(); // read L + R samples from ADC2 e1 a+ X& _6 f t9 J9 Y3 X# ^4 c$ M
output_sample(sample); // write L + R samples to DAC
7 I5 O% F9 F8 |8 O' }/ x( y return;; [* }) C1 \; X, h
}
4 U) l0 N7 {: U! w+ S/ {
& @9 \ P1 v7 g( {int main( void )
' F5 v1 I* C. ?4 N- r' P{
4 n, q u! ~5 }* {: L, r% ]6 {* s' Y% w2 l9 p0 }. h" Y7 w: N
/* Initialize BSL */
) @ D% K9 K: H9 W1 c* ~" P" k EVMC6747_init( );0 r6 j4 A) W; z% _6 I- e
/* Call evmc6747_intr function */2 ~1 g; t- D/ j* K a+ t# h& |3 X% ]
aic3106_init( );
' _+ ~9 G, I7 Q5 y while(1);
- D, P8 m5 N. F0 M1 c4 o5 I}3 z+ T) A/ o2 N i- J4 B
. M6 o8 D6 H, |& x
( x" i" J) O8 i9 q& u" `aic3106_init文件的一部分,McASP配置部分,采用内部时钟,I2S方式,同步传输。音频芯片的配置应该没问题( s. c2 O- v. w9 K7 F* L
/* Initialize MCASP1 */* h- ?" i( W; k1 e! L. u! h" w% U
mcasp = &MCASP_MODULE_1;
! D* W8 L$ Y- f. m8 J mcasp->regs->GBLCTL = 0; // Reset
+ }# n* u( Y# d mcasp->regs->RGBLCTL = 0; // Reset RX
H' I, v7 E# h- i mcasp->regs->XGBLCTL = 0; // Reset TX- z* z5 n3 g$ g5 ~+ ]2 N
mcasp->regs->PWRDEMU = 1; // Free-running
( C+ i. ^6 K' d/ E+ o // configure McASP0 receive registers$ o) F9 i! Q* s2 E4 F4 w$ O d9 ?
mcasp->regs->RMASK = 0xFFFFFFFF; // No padding used
) m4 t* z; W) g1 e; q0 ~: p- v mcasp->regs->RFMT = 0x00018078; // MSB 16bit, 0-delay, no pad, CFGBus: n8 `4 p( _% D5 V+ ^
mcasp->regs->AFSRCTL = 0x00000112; // 2TDM, 1bit Falling, External FS, word
- z. s6 f8 ?( o4 B' c9 V mcasp->regs->ACLKRCTL = 0x000000AF; // Rising INTERNAL CLK,(from tx side). B( X% Q+ X' M9 O6 o. o( X n
mcasp->regs->AHCLKRCTL = 0x00000000; // INT CLK (from tx side)8 h6 }; f7 V% w0 Q. X( ]+ ]1 t5 I6 k4 {
mcasp->regs->RTDM = 0x00000003; // Slots 0,1( G2 v% K, V4 R. {
mcasp->regs->RINTCTL = 0x00000000; // Not used
$ P# N. I* @1 L% L" q+ C mcasp->regs->RCLKCHK = 0x00FF0008; // 255-MAX 0-MIN, div-by-2561 |2 c5 t1 P6 L8 X, |7 m2 W
, S, [ L4 N% X. m0 M7 x, w
mcasp->regs->XMASK = 0xFFFFFFFF; // No padding used; @; j7 ^1 \5 r w9 T7 i) V
mcasp->regs->XFMT = 0x00018078; // MSB 16bit, 0-delay, no pad, CFGBus1 D+ d9 O4 h$ K. i) s
mcasp->regs->AFSXCTL = 0x00000112; // 2TDM, 1bit Rising edge INTERNAL FS, word( S% F0 M( g, @! M4 o
mcasp->regs->ACLKXCTL = 0x000000AF; // ASYNC, Rising INTERNAL CLK, div-by-16
' B: |( { ?/ ^% u mcasp->regs->AHCLKXCTL = 0x00000000; // EXT CLK6 c3 f4 n$ ^# D2 D3 S- N3 {8 O
mcasp->regs->XTDM = 0x00000003; // Slots 0,19 i0 q" [8 F% v% P6 r7 l2 q
mcasp->regs->XINTCTL = 0x00000020; // interrupt on transmit
" G" @: ]/ q- I mcasp->regs->XCLKCHK = 0x00FF0008; // 255-MAX 0-MIN, div-by-256
% l% w) X3 F- n: C* s3 ~: v) E7 @# s" ~# m' \; y- Q5 W6 U
mcasp->regs->SRCTL5 = 0x000D; // MCASP1.AXR1[5] --> DIN8 F- F8 [' X* T( z3 x
mcasp->regs->SRCTL0 = 0x000E; // MCASP1.AXR1[0] <-- DOUT: E) `( J7 d2 Z5 Z9 |
mcasp->regs->PFUNC = 0; // All MCASPs
3 [2 \6 U$ W5 t, O mcasp->regs->PDIR = 0x14000020; // All inputs except AXR0[5], ACLKX1, AFSX1
- T) z. \7 L6 E' z% q/ o6 u. g
/ J' }7 d5 r6 i9 l( U0 B2 \ mcasp->regs->DITCTL = 0x00000000; // Not used
+ B% b8 V8 K" G mcasp->regs->DLBCTL = 0x00000000; // Not used
" G( k- s0 Z! V5 Y) D mcasp->regs->AMUTE = 0x00000000; // Not used9 b" r; C& r) ` n; f3 l' J
$ j4 j- I' ^" Y; k/* Starting sections of the McASP*/& L2 x9 l( x5 M" `
mcasp->regs->XGBLCTL |= GBLCTL_XHCLKRST_ON; / n& K ], R6 V! n
while ( ( mcasp->regs->XGBLCTL & GBLCTL_XHCLKRST_ON ) != GBLCTL_XHCLKRST_ON );
1 a2 `. p( J! q% I$ `4 D0 _ mcasp->regs->RGBLCTL |= GBLCTL_RHCLKRST_ON;
+ h& f: k/ A5 i8 R3 H+ z/ U! t) X while ( ( mcasp->regs->RGBLCTL & GBLCTL_RHCLKRST_ON ) != GBLCTL_RHCLKRST_ON );
( t- X$ c. [: g4 L4 |( }* {9 D/ t3 X# M9 S
mcasp->regs->XGBLCTL |= GBLCTL_XCLKRST_ON;
{& d" O( S0 B$ X while ( ( mcasp->regs->XGBLCTL & GBLCTL_XCLKRST_ON ) != GBLCTL_XCLKRST_ON );% [) S4 `1 |: a* c( B
mcasp->regs->RGBLCTL |= GBLCTL_RCLKRST_ON;
; w; T/ r! E" j% y while ( ( mcasp->regs->RGBLCTL & GBLCTL_RCLKRST_ON ) != GBLCTL_RCLKRST_ON );& N# j$ S( Q' R- r$ c5 B( v s
\) W# V' X. [
mcasp->regs->XSTAT = 0x0000ffff; 2 o1 D- i/ H8 F( C
mcasp->regs->RSTAT = 0x0000ffff;
( S, s2 m# T* g8 N2 i; n( }6 J7 w$ h2 D
U. m3 v+ q2 N: E' a mcasp->regs->XGBLCTL |= GBLCTL_XSRCLR_ON;
7 W% G; j9 d) H# _# M while ( ( mcasp->regs->XGBLCTL & GBLCTL_XSRCLR_ON ) != GBLCTL_XSRCLR_ON );
. \4 w" F: H# H- |2 g9 E mcasp->regs->RGBLCTL |= GBLCTL_RSRCLR_ON;
) ?+ V ]7 E- ?$ e* T while ( ( mcasp->regs->RGBLCTL & GBLCTL_RSRCLR_ON ) != GBLCTL_RSRCLR_ON );
+ R/ E, h& r! R/ j% E2 J: o( }
3 x/ ?* H+ @# A- a5 } /* Write a 0, so that no underrun occurs after releasing the state machine */ | b6 j5 Z: B; `2 R& A
mcasp->regs->XBUF5 = 0;
* \- B. v8 V$ a mcasp->regs->RBUF0 = 0;) K; f' A' l3 h# j
# i- h2 ]7 o6 f, P) |0 f mcasp->regs->XGBLCTL |= GBLCTL_XSMRST_ON;
' ]+ x3 d, W1 {) z* x. }" A while ( ( mcasp->regs->XGBLCTL & GBLCTL_XSMRST_ON ) != GBLCTL_XSMRST_ON );
$ F7 }& Y, @( | mcasp->regs->RGBLCTL |= GBLCTL_RSMRST_ON;
0 V+ S& u) g2 w# N8 g* i while ( ( mcasp->regs->RGBLCTL & GBLCTL_RSMRST_ON ) != GBLCTL_RSMRST_ON );' Y! f0 L" R; r' b# ^8 Q
3 A3 j0 J0 Z% J8 n- x0 u7 V, Q
mcasp->regs->XGBLCTL |= GBLCTL_XFRST_ON; * o" U$ y: q& H, z* Y: ^
while ( ( mcasp->regs->XGBLCTL & GBLCTL_XFRST_ON ) != GBLCTL_XFRST_ON );
7 U( P# W( p1 u6 g' P0 I mcasp->regs->RGBLCTL |= GBLCTL_RFRST_ON; + U3 n& J( F1 k* ]3 b
while ( ( mcasp->regs->RGBLCTL & GBLCTL_RFRST_ON ) != GBLCTL_RFRST_ON );
+ Z: i1 ^+ `0 U) u7 O
6 c* y* }, T" k CSR = 0x0000;
0 S3 B' {5 K; o& |5 Z Y' a INTC_INTMUX1 = 0x3d;
# ~/ h" u; I, t& v) g ISTP = (unsigned int)vectors;1 ^5 d: [* F9 R3 d6 K4 R1 p) N
ICR = 0xFFF0;
3 ~2 C4 I$ \! ^- S- j i IER |= 0x12;
+ V0 Q( P- Y' F* q+ x CSR |= 0x01;
' ]2 u6 a3 i0 Q% D: w
8 H6 `0 {& b; L0 ?/ Z3 ~# ]# O' K9 S0 ]2 c+ W) W k. H/ z
% y6 e5 q) S3 F- n还有就是两个输入输出函数: {! }2 a8 Q5 G' z; ^9 k) G
void output_sample(Int32 out_data)
' Z, L7 y: P1 W( U( C/ G{
+ l. k; T/ C4 ^ AIC31_data.uint = out_data; ( M; C1 |/ Q2 {6 G9 U
MCASP1_XBUF5_32BIT = AIC31_data.uint;
B8 I5 Y$ h; y5 `4 U1 Y}, A6 W& v6 A) r* i! c8 q* p
9 q% U( |- J& [* |$ N
Int32 input_sample(void)
7 r* i8 b! E0 \( W5 W9 T7 i7 ~{
+ \$ @& e$ d' y6 w7 w! Z# I# z AIC31_data.uint = MCASP1_RBUF0_32BIT;& k9 u( @/ D" S4 ^) v# `
return (AIC31_data.uint);; {$ C, Z; Y8 |/ \' ]6 s" J
}
5 r* L2 \4 h$ k. K! P4 z3 e6 J* L/ G2 H/ Z" C
|
|