|
|
C6747和C6748感觉差不多,我想实现McASP发送中断方式控制音频信号,在轮询的例程基础上改的,轮询程序可以实现,但是中断一直实现不了,也找不到错误,求大神帮忙!下边是主要程序:
+ I% q$ A9 p2 z. z3 F' v0 t. v5 Ymain文件:" [- u" t$ }" ^5 `. O4 x' V3 p
interrupt void interrupt4(void)
( a8 l* s4 V# R$ g9 ]{+ f/ h: V4 K# |3 T# a
Uint32 sample;
% L& j% z) X) n. e$ v* s1 S( W/ } H8 l
sample = input_sample(); // read L + R samples from ADC8 H0 f! L$ @# j$ G6 l
output_sample(sample); // write L + R samples to DAC $ U0 V+ n" E+ B4 u7 O% V }
return;* e5 ~; O+ k' e( f3 w- X* x4 {
}+ P ~/ [% Y( O2 E: u c
6 j. ~ L4 A& K1 |) k& O
int main( void )
/ _) N1 }# ~9 d; Y9 {{0 Z( ]' y/ |9 g+ k
: k% S; W, I- Q# u /* Initialize BSL */
* L6 R* Q6 X1 S& `/ W EVMC6747_init( );
$ M; A+ t6 m0 l2 i, p /* Call evmc6747_intr function */! {8 C P! `4 m6 U# h( O3 B8 e
aic3106_init( );
3 b8 J- Z6 G* C) X) D: Q0 C' U( M F/ F while(1);; I d' S. @2 p1 _: T9 H
}6 M: z* z; A r
' ~/ @9 @' C6 Y1 c5 `
/ Q) V; v! E/ l9 paic3106_init文件的一部分,McASP配置部分,采用内部时钟,I2S方式,同步传输。音频芯片的配置应该没问题
9 q: S0 c1 d) j1 i3 B/* Initialize MCASP1 */
3 L n( L$ X- s5 K/ W mcasp = &MCASP_MODULE_1;
! j: r" h: a( G( X3 E6 T) Z% b mcasp->regs->GBLCTL = 0; // Reset0 P4 N D* G6 F, K
mcasp->regs->RGBLCTL = 0; // Reset RX9 d+ P* M3 j% ]0 S- G5 C/ V) u- Q
mcasp->regs->XGBLCTL = 0; // Reset TX
4 y7 N9 g5 u0 Y+ ^: u: J mcasp->regs->PWRDEMU = 1; // Free-running8 y& N! Z- H2 Y5 j& D; M
// configure McASP0 receive registers
0 L4 [# o# N$ {- ?( |) b mcasp->regs->RMASK = 0xFFFFFFFF; // No padding used
2 a: w1 o( Z2 U. W2 j { mcasp->regs->RFMT = 0x00018078; // MSB 16bit, 0-delay, no pad, CFGBus; u8 E# R7 w0 ^. A# R
mcasp->regs->AFSRCTL = 0x00000112; // 2TDM, 1bit Falling, External FS, word' ^( G2 N7 \, ?5 `: G
mcasp->regs->ACLKRCTL = 0x000000AF; // Rising INTERNAL CLK,(from tx side)6 Y) F: T- ? w6 w0 I
mcasp->regs->AHCLKRCTL = 0x00000000; // INT CLK (from tx side): c$ W# P) T! s; h7 J
mcasp->regs->RTDM = 0x00000003; // Slots 0,18 X. S, x8 |) F' L0 g/ T1 _. P, Z9 y
mcasp->regs->RINTCTL = 0x00000000; // Not used
' z' {8 k1 c# i) L! L mcasp->regs->RCLKCHK = 0x00FF0008; // 255-MAX 0-MIN, div-by-256
- v6 K& \3 i1 V- |( F n7 `
! ^. ^* H/ [( M mcasp->regs->XMASK = 0xFFFFFFFF; // No padding used0 n" S2 t6 K! J4 Z
mcasp->regs->XFMT = 0x00018078; // MSB 16bit, 0-delay, no pad, CFGBus
7 l% m5 ?7 E6 h% D mcasp->regs->AFSXCTL = 0x00000112; // 2TDM, 1bit Rising edge INTERNAL FS, word
+ f% K N; A! P0 l/ h6 y' e mcasp->regs->ACLKXCTL = 0x000000AF; // ASYNC, Rising INTERNAL CLK, div-by-162 H& u/ b4 U2 j) l0 D6 o3 R
mcasp->regs->AHCLKXCTL = 0x00000000; // EXT CLK! p: |. _* G3 O# A4 a
mcasp->regs->XTDM = 0x00000003; // Slots 0,1) m2 [ W) m' A+ X
mcasp->regs->XINTCTL = 0x00000020; // interrupt on transmit: e& ^0 H. K0 M# ]6 z! ?6 j
mcasp->regs->XCLKCHK = 0x00FF0008; // 255-MAX 0-MIN, div-by-256 _3 W9 N4 F1 A
. T6 h! q% m8 |- p' P7 Q
mcasp->regs->SRCTL5 = 0x000D; // MCASP1.AXR1[5] --> DIN
9 T2 H5 ?4 v$ \" w3 X mcasp->regs->SRCTL0 = 0x000E; // MCASP1.AXR1[0] <-- DOUT8 \% G4 }7 g$ _ v8 p
mcasp->regs->PFUNC = 0; // All MCASPs1 d- J j. [+ k! a( B3 s
mcasp->regs->PDIR = 0x14000020; // All inputs except AXR0[5], ACLKX1, AFSX1" }( c) B. t' N- K# @8 x
* p% j; S# s% H- S- i" O) ^ mcasp->regs->DITCTL = 0x00000000; // Not used
/ x4 c! i9 u! Z7 f5 ^* X mcasp->regs->DLBCTL = 0x00000000; // Not used. a: A6 U/ V$ e" w# G
mcasp->regs->AMUTE = 0x00000000; // Not used
% R4 ~, }6 O. Z9 K5 ?, c' ~& Y& q2 C D& V; \1 P
/* Starting sections of the McASP*/- j0 L+ Z$ X( Z; I3 M) @1 S
mcasp->regs->XGBLCTL |= GBLCTL_XHCLKRST_ON; 5 ^. h5 o/ e' r/ }( d
while ( ( mcasp->regs->XGBLCTL & GBLCTL_XHCLKRST_ON ) != GBLCTL_XHCLKRST_ON ); / {( T3 a: j# T3 q8 k/ R/ q0 B x+ K; C
mcasp->regs->RGBLCTL |= GBLCTL_RHCLKRST_ON;
2 h& Y& H6 a7 W" u+ C& T" r: J while ( ( mcasp->regs->RGBLCTL & GBLCTL_RHCLKRST_ON ) != GBLCTL_RHCLKRST_ON );
$ ?8 D; h" z: C2 j' M, O1 _# ]; A4 x4 T
mcasp->regs->XGBLCTL |= GBLCTL_XCLKRST_ON;
6 w9 l8 \; ?' J' X4 z while ( ( mcasp->regs->XGBLCTL & GBLCTL_XCLKRST_ON ) != GBLCTL_XCLKRST_ON );! ]* m1 L* _ M, W9 O7 G0 x) D
mcasp->regs->RGBLCTL |= GBLCTL_RCLKRST_ON; 6 D1 @. L$ V3 g: _" q! C
while ( ( mcasp->regs->RGBLCTL & GBLCTL_RCLKRST_ON ) != GBLCTL_RCLKRST_ON );
* M7 l% J$ E& V' [/ m
( N& N7 O2 ]5 Q5 w6 A5 R* P, R mcasp->regs->XSTAT = 0x0000ffff;
% @$ Y; O; r- U( _. B mcasp->regs->RSTAT = 0x0000ffff;
$ S% h% F% i# \1 D y, j6 t7 e; c: s
mcasp->regs->XGBLCTL |= GBLCTL_XSRCLR_ON;
7 r; _/ ]" b. p$ T( j while ( ( mcasp->regs->XGBLCTL & GBLCTL_XSRCLR_ON ) != GBLCTL_XSRCLR_ON );
' @1 ]3 D- z/ P, Q/ a mcasp->regs->RGBLCTL |= GBLCTL_RSRCLR_ON; 3 T- A6 o! q! X
while ( ( mcasp->regs->RGBLCTL & GBLCTL_RSRCLR_ON ) != GBLCTL_RSRCLR_ON );
8 P- W3 c! a/ T: R' M$ x9 t* o1 A
9 d' B- t/ }+ a+ L; z /* Write a 0, so that no underrun occurs after releasing the state machine */8 q- {8 ^ P4 f0 W* q$ o
mcasp->regs->XBUF5 = 0;; _& C3 A2 x5 r2 [4 O% l. E! }
mcasp->regs->RBUF0 = 0;
Z. s8 J( I' d0 W* ~$ u
& u9 O7 A8 o5 ?" U7 h; F0 M mcasp->regs->XGBLCTL |= GBLCTL_XSMRST_ON; 3 o- I2 W) _' K5 `
while ( ( mcasp->regs->XGBLCTL & GBLCTL_XSMRST_ON ) != GBLCTL_XSMRST_ON );) C6 [) U& o& d3 Q6 T5 O! d
mcasp->regs->RGBLCTL |= GBLCTL_RSMRST_ON; % [$ z' [ N2 T0 V. d
while ( ( mcasp->regs->RGBLCTL & GBLCTL_RSMRST_ON ) != GBLCTL_RSMRST_ON );
$ a6 L5 X n% D+ s
' \$ d$ C3 `6 _ mcasp->regs->XGBLCTL |= GBLCTL_XFRST_ON; , k2 l% I, Q7 p/ L" [
while ( ( mcasp->regs->XGBLCTL & GBLCTL_XFRST_ON ) != GBLCTL_XFRST_ON );' f) ^) @# z$ x" `/ S
mcasp->regs->RGBLCTL |= GBLCTL_RFRST_ON;
7 h9 x- } a4 a while ( ( mcasp->regs->RGBLCTL & GBLCTL_RFRST_ON ) != GBLCTL_RFRST_ON );
; r. C! t" ?" N+ H$ B. Q2 L
; D* u, I8 a B; M CSR = 0x0000; g( ^3 M! Z% K% G
INTC_INTMUX1 = 0x3d;+ Q# x& L, z# f/ Z
ISTP = (unsigned int)vectors;* ]# M `% q& F5 g5 ?
ICR = 0xFFF0; 1 f1 l6 Z0 \8 R; B/ A* d h
IER |= 0x12; 6 P7 V; P; Q+ t; J: k) C2 X& c
CSR |= 0x01; * i; F3 A2 {% d" h5 G! v
! s! l6 q: v8 K4 Z5 j% r
8 h2 N6 ^. ?. n2 H' |
6 k5 y' m5 P% C) Q% b7 [还有就是两个输入输出函数:7 N l% _8 \0 ~( L8 j
void output_sample(Int32 out_data)
. {4 S: I6 W0 x/ J{
& P( M3 z! N' M2 }9 W AIC31_data.uint = out_data;
6 p% Z: B; F* b# u6 J2 |5 Y1 H, p5 X MCASP1_XBUF5_32BIT = AIC31_data.uint;$ t4 d$ R2 c8 C$ @, k( ]: v4 S
}! _! J' c; c7 Y! m2 ^6 r# W
) ?2 c2 o# W/ e, U# E
Int32 input_sample(void)
: a) g7 U1 a& T; Z0 ]1 l4 t{ 9 X, c6 j% a- H8 J
AIC31_data.uint = MCASP1_RBUF0_32BIT;
c; e/ W" {0 R1 ?+ D7 f return (AIC31_data.uint);
* U, ^& z, [+ _# o; `( R- d}6 [7 m7 \( C0 C9 z9 h; |
% X! u9 I$ Q+ o N/ s7 E
|
|