|
|
C6747和C6748感觉差不多,我想实现McASP发送中断方式控制音频信号,在轮询的例程基础上改的,轮询程序可以实现,但是中断一直实现不了,也找不到错误,求大神帮忙!下边是主要程序:
$ F8 y) Y, i% E1 q9 kmain文件:
! b( O! R$ C& o9 P8 e) ]) `interrupt void interrupt4(void)
2 c# Z8 h6 R8 I% l1 J" J{3 F+ G8 z2 ]8 W' w; s4 L
Uint32 sample;+ n2 m: V# Q) ?3 w2 k0 V
+ V0 b4 Z& y' q; H- @, M; m- |$ N7 I" k sample = input_sample(); // read L + R samples from ADC
% f3 K" `2 [* h2 l5 W1 o" B output_sample(sample); // write L + R samples to DAC
) Z0 K/ q O7 y- Q# w. l return;
% o2 H" S0 [" v6 ], }6 t}/ [0 ^8 I& E i" |/ _% ^
4 p/ Y- a2 J& {. a" Rint main( void )2 D8 |+ r0 i" h% P) { e4 p- N
{
8 \' q: U6 r' i
2 v! _4 E" _6 k* k: |9 I* U l% ~ /* Initialize BSL */
$ i7 u$ M+ u; H- R" F EVMC6747_init( );5 V1 ^% ^$ G+ X; i4 ~- l
/* Call evmc6747_intr function */
7 n5 e7 T/ T- q/ S aic3106_init( );
+ a6 ^4 U2 h" Y while(1);
- D2 C1 j+ `, _( O$ C}
+ [; S8 b% J+ u5 k1 M0 W' H7 v- Z) i$ `4 U
2 |- C5 W: O: |1 v$ [aic3106_init文件的一部分,McASP配置部分,采用内部时钟,I2S方式,同步传输。音频芯片的配置应该没问题1 }7 r" u( d# i+ m. Y, F
/* Initialize MCASP1 */' }- h4 {8 K9 e3 c# H4 y0 g& z
mcasp = &MCASP_MODULE_1;) g# G% ?2 t+ D3 @
mcasp->regs->GBLCTL = 0; // Reset5 a+ f+ {/ [+ r4 {
mcasp->regs->RGBLCTL = 0; // Reset RX% E, y+ Z6 ^. m1 |5 V$ @
mcasp->regs->XGBLCTL = 0; // Reset TX. u, o3 u2 o; W0 `( U
mcasp->regs->PWRDEMU = 1; // Free-running
, Q, x* G5 ]* G/ _ // configure McASP0 receive registers
! [6 w/ B+ Q5 H% N4 b, l2 L& _ mcasp->regs->RMASK = 0xFFFFFFFF; // No padding used% ? S8 }. [! E' }- v+ r. I, m- o* F
mcasp->regs->RFMT = 0x00018078; // MSB 16bit, 0-delay, no pad, CFGBus
# o R$ a+ a" M A# ^3 w2 a6 b mcasp->regs->AFSRCTL = 0x00000112; // 2TDM, 1bit Falling, External FS, word$ w" w: H8 f. ?% ]
mcasp->regs->ACLKRCTL = 0x000000AF; // Rising INTERNAL CLK,(from tx side)7 K, k' \. v. S. J
mcasp->regs->AHCLKRCTL = 0x00000000; // INT CLK (from tx side)
2 I! i/ y4 }4 d2 b mcasp->regs->RTDM = 0x00000003; // Slots 0,1
# [' R0 p/ C0 [* ]. \ mcasp->regs->RINTCTL = 0x00000000; // Not used9 u. i( ^, Q9 B3 }) v, k
mcasp->regs->RCLKCHK = 0x00FF0008; // 255-MAX 0-MIN, div-by-256( B! Y+ @. k9 F2 |$ T4 C
E2 G& h: A" Y
mcasp->regs->XMASK = 0xFFFFFFFF; // No padding used7 X$ V/ \& V; v; p6 K. ~9 Z* U
mcasp->regs->XFMT = 0x00018078; // MSB 16bit, 0-delay, no pad, CFGBus
+ F1 ~) |: R% K. x% A# f0 M9 B3 Z mcasp->regs->AFSXCTL = 0x00000112; // 2TDM, 1bit Rising edge INTERNAL FS, word
* [$ b1 b$ a# P( m. q mcasp->regs->ACLKXCTL = 0x000000AF; // ASYNC, Rising INTERNAL CLK, div-by-16
& j9 j7 A5 o. k6 d mcasp->regs->AHCLKXCTL = 0x00000000; // EXT CLK
# }2 \& J, n! O' r% d+ | q mcasp->regs->XTDM = 0x00000003; // Slots 0,1
# P( n% W/ u! \! B: B4 Q; x mcasp->regs->XINTCTL = 0x00000020; // interrupt on transmit1 @* c0 c: j1 p! g4 j- e- B
mcasp->regs->XCLKCHK = 0x00FF0008; // 255-MAX 0-MIN, div-by-256
# J. |$ r8 q1 Z( ^. O4 Y2 s
9 N c4 ]! w& @' e! M( P f mcasp->regs->SRCTL5 = 0x000D; // MCASP1.AXR1[5] --> DIN
- H, v9 J7 x; i( h# F/ k mcasp->regs->SRCTL0 = 0x000E; // MCASP1.AXR1[0] <-- DOUT3 I& l3 x5 w& T* ]# i
mcasp->regs->PFUNC = 0; // All MCASPs
" w- O9 s8 t, u mcasp->regs->PDIR = 0x14000020; // All inputs except AXR0[5], ACLKX1, AFSX12 g7 ~4 M! ]* K
6 V2 \8 c, K" g p' ^) h( k
mcasp->regs->DITCTL = 0x00000000; // Not used
, w% G2 v, X: h( ]( g0 F mcasp->regs->DLBCTL = 0x00000000; // Not used
5 S; ]% A4 r2 d5 H- w$ X B mcasp->regs->AMUTE = 0x00000000; // Not used
, ]' r0 b2 E9 t- e1 f2 ^" m5 y8 W
/ e$ i; ^6 G* u# ]! E/ S/* Starting sections of the McASP*/
4 L" z# _# s9 D9 I/ l5 c1 Z mcasp->regs->XGBLCTL |= GBLCTL_XHCLKRST_ON; 1 _8 [6 s. Q% s8 S/ U, R+ j
while ( ( mcasp->regs->XGBLCTL & GBLCTL_XHCLKRST_ON ) != GBLCTL_XHCLKRST_ON );
1 c; u0 ~4 C% M' ]' l, M0 e mcasp->regs->RGBLCTL |= GBLCTL_RHCLKRST_ON;
) } w6 b# a+ a$ c* h& K while ( ( mcasp->regs->RGBLCTL & GBLCTL_RHCLKRST_ON ) != GBLCTL_RHCLKRST_ON );
/ B! |9 g; g* q3 ` ?/ b' |4 S' r. H1 e) f/ ~% H& T* F
mcasp->regs->XGBLCTL |= GBLCTL_XCLKRST_ON;
O1 T1 I8 N# ?9 t* Y& L* C% K while ( ( mcasp->regs->XGBLCTL & GBLCTL_XCLKRST_ON ) != GBLCTL_XCLKRST_ON );) R# c& I7 l* w9 \
mcasp->regs->RGBLCTL |= GBLCTL_RCLKRST_ON;
7 w; w# ^# D7 ^7 E6 M+ B2 p/ J* w while ( ( mcasp->regs->RGBLCTL & GBLCTL_RCLKRST_ON ) != GBLCTL_RCLKRST_ON );
6 |) |. P1 F9 a5 Z+ _9 r$ |% [
0 A: c( ~0 k" i mcasp->regs->XSTAT = 0x0000ffff; + g" W/ W' y% `
mcasp->regs->RSTAT = 0x0000ffff;
# l' A0 ?1 B, K" z; _9 ~
/ p1 C( b. J8 Z$ T1 o w1 G1 @ A mcasp->regs->XGBLCTL |= GBLCTL_XSRCLR_ON;
- x: d3 P) m* p while ( ( mcasp->regs->XGBLCTL & GBLCTL_XSRCLR_ON ) != GBLCTL_XSRCLR_ON );
4 x4 ]- k4 B. E- J mcasp->regs->RGBLCTL |= GBLCTL_RSRCLR_ON; ! m! {9 E+ p7 Z5 r9 h( [
while ( ( mcasp->regs->RGBLCTL & GBLCTL_RSRCLR_ON ) != GBLCTL_RSRCLR_ON );
% q! Z$ c% d( C9 D( r$ a
6 U" |! h; [+ j9 M8 g/ u3 _ /* Write a 0, so that no underrun occurs after releasing the state machine */
6 N2 m+ E( H# w& G mcasp->regs->XBUF5 = 0;
( r9 R( G! ~( n, O7 M1 h mcasp->regs->RBUF0 = 0;
/ n* x8 \( X r8 G0 q
1 r7 X/ d+ Y. b6 i6 ]5 S" g mcasp->regs->XGBLCTL |= GBLCTL_XSMRST_ON; 3 v1 _* q% [) U8 R) D4 \9 Q
while ( ( mcasp->regs->XGBLCTL & GBLCTL_XSMRST_ON ) != GBLCTL_XSMRST_ON );# ]4 y0 v( Z: D9 Q
mcasp->regs->RGBLCTL |= GBLCTL_RSMRST_ON; ( m6 Q# i6 @9 J
while ( ( mcasp->regs->RGBLCTL & GBLCTL_RSMRST_ON ) != GBLCTL_RSMRST_ON );
9 h$ ^0 [ `- {" ?' U$ ?; n- v w$ d
mcasp->regs->XGBLCTL |= GBLCTL_XFRST_ON;
1 ^/ q1 e0 }6 I( _- a6 W while ( ( mcasp->regs->XGBLCTL & GBLCTL_XFRST_ON ) != GBLCTL_XFRST_ON );
9 b: R3 \) o2 K9 t1 u mcasp->regs->RGBLCTL |= GBLCTL_RFRST_ON;
% d- F) c* W |7 [$ g while ( ( mcasp->regs->RGBLCTL & GBLCTL_RFRST_ON ) != GBLCTL_RFRST_ON );
1 \! u% a r) M
9 {6 A3 |7 ]9 t1 a# l- T* v+ n CSR = 0x0000;" x. k' x8 r) [& G+ p
INTC_INTMUX1 = 0x3d;. E% K" }+ \: i6 a/ {
ISTP = (unsigned int)vectors;
. l' f* }% {! ]1 X4 O% _ ICR = 0xFFF0; 9 x( ^/ ^3 H9 l" a6 m9 q9 V
IER |= 0x12; ; v/ m' A; M8 c0 ]& s
CSR |= 0x01;
$ e/ k* S R8 ^, t! H- M4 F k! h5 E
: f) }6 Q R9 a h7 Q, h0 m
2 r! G; ?7 `' F* W还有就是两个输入输出函数:: _! u; D7 R3 j1 r9 w
void output_sample(Int32 out_data)0 T/ L4 l! s1 |6 m1 J- p
{
, E9 j! Q3 L' b- W7 }$ d A7 _ AIC31_data.uint = out_data; ; V4 n, ~" o6 Z: J* Q6 g% N
MCASP1_XBUF5_32BIT = AIC31_data.uint;
: k0 l& n9 L" [$ E1 a! L}
* n9 E6 f% T* p n0 j; N8 ^) x, B( P% E9 {' a
Int32 input_sample(void)- e1 l8 q" {, F Z6 V. ^
{
# |! k7 Z3 i) F9 D7 V3 V AIC31_data.uint = MCASP1_RBUF0_32BIT;: h: _: U7 Q& Y, Z' @
return (AIC31_data.uint);! p, [* c- ]3 m, e
}6 S% U+ L1 F# {- q: e1 y6 b
/ N0 M' K( C! D) _ |
|