嵌入式开发者社区

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

作者: wapdasta    时间: 2018-11-7 13:28
标题: MCASP自环配置。
我项目上用OMAPL138的板子MCASP的引脚都是链接的FPGA,所以在FPGA这端设置的MCASP自环。把axr0接收到的通过axr1发回去。
部分代码如下
input mcasp_afsx,
0 }$ c& b& A* W9 Z( G4 Sinput mcasp_ahclkx,# n& E( ~/ t* `; h
input mcasp_aclkx,& v2 \% n. H2 Z8 y. J9 f3 B6 C
input axr0,5 R4 Q) L, J! A6 u  P

7 |4 K' N. N) f3 G5 O. J5 E- }. b, routput mcasp_afsr,% u6 a, P. @* t+ c7 V2 y
output mcasp_ahclkr,( D0 k; w# @; d6 N7 _4 t5 d
output mcasp_aclkr,
1 p4 H2 A. d: v$ o: Q  Soutput axr1,
1 o# B& h5 e% v' H
assign mcasp_afsr = mcasp_afsx;1 N$ q; g& i, @" W( [: A6 H
assign mcasp_aclkr = mcasp_aclkx;
; u2 K, k0 W9 e- f, Dassign mcasp_ahclkr = mcasp_ahclkx;3 L; ?6 H3 T* ]# T8 ?" T& I
assign axr1 = axr0;

