|
|
C6747和C6748感觉差不多,我想实现McASP发送中断方式控制音频信号,在轮询的例程基础上改的,轮询程序可以实现,但是中断一直实现不了,也找不到错误,求大神帮忙!下边是主要程序:
& w( }! v+ _' Vmain文件:, ~# i* V. d% w* G; C- f8 U# ?$ q
interrupt void interrupt4(void)
' x8 c9 {* x/ m: Y{
# A/ w, \/ P, h7 L2 n8 a) g Uint32 sample;
' l7 {, o$ O1 ?
3 L. P, f6 ] S$ D5 W( D sample = input_sample(); // read L + R samples from ADC
2 G \7 c* P# v0 B output_sample(sample); // write L + R samples to DAC . X Y" X- R( H8 A
return;
5 R; ~+ [+ Y: R& u( b2 R ^}
7 W" n+ Z0 B2 u0 {' Y, K8 ? H
' B) r/ X+ A0 ~ l9 Y3 p' dint main( void )
* `8 v& e; C \. i: A{5 ]3 S; ^) C; \ X( ]2 C R! x
. I( G3 G, g' l0 S
/* Initialize BSL */4 Q+ {. N' }% p5 c$ ?: Y* e) @
EVMC6747_init( );
. f7 X' z0 L# P* W5 y /* Call evmc6747_intr function */
6 |+ p8 E( Y! z2 d/ P$ S aic3106_init( );
5 |: O% F. U. k1 k! W while(1);4 ^5 V) ?- x7 T9 |; H
} ^# X* `2 Q4 x! t" _* C4 _! h
9 C- T. L0 E: n0 ~, I
& z$ {9 F% }' S; caic3106_init文件的一部分,McASP配置部分,采用内部时钟,I2S方式,同步传输。音频芯片的配置应该没问题2 C7 ]; w( h' D
/* Initialize MCASP1 */
' b& \& m2 A* V9 l+ W% z. g mcasp = &MCASP_MODULE_1;
( {' Q4 c7 n4 O( F" i: } mcasp->regs->GBLCTL = 0; // Reset
1 Y, u# N c; q2 B1 s7 q& ]7 O mcasp->regs->RGBLCTL = 0; // Reset RX7 j% y7 v1 ^, Q7 _( I: ^* ]
mcasp->regs->XGBLCTL = 0; // Reset TX
- [, b4 r0 `1 K) z- o9 U mcasp->regs->PWRDEMU = 1; // Free-running$ T; j7 \; F7 u: @. H
// configure McASP0 receive registers' v3 g! W9 X6 n0 u
mcasp->regs->RMASK = 0xFFFFFFFF; // No padding used3 h& S) y+ G2 x9 n; I p4 N/ i
mcasp->regs->RFMT = 0x00018078; // MSB 16bit, 0-delay, no pad, CFGBus8 g; f) A6 O+ O8 d
mcasp->regs->AFSRCTL = 0x00000112; // 2TDM, 1bit Falling, External FS, word- C* R7 |: |1 `! R: Y$ [9 X* G+ c. L
mcasp->regs->ACLKRCTL = 0x000000AF; // Rising INTERNAL CLK,(from tx side)+ g! E1 m* r7 u+ S( @& F3 H
mcasp->regs->AHCLKRCTL = 0x00000000; // INT CLK (from tx side)
) L# e5 A, n2 l mcasp->regs->RTDM = 0x00000003; // Slots 0,12 W1 p+ H& i2 @( s
mcasp->regs->RINTCTL = 0x00000000; // Not used" E* t) ] b# q; ?8 a
mcasp->regs->RCLKCHK = 0x00FF0008; // 255-MAX 0-MIN, div-by-256% X5 D: Y' \6 H, r0 ^+ |
+ n* Z; d- }1 _' s0 U% o7 P6 H
mcasp->regs->XMASK = 0xFFFFFFFF; // No padding used
3 ]/ w1 W K$ y% K6 W) a mcasp->regs->XFMT = 0x00018078; // MSB 16bit, 0-delay, no pad, CFGBus
3 r6 ]& K; ~% E& Q6 X2 p: D mcasp->regs->AFSXCTL = 0x00000112; // 2TDM, 1bit Rising edge INTERNAL FS, word7 {' v3 i- T1 u! t8 \1 `
mcasp->regs->ACLKXCTL = 0x000000AF; // ASYNC, Rising INTERNAL CLK, div-by-16
! S2 t% T, {7 B/ Y2 ^9 ^ mcasp->regs->AHCLKXCTL = 0x00000000; // EXT CLK5 q, A: B- `! @2 g3 o
mcasp->regs->XTDM = 0x00000003; // Slots 0,16 P" @- I/ i' y2 F8 S8 N
mcasp->regs->XINTCTL = 0x00000020; // interrupt on transmit
- n6 a4 L3 w2 M+ F- M mcasp->regs->XCLKCHK = 0x00FF0008; // 255-MAX 0-MIN, div-by-256! n/ s! n! M) P I
+ k' C$ z" r- h$ J t mcasp->regs->SRCTL5 = 0x000D; // MCASP1.AXR1[5] --> DIN: {) E9 d/ K2 z9 B4 R6 X
mcasp->regs->SRCTL0 = 0x000E; // MCASP1.AXR1[0] <-- DOUT
( U' ?4 q; o5 J6 ?$ Q& E mcasp->regs->PFUNC = 0; // All MCASPs4 q, n, ^* S, a: N" U# `6 j& k& U$ x
mcasp->regs->PDIR = 0x14000020; // All inputs except AXR0[5], ACLKX1, AFSX1
$ u6 p0 ]4 ]5 R% e. x8 B' F+ e. x' N: G% ~9 r: z$ y
mcasp->regs->DITCTL = 0x00000000; // Not used
- Z1 T5 M; R6 x' `4 ], p mcasp->regs->DLBCTL = 0x00000000; // Not used
+ g* d; ?$ ]' d# W4 Q/ { mcasp->regs->AMUTE = 0x00000000; // Not used
' Y8 Y) |! y4 V0 {4 L
5 Z4 b9 H( P. V' S- X: W( r/* Starting sections of the McASP*/
( d+ \8 }( T* N8 u6 R mcasp->regs->XGBLCTL |= GBLCTL_XHCLKRST_ON; 4 \0 S6 p2 W% {7 q G0 \! t- Q
while ( ( mcasp->regs->XGBLCTL & GBLCTL_XHCLKRST_ON ) != GBLCTL_XHCLKRST_ON ); 7 M, I% n" z4 f4 S& }* @
mcasp->regs->RGBLCTL |= GBLCTL_RHCLKRST_ON; 2 n" W1 V& f+ S8 r4 E* ?5 M5 g, R, `
while ( ( mcasp->regs->RGBLCTL & GBLCTL_RHCLKRST_ON ) != GBLCTL_RHCLKRST_ON );
/ g$ c* E! a- ~" @, y; N' A8 a* w* P0 E; L) @, e- \8 E7 |6 G
mcasp->regs->XGBLCTL |= GBLCTL_XCLKRST_ON; ( ~; t+ U W) R7 b
while ( ( mcasp->regs->XGBLCTL & GBLCTL_XCLKRST_ON ) != GBLCTL_XCLKRST_ON );
; B0 `3 ?, a& N- z) R% |. ` mcasp->regs->RGBLCTL |= GBLCTL_RCLKRST_ON; ) L- A y( V: \
while ( ( mcasp->regs->RGBLCTL & GBLCTL_RCLKRST_ON ) != GBLCTL_RCLKRST_ON );
( ^0 P9 `1 k3 B6 J$ ?+ v0 t5 n* C' d, u: g; I/ P
mcasp->regs->XSTAT = 0x0000ffff; * E# j+ N! q. a/ @
mcasp->regs->RSTAT = 0x0000ffff; 2 R0 c( K1 s2 I! |3 |7 R: K+ N( D( G
& |6 \, c1 c e/ I$ E j
mcasp->regs->XGBLCTL |= GBLCTL_XSRCLR_ON;7 P3 h' F$ y0 ~# A- T. Y' s
while ( ( mcasp->regs->XGBLCTL & GBLCTL_XSRCLR_ON ) != GBLCTL_XSRCLR_ON );7 f& M! M0 G( U7 Q1 I
mcasp->regs->RGBLCTL |= GBLCTL_RSRCLR_ON;
|9 U4 B& k4 _. i6 c c9 s while ( ( mcasp->regs->RGBLCTL & GBLCTL_RSRCLR_ON ) != GBLCTL_RSRCLR_ON );
4 R1 b( F: d+ C9 ]+ ^; m" U2 f6 P5 d- o# V
/* Write a 0, so that no underrun occurs after releasing the state machine */
$ h: W; D# V: x* L$ } mcasp->regs->XBUF5 = 0;2 _3 v0 q- j% w* a4 v; e1 Z2 ]( {
mcasp->regs->RBUF0 = 0;
0 w; u! G$ l j- |" a: _8 ?
2 A ^" ?8 u9 w mcasp->regs->XGBLCTL |= GBLCTL_XSMRST_ON; " {1 c! `6 ~! s
while ( ( mcasp->regs->XGBLCTL & GBLCTL_XSMRST_ON ) != GBLCTL_XSMRST_ON );. n! H- ]$ B+ ?% N
mcasp->regs->RGBLCTL |= GBLCTL_RSMRST_ON; 9 S: M" ]/ w& S& ?; Y, e
while ( ( mcasp->regs->RGBLCTL & GBLCTL_RSMRST_ON ) != GBLCTL_RSMRST_ON );
" P: v/ g2 w- z) T; f8 k) B+ F9 P5 | o9 {
mcasp->regs->XGBLCTL |= GBLCTL_XFRST_ON;
. Z( f% K! V+ D- p; M% I while ( ( mcasp->regs->XGBLCTL & GBLCTL_XFRST_ON ) != GBLCTL_XFRST_ON );4 J) @. Y5 e% x1 C* G5 x% r J! n, a
mcasp->regs->RGBLCTL |= GBLCTL_RFRST_ON;
; s$ y" q8 b! T2 M$ q2 G9 e while ( ( mcasp->regs->RGBLCTL & GBLCTL_RFRST_ON ) != GBLCTL_RFRST_ON );
7 p1 s) X: ~1 w
- D1 u( R0 a) R. o: }" {$ n! d/ s CSR = 0x0000;( b0 D' k: f( |0 H5 t
INTC_INTMUX1 = 0x3d;
8 b* {! |; j* @ T/ X" K# j. s: v ISTP = (unsigned int)vectors;
% e" O# N8 j4 M: ^ ] ICR = 0xFFF0;
) D2 _, E4 a% S+ n IER |= 0x12; + B* D" T: E3 o& T, j! m
CSR |= 0x01; # e# p, r" k5 ^0 `2 d
: u0 u( K/ R0 O% t% v: a4 o: U, O. u3 V; ^- b! p
$ q$ ^3 U' u/ K8 S: @$ j还有就是两个输入输出函数:
6 c) u1 Z8 Z' [# ]void output_sample(Int32 out_data)
% G; q% y2 J' u8 L{
2 {9 c) n. p1 |) E( v AIC31_data.uint = out_data; & P4 H3 m$ }3 x) {5 {$ g" P$ S1 n
MCASP1_XBUF5_32BIT = AIC31_data.uint;
' j$ ], W8 u: i}
. h& u d2 e6 l7 L w
! {. i$ V2 S$ G& `8 b% TInt32 input_sample(void)
) c; \8 q" G5 q8 V$ r2 w) ^{ # C2 ]7 A* k$ _. k8 a' N
AIC31_data.uint = MCASP1_RBUF0_32BIT;) ^# { W7 R& c, S
return (AIC31_data.uint);; H$ L6 H1 r9 R. x3 `: A( T/ Z
}# y, M4 e9 w! b! J# R
$ ^& a4 f6 ]: P9 j5 M a0 M |
|