|
|
C6747和C6748感觉差不多,我想实现McASP发送中断方式控制音频信号,在轮询的例程基础上改的,轮询程序可以实现,但是中断一直实现不了,也找不到错误,求大神帮忙!下边是主要程序:
" y j+ a0 i4 y9 [main文件:
6 k2 Z0 b+ _. U1 r9 Dinterrupt void interrupt4(void)
# W4 B. W1 M) e0 R{) }& z W4 `/ [& J; @ Y
Uint32 sample;" F/ u1 m8 \7 E6 a
' ]( W/ V1 Z7 S' t! b
sample = input_sample(); // read L + R samples from ADC# x+ P! @; Y" {1 q
output_sample(sample); // write L + R samples to DAC
' o. K/ F6 z, _- v( a2 M return;& N0 {: o2 o+ t7 s* \
}
9 }, b1 ]' o% O4 ?3 J; N5 s
% F1 m) }5 ?1 r! e* i) E# Bint main( void )' e; M! T/ E7 Y: ] [3 n
{
- @6 ?$ ~/ p+ C. R7 e
y0 ]/ ?' l6 n- K% T /* Initialize BSL */" B0 Q$ j, |8 O# o7 z n+ s
EVMC6747_init( );6 n% g: y4 |7 p$ j; K
/* Call evmc6747_intr function */
% E3 |8 `6 ?& {6 G$ o1 R aic3106_init( );& p+ @- N! n( J- m) l! A- E
while(1);" S( L; ~4 D. N& w) y5 p' _
}2 Z( K. `( ^# }/ S
# d+ h; a0 c) i' P- \
. L9 s& }" R3 B1 ]; t. laic3106_init文件的一部分,McASP配置部分,采用内部时钟,I2S方式,同步传输。音频芯片的配置应该没问题
3 c( L( O$ j {6 Y+ A/* Initialize MCASP1 */; h2 r% k+ F; B9 f: |
mcasp = &MCASP_MODULE_1;
! ^5 k3 R7 x2 B6 x" A: ] mcasp->regs->GBLCTL = 0; // Reset9 K$ s9 ]/ A f, _1 b) c5 J F
mcasp->regs->RGBLCTL = 0; // Reset RX
% O/ L3 S% c5 X mcasp->regs->XGBLCTL = 0; // Reset TX! p0 p7 L( F' L) x' R- y" B8 y8 f5 i
mcasp->regs->PWRDEMU = 1; // Free-running
8 n1 z( |0 U# h' ~+ \' Z$ Q // configure McASP0 receive registers
% f0 E; I& m0 Z e2 b mcasp->regs->RMASK = 0xFFFFFFFF; // No padding used
/ u1 ^: S0 x; [, C1 {( x, I# n mcasp->regs->RFMT = 0x00018078; // MSB 16bit, 0-delay, no pad, CFGBus! x- V' M4 y8 p0 r" R
mcasp->regs->AFSRCTL = 0x00000112; // 2TDM, 1bit Falling, External FS, word/ o; [3 Y6 t: \0 ?5 C" C
mcasp->regs->ACLKRCTL = 0x000000AF; // Rising INTERNAL CLK,(from tx side): R3 y5 M0 a0 p H0 |
mcasp->regs->AHCLKRCTL = 0x00000000; // INT CLK (from tx side)* t$ E1 c, N; B9 d; \% p; ?
mcasp->regs->RTDM = 0x00000003; // Slots 0,1
- s! U+ H2 f9 [5 m; ^+ L mcasp->regs->RINTCTL = 0x00000000; // Not used& W# d7 y2 R% c2 C J( S
mcasp->regs->RCLKCHK = 0x00FF0008; // 255-MAX 0-MIN, div-by-256
0 v, j5 e; N4 a' W# b
# C4 u. v3 _, V) v. w mcasp->regs->XMASK = 0xFFFFFFFF; // No padding used
/ }( |) h( c2 E# T& W% y mcasp->regs->XFMT = 0x00018078; // MSB 16bit, 0-delay, no pad, CFGBus' c) n+ ~+ T# X* g8 Y! I
mcasp->regs->AFSXCTL = 0x00000112; // 2TDM, 1bit Rising edge INTERNAL FS, word
- U+ G& d$ E8 O# s0 Z- O0 Z$ T mcasp->regs->ACLKXCTL = 0x000000AF; // ASYNC, Rising INTERNAL CLK, div-by-16
p% k4 u$ @" d$ q' n mcasp->regs->AHCLKXCTL = 0x00000000; // EXT CLK
( e& c( ~* Y0 l0 F4 N e/ P mcasp->regs->XTDM = 0x00000003; // Slots 0,1
. R! B; r/ K- k7 W4 l; q mcasp->regs->XINTCTL = 0x00000020; // interrupt on transmit
: |$ e( W: _. @0 m0 y0 W3 Z( C7 g. M mcasp->regs->XCLKCHK = 0x00FF0008; // 255-MAX 0-MIN, div-by-256
2 s1 G# J X9 N8 N% i6 \% y0 p: E' d P
mcasp->regs->SRCTL5 = 0x000D; // MCASP1.AXR1[5] --> DIN
0 Z0 }9 E. c8 _ mcasp->regs->SRCTL0 = 0x000E; // MCASP1.AXR1[0] <-- DOUT( q. A: \& ?' q8 B& V: c# u
mcasp->regs->PFUNC = 0; // All MCASPs9 Z+ }% t. B9 E* I$ ?
mcasp->regs->PDIR = 0x14000020; // All inputs except AXR0[5], ACLKX1, AFSX10 ~) n* X6 i0 h4 U9 L+ ?
: e3 Y# g% I) Z9 ?8 m/ h) ~; S/ o/ l mcasp->regs->DITCTL = 0x00000000; // Not used
# E1 l/ \8 d+ n mcasp->regs->DLBCTL = 0x00000000; // Not used
/ e" Z7 m* I+ k5 n; r mcasp->regs->AMUTE = 0x00000000; // Not used& @$ `7 X* i3 u! z" M; H
" i: k) X$ r# T/ l6 r/* Starting sections of the McASP*/% E; {4 I* A% V8 e
mcasp->regs->XGBLCTL |= GBLCTL_XHCLKRST_ON; 7 o, O* B# y+ y N8 g
while ( ( mcasp->regs->XGBLCTL & GBLCTL_XHCLKRST_ON ) != GBLCTL_XHCLKRST_ON );
. ?- W4 p+ R% C5 B4 J mcasp->regs->RGBLCTL |= GBLCTL_RHCLKRST_ON; + G% W& m8 T/ ]) C
while ( ( mcasp->regs->RGBLCTL & GBLCTL_RHCLKRST_ON ) != GBLCTL_RHCLKRST_ON );
! h, m. J' B; y0 `; H2 E* @
2 p4 w5 f" n' }, M2 M8 y mcasp->regs->XGBLCTL |= GBLCTL_XCLKRST_ON; & Z! x) A+ w$ B, G( p
while ( ( mcasp->regs->XGBLCTL & GBLCTL_XCLKRST_ON ) != GBLCTL_XCLKRST_ON ); P+ |$ F- N) i- d4 W5 M
mcasp->regs->RGBLCTL |= GBLCTL_RCLKRST_ON;
8 S- d1 T: @% C6 M: K7 v; h) ] while ( ( mcasp->regs->RGBLCTL & GBLCTL_RCLKRST_ON ) != GBLCTL_RCLKRST_ON );
, ?$ T; f* f+ o4 T5 w8 E: t% D r; h; C- |6 F9 b! w
mcasp->regs->XSTAT = 0x0000ffff; \. J( V, U; Y: p6 p- ?3 T7 [
mcasp->regs->RSTAT = 0x0000ffff; 0 n1 ], c4 N8 o+ a6 h# f; e: G
! w3 ^9 ]% X' O1 z( S mcasp->regs->XGBLCTL |= GBLCTL_XSRCLR_ON;2 ~- @% B! n5 h/ J9 }
while ( ( mcasp->regs->XGBLCTL & GBLCTL_XSRCLR_ON ) != GBLCTL_XSRCLR_ON );% e) D! Z9 Z1 X% Z5 m
mcasp->regs->RGBLCTL |= GBLCTL_RSRCLR_ON; 5 S( P. [" t8 o) `$ e8 @
while ( ( mcasp->regs->RGBLCTL & GBLCTL_RSRCLR_ON ) != GBLCTL_RSRCLR_ON );: l0 u" Z2 L5 j
- l7 k6 w0 E) X
/* Write a 0, so that no underrun occurs after releasing the state machine */$ N# R- T9 F0 J7 _
mcasp->regs->XBUF5 = 0;
( Y$ Y' o$ O/ E4 j8 }7 b mcasp->regs->RBUF0 = 0;1 V% w: E& F- J A6 F2 O
% ~2 M* w% d# B9 L8 B9 U! p
mcasp->regs->XGBLCTL |= GBLCTL_XSMRST_ON;
' K5 G1 Z& V7 c: n while ( ( mcasp->regs->XGBLCTL & GBLCTL_XSMRST_ON ) != GBLCTL_XSMRST_ON );9 N/ {& n, i! m4 m% Z# L2 d8 c% {) `
mcasp->regs->RGBLCTL |= GBLCTL_RSMRST_ON; * f$ S' d& ~# t+ Z
while ( ( mcasp->regs->RGBLCTL & GBLCTL_RSMRST_ON ) != GBLCTL_RSMRST_ON );+ ?, y' O/ S; A; u
) ]& I1 U9 w: Z. |% Q mcasp->regs->XGBLCTL |= GBLCTL_XFRST_ON;
6 Q" J8 R! O, b: W3 E% [ while ( ( mcasp->regs->XGBLCTL & GBLCTL_XFRST_ON ) != GBLCTL_XFRST_ON );
% V1 N! S3 D' ?* q" w M# I7 ` mcasp->regs->RGBLCTL |= GBLCTL_RFRST_ON;
+ }$ E/ S, X4 V* R0 ? while ( ( mcasp->regs->RGBLCTL & GBLCTL_RFRST_ON ) != GBLCTL_RFRST_ON );
3 [" G u! H2 D
! F6 a: ~* { V5 U3 |8 p# K) Z CSR = 0x0000;* O9 c; _+ m! a P+ v. N
INTC_INTMUX1 = 0x3d;! C# o+ A# E( w% ~# S+ {3 u% r
ISTP = (unsigned int)vectors;
) |3 E7 C' g# g/ ~% F ICR = 0xFFF0; " v4 y! i9 a8 ~! E
IER |= 0x12;
' }% F6 g2 Q Q7 b: I9 K1 N CSR |= 0x01; % R/ n: m' W" p _* s
/ ~% O0 ?& [& P: ^
2 g( S% ^, g2 ]# n, [* V' H0 r8 C6 ~9 w
还有就是两个输入输出函数:
1 ~! s3 W, A" P# [$ ?. h+ b% Zvoid output_sample(Int32 out_data)
i) W6 n Y Q# ]2 j; g5 v7 R& @{ I$ q& h9 I) d" w2 q' h
AIC31_data.uint = out_data; 0 C6 f7 @2 u, g" K
MCASP1_XBUF5_32BIT = AIC31_data.uint;
: J& T8 i6 I/ n! R}
/ n- S4 M, s- p( w2 A I1 `4 ^: I# T7 _" [
Int32 input_sample(void)2 A; c; l/ {. g, S+ T
{ $ X- A( N: c. S) }6 v7 P+ R: E
AIC31_data.uint = MCASP1_RBUF0_32BIT;
0 S- s$ y2 f0 U7 {; B return (AIC31_data.uint);7 Z C4 V% |1 {& `
}4 _* d9 q, {+ n$ U9 c* q& c3 [# s
$ ]8 m' E% L r9 G8 t7 R |
|