|
|
C6747和C6748感觉差不多,我想实现McASP发送中断方式控制音频信号,在轮询的例程基础上改的,轮询程序可以实现,但是中断一直实现不了,也找不到错误,求大神帮忙!下边是主要程序:$ K' w* Z/ {+ Q3 f, v6 A# @, k
main文件:
* L2 [+ M0 K! l, q6 y6 y/ m; linterrupt void interrupt4(void)
& Y4 b0 E$ l" F" }# X{
/ ~( B) H4 o- I5 Q7 k2 K1 W Uint32 sample;, W) |( j# o- }) a
: C* f. h5 F' ]: Y
sample = input_sample(); // read L + R samples from ADC# L8 }: N, Y! Q- p; G+ J7 E
output_sample(sample); // write L + R samples to DAC
# m5 N! ]1 d1 D7 C/ y- S1 \# q( \7 { return;9 y" U$ U5 ?1 S0 e
}9 @$ ^. J, }- R. v8 l( |: @: \
1 G5 k5 v4 t5 h/ R o- u+ i
int main( void )- V9 V2 a& u: O T5 d
{0 C7 h- h* H. q( }& {5 g4 i
" N* |% ^0 _7 e7 I5 w/ k /* Initialize BSL */
9 D! E0 M$ z/ s$ p" C' N EVMC6747_init( );
1 X4 g: u& {5 W5 } /* Call evmc6747_intr function */
. ]& H8 k+ x, y, X3 ^6 I: i aic3106_init( );5 T9 b2 t* A9 K; C2 x/ {8 Y' ^9 V
while(1);
; C+ D, `3 ?- T# `/ h+ o3 ~8 ^}
1 Z" g4 Q5 s" P; e+ K1 K- w, P Z7 z' p# C; A$ n
2 Z" c0 D; c/ }; Z3 s# r8 s3 H$ Q% w4 Taic3106_init文件的一部分,McASP配置部分,采用内部时钟,I2S方式,同步传输。音频芯片的配置应该没问题
$ `( U2 m+ o. Q/* Initialize MCASP1 */
/ ?; s+ }8 }* H! P/ G- z9 T2 C mcasp = &MCASP_MODULE_1;8 z) N" n& _: h# I9 c7 D, }
mcasp->regs->GBLCTL = 0; // Reset% O% Z3 {6 `" Q
mcasp->regs->RGBLCTL = 0; // Reset RX
% n1 x9 N3 I" k9 j8 N mcasp->regs->XGBLCTL = 0; // Reset TX
" t5 Z& \) ~2 ?% Z: Q+ q) T/ C$ G mcasp->regs->PWRDEMU = 1; // Free-running2 N. p) C$ h" c S9 T/ w9 Y* v' c
// configure McASP0 receive registers9 {2 m; y) h- M0 K
mcasp->regs->RMASK = 0xFFFFFFFF; // No padding used. h! _* z' p& B; F" b+ Q% _
mcasp->regs->RFMT = 0x00018078; // MSB 16bit, 0-delay, no pad, CFGBus
2 ^4 _2 W, x2 v mcasp->regs->AFSRCTL = 0x00000112; // 2TDM, 1bit Falling, External FS, word
4 T, z4 [; o/ ~- p! x$ x) u4 @ mcasp->regs->ACLKRCTL = 0x000000AF; // Rising INTERNAL CLK,(from tx side)
3 N' I5 p/ w- R! K mcasp->regs->AHCLKRCTL = 0x00000000; // INT CLK (from tx side)
2 I$ @7 n% Y' E. u) W mcasp->regs->RTDM = 0x00000003; // Slots 0,17 v) @' Y7 m1 T! T4 E: t$ [" t
mcasp->regs->RINTCTL = 0x00000000; // Not used
( s$ @) i. O9 R3 v1 r7 x k mcasp->regs->RCLKCHK = 0x00FF0008; // 255-MAX 0-MIN, div-by-256
# O, p$ e9 B9 X" W' c U9 `
+ ?- H) f. E7 X R8 d. P2 K; K' E5 _ mcasp->regs->XMASK = 0xFFFFFFFF; // No padding used
; K9 z% `/ H6 \2 ?3 H mcasp->regs->XFMT = 0x00018078; // MSB 16bit, 0-delay, no pad, CFGBus
% [% B& t- i% Z& [# X" m mcasp->regs->AFSXCTL = 0x00000112; // 2TDM, 1bit Rising edge INTERNAL FS, word( k! Z) n1 J. k- T# `1 ]
mcasp->regs->ACLKXCTL = 0x000000AF; // ASYNC, Rising INTERNAL CLK, div-by-16
2 {, V T, z* c* w! {9 w mcasp->regs->AHCLKXCTL = 0x00000000; // EXT CLK
7 U# p/ f, o& m1 z8 X) C% U mcasp->regs->XTDM = 0x00000003; // Slots 0,1: e7 A g( A* ]; M
mcasp->regs->XINTCTL = 0x00000020; // interrupt on transmit4 N3 \* p: ~8 }
mcasp->regs->XCLKCHK = 0x00FF0008; // 255-MAX 0-MIN, div-by-256
3 W, d0 E' X0 N
7 X! `) L" n8 W) r: `; p5 J }% \ mcasp->regs->SRCTL5 = 0x000D; // MCASP1.AXR1[5] --> DIN
" H3 O; T6 ^+ b; Q- ~ mcasp->regs->SRCTL0 = 0x000E; // MCASP1.AXR1[0] <-- DOUT
! ~( |$ q, }3 ~" F; d. j mcasp->regs->PFUNC = 0; // All MCASPs
6 M( W" G" A$ s# d; } mcasp->regs->PDIR = 0x14000020; // All inputs except AXR0[5], ACLKX1, AFSX1
* T7 u# H* ~, v( @7 ^' P9 A
+ y: \/ k o2 F+ J mcasp->regs->DITCTL = 0x00000000; // Not used
3 f2 ]3 o4 \. y4 y t$ X mcasp->regs->DLBCTL = 0x00000000; // Not used2 D, q3 \3 t6 ~6 K% ?! C- V
mcasp->regs->AMUTE = 0x00000000; // Not used+ x( d& e4 t; E0 j6 s1 h. \
! B/ \! Q+ k3 O/* Starting sections of the McASP*/
* }5 }+ O3 U, D7 U mcasp->regs->XGBLCTL |= GBLCTL_XHCLKRST_ON;
+ t! r2 O6 V B, \$ _ while ( ( mcasp->regs->XGBLCTL & GBLCTL_XHCLKRST_ON ) != GBLCTL_XHCLKRST_ON ); 8 z, n$ S E# L. O
mcasp->regs->RGBLCTL |= GBLCTL_RHCLKRST_ON;
9 `6 z' F0 ]7 W; E, n& q3 T( M while ( ( mcasp->regs->RGBLCTL & GBLCTL_RHCLKRST_ON ) != GBLCTL_RHCLKRST_ON );
; B. F ]/ e6 U$ c( c3 k" e$ D' ~4 J1 s) T4 ?3 l) }3 ?0 C! {
mcasp->regs->XGBLCTL |= GBLCTL_XCLKRST_ON;
; x3 v0 m0 q6 I2 N$ q( m while ( ( mcasp->regs->XGBLCTL & GBLCTL_XCLKRST_ON ) != GBLCTL_XCLKRST_ON );* n+ X4 t4 f }2 h6 e* i6 N, q( `
mcasp->regs->RGBLCTL |= GBLCTL_RCLKRST_ON; + ?* o$ r* z% W* ?* h" E
while ( ( mcasp->regs->RGBLCTL & GBLCTL_RCLKRST_ON ) != GBLCTL_RCLKRST_ON );
0 Z3 A* c' l; _9 z4 O; B. l- j7 V9 x
mcasp->regs->XSTAT = 0x0000ffff; ! c L/ X/ b4 ]0 F' {
mcasp->regs->RSTAT = 0x0000ffff;
* v- o; c& y& l1 N' x0 v/ c7 \. `0 v
mcasp->regs->XGBLCTL |= GBLCTL_XSRCLR_ON;. s: x( L, |8 e
while ( ( mcasp->regs->XGBLCTL & GBLCTL_XSRCLR_ON ) != GBLCTL_XSRCLR_ON );
" D! ` w* Q% u. k0 t [ mcasp->regs->RGBLCTL |= GBLCTL_RSRCLR_ON;
: \3 {/ {/ K) I& L+ L6 | while ( ( mcasp->regs->RGBLCTL & GBLCTL_RSRCLR_ON ) != GBLCTL_RSRCLR_ON );
0 q' |( J8 V$ A& i& {9 [4 z3 V( I+ t, c8 ]' Y+ w5 |! R
/* Write a 0, so that no underrun occurs after releasing the state machine */2 w, l# R' S2 b6 h
mcasp->regs->XBUF5 = 0;$ J& R3 F2 Z' Y
mcasp->regs->RBUF0 = 0;! @% y9 p) t" P' [6 `' X. ?2 Y
7 x8 W, J h# l* {& M) d( ] mcasp->regs->XGBLCTL |= GBLCTL_XSMRST_ON;
# M) |' u5 F$ h0 x5 D4 u while ( ( mcasp->regs->XGBLCTL & GBLCTL_XSMRST_ON ) != GBLCTL_XSMRST_ON );6 y# V9 F6 f; I
mcasp->regs->RGBLCTL |= GBLCTL_RSMRST_ON; . {. M" R# K8 Q; b# V2 l
while ( ( mcasp->regs->RGBLCTL & GBLCTL_RSMRST_ON ) != GBLCTL_RSMRST_ON );3 ~6 Z8 v( P0 T9 `5 S* O4 ^" L
, e- t8 v1 [3 I( m2 S mcasp->regs->XGBLCTL |= GBLCTL_XFRST_ON;
) x; l( {/ j) m4 c while ( ( mcasp->regs->XGBLCTL & GBLCTL_XFRST_ON ) != GBLCTL_XFRST_ON );
1 O/ f2 c, S7 [! S1 y5 Q9 n mcasp->regs->RGBLCTL |= GBLCTL_RFRST_ON;
) o! a7 X* O/ L$ d+ z) s7 R while ( ( mcasp->regs->RGBLCTL & GBLCTL_RFRST_ON ) != GBLCTL_RFRST_ON );
$ I0 `1 L6 Q6 [( B8 w0 H7 }9 d7 u$ L4 ~: J& k: G
CSR = 0x0000;
3 s) Y8 r3 Q. y& ~6 B6 K; G% y INTC_INTMUX1 = 0x3d;
1 x7 F& |% p. e: L( \ ISTP = (unsigned int)vectors;
/ x% m6 H2 o7 Y ICR = 0xFFF0; 6 }6 M1 a+ o* p9 v: `
IER |= 0x12;
8 K: T" z+ V/ A: A u% M8 ^. q CSR |= 0x01;
' f! g- s; L3 T! o+ O6 N7 S; h0 @1 d! L5 O% G8 K w5 c
' m) ~0 C& l, l' J5 @
: O" G" n6 ^% X
还有就是两个输入输出函数:- |5 j5 J4 g% [8 h( N. s/ w
void output_sample(Int32 out_data)
2 |6 ?. B! }' Z0 u; m2 f7 M% ?3 D{
+ o3 m7 y4 Q1 Y+ Q7 u AIC31_data.uint = out_data; M5 |6 o6 O" h4 P# d3 v- v3 |9 ^
MCASP1_XBUF5_32BIT = AIC31_data.uint;
' L( ]0 x K `9 x}
8 m3 _9 `' R1 b; z) ` E6 n1 X0 }$ G# H4 P' Y6 ?0 L ~( v
Int32 input_sample(void)% r7 U9 N9 i4 c3 X9 O
{ 4 s* E U0 x- J( A! V
AIC31_data.uint = MCASP1_RBUF0_32BIT;! D( s7 a8 F" ~1 g
return (AIC31_data.uint);" Q0 r8 A X7 ^, l9 E5 W% }
}. K0 J1 Z8 L# }. i N+ i6 F
; h' |7 \$ M2 W! [) g9 X
|
|