嵌入式开发者社区

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

作者: wapdasta    时间: 2018-11-7 13:28
标题: MCASP自环配置。
我项目上用OMAPL138的板子MCASP的引脚都是链接的FPGA,所以在FPGA这端设置的MCASP自环。把axr0接收到的通过axr1发回去。
部分代码如下
input mcasp_afsx,* j5 v2 k5 T, f8 M. Z
input mcasp_ahclkx,
$ V9 ]& i' B0 h' G: R& ]6 oinput mcasp_aclkx,; ?2 _& x% J# z3 D$ P7 t  a
input axr0,6 f1 E9 J: }% A( X, f8 K3 k

: {% B% T0 e% K2 d* X+ doutput mcasp_afsr,
% E! t2 R+ c8 t) q/ S( zoutput mcasp_ahclkr,
" b- T! x( T" d; aoutput mcasp_aclkr,
4 G+ v, u9 e7 X# houtput axr1,  z' E& x2 Q) t, X
assign mcasp_afsr = mcasp_afsx;
: y  |- d7 E( `+ S4 }& A9 o6 vassign mcasp_aclkr = mcasp_aclkx;
1 U$ `4 x0 z2 l8 h0 Q% M% }assign mcasp_ahclkr = mcasp_ahclkx;
# c. M0 s% j: ]8 e* k3 {! o8 Kassign axr1 = axr0;
+ e- W  W, H7 E6 Z4 \
, d( K, y. W  t
在OMAPL138这端,通过axr0接口发固定的数,axr1接收。
在配置MACASP的时候,发送全部取内部时钟,接收全部取外部时钟。
一直循环发送,但是接收不到。在FPGA端也没有看到时钟和信号的波形。
部分代码如下,关于edma3的部分未做变化。
4 |9 J: v% o% B
static void McASPI2SConfigure(void)
9 \) A2 A$ O* A$ O. H" ]7 N0 o{
0 P3 ]1 J3 {4 {McASPRxReset(SOC_MCASP_0_CTRL_REGS);" |9 |/ B% M% Q7 i& v, e6 f
McASPTxReset(SOC_MCASP_0_CTRL_REGS);
/* Enable the FIFOs for DMA transfer */
* o) }6 C1 [  x! HMcASPReadFifoEnable(SOC_MCASP_0_FIFO_REGS, 1, 1);: Q; A0 B- U2 r% l
McASPWriteFifoEnable(SOC_MCASP_0_FIFO_REGS, 1, 1);
/* Set I2S format in the transmitter/receiver format units */2 R: E* q! c, e) Q0 {  |' [: B5 N
McASPRxFmtI2SSet(SOC_MCASP_0_CTRL_REGS, WORD_SIZE, SLOT_SIZE,
. W& k* ?8 R/ l5 ^MCASP_RX_MODE_DMA);. l9 `! g+ j: |5 B5 J  Y0 [
McASPTxFmtI2SSet(SOC_MCASP_0_CTRL_REGS, WORD_SIZE, SLOT_SIZE,
) X' }# Q2 N- o9 IMCASP_TX_MODE_DMA);
/* Configure the frame sync. I2S shall work in TDM format with 2 slots */; v; v! w! V4 v& W& {8 h, J, `) y4 N5 d* Z: K
McASPRxFrameSyncCfg(SOC_MCASP_0_CTRL_REGS, 2, MCASP_RX_FS_WIDTH_WORD,
' `( {/ ^* H" H/ @% HMCASP_RX_FS_EXT_BEGIN_ON_FALL_EDGE);/ D% L& d$ t; N/ {. x6 q( D
McASPTxFrameSyncCfg(SOC_MCASP_0_CTRL_REGS, 2, MCASP_TX_FS_WIDTH_WORD,
( e6 {0 L6 v% @MCASP_TX_FS_INT_BEGIN_ON_RIS_EDGE);
/* configure the clock for receiver */& o& M+ W  r( _( ^
McASPRxClkCfg(SOC_MCASP_0_CTRL_REGS, MCASP_RX_CLK_EXTERNAL, 0, 0);
1 p1 d. w- i& M8 ^' ]1 O: I# i! aMcASPRxClkPolaritySet(SOC_MCASP_0_CTRL_REGS, MCASP_RX_CLK_POL_RIS_EDGE); ! f- p- q, x! Y$ q" E& o7 x
McASPRxClkCheckConfig(SOC_MCASP_0_CTRL_REGS, MCASP_RX_CLKCHCK_DIV32,/ ^) Z- I2 S1 _! l4 @8 L
0x00, 0xFF);
/* configure the clock for transmitter */( [% C- |& v, _6 e$ c
McASPTxClkCfg(SOC_MCASP_0_CTRL_REGS, MCASP_TX_CLK_INTERNAL, 11, 1);
. E1 P3 o. A; Q8 Q+ eMcASPTxClkPolaritySet(SOC_MCASP_0_CTRL_REGS, MCASP_TX_CLK_POL_FALL_EDGE);
: G' R5 Q9 r5 r) DMcASPTxClkCheckConfig(SOC_MCASP_0_CTRL_REGS, MCASP_TX_CLKCHCK_DIV32,
, T! _9 ~& j* l0x00, 0xFF);. ?" O  S3 z- b3 x7 S* V, P. E) C
  s2 D0 Q& a4 c; H* G; N
/* Enable synchronization of RX and TX sections */ : e3 a) C* N9 Y! _& J
McASPTxRxClkSyncEnable(SOC_MCASP_0_CTRL_REGS);
/* Enable the transmitter/receiver slots. I2S uses 2 slots */0 Y4 w; Y0 ^! |  b6 w! Y4 _4 v
McASPRxTimeSlotSet(SOC_MCASP_0_CTRL_REGS, I2S_SLOTS);# S7 y- l4 \8 Z2 ?* W$ P6 c
McASPTxTimeSlotSet(SOC_MCASP_0_CTRL_REGS, I2S_SLOTS);
/*1 T6 N  m0 j- `% A' l0 Q
** Set the serializers, Currently only one serializer is set as
  Z  y$ ]7 e/ Q6 i% i/ R7 x** transmitter and one serializer as receiver.
8 V. f5 U- x/ M% A. G) m*/
" ~$ @% U  [" `( w! iMcASPSerializerRxSet(SOC_MCASP_0_CTRL_REGS, MCASP_XSER_RX);
/ D. ~8 x# n$ y4 X/ Q' |( h& zMcASPSerializerTxSet(SOC_MCASP_0_CTRL_REGS, MCASP_XSER_TX);
/*
' t8 p% p8 S7 [& U9 R** Configure the McASP pins
% B% \- b0 z$ d3 b/ A0 s** Input - Frame Sync, Clock and Serializer Rx
2 |3 o1 k( _* W0 c. o** Output - Serializer Tx is connected to the input of the codec
" m- j. H# x" t$ F*/
$ X$ E  y) b9 ]9 f% tMcASPPinMcASPSet(SOC_MCASP_0_CTRL_REGS, 0xFFFFFFFF);; S* s  L% A* R0 t
McASPPinDirOutputSet(SOC_MCASP_0_CTRL_REGS,MCASP_PIN_AXR(MCASP_XSER_TX));
0 a, q9 h+ v4 }McASPPinDirInputSet(SOC_MCASP_0_CTRL_REGS, MCASP_PIN_AFSX& d6 h- s2 {/ p, O: C
| MCASP_PIN_ACLKX4 j9 N3 e! D7 x( f6 ^+ I
| MCASP_PIN_AHCLKX
% d/ \/ h9 ]9 X4 ^5 C| MCASP_PIN_AXR(MCASP_XSER_RX));
/* Enable error interrupts for McASP */# |+ F) R" `: J+ v9 F
McASPTxIntEnable(SOC_MCASP_0_CTRL_REGS, MCASP_TX_DMAERROR ) D; d9 h* B1 T0 G+ |1 }- Q7 I
| MCASP_TX_CLKFAIL
8 |$ f7 _( J; v% S; U| MCASP_TX_SYNCERROR
$ s, z* M0 R- ~7 {$ q. f0 S3 j| MCASP_TX_UNDERRUN);
McASPRxIntEnable(SOC_MCASP_0_CTRL_REGS, MCASP_RX_DMAERROR ' E1 S- N% Q' S7 O! @
| MCASP_RX_CLKFAIL
+ g+ P! I2 c6 G2 t3 U) r' K| MCASP_RX_SYNCERROR
! }! _* K1 ~' _; J  }8 E| MCASP_RX_OVERRUN);
- S1 Y. k# Q9 z3 a/ }8 e}
static void I2SDataTxRxActivate(void)
/ O/ S7 M+ D9 y! M  F: J5 {{2 P& c, S0 }* ^
/* Start the clocks */
" E/ g4 {7 Y4 ]4 j; \4 qMcASPRxClkStart(SOC_MCASP_0_CTRL_REGS, MCASP_RX_CLK_EXTERNAL);) w& H* \1 X: _, a1 A4 f
McASPTxClkStart(SOC_MCASP_0_CTRL_REGS, MCASP_TX_CLK_INTERNAL);
/* Enable EDMA for the transfer */8 J% S: ~. p" {& U1 a& ^
EDMA3EnableTransfer(SOC_EDMA30CC_0_REGS, EDMA3_CHA_MCASP0_RX,
( l1 a& x8 V1 ]EDMA3_TRIG_MODE_EVENT);1 E/ |1 `+ m& m, Z2 T+ Q2 k0 i
EDMA3EnableTransfer(SOC_EDMA30CC_0_REGS, % K: D0 G8 u  G, s& _; U5 R
EDMA3_CHA_MCASP0_TX, EDMA3_TRIG_MODE_EVENT);
/* Activate the serializers */
( O! F/ l, L$ e" }0 bMcASPRxSerActivate(SOC_MCASP_0_CTRL_REGS);1 G, D7 [" v( f! v  H# O( A% z
McASPTxSerActivate(SOC_MCASP_0_CTRL_REGS);
/* make sure that the XDATA bit is cleared to zero */% Y: V) e0 ]5 f; Z4 x  s! ^
while(McASPTxStatusGet(SOC_MCASP_0_CTRL_REGS) & MCASP_TX_STAT_DATAREADY);
/* Activate the state machines */9 \4 o, }. q% l6 N
McASPRxEnable(SOC_MCASP_0_CTRL_REGS);8 i- B2 T; N7 ]% c8 j9 @8 k
McASPTxEnable(SOC_MCASP_0_CTRL_REGS);% z3 L2 i. t% w3 d
}
0 x1 `5 v7 m9 n- N' `
请问:问题出在哪了,时钟按照这样配是否有错。
另外我看XDATA一直是0,接收的rxbuf0,1,2里有一般全是FFFF一半全是0.
/ J; j! E0 }& z* U8 N3 h. K





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