% k6 ^2 u! j! P4 x6 k- \' P
0 c0 N6 b4 k% E
在OMAPL138这端,通过axr0接口发固定的数,axr1接收。
在配置MACASP的时候,发送全部取内部时钟,接收全部取外部时钟。
一直循环发送,但是接收不到。在FPGA端也没有看到时钟和信号的波形。
部分代码如下,关于edma3的部分未做变化。
! D. j) Y% _6 U7 w) p9 O! y7 _
static void McASPI2SConfigure(void)9 k4 Q+ g. w$ ~" G9 L8 m7 C# [& o
{$ \- ]3 S$ t* Y) }: F- q
McASPRxReset(SOC_MCASP_0_CTRL_REGS);! g' \4 Y/ T2 I+ C8 h
McASPTxReset(SOC_MCASP_0_CTRL_REGS);
/* Enable the FIFOs for DMA transfer */
9 \( l; _9 y) k9 i$ v. [McASPReadFifoEnable(SOC_MCASP_0_FIFO_REGS, 1, 1);
# K* C0 H5 D1 W9 A. W/ r" OMcASPWriteFifoEnable(SOC_MCASP_0_FIFO_REGS, 1, 1);
/* Set I2S format in the transmitter/receiver format units */
, J+ J+ j$ s, d0 HMcASPRxFmtI2SSet(SOC_MCASP_0_CTRL_REGS, WORD_SIZE, SLOT_SIZE,
% ^1 t% Q+ v$ X  Z- @MCASP_RX_MODE_DMA);
) }5 r) |( }; l' u3 eMcASPTxFmtI2SSet(SOC_MCASP_0_CTRL_REGS, WORD_SIZE, SLOT_SIZE,
/ Q9 t5 x- P* ~- |; I1 v9 M  kMCASP_TX_MODE_DMA);
/* Configure the frame sync. I2S shall work in TDM format with 2 slots */% [9 O; _$ w, u0 t) t
McASPRxFrameSyncCfg(SOC_MCASP_0_CTRL_REGS, 2, MCASP_RX_FS_WIDTH_WORD, + a6 v/ N7 _" L4 s! |  @" r9 ^! ~" z1 ?
MCASP_RX_FS_EXT_BEGIN_ON_FALL_EDGE);" C* R& `" q- A0 C7 N
McASPTxFrameSyncCfg(SOC_MCASP_0_CTRL_REGS, 2, MCASP_TX_FS_WIDTH_WORD,
& ]; c" f  g& hMCASP_TX_FS_INT_BEGIN_ON_RIS_EDGE);
/* configure the clock for receiver */
& D6 f% J& C1 m3 T2 {3 ]McASPRxClkCfg(SOC_MCASP_0_CTRL_REGS, MCASP_RX_CLK_EXTERNAL, 0, 0);  s# [2 Y% z  C9 V/ W
McASPRxClkPolaritySet(SOC_MCASP_0_CTRL_REGS, MCASP_RX_CLK_POL_RIS_EDGE); * r; \7 q, Y. X  H( Q$ Z, F
McASPRxClkCheckConfig(SOC_MCASP_0_CTRL_REGS, MCASP_RX_CLKCHCK_DIV32,
0 ?$ u; d2 `8 |' c; x" ]6 j0 ~0x00, 0xFF);
/* configure the clock for transmitter */* y# H/ \4 w/ b
McASPTxClkCfg(SOC_MCASP_0_CTRL_REGS, MCASP_TX_CLK_INTERNAL, 11, 1);
2 H, u# B* x, v, m, \' [4 r* A  |McASPTxClkPolaritySet(SOC_MCASP_0_CTRL_REGS, MCASP_TX_CLK_POL_FALL_EDGE); 5 I6 x# ]( |3 e) c
McASPTxClkCheckConfig(SOC_MCASP_0_CTRL_REGS, MCASP_TX_CLKCHCK_DIV32,. u) v* `7 n, x: z. B9 c
0x00, 0xFF);
. W6 N( H& E0 H- j. G2 ~( E# ~0 x6 T5 d: K7 L% Z
/* Enable synchronization of RX and TX sections */ / f2 L1 z- f: U9 \/ x
McASPTxRxClkSyncEnable(SOC_MCASP_0_CTRL_REGS);
/* Enable the transmitter/receiver slots. I2S uses 2 slots */
3 U8 ]4 h/ J* D' G$ y% C: |  XMcASPRxTimeSlotSet(SOC_MCASP_0_CTRL_REGS, I2S_SLOTS);8 m# Q6 z! K& ?' k8 w( J
McASPTxTimeSlotSet(SOC_MCASP_0_CTRL_REGS, I2S_SLOTS);
/*/ C8 \4 I8 ?! g6 B; `+ ^
** Set the serializers, Currently only one serializer is set as
3 l  ?) c, Y& q5 Q6 f) l# I' x$ M** transmitter and one serializer as receiver.# z. k6 x8 G3 r  O" I
*/0 d4 o+ O6 s( i: l) \* K* i
McASPSerializerRxSet(SOC_MCASP_0_CTRL_REGS, MCASP_XSER_RX);
$ ^# l" a# I; W4 L7 {% WMcASPSerializerTxSet(SOC_MCASP_0_CTRL_REGS, MCASP_XSER_TX);
/*  W1 l. F1 q* c  v2 k( X
** Configure the McASP pins
* Y. m3 `" ]& p9 B** Input - Frame Sync, Clock and Serializer Rx
. G1 L% m8 L7 t** Output - Serializer Tx is connected to the input of the codec # `' m+ Y" y, S" _* B5 X8 f
*/5 i+ F. k- m" @/ d) y$ Z
McASPPinMcASPSet(SOC_MCASP_0_CTRL_REGS, 0xFFFFFFFF);
# |+ c! H& o5 A0 m  ZMcASPPinDirOutputSet(SOC_MCASP_0_CTRL_REGS,MCASP_PIN_AXR(MCASP_XSER_TX));
2 B, S7 q' y  r6 C  KMcASPPinDirInputSet(SOC_MCASP_0_CTRL_REGS, MCASP_PIN_AFSX8 t4 }; b! Y; r  {! M7 {1 g* s
| MCASP_PIN_ACLKX6 e% m# @5 i7 [3 }& c2 u
| MCASP_PIN_AHCLKX3 M7 b) \( M6 f+ }* P: A$ d9 A
| MCASP_PIN_AXR(MCASP_XSER_RX));
/* Enable error interrupts for McASP */
  q) U- A6 F/ x; EMcASPTxIntEnable(SOC_MCASP_0_CTRL_REGS, MCASP_TX_DMAERROR 0 j% a, T1 t3 x7 B6 W
| MCASP_TX_CLKFAIL # i9 \1 \+ `6 B4 i- h" w
| MCASP_TX_SYNCERROR
, ?1 h3 k1 O; `6 L' z) y. y5 ~| MCASP_TX_UNDERRUN);
McASPRxIntEnable(SOC_MCASP_0_CTRL_REGS, MCASP_RX_DMAERROR 3 ?2 I0 o  O2 B
| MCASP_RX_CLKFAIL
" t( j3 T) [, S+ h# C| MCASP_RX_SYNCERROR
8 v6 X3 E# ~( Z) b& g| MCASP_RX_OVERRUN);& h2 t4 l. L1 R3 ?  k( Q: k
}
static void I2SDataTxRxActivate(void)* i0 g, ]& Y5 ~4 F1 _" L6 r
{
/ ]1 P+ f+ ]  q8 V/* Start the clocks */: Y: [$ g. \( l% U
McASPRxClkStart(SOC_MCASP_0_CTRL_REGS, MCASP_RX_CLK_EXTERNAL);
  M' H1 l% _' B( V, {McASPTxClkStart(SOC_MCASP_0_CTRL_REGS, MCASP_TX_CLK_INTERNAL);
/* Enable EDMA for the transfer */
# Z5 B/ H  p' v' UEDMA3EnableTransfer(SOC_EDMA30CC_0_REGS, EDMA3_CHA_MCASP0_RX,
6 R7 `3 E# E: ?+ O" v+ X) HEDMA3_TRIG_MODE_EVENT);. N3 j( T- C$ A+ f- }$ ?+ [8 L4 m
EDMA3EnableTransfer(SOC_EDMA30CC_0_REGS,
0 g0 P5 _8 x( U' o# |% [EDMA3_CHA_MCASP0_TX, EDMA3_TRIG_MODE_EVENT);
/* Activate the serializers */8 u5 `  _3 l) |  w! `$ _
McASPRxSerActivate(SOC_MCASP_0_CTRL_REGS);2 y1 T# j0 r& `8 F
McASPTxSerActivate(SOC_MCASP_0_CTRL_REGS);
/* make sure that the XDATA bit is cleared to zero */! `# n; }0 j0 m
while(McASPTxStatusGet(SOC_MCASP_0_CTRL_REGS) & MCASP_TX_STAT_DATAREADY);
/* Activate the state machines */
3 F( i" H5 C& ?# bMcASPRxEnable(SOC_MCASP_0_CTRL_REGS);+ P. L/ ]: f6 z& ]3 O' Q4 S- K
McASPTxEnable(SOC_MCASP_0_CTRL_REGS);
! c  e4 N+ M  `/ B( }6 q( x9 [; l}

7 }9 f9 }# T0 @! ?9 J: P- `) w9 |! e
请问:问题出在哪了,时钟按照这样配是否有错。
另外我看XDATA一直是0,接收的rxbuf0,1,2里有一般全是FFFF一半全是0.

1 e8 {) [5 @, }2 o' n; w




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