|
|
C6747和C6748感觉差不多,我想实现McASP发送中断方式控制音频信号,在轮询的例程基础上改的,轮询程序可以实现,但是中断一直实现不了,也找不到错误,求大神帮忙!下边是主要程序:$ N8 i7 {5 a' q
main文件:- O: b' Z d: ]) d' M
interrupt void interrupt4(void) 1 L% Q% ^+ K! Q# F a/ h5 i, f0 Y
{
& m% u" Y: s+ C9 m Uint32 sample;
$ S0 y) k0 x- m
4 a5 F6 U! c: [" \- s sample = input_sample(); // read L + R samples from ADC- G# c: s& r2 p
output_sample(sample); // write L + R samples to DAC
1 ]* N; _1 ^+ P2 Y1 r3 @ return;+ @4 v; t$ g+ V
}
! C( L% e0 G' Y2 Y6 c
8 [ c& M: m8 Y) ^1 Pint main( void )
5 q3 C1 J2 F9 `. m; |, e1 X{, y' |" O: N" }3 @, Y
) n8 D: `3 H4 s& F+ U) E /* Initialize BSL */
/ ]$ W( \5 m0 ~' b EVMC6747_init( );
- v4 L. |% e% I+ I /* Call evmc6747_intr function */+ P0 j3 @) ^9 C0 k
aic3106_init( );, F! G+ y, ~3 e4 d
while(1);4 l6 y5 N" h% g+ b
}' z ?. m) r9 i3 {, ?" n5 y* A
1 C. A' {4 A t6 a, P4 O2 \9 v* e; P! W1 c# I6 w7 `% O6 |1 Y0 D
aic3106_init文件的一部分,McASP配置部分,采用内部时钟,I2S方式,同步传输。音频芯片的配置应该没问题) Z" P. T. u( U
/* Initialize MCASP1 */; Z& T3 j- t. E% c3 e5 G+ r) U
mcasp = &MCASP_MODULE_1;
* O0 P& F$ b) |7 i mcasp->regs->GBLCTL = 0; // Reset
" I1 F: C+ `" U- S: X* h mcasp->regs->RGBLCTL = 0; // Reset RX
/ L( [2 O) w5 F" \ mcasp->regs->XGBLCTL = 0; // Reset TX
& h- r* |8 D, }# N! n& n4 t: B mcasp->regs->PWRDEMU = 1; // Free-running( I2 w' d) J8 {8 r, _( x; J
// configure McASP0 receive registers
) j0 ^* B, h3 y$ j mcasp->regs->RMASK = 0xFFFFFFFF; // No padding used
* w! {; u3 v' c/ W mcasp->regs->RFMT = 0x00018078; // MSB 16bit, 0-delay, no pad, CFGBus9 h8 u8 W, ]: H& X0 E6 c
mcasp->regs->AFSRCTL = 0x00000112; // 2TDM, 1bit Falling, External FS, word
& Q, r5 f7 X0 m. V: A/ _* X mcasp->regs->ACLKRCTL = 0x000000AF; // Rising INTERNAL CLK,(from tx side)" c2 f+ a; f0 C# m/ ]
mcasp->regs->AHCLKRCTL = 0x00000000; // INT CLK (from tx side). Q% |9 I( Q; f: G4 `
mcasp->regs->RTDM = 0x00000003; // Slots 0,1
4 x# Z, W2 k4 i! ?/ k8 t) k mcasp->regs->RINTCTL = 0x00000000; // Not used9 j- ^3 x* {1 }" a. H r5 A, n& v
mcasp->regs->RCLKCHK = 0x00FF0008; // 255-MAX 0-MIN, div-by-256
! _9 K) ^+ r, h) h) S) r5 l8 Z, F, j
9 y6 Z4 R" `9 |( z( x/ G mcasp->regs->XMASK = 0xFFFFFFFF; // No padding used5 ] t ~- }9 A3 T" A
mcasp->regs->XFMT = 0x00018078; // MSB 16bit, 0-delay, no pad, CFGBus2 `0 R U# _. e$ Y' r
mcasp->regs->AFSXCTL = 0x00000112; // 2TDM, 1bit Rising edge INTERNAL FS, word0 H' ?9 z/ x. A4 X' a' D
mcasp->regs->ACLKXCTL = 0x000000AF; // ASYNC, Rising INTERNAL CLK, div-by-16! G+ D% ~; r$ D I
mcasp->regs->AHCLKXCTL = 0x00000000; // EXT CLK( p# {7 ^: W( c( u% H; E+ H
mcasp->regs->XTDM = 0x00000003; // Slots 0,1( b$ [# m k$ t
mcasp->regs->XINTCTL = 0x00000020; // interrupt on transmit
/ g5 p! r& ~* l8 G8 P1 x! H' {& @ mcasp->regs->XCLKCHK = 0x00FF0008; // 255-MAX 0-MIN, div-by-256
" E2 {7 I8 O6 M- ?
M3 F' c6 E$ A1 |& ~ mcasp->regs->SRCTL5 = 0x000D; // MCASP1.AXR1[5] --> DIN
c- I5 M! g% }1 U mcasp->regs->SRCTL0 = 0x000E; // MCASP1.AXR1[0] <-- DOUT
) x+ d5 K5 I/ P# w. M4 s mcasp->regs->PFUNC = 0; // All MCASPs
& R6 e) p. g* t: k! P: x5 O mcasp->regs->PDIR = 0x14000020; // All inputs except AXR0[5], ACLKX1, AFSX1% V2 ]; u/ G) k) p+ Y, _
! a% _, n. m9 c
mcasp->regs->DITCTL = 0x00000000; // Not used
# l& ]9 j9 F0 F& o- |: R1 _ mcasp->regs->DLBCTL = 0x00000000; // Not used
" z7 N$ v3 o$ l0 x mcasp->regs->AMUTE = 0x00000000; // Not used9 l6 H9 C9 y1 e
. G2 U r& J, K/* Starting sections of the McASP*/, e( c; _0 l" B# L" y1 q7 m
mcasp->regs->XGBLCTL |= GBLCTL_XHCLKRST_ON; 4 S' V6 n+ C3 h; O4 Y* H8 d- R
while ( ( mcasp->regs->XGBLCTL & GBLCTL_XHCLKRST_ON ) != GBLCTL_XHCLKRST_ON );
. o" z* y+ b R mcasp->regs->RGBLCTL |= GBLCTL_RHCLKRST_ON; & p0 U2 j' Q# l
while ( ( mcasp->regs->RGBLCTL & GBLCTL_RHCLKRST_ON ) != GBLCTL_RHCLKRST_ON );" G$ i( {6 d6 t1 B
2 U* w7 B* K0 K1 } N1 k5 f
mcasp->regs->XGBLCTL |= GBLCTL_XCLKRST_ON;
( H9 O* ^: @( u' L while ( ( mcasp->regs->XGBLCTL & GBLCTL_XCLKRST_ON ) != GBLCTL_XCLKRST_ON );
3 p1 ?. |/ b, C# j% h9 ~" t9 s mcasp->regs->RGBLCTL |= GBLCTL_RCLKRST_ON;
8 T* M2 M& A! z, J; R" o) I while ( ( mcasp->regs->RGBLCTL & GBLCTL_RCLKRST_ON ) != GBLCTL_RCLKRST_ON );
9 V: T# M# v6 j+ q& G8 O- S0 `: z' F* V, ^1 d i
mcasp->regs->XSTAT = 0x0000ffff;
5 T1 O' j9 ?* m4 J( W N mcasp->regs->RSTAT = 0x0000ffff; , n" `: ?* o% ^- m% y c0 I2 K
7 G2 \8 {# ?9 b% j+ y; L
mcasp->regs->XGBLCTL |= GBLCTL_XSRCLR_ON;
8 O% M6 I# `, D! i* M while ( ( mcasp->regs->XGBLCTL & GBLCTL_XSRCLR_ON ) != GBLCTL_XSRCLR_ON );! e) N, d ~, X9 T
mcasp->regs->RGBLCTL |= GBLCTL_RSRCLR_ON;
& Z H4 [. I" _" y" p8 @ while ( ( mcasp->regs->RGBLCTL & GBLCTL_RSRCLR_ON ) != GBLCTL_RSRCLR_ON );
+ X5 X# E) c: _" B0 n8 k5 k4 E. Y3 R7 ]! A' U5 Y8 {& t# z5 O! ~
/* Write a 0, so that no underrun occurs after releasing the state machine */: X9 d* S$ ]* B0 @8 ]( c
mcasp->regs->XBUF5 = 0;
% K6 a2 R& M" A3 X/ H) c& I0 V# F mcasp->regs->RBUF0 = 0;+ G* {% b; _- q$ K% e" q9 i ^
* ~, X3 t' K5 W% e# z- F: y mcasp->regs->XGBLCTL |= GBLCTL_XSMRST_ON;
. R9 \, L# y: J- v3 R while ( ( mcasp->regs->XGBLCTL & GBLCTL_XSMRST_ON ) != GBLCTL_XSMRST_ON );
+ H4 Q- j7 n9 {, x, U2 E mcasp->regs->RGBLCTL |= GBLCTL_RSMRST_ON; 9 C- s6 K$ o: u, m
while ( ( mcasp->regs->RGBLCTL & GBLCTL_RSMRST_ON ) != GBLCTL_RSMRST_ON );
9 C% {) v2 a( n8 `0 B
0 [; W" a! M3 u. G mcasp->regs->XGBLCTL |= GBLCTL_XFRST_ON; 2 X$ K: c! L4 a" a6 U
while ( ( mcasp->regs->XGBLCTL & GBLCTL_XFRST_ON ) != GBLCTL_XFRST_ON );
' F" d* z) D& p& {$ |7 ] mcasp->regs->RGBLCTL |= GBLCTL_RFRST_ON;
- i4 e5 ~3 X) v" ^. U while ( ( mcasp->regs->RGBLCTL & GBLCTL_RFRST_ON ) != GBLCTL_RFRST_ON );
4 z7 Y3 J5 s h% E" K8 G( b
+ J7 _8 u# d7 R5 b( Z CSR = 0x0000;
9 L5 F& O, T% G$ k INTC_INTMUX1 = 0x3d;
+ A+ r% j7 R$ \; M6 e ISTP = (unsigned int)vectors; e; R+ z' Q+ `1 P& t
ICR = 0xFFF0;
: ]+ o+ E; U' s' i IER |= 0x12;
0 [$ P5 r! l# {' O, S+ Y CSR |= 0x01;
3 k! W' y) G9 ~( ]. g; Z, Q+ Y8 p. F
; q1 C3 Q* b& n+ f- c; N
/ X3 W& p) L: o: }2 i+ }; T
, Q- d/ p0 J' i( C) I- c3 ^& Y还有就是两个输入输出函数:# j x1 v, \7 z3 @0 J4 R# V" Z
void output_sample(Int32 out_data)
0 X2 o0 d/ j, p, k( ^9 z& Y{" n3 h2 u# [, f8 B1 K3 @
AIC31_data.uint = out_data; ' o B" k( X* {2 H
MCASP1_XBUF5_32BIT = AIC31_data.uint;8 y2 ~7 b, l8 U$ M, x7 a6 }
}
- b- [ g5 B( j4 I: X. T
- z0 \; w* F4 C/ M8 |; IInt32 input_sample(void)
! l% {* k; n8 K/ W$ Y% @1 J" P{
. |: ?8 f+ v8 L! E AIC31_data.uint = MCASP1_RBUF0_32BIT;
- T' {3 F' t( Q4 f+ e# h B. G. x return (AIC31_data.uint);- x0 g$ U0 }, Q! \9 A$ } y
}6 \" M$ i6 ]# C% ~. o+ F# @2 C. J' {" a
; J* \, v6 }9 {$ _& | |
|