|
|
C6747和C6748感觉差不多,我想实现McASP发送中断方式控制音频信号,在轮询的例程基础上改的,轮询程序可以实现,但是中断一直实现不了,也找不到错误,求大神帮忙!下边是主要程序:
& W' V# c5 z& w4 e; F* i) Zmain文件:7 ?3 Y/ x5 I3 E. r/ N/ V: k8 i
interrupt void interrupt4(void)
# R4 J1 Q! f7 @1 ]{
" C3 {; B4 A5 n- a$ Z$ C: H8 ^ Uint32 sample;; z" {: m, I' I$ W a
8 ~3 I$ k- ^# |& y sample = input_sample(); // read L + R samples from ADC/ R6 a- F9 s" ^2 n! c0 v/ F- Q
output_sample(sample); // write L + R samples to DAC
: q+ q" X! g! G1 P. C* D7 i9 M return;
/ L* ]# }' v" _0 B$ ]}5 p7 @. @; B& m. _
E' i. H5 c2 ~% m3 u
int main( void )
4 [4 N( G$ }7 ?) D) S{
M1 W: L! l1 n" g* i5 j/ g5 U! \9 R. `* u
/* Initialize BSL */
5 z- P* Q6 c; X7 L( c4 P EVMC6747_init( );
/ g+ K$ A \) e1 b /* Call evmc6747_intr function */
0 z+ ]" C& ~/ ]2 ?6 a$ n% J( R aic3106_init( );
4 ?! ^9 Y- w! | while(1);
# W; N" C% d/ z7 R! }}# }6 I \6 r: q2 k+ s) }5 }* p
. c! A( F8 W; E: }; k& ~
/ X- n2 @1 A3 [8 H taic3106_init文件的一部分,McASP配置部分,采用内部时钟,I2S方式,同步传输。音频芯片的配置应该没问题% L. j1 Q ~/ \8 Q6 ~5 j9 l
/* Initialize MCASP1 */0 l* ]# |& m! q2 G
mcasp = &MCASP_MODULE_1;
4 R% T( j4 V# m4 i) @. I% } mcasp->regs->GBLCTL = 0; // Reset
( k3 \- ]% A: F4 U mcasp->regs->RGBLCTL = 0; // Reset RX) u" B* H" B! c5 P& c% w* c& v R
mcasp->regs->XGBLCTL = 0; // Reset TX
6 ~" ^2 _% i2 z# ? mcasp->regs->PWRDEMU = 1; // Free-running2 G9 ~4 z) e3 b1 V, ~
// configure McASP0 receive registers
2 V2 i$ t/ c# }. G' R mcasp->regs->RMASK = 0xFFFFFFFF; // No padding used
0 \4 `# Z: b' X( n# v9 A! J* P mcasp->regs->RFMT = 0x00018078; // MSB 16bit, 0-delay, no pad, CFGBus, J2 F4 P# J0 Z; i3 e: }: a! \9 B
mcasp->regs->AFSRCTL = 0x00000112; // 2TDM, 1bit Falling, External FS, word
2 @ p1 Y8 e7 L( U8 F mcasp->regs->ACLKRCTL = 0x000000AF; // Rising INTERNAL CLK,(from tx side)
: e/ P5 r2 B5 _) v* l0 J3 ? mcasp->regs->AHCLKRCTL = 0x00000000; // INT CLK (from tx side)# l% G `+ w! b$ o% ^) A2 p9 W
mcasp->regs->RTDM = 0x00000003; // Slots 0,1! n4 t" q1 U$ O( M. p' p3 M% m7 E
mcasp->regs->RINTCTL = 0x00000000; // Not used
9 U: u4 `! i# e- l$ e: R; S( V mcasp->regs->RCLKCHK = 0x00FF0008; // 255-MAX 0-MIN, div-by-2560 V- {2 b( J9 L* S* I/ O- H" M: o
; H' o- a, l/ k% B1 }2 G mcasp->regs->XMASK = 0xFFFFFFFF; // No padding used. Q& ^0 V1 H' N. V; h8 ~, Y7 v
mcasp->regs->XFMT = 0x00018078; // MSB 16bit, 0-delay, no pad, CFGBus
. J( j# ~9 w- a. x mcasp->regs->AFSXCTL = 0x00000112; // 2TDM, 1bit Rising edge INTERNAL FS, word
3 f4 y0 M4 u5 K4 C' N mcasp->regs->ACLKXCTL = 0x000000AF; // ASYNC, Rising INTERNAL CLK, div-by-16
. j* T6 H3 e6 \- ? mcasp->regs->AHCLKXCTL = 0x00000000; // EXT CLK7 Y4 o9 s' z3 ^( |' I0 N; m$ M
mcasp->regs->XTDM = 0x00000003; // Slots 0,1- P: A% V! j& S2 h5 K3 X C
mcasp->regs->XINTCTL = 0x00000020; // interrupt on transmit
1 d5 b- @$ F7 B: {. F% x( X7 q mcasp->regs->XCLKCHK = 0x00FF0008; // 255-MAX 0-MIN, div-by-256
9 k! s1 l" z1 f4 C7 Z8 [; O4 h7 y- [( s: q; ~% c
mcasp->regs->SRCTL5 = 0x000D; // MCASP1.AXR1[5] --> DIN
; h8 I Z$ Q# q* t mcasp->regs->SRCTL0 = 0x000E; // MCASP1.AXR1[0] <-- DOUT( Y9 W" L$ m% c1 ?+ f! B# D- ~3 K
mcasp->regs->PFUNC = 0; // All MCASPs
$ ^3 M* B$ e4 ~, o) l- x5 A mcasp->regs->PDIR = 0x14000020; // All inputs except AXR0[5], ACLKX1, AFSX1! o7 P* \; N- A0 a& J! m
+ s" u2 i7 `6 B7 \- h: n
mcasp->regs->DITCTL = 0x00000000; // Not used
1 c. w( q* q6 L; S& \ mcasp->regs->DLBCTL = 0x00000000; // Not used4 p1 b; Q$ F; n- l2 Q5 y$ o/ B3 G
mcasp->regs->AMUTE = 0x00000000; // Not used
* B3 @, q) ?# |$ h; s5 b1 S: g$ |9 J# p5 O7 ]" s9 R
/* Starting sections of the McASP*/% @% _$ a6 a* m `8 u! Y9 t
mcasp->regs->XGBLCTL |= GBLCTL_XHCLKRST_ON; - o" ?. G3 _; }+ O8 {( R0 C" ]
while ( ( mcasp->regs->XGBLCTL & GBLCTL_XHCLKRST_ON ) != GBLCTL_XHCLKRST_ON ); 3 K' W" \& s8 a# W' u M
mcasp->regs->RGBLCTL |= GBLCTL_RHCLKRST_ON; # O$ d( W' ~& G1 F0 c
while ( ( mcasp->regs->RGBLCTL & GBLCTL_RHCLKRST_ON ) != GBLCTL_RHCLKRST_ON );
3 T: b0 h! _9 U0 f6 f4 g( I7 ^" i
mcasp->regs->XGBLCTL |= GBLCTL_XCLKRST_ON;
N1 i* J( t' N2 P while ( ( mcasp->regs->XGBLCTL & GBLCTL_XCLKRST_ON ) != GBLCTL_XCLKRST_ON );
Q3 o7 p1 }; w7 A1 ?7 i mcasp->regs->RGBLCTL |= GBLCTL_RCLKRST_ON; e2 Y# ^4 O T: b: e" t$ g
while ( ( mcasp->regs->RGBLCTL & GBLCTL_RCLKRST_ON ) != GBLCTL_RCLKRST_ON );2 z3 D! d* L% q( M1 u. y
1 s# A M% t$ D1 \) D$ P mcasp->regs->XSTAT = 0x0000ffff; ( w' Y' d) v7 k8 N7 S/ ?2 z) j
mcasp->regs->RSTAT = 0x0000ffff;
q6 k) {7 T1 D: x& p/ H/ S
6 M$ @. V+ i& N8 ?" l7 k+ V$ ` mcasp->regs->XGBLCTL |= GBLCTL_XSRCLR_ON;6 ?1 h* d: ?, e9 Y8 P
while ( ( mcasp->regs->XGBLCTL & GBLCTL_XSRCLR_ON ) != GBLCTL_XSRCLR_ON );
2 K6 E C2 h! P C* W, n mcasp->regs->RGBLCTL |= GBLCTL_RSRCLR_ON;
- s/ j# u9 D% ?/ m while ( ( mcasp->regs->RGBLCTL & GBLCTL_RSRCLR_ON ) != GBLCTL_RSRCLR_ON );
+ W$ [& w( B' J
6 x) Y* T V! U. e1 Z% \( l /* Write a 0, so that no underrun occurs after releasing the state machine */
' x8 N) ?6 n' n3 u7 \* `' |8 W; |) D mcasp->regs->XBUF5 = 0;
( H$ V2 ?3 _) U5 w mcasp->regs->RBUF0 = 0;
- o, K7 A7 _ ?5 K
- T$ [8 @. Y1 o9 ]% h3 A) p mcasp->regs->XGBLCTL |= GBLCTL_XSMRST_ON; ! [2 h4 P( O: Q$ y
while ( ( mcasp->regs->XGBLCTL & GBLCTL_XSMRST_ON ) != GBLCTL_XSMRST_ON );) E+ Q. U4 n" z: Z1 K5 w0 L
mcasp->regs->RGBLCTL |= GBLCTL_RSMRST_ON;
3 |" u# _! w/ J, o# ~2 | while ( ( mcasp->regs->RGBLCTL & GBLCTL_RSMRST_ON ) != GBLCTL_RSMRST_ON );
6 N. t2 l/ P0 f$ D c5 x; g$ ~, d7 q8 C
mcasp->regs->XGBLCTL |= GBLCTL_XFRST_ON;
9 @1 G9 k* n" }3 _& _5 c1 t while ( ( mcasp->regs->XGBLCTL & GBLCTL_XFRST_ON ) != GBLCTL_XFRST_ON );
* h- z( v9 |. e mcasp->regs->RGBLCTL |= GBLCTL_RFRST_ON;
( k$ Q1 s# z8 X, o# h0 _6 t5 `& A while ( ( mcasp->regs->RGBLCTL & GBLCTL_RFRST_ON ) != GBLCTL_RFRST_ON );- G$ b- Y; s# ?1 a0 T
9 f: I/ l2 q- W/ T7 j: N
CSR = 0x0000; a8 Q4 P/ G: }: W7 N
INTC_INTMUX1 = 0x3d;3 Z7 _ o- f/ [5 V
ISTP = (unsigned int)vectors;
* K0 @' m4 L, a% w5 n ICR = 0xFFF0; % a4 z8 A+ P3 n/ C
IER |= 0x12; 0 J& B- B2 T. }) E
CSR |= 0x01; " _% i4 c! h3 [5 ?
. C5 D+ [' j L& y$ [4 \
W6 K: F' g" }# p) _5 |: v( t5 ~( m8 O9 V* T
还有就是两个输入输出函数:1 p7 j; _* k) x ~$ ~0 n
void output_sample(Int32 out_data)- S4 o$ l* S# w; ^/ p6 I( R& G
{
/ l% h$ V: t- w. C [' Q$ h! V) I AIC31_data.uint = out_data;
{, L- P* N$ w& `* P MCASP1_XBUF5_32BIT = AIC31_data.uint;
4 z. K- G \6 K1 ?! b0 ]7 b}1 O, n7 n$ I4 Z( N# z
7 W2 \$ F. U; k( K: m4 I! w
Int32 input_sample(void)
1 y: |$ f K3 m0 f5 }. U7 C$ c. {{ 4 ^7 s! o; C( K7 G4 g
AIC31_data.uint = MCASP1_RBUF0_32BIT;
# O: a9 T* P5 ]$ } return (AIC31_data.uint);- g, o; @. e0 V6 j* R3 r" ~% ?
}
. |! O) z- O) B- C! i4 O, r; N
* n3 C0 c/ I" e: P5 |6 t/ j |
|