|
|
C6747和C6748感觉差不多,我想实现McASP发送中断方式控制音频信号,在轮询的例程基础上改的,轮询程序可以实现,但是中断一直实现不了,也找不到错误,求大神帮忙!下边是主要程序:
2 X" `7 g5 Q6 }4 f5 U6 q( ]main文件:6 E. K! h* U7 ^# h% }: O
interrupt void interrupt4(void) 5 u" }$ V# Q$ T" Q3 I
{, G' I- }; P$ {
Uint32 sample;
v* A9 `- b: v; i0 ^* B0 _
9 | n; f2 ^2 g. }# N sample = input_sample(); // read L + R samples from ADC9 b& @$ T$ {8 Z" v9 G
output_sample(sample); // write L + R samples to DAC / }/ P8 z! {( }+ \0 p5 @
return;
) V0 V+ l- R6 {/ [3 W! E} Q+ {8 P9 b9 u9 y
8 W- j7 m- q5 M! V3 I+ P" S# I
int main( void )* g6 ?6 o" N; {
{
( q% B7 I0 S. B( t8 ~6 k, ~
L% r/ ]& v, g+ E: @. ` /* Initialize BSL */
; i/ k& v1 ?/ M# q! U" H. M EVMC6747_init( );
1 o' A7 x* o7 Z" h /* Call evmc6747_intr function */
! d. Z+ J4 i u aic3106_init( );$ ?/ v7 d% u P
while(1);
3 s7 [. ?, A. [# V1 I! w1 M( g! z* o}
6 ]' g! i( L! x6 y! m* d" x M4 ]7 t; d- `# [! y
7 H6 ~( {& v- b# M' d
aic3106_init文件的一部分,McASP配置部分,采用内部时钟,I2S方式,同步传输。音频芯片的配置应该没问题
3 T [. A) T9 I$ k4 P) e/* Initialize MCASP1 */# @8 `4 Z: X# h0 ?
mcasp = &MCASP_MODULE_1;+ a5 [" } t7 l: v% X+ [
mcasp->regs->GBLCTL = 0; // Reset
8 K0 v# W. E" G' B4 V mcasp->regs->RGBLCTL = 0; // Reset RX
8 g' `1 x6 @: A9 u B mcasp->regs->XGBLCTL = 0; // Reset TX
1 Z% v" D3 U3 z P$ v* j mcasp->regs->PWRDEMU = 1; // Free-running3 J, Z3 c6 k1 a. V7 k$ ^4 ^
// configure McASP0 receive registers
; H0 T- J: R0 z" m/ E: y6 J mcasp->regs->RMASK = 0xFFFFFFFF; // No padding used3 f7 I* G) F' ?
mcasp->regs->RFMT = 0x00018078; // MSB 16bit, 0-delay, no pad, CFGBus
l! \! a0 {" K0 Q mcasp->regs->AFSRCTL = 0x00000112; // 2TDM, 1bit Falling, External FS, word
2 ^, ?( m' F0 K5 c8 A4 c0 G4 i& [8 I mcasp->regs->ACLKRCTL = 0x000000AF; // Rising INTERNAL CLK,(from tx side)# Y% [+ m- }& q, X5 ~% L
mcasp->regs->AHCLKRCTL = 0x00000000; // INT CLK (from tx side)' Z4 P3 N* n T( q+ g8 `4 p$ D/ d
mcasp->regs->RTDM = 0x00000003; // Slots 0,1
+ y$ k* Q- f9 g* [; S1 \' L mcasp->regs->RINTCTL = 0x00000000; // Not used
+ D+ f; C5 N4 }9 B' G2 d mcasp->regs->RCLKCHK = 0x00FF0008; // 255-MAX 0-MIN, div-by-256" W J6 P) J' k& T' f$ b) ^
+ ~8 o: d0 H7 O0 ^ mcasp->regs->XMASK = 0xFFFFFFFF; // No padding used- u- }* z% U( f7 c2 V
mcasp->regs->XFMT = 0x00018078; // MSB 16bit, 0-delay, no pad, CFGBus
" Z* F* k7 @! b5 W mcasp->regs->AFSXCTL = 0x00000112; // 2TDM, 1bit Rising edge INTERNAL FS, word, _; ^2 r, r; x) l, a5 P2 I
mcasp->regs->ACLKXCTL = 0x000000AF; // ASYNC, Rising INTERNAL CLK, div-by-16
, X* H) g3 e0 R) l# x) y+ w" F( I5 ` mcasp->regs->AHCLKXCTL = 0x00000000; // EXT CLK n8 s6 E; h7 S& @9 R- S
mcasp->regs->XTDM = 0x00000003; // Slots 0,1$ F$ y6 B H0 D: z
mcasp->regs->XINTCTL = 0x00000020; // interrupt on transmit( N( E/ P2 Z9 I+ W. I
mcasp->regs->XCLKCHK = 0x00FF0008; // 255-MAX 0-MIN, div-by-2562 B1 w) L" r/ i$ `% I7 O' d
& y- f. P- Z w
mcasp->regs->SRCTL5 = 0x000D; // MCASP1.AXR1[5] --> DIN
# x; @. C, k& U! Z, t4 }2 h2 F mcasp->regs->SRCTL0 = 0x000E; // MCASP1.AXR1[0] <-- DOUT, c6 f, C7 p+ }' c% Y/ A- h
mcasp->regs->PFUNC = 0; // All MCASPs
]8 G0 M* L3 \) \: G# b: [* V. z mcasp->regs->PDIR = 0x14000020; // All inputs except AXR0[5], ACLKX1, AFSX1: |7 ^% U$ H, S( |
9 i/ S7 m1 o" E# t; g( Y, n mcasp->regs->DITCTL = 0x00000000; // Not used7 S+ Y: b: i1 q
mcasp->regs->DLBCTL = 0x00000000; // Not used" I6 @; E7 ~* w; }, G# n _
mcasp->regs->AMUTE = 0x00000000; // Not used
" {0 B( k# a9 d4 R/ R9 p# ?: b* R" b$ B- ^
/* Starting sections of the McASP*/' E* h* e/ h$ T0 ^5 X! D! Q# @
mcasp->regs->XGBLCTL |= GBLCTL_XHCLKRST_ON;
" {$ _' \4 M9 a/ ^6 ?+ N. k while ( ( mcasp->regs->XGBLCTL & GBLCTL_XHCLKRST_ON ) != GBLCTL_XHCLKRST_ON );
9 D, c4 U+ M7 S4 k mcasp->regs->RGBLCTL |= GBLCTL_RHCLKRST_ON; * l: `+ f/ S! g2 N9 d
while ( ( mcasp->regs->RGBLCTL & GBLCTL_RHCLKRST_ON ) != GBLCTL_RHCLKRST_ON );
) m! R, q' S' _1 K2 ~0 L0 V* a( I2 a+ u
mcasp->regs->XGBLCTL |= GBLCTL_XCLKRST_ON;
, l+ x, C$ l9 x! h8 \; h5 R while ( ( mcasp->regs->XGBLCTL & GBLCTL_XCLKRST_ON ) != GBLCTL_XCLKRST_ON );0 }6 ~' `0 Q! O; m
mcasp->regs->RGBLCTL |= GBLCTL_RCLKRST_ON; ( R$ p$ q1 [! o0 f2 ]3 c
while ( ( mcasp->regs->RGBLCTL & GBLCTL_RCLKRST_ON ) != GBLCTL_RCLKRST_ON );0 _- @4 y8 L8 |9 n
( q; h. C5 L5 V, r! l, K) s
mcasp->regs->XSTAT = 0x0000ffff; ( e2 N+ n- e& @9 q+ H
mcasp->regs->RSTAT = 0x0000ffff;
8 y$ x! H! Z) {
" K/ E' H6 O) Z% ^3 Z mcasp->regs->XGBLCTL |= GBLCTL_XSRCLR_ON;
4 @3 C( f# I# D9 E6 d9 w/ p2 H while ( ( mcasp->regs->XGBLCTL & GBLCTL_XSRCLR_ON ) != GBLCTL_XSRCLR_ON );! _. W( I v% H3 c. t
mcasp->regs->RGBLCTL |= GBLCTL_RSRCLR_ON; 4 _0 f2 ~# v( o; V7 ?
while ( ( mcasp->regs->RGBLCTL & GBLCTL_RSRCLR_ON ) != GBLCTL_RSRCLR_ON );
2 Z/ h5 a: Q# X7 x0 J
`3 v. L ^. m; E( J; h /* Write a 0, so that no underrun occurs after releasing the state machine */
2 d5 t: t# |) c5 f; v mcasp->regs->XBUF5 = 0;
/ X2 |6 K, w) P& h9 d2 a- @! Q; d$ T6 n/ O mcasp->regs->RBUF0 = 0;% `. N6 T! G- q0 u& D# e
9 q6 B& V5 N2 u1 U" O$ q/ s+ {
mcasp->regs->XGBLCTL |= GBLCTL_XSMRST_ON; 3 a- n9 u* P9 Z4 t( l
while ( ( mcasp->regs->XGBLCTL & GBLCTL_XSMRST_ON ) != GBLCTL_XSMRST_ON );$ w% r( h- ]( x+ V% j
mcasp->regs->RGBLCTL |= GBLCTL_RSMRST_ON;
! E8 P; Q, K% ~/ b H while ( ( mcasp->regs->RGBLCTL & GBLCTL_RSMRST_ON ) != GBLCTL_RSMRST_ON );6 w$ G) R! ?' _
& }- F; D7 Q& ^! A- K$ f( R' w
mcasp->regs->XGBLCTL |= GBLCTL_XFRST_ON;
" z/ T9 i* [' o, f while ( ( mcasp->regs->XGBLCTL & GBLCTL_XFRST_ON ) != GBLCTL_XFRST_ON );! Z/ B$ _- Q; \# R) P
mcasp->regs->RGBLCTL |= GBLCTL_RFRST_ON; ) y7 M8 B: Y: T9 M9 ^
while ( ( mcasp->regs->RGBLCTL & GBLCTL_RFRST_ON ) != GBLCTL_RFRST_ON );' J$ z6 ]. z" f: Y
7 I7 }. \' y) T; B; E4 R4 x5 U
CSR = 0x0000;
" A% D0 B/ I5 k8 b INTC_INTMUX1 = 0x3d;
8 ], Q; u2 X6 {$ ^9 Y ISTP = (unsigned int)vectors;
5 x0 ?* U7 @* B1 L# c ICR = 0xFFF0;
' ^3 q# M8 e9 k6 r IER |= 0x12;
! E" m" C' B7 H$ p% n6 p' I CSR |= 0x01;
$ Z. a5 b/ S' b& r+ K6 D6 n# V4 T Y# U U
: v6 e9 i+ m! d$ f; i% M* j. ~8 t' Q }
还有就是两个输入输出函数:0 r: ?8 d! B Y: I3 v* W
void output_sample(Int32 out_data) d* y3 C% d. U; R( v9 L K% s- Y8 c( f
{9 o, K/ |. C; L9 p3 L
AIC31_data.uint = out_data;
9 o$ }2 I% K& T7 v7 d MCASP1_XBUF5_32BIT = AIC31_data.uint;
% v* }# C/ I9 x" J}
* `7 @$ _/ i( v9 p% b' U5 u7 j, e% q5 f7 P4 i5 |+ B
Int32 input_sample(void) H! q6 G# v5 L! e' x0 U
{
$ G& M& a3 l# d' Y4 \( X+ {6 G$ M AIC31_data.uint = MCASP1_RBUF0_32BIT;
3 \( q6 X' {; ]4 {# L1 m, e return (AIC31_data.uint);: O, G" ? d1 n& ^6 x, W# s
}
* Q, U+ J. |2 F1 g( v; ~6 i$ q1 z% E0 Q) G- |
|
|