嵌入式开发者社区

标题: MCASP自环配置。 [打印本页]

作者: wapdasta    时间: 2018-11-7 13:28
标题: MCASP自环配置。
我项目上用OMAPL138的板子MCASP的引脚都是链接的FPGA,所以在FPGA这端设置的MCASP自环。把axr0接收到的通过axr1发回去。
部分代码如下
input mcasp_afsx,
$ L/ W" a. e: a+ minput mcasp_ahclkx,$ h$ B0 ]5 z) Y# X, g( K4 J7 f
input mcasp_aclkx,
3 s5 T9 R# P) q; {input axr0,. T) _% t, r7 z2 ?! A5 H- d% W; ~/ P
0 x. a$ ~  Q. u4 m$ b
output mcasp_afsr,
4 A- T1 j* ~; o1 t" l! {output mcasp_ahclkr,+ i+ M; J4 k; |
output mcasp_aclkr,
$ Q* \3 O: p" t$ a- joutput axr1,
, {- E! y& G3 l8 a' \4 L
assign mcasp_afsr = mcasp_afsx;1 A) `6 O: U' x
assign mcasp_aclkr = mcasp_aclkx;
! e7 q( \& S) \assign mcasp_ahclkr = mcasp_ahclkx;2 }  U/ U* z* [# H* J# h1 T9 ]6 C
assign axr1 = axr0;
& k# R! ^, {( q, q  m! J- {1 S5 O" R

( u5 `2 T' w# Z3 ^. b$ K; R. @
在OMAPL138这端,通过axr0接口发固定的数,axr1接收。
在配置MACASP的时候,发送全部取内部时钟,接收全部取外部时钟。
一直循环发送,但是接收不到。在FPGA端也没有看到时钟和信号的波形。
部分代码如下,关于edma3的部分未做变化。
( O$ u( ~5 q8 {8 Y
static void McASPI2SConfigure(void)) x9 S! h9 j  M. _+ w( N
{
8 O0 G4 |% R8 y3 u: h0 mMcASPRxReset(SOC_MCASP_0_CTRL_REGS);! Z2 [  [+ z) Z1 ?" O
McASPTxReset(SOC_MCASP_0_CTRL_REGS);
/* Enable the FIFOs for DMA transfer */7 K; d' |, h/ z* A; g5 n: b
McASPReadFifoEnable(SOC_MCASP_0_FIFO_REGS, 1, 1);  Y" Z, }, ~& W& d/ X
McASPWriteFifoEnable(SOC_MCASP_0_FIFO_REGS, 1, 1);
/* Set I2S format in the transmitter/receiver format units */
/ z. X, \  U) R; XMcASPRxFmtI2SSet(SOC_MCASP_0_CTRL_REGS, WORD_SIZE, SLOT_SIZE,
4 J  m, z1 f8 f" x; v, `4 JMCASP_RX_MODE_DMA);- z" r4 S4 e6 A- l( B+ G
McASPTxFmtI2SSet(SOC_MCASP_0_CTRL_REGS, WORD_SIZE, SLOT_SIZE,
3 G9 V0 G" c3 u9 Y0 i. bMCASP_TX_MODE_DMA);
/* Configure the frame sync. I2S shall work in TDM format with 2 slots */. A+ I; ?, X; I
McASPRxFrameSyncCfg(SOC_MCASP_0_CTRL_REGS, 2, MCASP_RX_FS_WIDTH_WORD,
' n) Z% r  Y0 Y! u2 XMCASP_RX_FS_EXT_BEGIN_ON_FALL_EDGE);
* o/ e. E8 _2 u7 B- G4 W% c# c8 jMcASPTxFrameSyncCfg(SOC_MCASP_0_CTRL_REGS, 2, MCASP_TX_FS_WIDTH_WORD,
$ l( b( a3 p: j  U- i/ a& XMCASP_TX_FS_INT_BEGIN_ON_RIS_EDGE);
/* configure the clock for receiver */
/ |+ Z2 p; q3 G: n1 d' A0 \McASPRxClkCfg(SOC_MCASP_0_CTRL_REGS, MCASP_RX_CLK_EXTERNAL, 0, 0);
1 p, Z6 g9 p7 U# `6 XMcASPRxClkPolaritySet(SOC_MCASP_0_CTRL_REGS, MCASP_RX_CLK_POL_RIS_EDGE);   f5 d! O0 h$ `
McASPRxClkCheckConfig(SOC_MCASP_0_CTRL_REGS, MCASP_RX_CLKCHCK_DIV32,
4 F5 h: E8 X0 Y8 X3 b! [0x00, 0xFF);
/* configure the clock for transmitter */7 |' |8 F1 r: p; ~- L9 n
McASPTxClkCfg(SOC_MCASP_0_CTRL_REGS, MCASP_TX_CLK_INTERNAL, 11, 1);" p# T+ Q( y; T, G% ?
McASPTxClkPolaritySet(SOC_MCASP_0_CTRL_REGS, MCASP_TX_CLK_POL_FALL_EDGE);
# B8 Z7 [, X4 D6 y- o8 CMcASPTxClkCheckConfig(SOC_MCASP_0_CTRL_REGS, MCASP_TX_CLKCHCK_DIV32,
, `9 a! X+ g& p' c/ c$ N0x00, 0xFF);
3 C% q8 M5 U  I0 b8 Q, T  i  _4 F" p/ I, V8 h2 B. D9 o% C/ J; C+ h
/* Enable synchronization of RX and TX sections */ ! z: \% Z1 B. R9 L. t
McASPTxRxClkSyncEnable(SOC_MCASP_0_CTRL_REGS);
/* Enable the transmitter/receiver slots. I2S uses 2 slots */
0 L7 |0 |& @1 m5 K, V; {McASPRxTimeSlotSet(SOC_MCASP_0_CTRL_REGS, I2S_SLOTS);
" s# b$ H; U$ H% J9 ?& LMcASPTxTimeSlotSet(SOC_MCASP_0_CTRL_REGS, I2S_SLOTS);
/*1 P8 L$ Y" \7 Z
** Set the serializers, Currently only one serializer is set as, P7 _1 p: n0 Z/ q
** transmitter and one serializer as receiver.* V- @+ {' z* P4 }9 G/ C  z
*/) U% D* H" ]% Z
McASPSerializerRxSet(SOC_MCASP_0_CTRL_REGS, MCASP_XSER_RX);
+ w% ^( C" R; ~0 G: K' EMcASPSerializerTxSet(SOC_MCASP_0_CTRL_REGS, MCASP_XSER_TX);
/*, D# m" Q% E" v! G. }
** Configure the McASP pins , j, s) ]9 Q$ r: r* i) K# x* A0 i* N
** Input - Frame Sync, Clock and Serializer Rx+ P: g  q, S% o' ~
** Output - Serializer Tx is connected to the input of the codec
( }: t4 }; a3 c3 L*/
1 Z3 R6 h' a) _6 W# d& iMcASPPinMcASPSet(SOC_MCASP_0_CTRL_REGS, 0xFFFFFFFF);! [' D$ F4 l  ^% c* b' N) n2 p6 r
McASPPinDirOutputSet(SOC_MCASP_0_CTRL_REGS,MCASP_PIN_AXR(MCASP_XSER_TX));
8 W; c0 m# G2 b3 s% W& \7 D* dMcASPPinDirInputSet(SOC_MCASP_0_CTRL_REGS, MCASP_PIN_AFSX
% W' p3 C$ h3 X) s- F6 u2 g: J| MCASP_PIN_ACLKX7 `; ~/ k5 f5 K2 `& o
| MCASP_PIN_AHCLKX
8 Z: u5 _5 a: B6 d$ }+ X3 n5 V3 d| MCASP_PIN_AXR(MCASP_XSER_RX));
/* Enable error interrupts for McASP */7 h" n3 m4 Y; j1 F" P
McASPTxIntEnable(SOC_MCASP_0_CTRL_REGS, MCASP_TX_DMAERROR ( S' [  X1 }+ Z6 T  e
| MCASP_TX_CLKFAIL 8 I2 ?" F) [% I/ T: b# c5 R% `' ~" C
| MCASP_TX_SYNCERROR6 f& Z6 ~) o, q* c* G4 `& k# E# }) J8 @
| MCASP_TX_UNDERRUN);
McASPRxIntEnable(SOC_MCASP_0_CTRL_REGS, MCASP_RX_DMAERROR
, o# D0 {; Q5 N/ L# ?| MCASP_RX_CLKFAIL" n* z4 n1 l/ w9 Z/ N7 }
| MCASP_RX_SYNCERROR
* f, V) R; N3 B0 ]' _# a| MCASP_RX_OVERRUN);
; E( i5 }! o, ?2 k* w  B# N}
static void I2SDataTxRxActivate(void)2 F; s9 p5 l+ O: `4 d2 i5 c- t9 T
{
6 N, f* E+ Y; b8 C% U, ?% p) K' p/* Start the clocks */
1 w; u+ \% d' c/ h4 }( \McASPRxClkStart(SOC_MCASP_0_CTRL_REGS, MCASP_RX_CLK_EXTERNAL);
6 Z/ V0 q+ L' o% x7 t- h- SMcASPTxClkStart(SOC_MCASP_0_CTRL_REGS, MCASP_TX_CLK_INTERNAL);
/* Enable EDMA for the transfer */9 ~$ y1 r- B6 y3 w# H6 {5 `
EDMA3EnableTransfer(SOC_EDMA30CC_0_REGS, EDMA3_CHA_MCASP0_RX,+ R+ t4 a8 [7 Q2 |0 i- S- T
EDMA3_TRIG_MODE_EVENT);
( Y6 g+ }/ z1 LEDMA3EnableTransfer(SOC_EDMA30CC_0_REGS,
5 a$ W* P- a7 b6 |5 l8 |- X1 lEDMA3_CHA_MCASP0_TX, EDMA3_TRIG_MODE_EVENT);
/* Activate the serializers */
9 L: M" V4 }# ]% c8 _; v1 d( dMcASPRxSerActivate(SOC_MCASP_0_CTRL_REGS);( n% U" e/ j8 \& }
McASPTxSerActivate(SOC_MCASP_0_CTRL_REGS);
/* make sure that the XDATA bit is cleared to zero */& d' J# m9 L+ b
while(McASPTxStatusGet(SOC_MCASP_0_CTRL_REGS) & MCASP_TX_STAT_DATAREADY);
/* Activate the state machines */
7 k  Q- S! K* {, A; R1 k0 R4 HMcASPRxEnable(SOC_MCASP_0_CTRL_REGS);( d. L, _: g# L' J! G
McASPTxEnable(SOC_MCASP_0_CTRL_REGS);
7 g7 W+ ~! E7 M1 Q3 N}

# p  g: |+ H, y& l( w" u/ D+ Z8 F
请问:问题出在哪了,时钟按照这样配是否有错。
另外我看XDATA一直是0,接收的rxbuf0,1,2里有一般全是FFFF一半全是0.
* W3 F) e' ]/ g% [2 z* |" ]





欢迎光临 嵌入式开发者社区 (https://www.51ele.net/) Powered by Discuz! X3.4