|
|
C6747和C6748感觉差不多,我想实现McASP发送中断方式控制音频信号,在轮询的例程基础上改的,轮询程序可以实现,但是中断一直实现不了,也找不到错误,求大神帮忙!下边是主要程序:# n8 j D" g: L, e, q z: L
main文件:' n4 V1 R7 k, \" G4 }! ^* t$ y
interrupt void interrupt4(void) 5 C% S1 a8 r8 O2 f+ \
{8 l1 C l* {+ }. E: F, e5 C* _
Uint32 sample;
/ P" ]! }/ G# ?+ c
$ O$ g( b6 ~9 G; n sample = input_sample(); // read L + R samples from ADC$ d- S3 \* y7 L+ g7 o9 K3 F
output_sample(sample); // write L + R samples to DAC , R1 X! H4 j$ ^# E: |# ]2 x; U
return;
o/ Q1 u# {& ]$ Y% {+ i0 F}
: T; B' ~/ S9 {4 {7 }# q9 C9 Y" [$ d
int main( void )
& s2 h, f# L7 a) N$ C) u{
: B9 M, w! n$ S, l* L! j
7 f7 V6 O; Q1 W /* Initialize BSL */
# E4 ~3 G9 R- r8 E! p EVMC6747_init( );) Y2 M' [1 N# P. w7 p
/* Call evmc6747_intr function */
4 _3 \/ d. M9 R6 ~" T+ v aic3106_init( );
9 x2 b1 D3 z: x$ s while(1);/ D8 ^8 o! v, E2 U' q
}
- z* g$ q& f) a& ~" F1 w6 } z/ Q5 x, z$ {$ w- g
3 x. Y/ `( x1 j$ x7 j) B
aic3106_init文件的一部分,McASP配置部分,采用内部时钟,I2S方式,同步传输。音频芯片的配置应该没问题3 H7 ~# \4 F7 \7 r
/* Initialize MCASP1 */3 g( q6 {# b7 u- }( ]
mcasp = &MCASP_MODULE_1;5 B6 K- f# A3 b* K2 N/ }1 y
mcasp->regs->GBLCTL = 0; // Reset: @+ o, T- ?5 X( [6 Q* f: u
mcasp->regs->RGBLCTL = 0; // Reset RX
# P' \' C o. v0 E" n: l mcasp->regs->XGBLCTL = 0; // Reset TX
+ p7 [$ I7 j$ ]0 |' F3 ` mcasp->regs->PWRDEMU = 1; // Free-running
* j9 ]" R- J1 u$ A" \" m // configure McASP0 receive registers; V2 J* L' [0 G! T- V# E9 D
mcasp->regs->RMASK = 0xFFFFFFFF; // No padding used+ k# U( I' K9 P6 k7 Q6 {* g! M
mcasp->regs->RFMT = 0x00018078; // MSB 16bit, 0-delay, no pad, CFGBus
) M) @3 P/ ^2 j& z P; E8 d- O mcasp->regs->AFSRCTL = 0x00000112; // 2TDM, 1bit Falling, External FS, word- B; g# K9 X* v7 ^) c5 b5 L
mcasp->regs->ACLKRCTL = 0x000000AF; // Rising INTERNAL CLK,(from tx side)
0 Q* r Q1 h- P% g3 T mcasp->regs->AHCLKRCTL = 0x00000000; // INT CLK (from tx side)
7 m* p! `$ \6 q/ p8 X; R6 } mcasp->regs->RTDM = 0x00000003; // Slots 0,1
2 x+ b, K5 M7 p" D; H: d$ @8 b. H mcasp->regs->RINTCTL = 0x00000000; // Not used7 W1 K# ?0 k8 b8 R: F
mcasp->regs->RCLKCHK = 0x00FF0008; // 255-MAX 0-MIN, div-by-256: o: w7 z$ ]0 v# c- N* O6 b1 k
/ \' V% l& O: b1 c' U8 r! I% {- E1 m mcasp->regs->XMASK = 0xFFFFFFFF; // No padding used z( }& V' z4 U/ [0 Y
mcasp->regs->XFMT = 0x00018078; // MSB 16bit, 0-delay, no pad, CFGBus1 C9 v$ W8 {7 U
mcasp->regs->AFSXCTL = 0x00000112; // 2TDM, 1bit Rising edge INTERNAL FS, word
% u& u% r) i" s mcasp->regs->ACLKXCTL = 0x000000AF; // ASYNC, Rising INTERNAL CLK, div-by-16
# J7 u7 d# Y! h$ |5 n, `& n mcasp->regs->AHCLKXCTL = 0x00000000; // EXT CLK
/ b% d* u( r* w5 X. y7 V7 | mcasp->regs->XTDM = 0x00000003; // Slots 0,1
! Y8 `1 I$ j$ g+ K mcasp->regs->XINTCTL = 0x00000020; // interrupt on transmit
# F/ X4 \+ T' c: e2 I- F6 L mcasp->regs->XCLKCHK = 0x00FF0008; // 255-MAX 0-MIN, div-by-256
$ b7 I1 F! [+ O4 B& `
/ @# {( y1 A) F mcasp->regs->SRCTL5 = 0x000D; // MCASP1.AXR1[5] --> DIN9 o, m( Z* X9 e, D
mcasp->regs->SRCTL0 = 0x000E; // MCASP1.AXR1[0] <-- DOUT- {, |; u. u; ^8 k! ?: e5 g ~
mcasp->regs->PFUNC = 0; // All MCASPs" o5 C+ P, [- w; s" K
mcasp->regs->PDIR = 0x14000020; // All inputs except AXR0[5], ACLKX1, AFSX1
0 q8 j* }+ [* p, F: z% z$ N
9 n7 P. n7 ~% P- e" L mcasp->regs->DITCTL = 0x00000000; // Not used% `3 f8 `4 z+ M! }1 d: u) T% ?7 \
mcasp->regs->DLBCTL = 0x00000000; // Not used
2 M: E. ]+ {+ ^8 p8 f5 {/ v mcasp->regs->AMUTE = 0x00000000; // Not used
5 d! ~0 g0 t+ [- T$ k# W6 A/ |3 y, e0 F2 q
/* Starting sections of the McASP*/
I; k: g V E" p mcasp->regs->XGBLCTL |= GBLCTL_XHCLKRST_ON;
* ?8 B' [; j5 @+ u* c while ( ( mcasp->regs->XGBLCTL & GBLCTL_XHCLKRST_ON ) != GBLCTL_XHCLKRST_ON ); {7 j' [ E& b0 m) Z
mcasp->regs->RGBLCTL |= GBLCTL_RHCLKRST_ON; : [5 C$ F+ C2 P! C* H
while ( ( mcasp->regs->RGBLCTL & GBLCTL_RHCLKRST_ON ) != GBLCTL_RHCLKRST_ON );& R$ B+ B3 W4 Z% N* M
; t @$ R- R; \3 ?! e2 | mcasp->regs->XGBLCTL |= GBLCTL_XCLKRST_ON; 3 N6 o6 t0 u+ t0 X/ |
while ( ( mcasp->regs->XGBLCTL & GBLCTL_XCLKRST_ON ) != GBLCTL_XCLKRST_ON );+ k; S1 {8 r0 M6 W4 ^
mcasp->regs->RGBLCTL |= GBLCTL_RCLKRST_ON;
' {1 O( H. w& r2 v5 E5 Y* n while ( ( mcasp->regs->RGBLCTL & GBLCTL_RCLKRST_ON ) != GBLCTL_RCLKRST_ON );
0 Y+ K. \3 j8 }5 L/ g: E P
$ o* T" Y& x" |" Q mcasp->regs->XSTAT = 0x0000ffff;
; G2 U6 x2 ?2 ?2 M/ `- p' p+ C mcasp->regs->RSTAT = 0x0000ffff;
. F. f3 O2 |' t+ S' {
2 X* n( o k u$ d) G. I mcasp->regs->XGBLCTL |= GBLCTL_XSRCLR_ON;
7 f$ g* H$ F7 {: S$ @9 e6 K3 p) | while ( ( mcasp->regs->XGBLCTL & GBLCTL_XSRCLR_ON ) != GBLCTL_XSRCLR_ON );( i1 b8 P+ R6 g) m* w% q, q6 I- K
mcasp->regs->RGBLCTL |= GBLCTL_RSRCLR_ON; ' F8 P! G, F# B3 w6 R7 f
while ( ( mcasp->regs->RGBLCTL & GBLCTL_RSRCLR_ON ) != GBLCTL_RSRCLR_ON );* J, N3 v6 ~6 f; j9 @0 S2 Y
0 r4 M3 |4 N t5 p2 g /* Write a 0, so that no underrun occurs after releasing the state machine */0 R. }4 z- `* @$ e8 D# ]
mcasp->regs->XBUF5 = 0;
0 j% d$ ]& B0 D9 y mcasp->regs->RBUF0 = 0;9 F- s0 f% ]/ S! P- @# U2 M
* T9 ]1 {' q9 R- P mcasp->regs->XGBLCTL |= GBLCTL_XSMRST_ON; & H6 p" W, r+ F& \
while ( ( mcasp->regs->XGBLCTL & GBLCTL_XSMRST_ON ) != GBLCTL_XSMRST_ON );
& E8 y% F3 D* N2 c1 c. R/ H6 R mcasp->regs->RGBLCTL |= GBLCTL_RSMRST_ON; 4 N, P3 J" A9 m8 T0 M) v- ]) L; [
while ( ( mcasp->regs->RGBLCTL & GBLCTL_RSMRST_ON ) != GBLCTL_RSMRST_ON );
. T& A, Y0 ~2 f4 H5 S9 e" z: J _7 M/ X7 H1 Y
mcasp->regs->XGBLCTL |= GBLCTL_XFRST_ON; / E: J |: d- s3 \1 l
while ( ( mcasp->regs->XGBLCTL & GBLCTL_XFRST_ON ) != GBLCTL_XFRST_ON );1 I! p; e" ~2 k! E- K/ s, l
mcasp->regs->RGBLCTL |= GBLCTL_RFRST_ON;
, ] x; [+ k# l while ( ( mcasp->regs->RGBLCTL & GBLCTL_RFRST_ON ) != GBLCTL_RFRST_ON );: D4 g0 k1 T0 i% D2 {1 C# b
y- c z/ [# ]+ k CSR = 0x0000;+ i, E" R6 T/ z* D2 [* a
INTC_INTMUX1 = 0x3d;
5 E5 _1 \; Y$ f1 {- J8 g9 b ISTP = (unsigned int)vectors;+ k j3 V" Q, |# o
ICR = 0xFFF0; / T6 p' p% u! M6 s
IER |= 0x12;
% a% [" ^7 ?, a5 x5 x CSR |= 0x01; ; D ~, r3 x# V) }
9 S: E2 ~) Z5 h% f
( R+ i7 b N7 V, o; P" x
# h' ^5 x4 `7 K' i N/ `
还有就是两个输入输出函数:
1 |- f9 D8 l/ j' Jvoid output_sample(Int32 out_data)
8 U. d9 B3 p2 F" |# k) O{9 ?4 q: r$ R7 i8 v2 b, Y
AIC31_data.uint = out_data;
' ?: i/ P1 K8 R8 C" R4 v MCASP1_XBUF5_32BIT = AIC31_data.uint;
" P/ x5 M1 C8 y" K; G" J) J4 O}
: q# C3 ~ C/ o) i1 \$ I7 X- v( [0 x0 W
Int32 input_sample(void)# `3 c& F- T) R+ G: p1 D
{ 7 g" e; @% P* @0 \% ]
AIC31_data.uint = MCASP1_RBUF0_32BIT;, f' K! a4 S& {# W
return (AIC31_data.uint);
( r3 u, C% i$ _}
; r# r7 C. p7 P
/ E: V q4 O! T# H7 ]7 y D# i2 N |
|