|
|
C6747和C6748感觉差不多,我想实现McASP发送中断方式控制音频信号,在轮询的例程基础上改的,轮询程序可以实现,但是中断一直实现不了,也找不到错误,求大神帮忙!下边是主要程序:2 i7 Y9 T$ R8 E7 j, O
main文件:2 a2 { s) ]+ V1 R' C- t, l! O
interrupt void interrupt4(void) : e) K0 A% L& q3 ~: |' J8 C
{4 D5 ?" l; [; d
Uint32 sample;
: p P. B6 `1 t5 S6 X/ |2 m" V5 o" G9 v" ]. F6 |7 [' f
sample = input_sample(); // read L + R samples from ADC2 ^, X1 F3 K4 J# _
output_sample(sample); // write L + R samples to DAC
$ Q9 q- B3 s- u- _ return;
2 p1 B0 k; j. F}
5 c% r; S `# X4 K' R; O' N9 B+ ]9 B, n& K, l
int main( void )7 Y+ B |, ]# N$ T4 ?: y
{7 M: |+ q+ i5 [- V+ t9 {) {" r
4 |( W+ I1 C W! a/ Z/ A/ u, v
/* Initialize BSL */. @" `5 a$ J: l5 r+ ?: g# r' Y
EVMC6747_init( );
( G& j' f; T; h z7 D! } /* Call evmc6747_intr function */
, T" h; h, n) q: F" j& N I aic3106_init( ); L3 W+ J9 e0 ?1 u: J
while(1);
/ D- }( }# \$ _) I}6 z' ~, q6 r& E% c( d+ H1 p! u
( g- U/ v! ?8 n d: T z8 |
/ o! p! [5 f$ {4 V b
aic3106_init文件的一部分,McASP配置部分,采用内部时钟,I2S方式,同步传输。音频芯片的配置应该没问题 P; q* C ~3 B* f+ y6 G2 A
/* Initialize MCASP1 */
0 G5 ?; L$ z& j0 C$ s8 `" v mcasp = &MCASP_MODULE_1;" a& Y5 F: _" m" e3 [% u) ?' M, i
mcasp->regs->GBLCTL = 0; // Reset3 g+ f- Q4 @9 @6 a
mcasp->regs->RGBLCTL = 0; // Reset RX
% B3 a7 V' I) ~6 |4 n, n mcasp->regs->XGBLCTL = 0; // Reset TX
& `, H9 U# M" T mcasp->regs->PWRDEMU = 1; // Free-running3 `* E8 `4 Y `2 ]0 h
// configure McASP0 receive registers
8 w& i- F6 U b' z6 } mcasp->regs->RMASK = 0xFFFFFFFF; // No padding used
U1 t. \7 f6 v7 R, H7 C mcasp->regs->RFMT = 0x00018078; // MSB 16bit, 0-delay, no pad, CFGBus5 {& B* f; w( K) o5 [$ O! q
mcasp->regs->AFSRCTL = 0x00000112; // 2TDM, 1bit Falling, External FS, word
- a! m: V- Y7 R8 l mcasp->regs->ACLKRCTL = 0x000000AF; // Rising INTERNAL CLK,(from tx side). m) k0 X+ T: T( B1 n
mcasp->regs->AHCLKRCTL = 0x00000000; // INT CLK (from tx side)
" d+ n. H- `5 N; J, G# ~9 }, \$ l mcasp->regs->RTDM = 0x00000003; // Slots 0,19 K( z+ o# ?2 h2 n$ k: y: G) z, |
mcasp->regs->RINTCTL = 0x00000000; // Not used
; K4 Q7 x# P$ _: G! V; i" D9 h mcasp->regs->RCLKCHK = 0x00FF0008; // 255-MAX 0-MIN, div-by-256, x B7 G" G8 j R9 v) g) q2 ^
8 V8 n$ C, J ]# z i mcasp->regs->XMASK = 0xFFFFFFFF; // No padding used
; Q! D% j5 K! A9 x mcasp->regs->XFMT = 0x00018078; // MSB 16bit, 0-delay, no pad, CFGBus
& h2 ^( Z- G3 n; {4 X! R mcasp->regs->AFSXCTL = 0x00000112; // 2TDM, 1bit Rising edge INTERNAL FS, word
# q9 Z; A9 \8 c mcasp->regs->ACLKXCTL = 0x000000AF; // ASYNC, Rising INTERNAL CLK, div-by-16
3 m o4 Z4 e5 ~ mcasp->regs->AHCLKXCTL = 0x00000000; // EXT CLK
S& d" q$ s- d# N! V) s4 K- W( | mcasp->regs->XTDM = 0x00000003; // Slots 0,13 I. l) |5 G3 P5 v. I
mcasp->regs->XINTCTL = 0x00000020; // interrupt on transmit
/ N, n1 H% v* I' @ mcasp->regs->XCLKCHK = 0x00FF0008; // 255-MAX 0-MIN, div-by-256- m- \' q7 H6 Y5 q1 K7 m* L* r
8 _6 p7 Y; t& M& F# E" O# y mcasp->regs->SRCTL5 = 0x000D; // MCASP1.AXR1[5] --> DIN& x$ H" s K3 M4 ]$ I8 q( I
mcasp->regs->SRCTL0 = 0x000E; // MCASP1.AXR1[0] <-- DOUT: j0 E- V4 x: F4 ]8 [+ @
mcasp->regs->PFUNC = 0; // All MCASPs
5 Z; O. c i" ^3 Z ~& V/ g& E- {. S mcasp->regs->PDIR = 0x14000020; // All inputs except AXR0[5], ACLKX1, AFSX1/ h/ T5 W0 R- {2 d3 Y; e2 S! q
2 Y2 l: m0 @* Z- T2 ~ mcasp->regs->DITCTL = 0x00000000; // Not used* z: i% h7 ^! J- V l+ i. J1 U
mcasp->regs->DLBCTL = 0x00000000; // Not used
}/ h( ]6 J# B mcasp->regs->AMUTE = 0x00000000; // Not used
n0 U3 G) z8 a2 e" H+ E; i6 `# I7 u6 S
/* Starting sections of the McASP*/6 [" g$ f4 r l+ T) X
mcasp->regs->XGBLCTL |= GBLCTL_XHCLKRST_ON;
5 I* a2 | B& B while ( ( mcasp->regs->XGBLCTL & GBLCTL_XHCLKRST_ON ) != GBLCTL_XHCLKRST_ON );
( }4 S& D: J" q% O2 A9 g+ |. X" ~ mcasp->regs->RGBLCTL |= GBLCTL_RHCLKRST_ON;
) R8 U$ v( |" P while ( ( mcasp->regs->RGBLCTL & GBLCTL_RHCLKRST_ON ) != GBLCTL_RHCLKRST_ON );
' X0 I5 ~& ?3 ~/ l& t
d4 }' S% J! J$ n0 f1 v mcasp->regs->XGBLCTL |= GBLCTL_XCLKRST_ON;
! T& e9 S0 x* r3 S while ( ( mcasp->regs->XGBLCTL & GBLCTL_XCLKRST_ON ) != GBLCTL_XCLKRST_ON );
- P( G" O7 e' _3 V mcasp->regs->RGBLCTL |= GBLCTL_RCLKRST_ON; 1 R$ i$ r( K% E l# A. R
while ( ( mcasp->regs->RGBLCTL & GBLCTL_RCLKRST_ON ) != GBLCTL_RCLKRST_ON );
' t7 |4 i2 C" Y& y) C( W9 g, Y+ S {+ T6 @8 b! g2 K
mcasp->regs->XSTAT = 0x0000ffff;
! r) K" l5 F# [ mcasp->regs->RSTAT = 0x0000ffff;
# M4 [2 ^6 a8 Z f( s ?
1 z1 ?7 a8 l; v% v2 e mcasp->regs->XGBLCTL |= GBLCTL_XSRCLR_ON;
5 h$ X0 Z5 \6 p* K5 _: D while ( ( mcasp->regs->XGBLCTL & GBLCTL_XSRCLR_ON ) != GBLCTL_XSRCLR_ON );8 o) o4 c5 i# J+ y
mcasp->regs->RGBLCTL |= GBLCTL_RSRCLR_ON; ( B, i, U+ g& C' o) G
while ( ( mcasp->regs->RGBLCTL & GBLCTL_RSRCLR_ON ) != GBLCTL_RSRCLR_ON );
6 B0 y, A6 c5 ~: B2 r3 {$ h* \% W
" L" q4 T* D6 N0 k5 Q5 E [8 V /* Write a 0, so that no underrun occurs after releasing the state machine */
+ W( h1 N/ n0 D% \, ^) G7 J b' F1 v mcasp->regs->XBUF5 = 0;
! K% ^' s* B) j/ T( j mcasp->regs->RBUF0 = 0;. ]; q, v5 w5 w& Q: ~
# s8 c; F$ c" A+ t mcasp->regs->XGBLCTL |= GBLCTL_XSMRST_ON; % P! J0 Z! T+ P- ~ s
while ( ( mcasp->regs->XGBLCTL & GBLCTL_XSMRST_ON ) != GBLCTL_XSMRST_ON );* P3 ]; i) u& U
mcasp->regs->RGBLCTL |= GBLCTL_RSMRST_ON;
# m, E+ b; s: S7 d. v+ ~ while ( ( mcasp->regs->RGBLCTL & GBLCTL_RSMRST_ON ) != GBLCTL_RSMRST_ON );
: n5 |" z! E' a
9 B, L% Q9 V d; b# T mcasp->regs->XGBLCTL |= GBLCTL_XFRST_ON; - A# U4 u0 Z) l! s+ @
while ( ( mcasp->regs->XGBLCTL & GBLCTL_XFRST_ON ) != GBLCTL_XFRST_ON );2 }+ B5 |3 n! Z) ~
mcasp->regs->RGBLCTL |= GBLCTL_RFRST_ON; - I/ b3 B/ [5 v4 X" O
while ( ( mcasp->regs->RGBLCTL & GBLCTL_RFRST_ON ) != GBLCTL_RFRST_ON );
" s9 E$ z5 D1 x" r. o- u& K. M* v1 u1 L
CSR = 0x0000;3 v- _( }2 F9 I( `
INTC_INTMUX1 = 0x3d;
6 w* U* h# Z* |$ h5 B1 e5 o ISTP = (unsigned int)vectors;& X" v7 T2 ]' r* j% y
ICR = 0xFFF0; : I& m) X3 |$ a8 v
IER |= 0x12;
2 v" M E/ H& |" f0 k CSR |= 0x01; 8 _- o! S& Y1 Y5 }3 x4 z' A U
7 [: [# _: E3 L, ]$ E- L) l
! M T5 c) n- B
) {6 v0 i8 n0 c# l) a- j1 ]还有就是两个输入输出函数:. o/ I2 P* B& O9 @ o1 {
void output_sample(Int32 out_data)1 Y1 U! o% u( Z
{9 t: J& e9 T) T4 R; E* a
AIC31_data.uint = out_data;
& B1 K, L3 ]2 K5 w( k0 k0 X( f ^; g MCASP1_XBUF5_32BIT = AIC31_data.uint;) w1 O% U- T" p
}; D0 ^2 f" f3 B0 e& A% T8 Y0 [
7 j9 g+ _7 L+ m# K0 s0 ^
Int32 input_sample(void)0 n" J& |3 @, ~% d$ X- G0 B
{
3 d- ^3 e( D" Z# @- ?2 ?8 B AIC31_data.uint = MCASP1_RBUF0_32BIT;
, o4 W6 {- B8 p( J, |, U% [ return (AIC31_data.uint);
9 {. d. c+ W1 T, Q+ e( j}) a7 G3 A6 t" z) K+ _( r" f7 A3 r' ~5 f6 | o
/ J" y4 ~; ]5 W/ _$ N! t" p
|
|