|
|
C6747和C6748感觉差不多,我想实现McASP发送中断方式控制音频信号,在轮询的例程基础上改的,轮询程序可以实现,但是中断一直实现不了,也找不到错误,求大神帮忙!下边是主要程序:
) l' E7 {, I% P+ g3 _main文件:$ \8 x# K' a. K' N
interrupt void interrupt4(void) % }, e, b4 b+ }
{
( u) k5 b( [ W* P) j Uint32 sample;+ O/ f, A4 N& _+ X9 ^3 `# L
$ H0 v; u( z/ O: a
sample = input_sample(); // read L + R samples from ADC6 i* O6 L$ _/ H% d
output_sample(sample); // write L + R samples to DAC
* p9 A' R1 D6 H1 G return;
& n, B8 p1 D3 X6 t' b: ?2 w}
1 C/ i( D4 ^1 C; y& A0 E! n {6 V1 ~9 T+ ^$ f
int main( void )
$ Y. D$ b' c# j' X/ R. W{
$ h* p# o" T% b P- @0 F9 h- K8 h2 T* O/ g+ y
/* Initialize BSL */
/ o p. M/ ]; u3 M9 h EVMC6747_init( );
7 X3 b0 o4 T% Y/ P) J1 y `0 e7 ^ /* Call evmc6747_intr function */1 L9 ?# y+ n# W' r: Q
aic3106_init( );' c% K% r4 c0 {/ E1 M
while(1);
1 L, \' W! [. |5 h, ~}4 h& }+ @3 c! C4 P
{8 Z* g- A+ d$ h1 y
% ?) Q7 g& d; R' ?aic3106_init文件的一部分,McASP配置部分,采用内部时钟,I2S方式,同步传输。音频芯片的配置应该没问题: F4 S4 ~, P% @4 f* _8 W4 z( T4 u
/* Initialize MCASP1 */
8 Q' Y- X+ ^. m5 I mcasp = &MCASP_MODULE_1;
' A# @9 }3 P& j5 C# H4 z4 w mcasp->regs->GBLCTL = 0; // Reset$ Y- ]5 X [2 B/ p( C' m# [% r) G
mcasp->regs->RGBLCTL = 0; // Reset RX
. p2 v m& j+ V6 r mcasp->regs->XGBLCTL = 0; // Reset TX
; E- [2 \- A: k% ] mcasp->regs->PWRDEMU = 1; // Free-running
# @; r9 ^/ e" v. C* M // configure McASP0 receive registers/ p% ~0 U9 _& [
mcasp->regs->RMASK = 0xFFFFFFFF; // No padding used
8 \% R/ |! U0 _- |. k2 }* d" H mcasp->regs->RFMT = 0x00018078; // MSB 16bit, 0-delay, no pad, CFGBus. _0 t' v9 G! q# G2 l$ P* a
mcasp->regs->AFSRCTL = 0x00000112; // 2TDM, 1bit Falling, External FS, word
' q7 V6 J; l6 {2 |% v u$ h; N6 h0 b# D mcasp->regs->ACLKRCTL = 0x000000AF; // Rising INTERNAL CLK,(from tx side)
" d: E- p0 U/ W$ z) Z/ n) @3 D mcasp->regs->AHCLKRCTL = 0x00000000; // INT CLK (from tx side)
/ j: @! b) P! W* l% [) k- j mcasp->regs->RTDM = 0x00000003; // Slots 0,10 h% J- }2 G4 ]. F6 O% B# k: j
mcasp->regs->RINTCTL = 0x00000000; // Not used
6 X' X3 { O0 w. S2 h2 Z# ~' u, ^ mcasp->regs->RCLKCHK = 0x00FF0008; // 255-MAX 0-MIN, div-by-256& A/ K: B. x" \8 x$ W
X8 j. s7 q# d' [$ j: n mcasp->regs->XMASK = 0xFFFFFFFF; // No padding used' P, T* m0 g# c* ~) a# v
mcasp->regs->XFMT = 0x00018078; // MSB 16bit, 0-delay, no pad, CFGBus
; z0 T& s" P$ q4 C! c mcasp->regs->AFSXCTL = 0x00000112; // 2TDM, 1bit Rising edge INTERNAL FS, word- O) H2 i7 n9 r) J( G1 q
mcasp->regs->ACLKXCTL = 0x000000AF; // ASYNC, Rising INTERNAL CLK, div-by-16
/ l6 A" l: _) m) k! @5 v mcasp->regs->AHCLKXCTL = 0x00000000; // EXT CLK
" A g* |* o4 D$ G: G d; Q mcasp->regs->XTDM = 0x00000003; // Slots 0,1
( r$ _% {3 C; c mcasp->regs->XINTCTL = 0x00000020; // interrupt on transmit
% C0 C0 U6 E9 W2 J! x mcasp->regs->XCLKCHK = 0x00FF0008; // 255-MAX 0-MIN, div-by-256
l! N' L2 a# i- e
' W: o' V6 R6 v$ _5 B6 T( { mcasp->regs->SRCTL5 = 0x000D; // MCASP1.AXR1[5] --> DIN
5 y+ h4 r1 T" `; X o* s mcasp->regs->SRCTL0 = 0x000E; // MCASP1.AXR1[0] <-- DOUT2 [0 a- ^% Q" ] r5 j- j- _3 F! o v
mcasp->regs->PFUNC = 0; // All MCASPs; {+ s6 B* b/ f W, Y: m
mcasp->regs->PDIR = 0x14000020; // All inputs except AXR0[5], ACLKX1, AFSX1; p$ M2 B5 Z7 O, u9 U
: o/ R; b( b' X; C: O
mcasp->regs->DITCTL = 0x00000000; // Not used- q+ }8 N7 Y, S3 @8 R
mcasp->regs->DLBCTL = 0x00000000; // Not used! _* Y5 {- {0 F3 ^& V
mcasp->regs->AMUTE = 0x00000000; // Not used9 ?7 {/ O/ e, L b
5 `5 p# @9 \$ }
/* Starting sections of the McASP*/
, c) Z/ M! x3 B$ \9 q4 v mcasp->regs->XGBLCTL |= GBLCTL_XHCLKRST_ON;
( y6 J1 T) r3 e while ( ( mcasp->regs->XGBLCTL & GBLCTL_XHCLKRST_ON ) != GBLCTL_XHCLKRST_ON ); $ @# ?3 n& e) y f0 R: ~" Y
mcasp->regs->RGBLCTL |= GBLCTL_RHCLKRST_ON;
0 b+ Y4 ?) E' y$ h while ( ( mcasp->regs->RGBLCTL & GBLCTL_RHCLKRST_ON ) != GBLCTL_RHCLKRST_ON );6 L3 g/ @& t) r1 |5 o) X. ^3 A
7 v$ {4 l+ l8 Y5 y, J9 ^
mcasp->regs->XGBLCTL |= GBLCTL_XCLKRST_ON;
: d" p/ T! D0 j: g* e7 O7 b while ( ( mcasp->regs->XGBLCTL & GBLCTL_XCLKRST_ON ) != GBLCTL_XCLKRST_ON );
# s, a: Y$ y- g9 C. a- M mcasp->regs->RGBLCTL |= GBLCTL_RCLKRST_ON;
' |! K* T. s6 X! ]% L3 H while ( ( mcasp->regs->RGBLCTL & GBLCTL_RCLKRST_ON ) != GBLCTL_RCLKRST_ON );% o' o0 V% C7 n/ o" Q. b8 m
4 A$ X/ C" ~: M4 {/ ]& `
mcasp->regs->XSTAT = 0x0000ffff; ) O* g" @1 [+ H, W
mcasp->regs->RSTAT = 0x0000ffff;
3 o2 ?- M& k' u m$ h; w
2 h7 c8 y" N7 d mcasp->regs->XGBLCTL |= GBLCTL_XSRCLR_ON;
" @4 S- |: L2 Y' z while ( ( mcasp->regs->XGBLCTL & GBLCTL_XSRCLR_ON ) != GBLCTL_XSRCLR_ON );7 ?) o- d+ U3 {% m, u; [* J
mcasp->regs->RGBLCTL |= GBLCTL_RSRCLR_ON;
: _; p% b- p7 p1 h while ( ( mcasp->regs->RGBLCTL & GBLCTL_RSRCLR_ON ) != GBLCTL_RSRCLR_ON );
; d9 `8 B1 d! K! ?
2 i2 J' q! s- h' S0 a0 G5 [/ K1 i /* Write a 0, so that no underrun occurs after releasing the state machine */3 o+ J: J) t4 ~0 {! _
mcasp->regs->XBUF5 = 0;3 F9 a/ |2 t$ D3 J l6 Z( j% @* X
mcasp->regs->RBUF0 = 0;( G" E1 M9 Q/ l7 C" g$ ?4 H
" A L# m7 r' n5 b/ }+ U
mcasp->regs->XGBLCTL |= GBLCTL_XSMRST_ON;
3 {* [) O3 n$ A" {% G/ q; ?# R while ( ( mcasp->regs->XGBLCTL & GBLCTL_XSMRST_ON ) != GBLCTL_XSMRST_ON );
* R# m1 t& J! h$ r2 D mcasp->regs->RGBLCTL |= GBLCTL_RSMRST_ON; 1 C0 f2 k# U ?& W5 X
while ( ( mcasp->regs->RGBLCTL & GBLCTL_RSMRST_ON ) != GBLCTL_RSMRST_ON );
2 j2 _9 L; r$ N! p* _4 |
( d, o" z# z, ] mcasp->regs->XGBLCTL |= GBLCTL_XFRST_ON;
7 i) m" B2 \8 c4 S- Y' ^! I4 U while ( ( mcasp->regs->XGBLCTL & GBLCTL_XFRST_ON ) != GBLCTL_XFRST_ON );9 u' Y- B. x$ s( X" l& L
mcasp->regs->RGBLCTL |= GBLCTL_RFRST_ON;
$ F2 t- K* K w: R% T# T while ( ( mcasp->regs->RGBLCTL & GBLCTL_RFRST_ON ) != GBLCTL_RFRST_ON );$ f3 G4 h& M/ `! D& j1 u
/ T8 e$ p* |/ `9 P+ v
CSR = 0x0000;5 x& s0 d- O; m; x1 z" ]+ U
INTC_INTMUX1 = 0x3d;7 Y* F% V+ {% E: o
ISTP = (unsigned int)vectors;
0 I* q# i! F5 q2 U, L ICR = 0xFFF0;
6 b6 j4 k2 A) M; _# R, }' O IER |= 0x12; " @$ E" L. Q4 t
CSR |= 0x01;
# g' _) u6 {, B a$ r+ Q5 Q B1 m& I+ e
2 g8 ~, w; W: s2 x) v' p$ h9 l% r+ X
% {2 |$ }: M( m" P/ C3 B+ A- v还有就是两个输入输出函数:+ M0 L6 W% ~- C" u0 h% I; |
void output_sample(Int32 out_data)) i& p0 u2 z5 p9 E) y% J
{
, X/ x# W! K" H9 z* U+ Q AIC31_data.uint = out_data;
% Q9 }* E. w* a% x; N3 P" F# @8 k MCASP1_XBUF5_32BIT = AIC31_data.uint;# y% u4 t4 b2 u% [. A& u
}
) P1 R, E; T" J$ f3 e
7 ?" P+ k( o# uInt32 input_sample(void)
- D3 m1 k+ e3 i( L- |* @0 X8 c{ & |/ v4 y: ~6 H
AIC31_data.uint = MCASP1_RBUF0_32BIT;
# A. \/ `( |) L1 f! w+ V- n return (AIC31_data.uint);
! Y; U0 T( k, _& Q$ y' L* a}2 E& Z+ c( z' \7 u
( L a' a' w y+ ?
|
|