|
|
C6747和C6748感觉差不多,我想实现McASP发送中断方式控制音频信号,在轮询的例程基础上改的,轮询程序可以实现,但是中断一直实现不了,也找不到错误,求大神帮忙!下边是主要程序:4 e( `5 E+ f/ }
main文件:
: D( ?: t% m( u: K4 r* m0 ^interrupt void interrupt4(void)
+ ?, |4 T4 l8 M7 V* h{' J3 U& |! n* t2 ~- U: ]2 \* e! o
Uint32 sample;
3 t7 `1 V# Y0 r2 g9 d1 f1 |# ]% w [0 u, `
sample = input_sample(); // read L + R samples from ADC; j+ K) c: b+ J+ d2 i
output_sample(sample); // write L + R samples to DAC
6 S% Z# G( _ [ return;% K4 m* H' D, E( D m6 W5 p: A
}" A% @7 z& N5 A% P
3 D8 N$ I" N# E% Z b8 b Mint main( void )! w% D. L8 y; E
{6 Y* v. _/ q j4 w% K
9 f2 {/ i0 [$ @& m H' s# W
/* Initialize BSL *// `* Z1 H% z( c4 y% B# _" i( c
EVMC6747_init( );* w+ }2 @1 L1 Z V; Y* C# p6 `! G
/* Call evmc6747_intr function */
8 @ Q; {2 \) q$ @, W$ ^+ l) r aic3106_init( );
1 e& j/ @. h$ j6 i while(1);
2 P, J" W& q) B- `}9 L1 n6 }6 R/ \7 J. c
5 J) _" n r" y+ B6 S4 M* T* A+ k1 k6 h: S; w% a1 d4 e" V8 p
aic3106_init文件的一部分,McASP配置部分,采用内部时钟,I2S方式,同步传输。音频芯片的配置应该没问题
: i0 K/ @4 e/ r" H/* Initialize MCASP1 */
" a8 E" s8 ?1 l mcasp = &MCASP_MODULE_1;" [. ? W! |* A
mcasp->regs->GBLCTL = 0; // Reset
! r& e) c1 U* Z3 C( m# P ] mcasp->regs->RGBLCTL = 0; // Reset RX
' {3 l6 Z: }3 |7 i mcasp->regs->XGBLCTL = 0; // Reset TX
( c) }+ O( c" ~/ Q* W$ Z mcasp->regs->PWRDEMU = 1; // Free-running Y8 n( t; K7 `- v1 b# S
// configure McASP0 receive registers8 b5 ?) D$ Y7 r/ F- I' e6 E) a
mcasp->regs->RMASK = 0xFFFFFFFF; // No padding used% _" P( i( j7 {: a- @7 [+ b' q- k- k
mcasp->regs->RFMT = 0x00018078; // MSB 16bit, 0-delay, no pad, CFGBus
3 [# B5 u7 x( a5 j6 Y! o# g7 ] mcasp->regs->AFSRCTL = 0x00000112; // 2TDM, 1bit Falling, External FS, word
+ q; @1 d5 c0 h+ D) n E mcasp->regs->ACLKRCTL = 0x000000AF; // Rising INTERNAL CLK,(from tx side)& r% S R/ D+ q9 ^% B: N0 f; r
mcasp->regs->AHCLKRCTL = 0x00000000; // INT CLK (from tx side)5 F+ N, ]' ]$ X6 ]2 g! R( F2 \
mcasp->regs->RTDM = 0x00000003; // Slots 0,16 R) ~+ ]2 i/ N5 q/ l& E( j! b
mcasp->regs->RINTCTL = 0x00000000; // Not used) |4 {) | E% f
mcasp->regs->RCLKCHK = 0x00FF0008; // 255-MAX 0-MIN, div-by-256* o2 U' y% E2 C% n5 S
2 T ^/ q9 ~1 Y$ ]0 Q( K# D
mcasp->regs->XMASK = 0xFFFFFFFF; // No padding used
$ s, @" E6 \8 a c: K7 {9 W: j4 V mcasp->regs->XFMT = 0x00018078; // MSB 16bit, 0-delay, no pad, CFGBus+ S/ A9 ]- {* l9 q
mcasp->regs->AFSXCTL = 0x00000112; // 2TDM, 1bit Rising edge INTERNAL FS, word6 y. _0 S9 q9 T4 i2 a$ L+ _
mcasp->regs->ACLKXCTL = 0x000000AF; // ASYNC, Rising INTERNAL CLK, div-by-16
5 |( K4 P7 T3 h0 O( g mcasp->regs->AHCLKXCTL = 0x00000000; // EXT CLK
3 ]% N3 Z: ^& N p mcasp->regs->XTDM = 0x00000003; // Slots 0,1: o3 e( {8 m, s* z
mcasp->regs->XINTCTL = 0x00000020; // interrupt on transmit* S% i) \, T3 n
mcasp->regs->XCLKCHK = 0x00FF0008; // 255-MAX 0-MIN, div-by-256( C& r9 M+ D. g! r
$ L; I4 ?3 q; {4 u( d- M$ \- u mcasp->regs->SRCTL5 = 0x000D; // MCASP1.AXR1[5] --> DIN$ j$ q) j0 Q2 ` F
mcasp->regs->SRCTL0 = 0x000E; // MCASP1.AXR1[0] <-- DOUT
- K& C! j$ b. |* H: v- }0 W v, F mcasp->regs->PFUNC = 0; // All MCASPs- {3 u: k; I( L o
mcasp->regs->PDIR = 0x14000020; // All inputs except AXR0[5], ACLKX1, AFSX1
- m8 I, J* v$ h! _3 Z
0 ?# ]: a4 t3 ^+ @1 q. c0 f mcasp->regs->DITCTL = 0x00000000; // Not used0 H5 Z4 o |+ b. V
mcasp->regs->DLBCTL = 0x00000000; // Not used9 a+ O4 g/ k, ^! K
mcasp->regs->AMUTE = 0x00000000; // Not used6 X% @7 s8 }" ^9 D( w9 ^8 n+ m4 R
1 D w$ k V+ a5 ^& g+ x( l
/* Starting sections of the McASP*/
+ Z/ s9 n/ @' H4 `+ d% b" Q1 D mcasp->regs->XGBLCTL |= GBLCTL_XHCLKRST_ON; # T- u& J; A, ~9 ]1 h/ s
while ( ( mcasp->regs->XGBLCTL & GBLCTL_XHCLKRST_ON ) != GBLCTL_XHCLKRST_ON );
' @( {# W- q7 w) a( k V* O mcasp->regs->RGBLCTL |= GBLCTL_RHCLKRST_ON; , I- i% l# p$ a; @' F* m" J2 ~
while ( ( mcasp->regs->RGBLCTL & GBLCTL_RHCLKRST_ON ) != GBLCTL_RHCLKRST_ON );1 _ [7 m: m e4 [2 l) }& Z* d" J
$ |4 p6 s0 t8 b mcasp->regs->XGBLCTL |= GBLCTL_XCLKRST_ON; + B8 n6 e9 {- d8 s
while ( ( mcasp->regs->XGBLCTL & GBLCTL_XCLKRST_ON ) != GBLCTL_XCLKRST_ON );
/ k: y5 y1 B/ f* q0 |2 d mcasp->regs->RGBLCTL |= GBLCTL_RCLKRST_ON;
5 k( n* m) o" Q& {2 @9 o! j while ( ( mcasp->regs->RGBLCTL & GBLCTL_RCLKRST_ON ) != GBLCTL_RCLKRST_ON );7 m0 q* E r) p1 g( |, s
" | U- {% S2 B& p/ Z% a1 \ mcasp->regs->XSTAT = 0x0000ffff; 8 \( ^7 {0 s$ f; Z4 v! p
mcasp->regs->RSTAT = 0x0000ffff; 0 {$ o4 ]+ o. s# h8 f
8 [; L, w& v8 g5 T! x mcasp->regs->XGBLCTL |= GBLCTL_XSRCLR_ON;2 A8 m2 n! V! F6 M7 K% U. e
while ( ( mcasp->regs->XGBLCTL & GBLCTL_XSRCLR_ON ) != GBLCTL_XSRCLR_ON );! E; s4 i6 h/ ?0 A$ Y
mcasp->regs->RGBLCTL |= GBLCTL_RSRCLR_ON; , ^6 n( C$ |+ i8 I9 P. {9 j
while ( ( mcasp->regs->RGBLCTL & GBLCTL_RSRCLR_ON ) != GBLCTL_RSRCLR_ON );( A+ s3 b2 ]: s! a/ _8 b, [0 \; G
0 i9 n% ~& k. _$ d* P$ h/ | /* Write a 0, so that no underrun occurs after releasing the state machine */
( H4 J1 g* s S) r mcasp->regs->XBUF5 = 0;) g j/ x; Y' T
mcasp->regs->RBUF0 = 0;6 u7 O1 i* w, L. s( O8 u
' Y. b5 o# L: @5 y% A" j$ K: I4 ^( s( K mcasp->regs->XGBLCTL |= GBLCTL_XSMRST_ON;
+ u9 i5 m5 T9 @7 W. l u while ( ( mcasp->regs->XGBLCTL & GBLCTL_XSMRST_ON ) != GBLCTL_XSMRST_ON );
$ Y$ W q: o2 I" f' k s' Q mcasp->regs->RGBLCTL |= GBLCTL_RSMRST_ON; % W% w& V+ x1 _8 h
while ( ( mcasp->regs->RGBLCTL & GBLCTL_RSMRST_ON ) != GBLCTL_RSMRST_ON );7 L$ A/ w2 G; ?2 [ d! _) R4 L
- o# A/ R" O# }/ K( h( o9 f; Y o
mcasp->regs->XGBLCTL |= GBLCTL_XFRST_ON; 7 d' e$ l; \; p/ g1 ?3 Z4 `. z
while ( ( mcasp->regs->XGBLCTL & GBLCTL_XFRST_ON ) != GBLCTL_XFRST_ON );3 D5 e5 y0 d$ _$ ]* n& s& U% F8 V
mcasp->regs->RGBLCTL |= GBLCTL_RFRST_ON; # C7 o0 e4 f8 Z0 h6 W1 p3 C
while ( ( mcasp->regs->RGBLCTL & GBLCTL_RFRST_ON ) != GBLCTL_RFRST_ON );' t+ K0 h$ N* Z
( _0 h6 l) B6 ]/ G CSR = 0x0000;
$ L4 [* v' ~# V+ [ INTC_INTMUX1 = 0x3d;
& O, R, a# C9 q( Q6 I8 y" }6 x- r$ e ISTP = (unsigned int)vectors;
Q+ Y! u6 n& w ICR = 0xFFF0; . u* D/ ]$ Z7 C3 C! W* H6 ^$ X% ]
IER |= 0x12;
+ D9 B; |3 L& ]) r CSR |= 0x01;
2 H0 u& G# j9 s6 S1 t6 a4 n2 R
) \, W+ Z4 W+ F2 }4 ?; F/ c0 g
9 {! h. L7 p V) g# Q+ N
! ~% O6 E f* Z$ _$ [# `8 E还有就是两个输入输出函数:7 t& Q7 S% P- [) ?8 Q
void output_sample(Int32 out_data)
. s+ [' D9 f4 Q) X( V+ d9 ^8 X{
" G, m8 z" }+ D; ]# F AIC31_data.uint = out_data; 5 f" N4 n ^0 i6 X1 H- T4 r4 J2 c7 k
MCASP1_XBUF5_32BIT = AIC31_data.uint;# P# |1 _! z2 [# D5 P c$ ^1 S
}! ?/ b: r- |3 ?3 ^8 l- i) H2 n, M0 A0 D
1 G& P3 ?: |$ T
Int32 input_sample(void)
/ O, L! M( ^( G) Y{
2 l7 B9 h/ k% e5 D- |% X) A& i AIC31_data.uint = MCASP1_RBUF0_32BIT;7 m* }6 P& E8 {& W( C1 p
return (AIC31_data.uint);8 l( t9 d1 x. N
}6 }% f2 s3 u7 n& T, f
* f( j1 M4 h9 h+ S
|
|