嵌入式开发者社区
标题: MCASP自环配置。 [打印本页]
作者: wapdasta 时间: 2018-11-7 13:28
标题: MCASP自环配置。
我项目上用OMAPL138的板子MCASP的引脚都是链接的FPGA,所以在FPGA这端设置的MCASP自环。把axr0接收到的通过axr1发回去。
部分代码如下
input mcasp_afsx,
9 c' l W* h% ~5 ] h; g: {input mcasp_ahclkx,. D* n# g h: R2 w
input mcasp_aclkx,6 F% f. k, V5 ?
input axr0,
8 }: [( a% l) m; v1 R# O/ Z" x- @, H: h; M2 L0 e u% j
output mcasp_afsr,) X* b* R' k- r# G% T I! n5 L
output mcasp_ahclkr,
: T+ h' s, i x5 ioutput mcasp_aclkr,
4 } B; Q. d) U0 G8 |, b+ uoutput axr1,
2 ~5 }, p5 S8 C6 I1 q5 j
assign mcasp_afsr = mcasp_afsx;
% y- [5 {4 t1 b" Yassign mcasp_aclkr = mcasp_aclkx;
" H, F" _- ]2 @3 g1 f' ?assign mcasp_ahclkr = mcasp_ahclkx;
; A" @' k, U; C1 t9 h; oassign axr1 = axr0;
) T9 n z. C7 [% l' Y8 R$ m$ j& @7 {0 [
5 V" ~' A% G9 y: }: `; E! ]在OMAPL138这端,通过axr0接口发固定的数,axr1接收。
在配置MACASP的时候,发送全部取内部时钟,接收全部取外部时钟。
一直循环发送,但是接收不到。在FPGA端也没有看到时钟和信号的波形。
部分代码如下,关于edma3的部分未做变化。
1 i" S/ E+ A2 B/ a" Y, hstatic void McASPI2SConfigure(void)+ p/ q% f$ p3 L$ L
{
4 Y+ R0 h( H7 F. j6 UMcASPRxReset(SOC_MCASP_0_CTRL_REGS);
4 E7 T! \) d/ y# j3 v& kMcASPTxReset(SOC_MCASP_0_CTRL_REGS);
/* Enable the FIFOs for DMA transfer */: w9 o, z& E' |1 r- d
McASPReadFifoEnable(SOC_MCASP_0_FIFO_REGS, 1, 1);
8 [/ h5 w- b: `- s8 K V0 W7 ?: q" \McASPWriteFifoEnable(SOC_MCASP_0_FIFO_REGS, 1, 1);
/* Set I2S format in the transmitter/receiver format units */$ s" L/ f# M5 [
McASPRxFmtI2SSet(SOC_MCASP_0_CTRL_REGS, WORD_SIZE, SLOT_SIZE,
' k* Z% J' G# @; c9 g! C( F" @3 L0 K* pMCASP_RX_MODE_DMA);
. _- v* V: Y4 X/ T- T- R: OMcASPTxFmtI2SSet(SOC_MCASP_0_CTRL_REGS, WORD_SIZE, SLOT_SIZE,
2 U+ U7 P) v) dMCASP_TX_MODE_DMA);
/* Configure the frame sync. I2S shall work in TDM format with 2 slots */
. D& `! S- y8 L" NMcASPRxFrameSyncCfg(SOC_MCASP_0_CTRL_REGS, 2, MCASP_RX_FS_WIDTH_WORD,
8 b2 [6 ~& N3 l3 [9 qMCASP_RX_FS_EXT_BEGIN_ON_FALL_EDGE);. Y. E, {. q3 b- t* L1 D$ m$ D
McASPTxFrameSyncCfg(SOC_MCASP_0_CTRL_REGS, 2, MCASP_TX_FS_WIDTH_WORD,
# T1 P. f' |; zMCASP_TX_FS_INT_BEGIN_ON_RIS_EDGE);
/* configure the clock for receiver */: K/ D) x1 A4 v
McASPRxClkCfg(SOC_MCASP_0_CTRL_REGS, MCASP_RX_CLK_EXTERNAL, 0, 0);
% \( T6 T( k" t8 K; ?; m# Y; t5 [McASPRxClkPolaritySet(SOC_MCASP_0_CTRL_REGS, MCASP_RX_CLK_POL_RIS_EDGE);
5 q$ M" q, ^" B0 wMcASPRxClkCheckConfig(SOC_MCASP_0_CTRL_REGS, MCASP_RX_CLKCHCK_DIV32,7 |- k2 h9 n$ H3 R, p( i# ~# b
0x00, 0xFF);
/* configure the clock for transmitter *// n5 q. g3 P8 Y1 f* J) b
McASPTxClkCfg(SOC_MCASP_0_CTRL_REGS, MCASP_TX_CLK_INTERNAL, 11, 1);
* ~% M+ o5 j+ t, \" YMcASPTxClkPolaritySet(SOC_MCASP_0_CTRL_REGS, MCASP_TX_CLK_POL_FALL_EDGE);
5 x6 [# }* ]1 ?$ K6 kMcASPTxClkCheckConfig(SOC_MCASP_0_CTRL_REGS, MCASP_TX_CLKCHCK_DIV32,8 `% `# W0 B) `; a' t, {9 d; [4 p
0x00, 0xFF);9 |2 D* B7 i7 @
8 F' }6 U2 I0 J% D, z
/* Enable synchronization of RX and TX sections */
8 {/ b0 d6 [5 t5 OMcASPTxRxClkSyncEnable(SOC_MCASP_0_CTRL_REGS);
/* Enable the transmitter/receiver slots. I2S uses 2 slots */
1 o) N: p- d7 [, I# mMcASPRxTimeSlotSet(SOC_MCASP_0_CTRL_REGS, I2S_SLOTS);2 |% z" a; X9 K: r0 z/ V! d# d5 k
McASPTxTimeSlotSet(SOC_MCASP_0_CTRL_REGS, I2S_SLOTS);
/*
3 u4 Y$ y( |* `' u9 J u** Set the serializers, Currently only one serializer is set as3 z9 T5 j" z4 j) D
** transmitter and one serializer as receiver.
2 C5 n, S4 G- z# G1 M*/
9 N2 m4 F; w YMcASPSerializerRxSet(SOC_MCASP_0_CTRL_REGS, MCASP_XSER_RX);
- h g/ M J- W7 K9 D- pMcASPSerializerTxSet(SOC_MCASP_0_CTRL_REGS, MCASP_XSER_TX);
/*
9 r- x- M8 E& T2 J' V** Configure the McASP pins
) n c" b1 _5 E" O1 p/ L) R( x** Input - Frame Sync, Clock and Serializer Rx
& X) G; J* h- g1 z** Output - Serializer Tx is connected to the input of the codec
- W2 d1 L0 L# U- \# h. J*/
2 s$ ?+ E) U8 @McASPPinMcASPSet(SOC_MCASP_0_CTRL_REGS, 0xFFFFFFFF);
! o2 ]1 F, Y) A' d3 F0 |. u& e& nMcASPPinDirOutputSet(SOC_MCASP_0_CTRL_REGS,MCASP_PIN_AXR(MCASP_XSER_TX));3 ]1 j0 ~7 }+ j2 b: Y( Q; |
McASPPinDirInputSet(SOC_MCASP_0_CTRL_REGS, MCASP_PIN_AFSX/ q3 D: ^' P' E/ [. m$ H2 Q8 y" Q
| MCASP_PIN_ACLKX5 G( c% O' I) P5 t+ C; y
| MCASP_PIN_AHCLKX7 F% G( L4 ^4 d9 R; q- |" n) k
| MCASP_PIN_AXR(MCASP_XSER_RX));
/* Enable error interrupts for McASP */+ i; q4 I0 p( |, @3 N
McASPTxIntEnable(SOC_MCASP_0_CTRL_REGS, MCASP_TX_DMAERROR
# m# |/ p- T" |- W1 O& V| MCASP_TX_CLKFAIL % l0 g4 c: Y7 j& A; H; c
| MCASP_TX_SYNCERROR
+ L' b o- L, v2 g| MCASP_TX_UNDERRUN);
McASPRxIntEnable(SOC_MCASP_0_CTRL_REGS, MCASP_RX_DMAERROR
% e' F$ O' ?- e1 u5 v% @) Y/ e| MCASP_RX_CLKFAIL
2 W/ a$ g k1 ~5 \2 _/ g| MCASP_RX_SYNCERROR . U' F* l* V( b" y4 x2 d
| MCASP_RX_OVERRUN);
8 I7 y0 H/ t. e6 x}
static void I2SDataTxRxActivate(void)
6 l/ z% r/ A5 B% Y3 m% ^. a! g, k{$ o/ `8 n) f0 p) [3 I
/* Start the clocks */5 B& u) N; [! t D' P: f) \
McASPRxClkStart(SOC_MCASP_0_CTRL_REGS, MCASP_RX_CLK_EXTERNAL);2 w" [7 }/ \" _: j1 M
McASPTxClkStart(SOC_MCASP_0_CTRL_REGS, MCASP_TX_CLK_INTERNAL);
/* Enable EDMA for the transfer */' U" l# w; x+ G5 p
EDMA3EnableTransfer(SOC_EDMA30CC_0_REGS, EDMA3_CHA_MCASP0_RX,
0 ?) U1 \6 d3 ?1 B( KEDMA3_TRIG_MODE_EVENT);
& f* Y: M$ I" ?, gEDMA3EnableTransfer(SOC_EDMA30CC_0_REGS, 5 g, _3 k% \7 ^1 o- {2 i
EDMA3_CHA_MCASP0_TX, EDMA3_TRIG_MODE_EVENT);
/* Activate the serializers */% G: s( V" n$ e8 t$ Z# e) s
McASPRxSerActivate(SOC_MCASP_0_CTRL_REGS);$ n& l* P6 n+ m
McASPTxSerActivate(SOC_MCASP_0_CTRL_REGS);
/* make sure that the XDATA bit is cleared to zero */( S2 O6 U2 r5 A. @ g
while(McASPTxStatusGet(SOC_MCASP_0_CTRL_REGS) & MCASP_TX_STAT_DATAREADY);
/* Activate the state machines */# `' i: u- x: F
McASPRxEnable(SOC_MCASP_0_CTRL_REGS);( B& L+ X& S. {* S' a i
McASPTxEnable(SOC_MCASP_0_CTRL_REGS);, E& g" F7 n `* G/ B0 [
}
0 h9 ?# n8 z+ q3 w7 W+ b
请问:问题出在哪了,时钟按照这样配是否有错。
另外我看XDATA一直是0,接收的rxbuf0,1,2里有一般全是FFFF一半全是0.
5 ^6 }# C2 g) |# e& I$ [6 @1 O
| 欢迎光临 嵌入式开发者社区 (https://www.51ele.net/) |
Powered by Discuz! X3.4 |