|
|
C6747和C6748感觉差不多,我想实现McASP发送中断方式控制音频信号,在轮询的例程基础上改的,轮询程序可以实现,但是中断一直实现不了,也找不到错误,求大神帮忙!下边是主要程序:7 M+ U; W. ?0 _) L2 O* v) j
main文件:) U( ?6 P7 g: g3 J
interrupt void interrupt4(void) % J h3 v, X* ~
{
% u' |/ R- s) I( r1 g4 a9 o; Z! \ Uint32 sample;7 N5 Q s8 e( A1 {2 o
9 Q- {" K) i/ i1 _3 k+ Z* p) @; U! X sample = input_sample(); // read L + R samples from ADC1 y/ ^) A( y' X! ^0 b
output_sample(sample); // write L + R samples to DAC
H* a3 V [: p. F# T9 A return;9 V2 Z* \2 [$ ^; P5 S
}
, q1 \' G0 b. S/ R0 w/ r6 R- D* d) m6 A! W
int main( void ), N2 g0 V$ i3 }9 B8 a! R8 x
{
8 o0 z8 x" ]$ X* e0 J! d) R" v
7 D; | L N9 l* ]: d /* Initialize BSL */
$ {) h3 U, u+ G! c9 w EVMC6747_init( );
* B/ ^. B0 U1 O /* Call evmc6747_intr function */
/ q. U# a' A) J aic3106_init( );
/ N- F( f* T; T+ y while(1);
" V0 L3 n x1 R& K$ Z) p3 R}# b8 i) [; [3 x' J D& _; x" w- N1 A
8 O1 m+ [6 V/ I E; ]' P
d. h6 \/ ^8 t! f0 W6 Gaic3106_init文件的一部分,McASP配置部分,采用内部时钟,I2S方式,同步传输。音频芯片的配置应该没问题
( n1 _5 U& X/ Y: E7 N# E$ Y/* Initialize MCASP1 */* h, P8 i. n; ^5 r. [
mcasp = &MCASP_MODULE_1;5 t8 P5 L2 z' t$ g1 }4 e
mcasp->regs->GBLCTL = 0; // Reset
$ E O- y" G% i+ u2 L; \, | mcasp->regs->RGBLCTL = 0; // Reset RX
; W- y' K+ c5 n Y5 i- t! S mcasp->regs->XGBLCTL = 0; // Reset TX
$ @/ s; u1 E3 @( `9 K mcasp->regs->PWRDEMU = 1; // Free-running4 C% _3 b, ~4 o) W& F5 Y$ h
// configure McASP0 receive registers
& D) z9 @6 E- i! }* f mcasp->regs->RMASK = 0xFFFFFFFF; // No padding used
" x9 q0 O% M. g% k$ T, r mcasp->regs->RFMT = 0x00018078; // MSB 16bit, 0-delay, no pad, CFGBus' x$ N" P: B* H9 A! R2 N
mcasp->regs->AFSRCTL = 0x00000112; // 2TDM, 1bit Falling, External FS, word. i1 \* k( `/ W9 J0 b+ f* L
mcasp->regs->ACLKRCTL = 0x000000AF; // Rising INTERNAL CLK,(from tx side)
8 j Z. [+ e0 t* O* [9 {6 Z mcasp->regs->AHCLKRCTL = 0x00000000; // INT CLK (from tx side)* r; L' a! _; O" {* W, r2 W7 ]* m
mcasp->regs->RTDM = 0x00000003; // Slots 0,1
6 I0 \, ^& Q: n; L! n mcasp->regs->RINTCTL = 0x00000000; // Not used& q6 h" t7 P, Z! N, k$ U8 U; Q
mcasp->regs->RCLKCHK = 0x00FF0008; // 255-MAX 0-MIN, div-by-256
; T T! {# b6 J% X. t
`2 X: f( a! f mcasp->regs->XMASK = 0xFFFFFFFF; // No padding used
' ~# X8 n1 d. j$ O# X mcasp->regs->XFMT = 0x00018078; // MSB 16bit, 0-delay, no pad, CFGBus( j" f9 o9 I9 V/ m9 Z4 t( o
mcasp->regs->AFSXCTL = 0x00000112; // 2TDM, 1bit Rising edge INTERNAL FS, word7 s: A: c( ^$ Q0 I
mcasp->regs->ACLKXCTL = 0x000000AF; // ASYNC, Rising INTERNAL CLK, div-by-16
% Q7 s6 c4 D7 ? mcasp->regs->AHCLKXCTL = 0x00000000; // EXT CLK* @2 D3 q$ [7 O( l( w, W+ C4 _; G
mcasp->regs->XTDM = 0x00000003; // Slots 0,1
/ R2 J% i1 g. r mcasp->regs->XINTCTL = 0x00000020; // interrupt on transmit
# v$ a8 X4 z$ b* y) [% U6 f mcasp->regs->XCLKCHK = 0x00FF0008; // 255-MAX 0-MIN, div-by-256& t4 q; q: H9 m4 \- b: d1 Q
! i ~0 W; `% Y5 O2 k: U- ^+ w4 Q
mcasp->regs->SRCTL5 = 0x000D; // MCASP1.AXR1[5] --> DIN
7 r6 F' o2 x) D* b( q- j0 Z4 Q mcasp->regs->SRCTL0 = 0x000E; // MCASP1.AXR1[0] <-- DOUT
7 B3 \( {8 D1 q3 {) A' G mcasp->regs->PFUNC = 0; // All MCASPs
4 _1 N9 Q5 ]$ ?) E mcasp->regs->PDIR = 0x14000020; // All inputs except AXR0[5], ACLKX1, AFSX1
/ G r0 A, ?, H
/ R5 h8 h) N- F9 {3 ~% ?; Q mcasp->regs->DITCTL = 0x00000000; // Not used
: I' B) h, Z7 d" o mcasp->regs->DLBCTL = 0x00000000; // Not used
. x, r+ @4 I5 C mcasp->regs->AMUTE = 0x00000000; // Not used
1 I# N- E# O: i2 ]9 N; [
$ t' T" N1 J' f/* Starting sections of the McASP*/
1 T( T2 p, w4 K, ?+ L mcasp->regs->XGBLCTL |= GBLCTL_XHCLKRST_ON;
$ n, ?2 w0 _1 M6 ~. i( | while ( ( mcasp->regs->XGBLCTL & GBLCTL_XHCLKRST_ON ) != GBLCTL_XHCLKRST_ON ); 7 V: g# \1 ?! X" L2 ?0 K( D
mcasp->regs->RGBLCTL |= GBLCTL_RHCLKRST_ON;
]5 }/ w( r, ?$ a% b while ( ( mcasp->regs->RGBLCTL & GBLCTL_RHCLKRST_ON ) != GBLCTL_RHCLKRST_ON );
& K4 N4 ]+ h: O) W
+ j. ]1 L" R# B8 m; g5 h/ g5 G0 ^7 L mcasp->regs->XGBLCTL |= GBLCTL_XCLKRST_ON;
~& w" v8 l' i# P while ( ( mcasp->regs->XGBLCTL & GBLCTL_XCLKRST_ON ) != GBLCTL_XCLKRST_ON );
* j( {- H1 Q; c) @* ^* z mcasp->regs->RGBLCTL |= GBLCTL_RCLKRST_ON; ) ~2 {: {1 m' ?+ h, X& C
while ( ( mcasp->regs->RGBLCTL & GBLCTL_RCLKRST_ON ) != GBLCTL_RCLKRST_ON );1 _& p3 [! r% B/ \- h' V
" X4 c8 Q! c4 x! C, e8 [ mcasp->regs->XSTAT = 0x0000ffff;
6 v1 f0 z/ Y8 _! c mcasp->regs->RSTAT = 0x0000ffff;
7 r; X5 I" e. C f
) L. [/ g9 |# [, w6 l mcasp->regs->XGBLCTL |= GBLCTL_XSRCLR_ON;
$ r% ^5 D7 m) \7 U: m2 _6 l' P while ( ( mcasp->regs->XGBLCTL & GBLCTL_XSRCLR_ON ) != GBLCTL_XSRCLR_ON );
) `" V& J) k2 U7 [- z5 ? mcasp->regs->RGBLCTL |= GBLCTL_RSRCLR_ON;
9 B- M8 r8 X/ X- z: _' k$ b+ C) c while ( ( mcasp->regs->RGBLCTL & GBLCTL_RSRCLR_ON ) != GBLCTL_RSRCLR_ON );
5 q+ J6 ^) }0 _; T+ f, r3 k& u: a% Y8 Z9 I# `6 U
/* Write a 0, so that no underrun occurs after releasing the state machine */
6 y. N Y% n& E6 G/ \9 m0 h mcasp->regs->XBUF5 = 0;
1 X6 V$ w, q2 f& L& i0 v4 X: t# ?. w) ~ mcasp->regs->RBUF0 = 0;
4 d9 R! G0 q, e9 E
D) N9 k5 y' [- ?9 h4 c) L( i mcasp->regs->XGBLCTL |= GBLCTL_XSMRST_ON;
8 ?% i' S8 n$ g; S9 T ^ while ( ( mcasp->regs->XGBLCTL & GBLCTL_XSMRST_ON ) != GBLCTL_XSMRST_ON );! W1 Y1 w' S( Q
mcasp->regs->RGBLCTL |= GBLCTL_RSMRST_ON;
v8 H. C, C& S/ y' U- H; o, T+ [2 ]. { while ( ( mcasp->regs->RGBLCTL & GBLCTL_RSMRST_ON ) != GBLCTL_RSMRST_ON );
; m/ G3 c# k. ]8 N% i! |7 c# y& `4 J5 X# {$ p+ N$ e& y3 [
mcasp->regs->XGBLCTL |= GBLCTL_XFRST_ON; 1 m" w' Y/ o+ X% i0 E( n+ F! k9 f- z
while ( ( mcasp->regs->XGBLCTL & GBLCTL_XFRST_ON ) != GBLCTL_XFRST_ON );
: n2 [* h1 [* i1 b# z mcasp->regs->RGBLCTL |= GBLCTL_RFRST_ON; 7 r8 Y; ?* p: [/ k0 u
while ( ( mcasp->regs->RGBLCTL & GBLCTL_RFRST_ON ) != GBLCTL_RFRST_ON );& @+ a1 u9 X0 v
* z3 F4 g, L% c- O" a: @ CSR = 0x0000;
2 o6 \9 @1 Z* ]* s" b# J: @; b INTC_INTMUX1 = 0x3d;% c. m# l- }7 j. n- S
ISTP = (unsigned int)vectors;7 T3 @! v+ \: v0 R# Q
ICR = 0xFFF0;
B4 q: {* s; K9 T5 L+ D8 V IER |= 0x12; 4 Y r+ k5 j) Y: X- S6 i8 h% K
CSR |= 0x01;
$ h$ @0 y, [/ J& t6 O+ N2 V; j8 W8 d% F0 s
+ V- {$ e! b7 h$ ?
4 a: y7 e, G. l, c5 B0 m1 {
还有就是两个输入输出函数:& {4 K: Z5 C! w4 B0 `; q8 s# E$ C% p
void output_sample(Int32 out_data)6 K/ u+ o5 R7 R) s9 e( w5 U
{
) F+ a* A' D: I$ {- x2 l9 a5 B AIC31_data.uint = out_data;
$ v& P1 {" E S+ E$ ] MCASP1_XBUF5_32BIT = AIC31_data.uint;2 E: E+ [- `+ B" A7 a+ [: G
}
9 M2 a: {8 ^5 P/ m* _6 \# ^: y; a3 A
Int32 input_sample(void)
4 W8 R7 S' u( ?( o: y4 F( E{ 1 ?1 \& U* O C# h# z
AIC31_data.uint = MCASP1_RBUF0_32BIT;
( j9 U. b: H: y3 b! S* Z) R6 ~9 d$ Q5 ` return (AIC31_data.uint);& Q7 T( `' e# I' Y+ u/ k
}) ^' {7 E0 h% d+ X& g
5 k7 r! |; o$ j% L& \1 F! t, [! a
|
|