|
|
C6747和C6748感觉差不多,我想实现McASP发送中断方式控制音频信号,在轮询的例程基础上改的,轮询程序可以实现,但是中断一直实现不了,也找不到错误,求大神帮忙!下边是主要程序:
( ?5 [( L: L1 Umain文件:( X( B# b, y K/ J
interrupt void interrupt4(void)
# H: s6 x! }5 d3 q" @. u" g" ]{
; N& J4 j3 T' v, B5 ?4 R5 h; P' w Uint32 sample;
: i7 S' U! d& [1 |+ [! Y2 e* r! t$ @3 s% G8 P3 A {' Q
sample = input_sample(); // read L + R samples from ADC- O: G8 V$ g1 z7 w. F$ V5 \- s
output_sample(sample); // write L + R samples to DAC
; _" R; U& m7 I# |& d5 P4 I return;
5 a w2 J2 s+ |. T( E}# H. N3 S0 @8 P. _7 P' `. N
4 \: j3 V# ?: I3 p2 l5 W8 p; Z
int main( void )
" D( |6 D. M) v( v. ]* }& X{
: [9 [4 @: Q3 k% U; p2 k" m' f, _7 z9 l1 k
/* Initialize BSL */
9 J) j1 \9 J5 E) C, }6 W& ?5 G EVMC6747_init( );$ J, l# F6 U& G3 B, C5 a
/* Call evmc6747_intr function */
; @( f: a) [# e( J+ C aic3106_init( );
" j- [2 S% _' L- O7 { while(1);# L4 S `5 l3 H9 s0 P" |# T. g
}
2 x5 p7 Z' l" [* u! a L8 b
0 b" e" Q% \! e1 n0 v+ F
% n( X( L0 V" I4 N" }aic3106_init文件的一部分,McASP配置部分,采用内部时钟,I2S方式,同步传输。音频芯片的配置应该没问题
" O# u& R4 ]8 Z2 y; S n/* Initialize MCASP1 */7 L! \! J- \ `4 A8 G5 u; t
mcasp = &MCASP_MODULE_1;2 u! ^) B. O Q/ \/ ~
mcasp->regs->GBLCTL = 0; // Reset6 F3 B+ A9 h9 j z1 A* ~0 n
mcasp->regs->RGBLCTL = 0; // Reset RX
2 ~3 A- g# E+ v6 i) U3 @ mcasp->regs->XGBLCTL = 0; // Reset TX
& G j, A- A* H( B1 f mcasp->regs->PWRDEMU = 1; // Free-running2 b u. b1 d$ _' p: p/ E3 C' [
// configure McASP0 receive registers
( M/ X5 i) ?: `& g mcasp->regs->RMASK = 0xFFFFFFFF; // No padding used
0 h2 A! f) u% O6 s% b* }2 D$ s mcasp->regs->RFMT = 0x00018078; // MSB 16bit, 0-delay, no pad, CFGBus
, A% F1 g' @! l4 ]+ l3 k. Q' M4 G mcasp->regs->AFSRCTL = 0x00000112; // 2TDM, 1bit Falling, External FS, word5 f8 @. P# u9 d: o$ Z
mcasp->regs->ACLKRCTL = 0x000000AF; // Rising INTERNAL CLK,(from tx side)
/ a: a' A* h( A# H% E" N, o mcasp->regs->AHCLKRCTL = 0x00000000; // INT CLK (from tx side)
$ I. a3 i( ^, w# b; q mcasp->regs->RTDM = 0x00000003; // Slots 0,1: Q! m; B" q1 l
mcasp->regs->RINTCTL = 0x00000000; // Not used
0 m9 D/ A/ ?3 B7 w U: ` mcasp->regs->RCLKCHK = 0x00FF0008; // 255-MAX 0-MIN, div-by-256
9 x0 \ l: p3 w+ x- K) j; L* K# [5 g; e _3 S5 v# z0 s' m) ~
mcasp->regs->XMASK = 0xFFFFFFFF; // No padding used
7 j/ [- D% }# P, Q" G mcasp->regs->XFMT = 0x00018078; // MSB 16bit, 0-delay, no pad, CFGBus! ?. R* }: ^) L7 W* g
mcasp->regs->AFSXCTL = 0x00000112; // 2TDM, 1bit Rising edge INTERNAL FS, word
5 l4 @' w' K- |! m! k3 \) w% d& l7 k mcasp->regs->ACLKXCTL = 0x000000AF; // ASYNC, Rising INTERNAL CLK, div-by-16. d, ]2 }$ J# Y4 m' O
mcasp->regs->AHCLKXCTL = 0x00000000; // EXT CLK1 j; s; B6 Y; n0 i; \
mcasp->regs->XTDM = 0x00000003; // Slots 0,1
6 Y3 \/ T4 B% R+ m mcasp->regs->XINTCTL = 0x00000020; // interrupt on transmit' B6 d4 V; r, j* n5 s. \
mcasp->regs->XCLKCHK = 0x00FF0008; // 255-MAX 0-MIN, div-by-256
# E+ _" t+ L0 N: m
* B$ ~( M8 ^% G- G- @ b1 { mcasp->regs->SRCTL5 = 0x000D; // MCASP1.AXR1[5] --> DIN
. d5 U- F: a! ] mcasp->regs->SRCTL0 = 0x000E; // MCASP1.AXR1[0] <-- DOUT# Y1 o0 D+ {9 g( t
mcasp->regs->PFUNC = 0; // All MCASPs4 h! ^# V7 a0 w1 [. d* X( _
mcasp->regs->PDIR = 0x14000020; // All inputs except AXR0[5], ACLKX1, AFSX1' @% m' z# I+ D- p4 P
5 l0 V$ j# B+ S8 H! W# n
mcasp->regs->DITCTL = 0x00000000; // Not used3 U% _, r- J& z' i, _
mcasp->regs->DLBCTL = 0x00000000; // Not used
! [& f' l! |! ? mcasp->regs->AMUTE = 0x00000000; // Not used; N v3 r9 m4 R2 x" ]9 ^ X
4 f9 F2 ]& p' S% g/* Starting sections of the McASP*/
. W( ~2 R8 A1 [3 Y( v) P8 c- L mcasp->regs->XGBLCTL |= GBLCTL_XHCLKRST_ON; ' k) p U: ^3 I+ E: o% S, | V' l
while ( ( mcasp->regs->XGBLCTL & GBLCTL_XHCLKRST_ON ) != GBLCTL_XHCLKRST_ON );
& \" @9 Z# R3 G4 X mcasp->regs->RGBLCTL |= GBLCTL_RHCLKRST_ON; , q2 B3 t2 P+ D# V4 o, a
while ( ( mcasp->regs->RGBLCTL & GBLCTL_RHCLKRST_ON ) != GBLCTL_RHCLKRST_ON );
. D& z. [8 E# e _9 e7 j+ M: M1 z# U7 q; k# z! |+ k
mcasp->regs->XGBLCTL |= GBLCTL_XCLKRST_ON; 0 p. t5 j* b; s6 Z; d
while ( ( mcasp->regs->XGBLCTL & GBLCTL_XCLKRST_ON ) != GBLCTL_XCLKRST_ON );
+ l* A9 C! c8 V1 s1 ]4 u0 v mcasp->regs->RGBLCTL |= GBLCTL_RCLKRST_ON;
4 y6 G" z1 M: l) t& y0 F$ [ while ( ( mcasp->regs->RGBLCTL & GBLCTL_RCLKRST_ON ) != GBLCTL_RCLKRST_ON );! q+ q0 F2 d. W( j- r$ Z. Y) K( t. ~
% l& h* ? H( F' @ mcasp->regs->XSTAT = 0x0000ffff;
1 ]! ^5 g' n3 p: T! w+ n* t/ X mcasp->regs->RSTAT = 0x0000ffff; $ {( D) z( s3 b, G) J! Q! L5 X
4 T% B$ Q) k3 b8 X- E; p4 I
mcasp->regs->XGBLCTL |= GBLCTL_XSRCLR_ON;
1 ^8 T* k: l. g4 t4 w' } H while ( ( mcasp->regs->XGBLCTL & GBLCTL_XSRCLR_ON ) != GBLCTL_XSRCLR_ON );+ B1 w! k! \/ w8 E5 k7 |
mcasp->regs->RGBLCTL |= GBLCTL_RSRCLR_ON; " v' U7 |/ l2 T" b
while ( ( mcasp->regs->RGBLCTL & GBLCTL_RSRCLR_ON ) != GBLCTL_RSRCLR_ON );) B$ Y1 o B% E
1 K5 c/ j" Q V/ U" y
/* Write a 0, so that no underrun occurs after releasing the state machine */, m2 Y2 U3 z( c8 J9 P! l
mcasp->regs->XBUF5 = 0;5 k" z; |/ O$ y0 Z* m5 d
mcasp->regs->RBUF0 = 0;
; ~, `5 s% v% ` t
# z1 I" x" b( [2 {; q mcasp->regs->XGBLCTL |= GBLCTL_XSMRST_ON; ( C: Z" s* f1 I; l; { A# N3 g3 c
while ( ( mcasp->regs->XGBLCTL & GBLCTL_XSMRST_ON ) != GBLCTL_XSMRST_ON );
5 O \0 X; n3 V1 A9 j mcasp->regs->RGBLCTL |= GBLCTL_RSMRST_ON; ! R" ~' `0 v, @4 t7 O. W+ r
while ( ( mcasp->regs->RGBLCTL & GBLCTL_RSMRST_ON ) != GBLCTL_RSMRST_ON );( N3 I* h" D9 H- R/ o7 k
( Q @5 o8 [3 B& d; k) s+ r Q* o mcasp->regs->XGBLCTL |= GBLCTL_XFRST_ON;
. y! v/ T/ ?9 }) N# t: y while ( ( mcasp->regs->XGBLCTL & GBLCTL_XFRST_ON ) != GBLCTL_XFRST_ON );5 m, X5 u( D `8 n: k) \+ I
mcasp->regs->RGBLCTL |= GBLCTL_RFRST_ON;
6 O6 S6 g) c! q while ( ( mcasp->regs->RGBLCTL & GBLCTL_RFRST_ON ) != GBLCTL_RFRST_ON );; v3 w, l k: s% L4 p2 b- {
- Y1 r* e/ h& Y0 i
CSR = 0x0000;8 g- a! S @9 E* b* Z2 R& m& {7 W7 I0 e
INTC_INTMUX1 = 0x3d;; v' V+ R" {# l! s9 l* n( T2 u
ISTP = (unsigned int)vectors;
; L- X5 n2 [# O9 l; v: f6 J ICR = 0xFFF0;
) N2 x& {) E9 X7 W% ^ IER |= 0x12; / e, k/ p) C& K4 F1 i
CSR |= 0x01;
% F4 [' b' E* p* s
- i" R- D, Y, S4 q$ s B* m* s3 G# w: j! t. G' d
4 B. G2 s5 y& j2 m* J4 R/ `
还有就是两个输入输出函数:$ c4 `, Y) G( Q- [2 @
void output_sample(Int32 out_data)
( a8 G" k* ~- w1 U3 [3 c( P! I{4 F; v# E5 d2 l- g0 }
AIC31_data.uint = out_data; ' P: X% L3 ~1 Y' N0 V& c" v
MCASP1_XBUF5_32BIT = AIC31_data.uint;1 ~ w8 C' R2 Q! g* N. y- g7 _
}
" O# t+ C- x+ J- j0 B: L& [6 b& I
Int32 input_sample(void)
/ D/ U' S& D( w5 J8 C, `( r{ : x0 {# Z7 Y. K1 j
AIC31_data.uint = MCASP1_RBUF0_32BIT;' r* h- j Q8 W) y1 R( s8 i
return (AIC31_data.uint);. {& M2 P3 ]1 o
}2 B# @$ q9 T1 {" C
% ~9 T. R5 W1 p5 ?' I7 ]. w# A7 R |
|