|
|
C6747和C6748感觉差不多,我想实现McASP发送中断方式控制音频信号,在轮询的例程基础上改的,轮询程序可以实现,但是中断一直实现不了,也找不到错误,求大神帮忙!下边是主要程序:, [7 Z, v$ Q1 c3 u
main文件:
: d3 Z6 v& y6 o1 K2 sinterrupt void interrupt4(void) ; T/ M: v0 O# V' O) E
{
. g0 n! P7 ]0 N' C V Uint32 sample;
0 \ e0 G0 b1 }& \( H
/ p7 L* n( G9 X Q sample = input_sample(); // read L + R samples from ADC
3 h9 K, [ s0 H output_sample(sample); // write L + R samples to DAC 9 U1 f& O: @( ]: B" W& X- A# B
return;
5 ~, G& |0 X! E" _+ y}
, C/ S$ f' o* V1 {3 X: c& A ^$ `2 u, L) q6 o
int main( void )
: A' g M; U& F8 V; i1 w" R{
6 N! V* V% ?$ U' d, \9 g& M# ^, e
5 K; z' Z q% q1 j /* Initialize BSL */% x/ L3 l5 P! g1 S0 o
EVMC6747_init( );
V7 I+ x& X( R /* Call evmc6747_intr function */
' l4 U @! L l7 Z V8 K# d aic3106_init( );& {: G0 R5 w/ j7 E! W! U" ^
while(1);
7 }7 u4 K" K; @$ ~}
. m. e3 ]4 s' \9 A
# e; I# d& S" F+ b/ w
; }9 I5 w& z9 Y6 i3 uaic3106_init文件的一部分,McASP配置部分,采用内部时钟,I2S方式,同步传输。音频芯片的配置应该没问题
5 L9 W' L. _6 x8 J/ a! T# C/* Initialize MCASP1 */
8 i [4 q" O1 }' r7 u( w mcasp = &MCASP_MODULE_1;
, m7 _4 {8 y" i( V% d mcasp->regs->GBLCTL = 0; // Reset
+ Z8 g$ m) i( ? mcasp->regs->RGBLCTL = 0; // Reset RX
4 N4 X7 |0 D. Z4 h# o mcasp->regs->XGBLCTL = 0; // Reset TX
; b' c+ A2 O; q; t mcasp->regs->PWRDEMU = 1; // Free-running
8 h) T* [5 G/ m // configure McASP0 receive registers
9 u6 h I+ x- S( M5 V mcasp->regs->RMASK = 0xFFFFFFFF; // No padding used6 z" q& U$ u7 Y# y6 x: p6 x
mcasp->regs->RFMT = 0x00018078; // MSB 16bit, 0-delay, no pad, CFGBus
8 D" O5 K) E1 X mcasp->regs->AFSRCTL = 0x00000112; // 2TDM, 1bit Falling, External FS, word0 D' j3 |( u0 E9 [* c; \2 T+ ~4 g
mcasp->regs->ACLKRCTL = 0x000000AF; // Rising INTERNAL CLK,(from tx side)
* ]! n, i& ]) }+ c+ w5 ? mcasp->regs->AHCLKRCTL = 0x00000000; // INT CLK (from tx side)& H5 c5 m# ]: W* ^7 D0 S0 C
mcasp->regs->RTDM = 0x00000003; // Slots 0,1- q$ c( k# K- D* w
mcasp->regs->RINTCTL = 0x00000000; // Not used
: q* q" c5 ?9 d( x9 A mcasp->regs->RCLKCHK = 0x00FF0008; // 255-MAX 0-MIN, div-by-256# j' p% Z4 L) E' T
1 ], K3 \5 S0 [% l& {7 q* H. @ mcasp->regs->XMASK = 0xFFFFFFFF; // No padding used5 E$ K. K3 x0 x$ `# k# u
mcasp->regs->XFMT = 0x00018078; // MSB 16bit, 0-delay, no pad, CFGBus( l& _/ \6 R. @' a
mcasp->regs->AFSXCTL = 0x00000112; // 2TDM, 1bit Rising edge INTERNAL FS, word
/ ?1 K# |: x0 j9 e5 B mcasp->regs->ACLKXCTL = 0x000000AF; // ASYNC, Rising INTERNAL CLK, div-by-166 I Q6 C7 c+ M" H. x, Y# ~
mcasp->regs->AHCLKXCTL = 0x00000000; // EXT CLK/ G& n, `( T. A5 k
mcasp->regs->XTDM = 0x00000003; // Slots 0,13 `; U2 ]- _( U* D; o& [( D
mcasp->regs->XINTCTL = 0x00000020; // interrupt on transmit5 K" G& f2 N0 E5 f
mcasp->regs->XCLKCHK = 0x00FF0008; // 255-MAX 0-MIN, div-by-256
! ]3 h8 x/ D! G# g- @1 T1 [0 S
, Q5 f- Q9 T& {: C+ W mcasp->regs->SRCTL5 = 0x000D; // MCASP1.AXR1[5] --> DIN3 ]1 R0 d7 ~" K; K- m7 V
mcasp->regs->SRCTL0 = 0x000E; // MCASP1.AXR1[0] <-- DOUT7 z* b9 n" D6 Y; D
mcasp->regs->PFUNC = 0; // All MCASPs
2 s; `$ W$ @9 B* U mcasp->regs->PDIR = 0x14000020; // All inputs except AXR0[5], ACLKX1, AFSX1
) t* R r, ~" }+ G& u6 d( G- I6 T" F: i4 w
mcasp->regs->DITCTL = 0x00000000; // Not used
. r+ e8 G) m9 d: P' W mcasp->regs->DLBCTL = 0x00000000; // Not used" _( y$ w" R6 F* c
mcasp->regs->AMUTE = 0x00000000; // Not used5 e; x. p6 Y' g) D5 ~
L! [; x( k; h/* Starting sections of the McASP*/! x$ X0 K2 ]1 c* h- t! u, O. x Q4 j* F/ {
mcasp->regs->XGBLCTL |= GBLCTL_XHCLKRST_ON; ( o2 `; S2 y& x e9 `
while ( ( mcasp->regs->XGBLCTL & GBLCTL_XHCLKRST_ON ) != GBLCTL_XHCLKRST_ON ); , D/ }, y, ~/ u" i
mcasp->regs->RGBLCTL |= GBLCTL_RHCLKRST_ON;
& ]' s# w% c, `& p" Y% L: a while ( ( mcasp->regs->RGBLCTL & GBLCTL_RHCLKRST_ON ) != GBLCTL_RHCLKRST_ON );: s2 \: a( V# N' \5 X4 L+ F/ M
9 y8 j' S; i+ v% ` M mcasp->regs->XGBLCTL |= GBLCTL_XCLKRST_ON;
5 @; C( y5 N1 u while ( ( mcasp->regs->XGBLCTL & GBLCTL_XCLKRST_ON ) != GBLCTL_XCLKRST_ON );
7 a8 t6 p! j* { mcasp->regs->RGBLCTL |= GBLCTL_RCLKRST_ON; & @& a$ P T' w0 \) a
while ( ( mcasp->regs->RGBLCTL & GBLCTL_RCLKRST_ON ) != GBLCTL_RCLKRST_ON );
' R$ M3 j; N' G2 T9 N! c/ {& F v0 \( |3 u5 B3 i9 u8 r
mcasp->regs->XSTAT = 0x0000ffff; " @9 v. O' J5 V- h
mcasp->regs->RSTAT = 0x0000ffff;
* H3 t3 w; ^, v, a5 ]
' {8 u$ a2 I' N4 [! f& q mcasp->regs->XGBLCTL |= GBLCTL_XSRCLR_ON;1 m6 n3 M: d7 @2 Y( V' Y7 A
while ( ( mcasp->regs->XGBLCTL & GBLCTL_XSRCLR_ON ) != GBLCTL_XSRCLR_ON );
: ]$ f) H" J5 y mcasp->regs->RGBLCTL |= GBLCTL_RSRCLR_ON;
! C& T% g4 v& H, y+ |8 v# J/ p while ( ( mcasp->regs->RGBLCTL & GBLCTL_RSRCLR_ON ) != GBLCTL_RSRCLR_ON );8 H/ U, n: a0 Z$ M2 g. \+ h7 W
6 S @. X7 ^) [' e) |0 ]+ ]+ Y7 v /* Write a 0, so that no underrun occurs after releasing the state machine */& g0 n1 x3 z- Q1 B; y+ y6 e- ?) r2 x
mcasp->regs->XBUF5 = 0;
" C( \+ Q% w+ A! u mcasp->regs->RBUF0 = 0;7 @9 ?" }3 H5 f3 Y3 Z
c, V: k4 r4 y+ i) O/ L$ J3 N
mcasp->regs->XGBLCTL |= GBLCTL_XSMRST_ON;
- d8 G7 |: U* U while ( ( mcasp->regs->XGBLCTL & GBLCTL_XSMRST_ON ) != GBLCTL_XSMRST_ON );
' z) Z$ L) [2 | H mcasp->regs->RGBLCTL |= GBLCTL_RSMRST_ON; 0 e8 C5 G" a, W. t2 r
while ( ( mcasp->regs->RGBLCTL & GBLCTL_RSMRST_ON ) != GBLCTL_RSMRST_ON );
& V4 y1 z& D- n! v' z B7 b1 ]4 O. F! A: Z! P" N( v7 N
mcasp->regs->XGBLCTL |= GBLCTL_XFRST_ON;
! ]' x: y q6 m$ d" d while ( ( mcasp->regs->XGBLCTL & GBLCTL_XFRST_ON ) != GBLCTL_XFRST_ON );$ a8 g. L( U' l# q u6 E* ^
mcasp->regs->RGBLCTL |= GBLCTL_RFRST_ON;
+ }& z! j8 C% W2 t while ( ( mcasp->regs->RGBLCTL & GBLCTL_RFRST_ON ) != GBLCTL_RFRST_ON );( U. O$ A" h& q" n! A& q
) @2 a, G/ m9 s/ M CSR = 0x0000;6 u; T6 ^4 |/ v8 v- W
INTC_INTMUX1 = 0x3d;
0 |+ [# A4 m0 ~; V( x& o+ I+ T ISTP = (unsigned int)vectors;
* i( }6 ^6 g7 H ICR = 0xFFF0; # U9 p. m5 l- j1 C: P
IER |= 0x12;
( S+ m0 r. E/ e4 n CSR |= 0x01;
3 T9 ]/ T) x/ ]8 X! q& ~5 n p
, `& S4 d/ w) \7 v2 F7 D. s
- I' d0 T* @1 n }
- B! l) V% O* I/ J' A5 z3 F还有就是两个输入输出函数:
" m7 ~: Y& p# z( Uvoid output_sample(Int32 out_data). G" d; |, J- q% V s! M1 {9 R
{9 q0 p) V4 A% Y6 u, h5 c
AIC31_data.uint = out_data; : v& Y9 V& r/ G, \( R3 H
MCASP1_XBUF5_32BIT = AIC31_data.uint;
* c+ I/ i$ a6 M( [8 G}
/ o8 u1 }& z. ^. Q) ?% F, e. }& r: {
! U) U! |; p& {5 w# eInt32 input_sample(void)
' q3 x( l T1 y- J{
, S" J9 m: J4 M) Q2 M AIC31_data.uint = MCASP1_RBUF0_32BIT;. B7 \3 J7 T8 F* X7 q
return (AIC31_data.uint);
+ S* m! P) ]" S; e9 E' b}* q! h4 a% n1 h; e
- h }; C8 v8 k# n7 h& [# \ |
|