|
|
C6747和C6748感觉差不多,我想实现McASP发送中断方式控制音频信号,在轮询的例程基础上改的,轮询程序可以实现,但是中断一直实现不了,也找不到错误,求大神帮忙!下边是主要程序: Z* M9 [1 }7 E. S$ Y6 C& J7 C
main文件:
; {' m# _' B8 X9 H! k; Ginterrupt void interrupt4(void) 0 B& z4 M/ m5 c+ i
{4 N! @: V; x. j% Z1 N5 \. U
Uint32 sample;
9 _) _( C4 O8 E7 Z; l7 `
' `9 T$ \* f& J5 a sample = input_sample(); // read L + R samples from ADC
; }0 X' W' h) [0 x* o5 P) A output_sample(sample); // write L + R samples to DAC
8 x' \$ c, L5 @) M/ d6 y( g6 _ return;0 u# K' D) ?) k6 ~' @2 y
}$ D5 ]" L8 ?4 V- {' _% k% M
3 \, ]7 m; q+ X! Iint main( void )
) t: @# K0 m0 j! f8 `9 ^{
6 K- ^" X+ d! I- V0 j, M
5 K" l i4 k9 a# e$ U4 E& n /* Initialize BSL */
$ K& U1 ^3 f1 y: K EVMC6747_init( );2 E- a" P! X7 t9 X; I4 F1 r) p
/* Call evmc6747_intr function */
. Z0 Q8 `( n3 t! |. P4 I aic3106_init( );2 d; l% a7 O& N! m* J9 t
while(1);7 i6 T/ o. o, }+ `$ m" f: n
}2 w5 B5 b8 }3 b2 S
4 x. i- |4 X& p9 l( i) R* ?/ p0 i$ G' t# d3 U8 l. ?5 p& E0 G0 R' R2 z
aic3106_init文件的一部分,McASP配置部分,采用内部时钟,I2S方式,同步传输。音频芯片的配置应该没问题) h& ?# c1 J0 N& Y9 O2 ]# I/ o0 [& o
/* Initialize MCASP1 */1 t$ O3 A! S6 S7 A
mcasp = &MCASP_MODULE_1;% g% {4 ^7 ]; e# ^$ w/ {
mcasp->regs->GBLCTL = 0; // Reset
, G& r" H9 ~: ~' r& s mcasp->regs->RGBLCTL = 0; // Reset RX6 o+ r! G- U$ ]! d/ f2 U8 c
mcasp->regs->XGBLCTL = 0; // Reset TX9 M) d( ]' ]9 A. ^6 O8 b
mcasp->regs->PWRDEMU = 1; // Free-running
: H8 t+ z6 B8 D3 O // configure McASP0 receive registers1 [# ~/ Q: q& X, Q
mcasp->regs->RMASK = 0xFFFFFFFF; // No padding used
: s% I' `" Y1 X7 \/ S mcasp->regs->RFMT = 0x00018078; // MSB 16bit, 0-delay, no pad, CFGBus
, J7 R5 ` m7 R. C0 }9 S mcasp->regs->AFSRCTL = 0x00000112; // 2TDM, 1bit Falling, External FS, word
- @% ]: c5 Y! o& |: `( E2 k+ w mcasp->regs->ACLKRCTL = 0x000000AF; // Rising INTERNAL CLK,(from tx side)
, a% Z8 ^# ]" \" F" P mcasp->regs->AHCLKRCTL = 0x00000000; // INT CLK (from tx side)
- ~, S4 {5 I4 P9 X! @ mcasp->regs->RTDM = 0x00000003; // Slots 0,1( D# T% f; a4 u' E1 k/ W
mcasp->regs->RINTCTL = 0x00000000; // Not used' v3 z6 r' A( R1 K5 o7 m
mcasp->regs->RCLKCHK = 0x00FF0008; // 255-MAX 0-MIN, div-by-256( t9 D# S" _8 G- w
& _- D8 t9 H$ r
mcasp->regs->XMASK = 0xFFFFFFFF; // No padding used x% g6 G: ^: G
mcasp->regs->XFMT = 0x00018078; // MSB 16bit, 0-delay, no pad, CFGBus
5 s8 F- D# E5 a' v mcasp->regs->AFSXCTL = 0x00000112; // 2TDM, 1bit Rising edge INTERNAL FS, word
) A! I, w8 C' I( Q* q( h6 [: {% a! u; Q mcasp->regs->ACLKXCTL = 0x000000AF; // ASYNC, Rising INTERNAL CLK, div-by-16
1 S# f7 A- L& B mcasp->regs->AHCLKXCTL = 0x00000000; // EXT CLK: q- H) |3 V* o2 V8 J% ~
mcasp->regs->XTDM = 0x00000003; // Slots 0,1
! ?2 `6 g' u# t# I9 W- y9 S mcasp->regs->XINTCTL = 0x00000020; // interrupt on transmit
. e( H! Z, i% W/ Q$ Q mcasp->regs->XCLKCHK = 0x00FF0008; // 255-MAX 0-MIN, div-by-256
0 I5 N+ C" f: m/ v3 ~# |5 M; I8 X/ e* M6 m) y2 g8 A
mcasp->regs->SRCTL5 = 0x000D; // MCASP1.AXR1[5] --> DIN5 R9 ^! e. O1 F+ t/ }( z
mcasp->regs->SRCTL0 = 0x000E; // MCASP1.AXR1[0] <-- DOUT# u4 o* w' G# r8 e7 w0 ]% W
mcasp->regs->PFUNC = 0; // All MCASPs2 D6 e6 e% n5 P" ~
mcasp->regs->PDIR = 0x14000020; // All inputs except AXR0[5], ACLKX1, AFSX1/ z, x# c `/ |/ q
& r/ [* n D) \9 ?
mcasp->regs->DITCTL = 0x00000000; // Not used
% G( c0 b4 Y7 ?4 K3 C/ d mcasp->regs->DLBCTL = 0x00000000; // Not used
* ]! t, J z! n/ W5 [ mcasp->regs->AMUTE = 0x00000000; // Not used
9 F# l7 v% P! k. u' I2 X4 h: X. ` S
/* Starting sections of the McASP*/
4 N" ?8 R! O; ] mcasp->regs->XGBLCTL |= GBLCTL_XHCLKRST_ON;
! k v' R4 D8 t7 t/ f8 ]8 Q1 N1 a while ( ( mcasp->regs->XGBLCTL & GBLCTL_XHCLKRST_ON ) != GBLCTL_XHCLKRST_ON ); " l8 K; j' ]- s( A: ?+ _% K
mcasp->regs->RGBLCTL |= GBLCTL_RHCLKRST_ON; 5 o: E) u; d J0 S4 m+ ]1 J/ I- [3 |# D
while ( ( mcasp->regs->RGBLCTL & GBLCTL_RHCLKRST_ON ) != GBLCTL_RHCLKRST_ON );
' \4 o, O+ q, L _) }! e* z+ c" |6 V3 p. P" D$ C, ^
mcasp->regs->XGBLCTL |= GBLCTL_XCLKRST_ON; - h# b/ c7 e Y/ ?: B
while ( ( mcasp->regs->XGBLCTL & GBLCTL_XCLKRST_ON ) != GBLCTL_XCLKRST_ON );
3 A. {) z, v, q( a3 T) w mcasp->regs->RGBLCTL |= GBLCTL_RCLKRST_ON;
/ u! R2 _# I' I/ k4 [ while ( ( mcasp->regs->RGBLCTL & GBLCTL_RCLKRST_ON ) != GBLCTL_RCLKRST_ON );/ P* @+ t A* r7 K; d. b' \
( q. A. q- Z5 }/ s mcasp->regs->XSTAT = 0x0000ffff; # E1 M3 Y+ |3 t+ e0 |: {6 o
mcasp->regs->RSTAT = 0x0000ffff;
, R: X R/ s/ ?# N% S: {6 h# W# c5 n/ @) s
mcasp->regs->XGBLCTL |= GBLCTL_XSRCLR_ON;3 n0 O6 p, O6 r/ {3 P
while ( ( mcasp->regs->XGBLCTL & GBLCTL_XSRCLR_ON ) != GBLCTL_XSRCLR_ON );
% _1 i" H! Y f6 {. ^ mcasp->regs->RGBLCTL |= GBLCTL_RSRCLR_ON; ' @+ X; C& S! a4 i" b- z8 _
while ( ( mcasp->regs->RGBLCTL & GBLCTL_RSRCLR_ON ) != GBLCTL_RSRCLR_ON );/ z( \. H" q, H0 k; F! _
% Y: S0 S# d+ h. ~
/* Write a 0, so that no underrun occurs after releasing the state machine */
, W5 h) w, U V, J! _ mcasp->regs->XBUF5 = 0; S# A, m! U8 W* C
mcasp->regs->RBUF0 = 0;' X% L3 U. W7 ?
# m; L! |' l$ y- f. q) w. L mcasp->regs->XGBLCTL |= GBLCTL_XSMRST_ON; 9 W0 }$ g7 a2 T: c. Z I* `+ y/ m
while ( ( mcasp->regs->XGBLCTL & GBLCTL_XSMRST_ON ) != GBLCTL_XSMRST_ON );; ^0 U4 u: A- I: A
mcasp->regs->RGBLCTL |= GBLCTL_RSMRST_ON;
3 x e1 d/ P' Y+ l while ( ( mcasp->regs->RGBLCTL & GBLCTL_RSMRST_ON ) != GBLCTL_RSMRST_ON );
1 s5 T5 H6 Q0 Y: t6 N( c: x
8 n" y: ^% a }7 o, O- Z- E; X mcasp->regs->XGBLCTL |= GBLCTL_XFRST_ON;
/ X- u( j) F0 E# [8 I while ( ( mcasp->regs->XGBLCTL & GBLCTL_XFRST_ON ) != GBLCTL_XFRST_ON );
6 g2 I. x$ x/ x% [2 U4 `1 s6 { mcasp->regs->RGBLCTL |= GBLCTL_RFRST_ON;
2 u) `4 q: ?5 W( A; c% C- E5 E& i while ( ( mcasp->regs->RGBLCTL & GBLCTL_RFRST_ON ) != GBLCTL_RFRST_ON );
# r& H. V! j+ E* _# @( f/ I3 A) k% p/ w5 V4 Q- N; N* |9 v. ?
CSR = 0x0000;, c& E) s+ F, _6 y* P, p8 {
INTC_INTMUX1 = 0x3d;7 Z1 B9 u h& d- K( |& d
ISTP = (unsigned int)vectors;6 Y( q" _$ }- `( J7 ?! h
ICR = 0xFFF0; : p* ^& A( {2 Y
IER |= 0x12;
) X) i4 j/ C# s, L CSR |= 0x01; ) W8 i* s( C& b: Q! Y- }
- N: W/ D7 I$ @8 M0 V$ ^6 r# c( V8 |# L( V& d' N- E3 d, O, C0 O; I
8 [% X" i: U: k; u4 U- ?
还有就是两个输入输出函数:5 ?) Z& w2 i) y( }/ m
void output_sample(Int32 out_data)
8 ]" I8 z! `2 Z7 f% g( U' Q8 A [{
# E! R0 i+ w7 Y( F" l' ] AIC31_data.uint = out_data; 1 F7 ?: u- q1 M, ~, j7 s% }" Y z& U
MCASP1_XBUF5_32BIT = AIC31_data.uint;$ O) v# Z& n5 S# J9 m0 H
}" K o9 m W* P, l4 A# t- V: U7 \* {
- H# Y8 t, R$ ?# \
Int32 input_sample(void)+ O3 W# p, P% b8 u
{ - u: |7 d' Y4 H( r4 \5 w
AIC31_data.uint = MCASP1_RBUF0_32BIT;) S8 r' { X1 q; V1 ?% r
return (AIC31_data.uint);
, T) W+ u& F- F. |& k Z6 ~}
& m# ? p8 s/ D& l9 O8 J, [, {$ k% _) O' ^* M) U
|
|