嵌入式开发者社区

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

作者: wapdasta    时间: 2018-11-7 13:28
标题: MCASP自环配置。
我项目上用OMAPL138的板子MCASP的引脚都是链接的FPGA,所以在FPGA这端设置的MCASP自环。把axr0接收到的通过axr1发回去。
部分代码如下
input mcasp_afsx,
, a8 f5 I9 o0 dinput mcasp_ahclkx,: ^) }8 m' }7 K9 a
input mcasp_aclkx,
: W8 P. V$ Z# c: O7 D' I5 Ninput axr0,
  x  L. m' j4 V( G- f9 `7 [! n# K3 |! n8 I* j, R0 b
output mcasp_afsr,
) F0 Z9 y; O" eoutput mcasp_ahclkr,7 {4 N) _0 H+ {& l, J# K
output mcasp_aclkr,8 m" a' {$ v! o+ Y
output axr1,( k4 J" M2 w: F& x0 s& I& x
assign mcasp_afsr = mcasp_afsx;0 _3 \/ ?' @# A' v
assign mcasp_aclkr = mcasp_aclkx;
+ W2 u0 O3 l4 ^5 _- _, |. q6 C* fassign mcasp_ahclkr = mcasp_ahclkx;: A5 S8 \. ?/ c# ?, u* R
assign axr1 = axr0;

5 P" S* _! E$ X1 {/ _, \
; z& n: R6 v$ r' p1 ~. k# z+ O
在OMAPL138这端,通过axr0接口发固定的数,axr1接收。
在配置MACASP的时候,发送全部取内部时钟,接收全部取外部时钟。
一直循环发送,但是接收不到。在FPGA端也没有看到时钟和信号的波形。
部分代码如下,关于edma3的部分未做变化。
7 z2 g2 _; J- u8 a  v7 e- Q( u- w7 h
static void McASPI2SConfigure(void)) R- n! U9 c* @( Q# S
{! @6 L2 u( `# W
McASPRxReset(SOC_MCASP_0_CTRL_REGS);
& x5 ]6 h" j# bMcASPTxReset(SOC_MCASP_0_CTRL_REGS);
/* Enable the FIFOs for DMA transfer */
! T1 t- o! S& ]0 m! q$ TMcASPReadFifoEnable(SOC_MCASP_0_FIFO_REGS, 1, 1);
0 Y9 ~% d9 i6 q) A& w; ^2 `+ `( k9 RMcASPWriteFifoEnable(SOC_MCASP_0_FIFO_REGS, 1, 1);
/* Set I2S format in the transmitter/receiver format units */2 e( b$ [0 V8 H* H) o) D; j
McASPRxFmtI2SSet(SOC_MCASP_0_CTRL_REGS, WORD_SIZE, SLOT_SIZE,
! a7 m" n! X0 Q9 G; b% SMCASP_RX_MODE_DMA);3 F0 a) k2 T& a" p+ k
McASPTxFmtI2SSet(SOC_MCASP_0_CTRL_REGS, WORD_SIZE, SLOT_SIZE,- @6 [3 P8 @, l& R: p7 }) |% U' ?2 q& c
MCASP_TX_MODE_DMA);
/* Configure the frame sync. I2S shall work in TDM format with 2 slots */
/ U' T" M/ ?6 [  f" RMcASPRxFrameSyncCfg(SOC_MCASP_0_CTRL_REGS, 2, MCASP_RX_FS_WIDTH_WORD, " W1 S" s, |8 p
MCASP_RX_FS_EXT_BEGIN_ON_FALL_EDGE);- h" @4 {& ?, O$ K7 B  g( @
McASPTxFrameSyncCfg(SOC_MCASP_0_CTRL_REGS, 2, MCASP_TX_FS_WIDTH_WORD, 2 J* |1 o+ L* v4 N, K
MCASP_TX_FS_INT_BEGIN_ON_RIS_EDGE);
/* configure the clock for receiver */
% H  m. y2 J! z+ i( B) C6 _McASPRxClkCfg(SOC_MCASP_0_CTRL_REGS, MCASP_RX_CLK_EXTERNAL, 0, 0);
; c9 ^* w# B" n5 p+ r# _7 @McASPRxClkPolaritySet(SOC_MCASP_0_CTRL_REGS, MCASP_RX_CLK_POL_RIS_EDGE); % ]9 P3 f7 h! _  ^$ j5 l
McASPRxClkCheckConfig(SOC_MCASP_0_CTRL_REGS, MCASP_RX_CLKCHCK_DIV32,
0 }2 Y' ?/ b* J' T$ \& p) B0x00, 0xFF);
/* configure the clock for transmitter */2 d7 a& q- c1 _0 @
McASPTxClkCfg(SOC_MCASP_0_CTRL_REGS, MCASP_TX_CLK_INTERNAL, 11, 1);
" n0 @+ a4 C/ v9 {2 n) K3 qMcASPTxClkPolaritySet(SOC_MCASP_0_CTRL_REGS, MCASP_TX_CLK_POL_FALL_EDGE); : `( r3 @* T8 ]7 j
McASPTxClkCheckConfig(SOC_MCASP_0_CTRL_REGS, MCASP_TX_CLKCHCK_DIV32,
/ }. X) I0 l0 V6 c& `9 i, t( _: |0x00, 0xFF);
* ~# G, v0 ?) c) ?" f5 S  \; r  }9 I% K0 S# M
/* Enable synchronization of RX and TX sections */ 2 ?" e* \7 W; O* w2 H
McASPTxRxClkSyncEnable(SOC_MCASP_0_CTRL_REGS);
/* Enable the transmitter/receiver slots. I2S uses 2 slots */
+ f- ^1 z$ Z9 |0 f' N9 h/ PMcASPRxTimeSlotSet(SOC_MCASP_0_CTRL_REGS, I2S_SLOTS);+ P% y1 C  x1 V) h+ G
McASPTxTimeSlotSet(SOC_MCASP_0_CTRL_REGS, I2S_SLOTS);
/*
% U8 z7 y- y) U7 b8 b' {" p( u1 ^** Set the serializers, Currently only one serializer is set as
' G) D, A* T& M- `; ]** transmitter and one serializer as receiver.
6 _' l# E. T6 [- J" O! ~& i/ P*/; S7 B+ K* u) p8 K1 p; p; M! L
McASPSerializerRxSet(SOC_MCASP_0_CTRL_REGS, MCASP_XSER_RX);9 ]# k4 P) Q0 B# \# O  V
McASPSerializerTxSet(SOC_MCASP_0_CTRL_REGS, MCASP_XSER_TX);
/*
' T5 H) C/ J  O** Configure the McASP pins
7 T% Y( m! J. ^: W* d) A4 _** Input - Frame Sync, Clock and Serializer Rx7 r9 e( `  u2 i. L$ i- i1 e0 J* F4 ?; e
** Output - Serializer Tx is connected to the input of the codec 9 g% Y9 D& A" a2 b- Y
*/& m; s# k" E( h7 [; Q# M( h
McASPPinMcASPSet(SOC_MCASP_0_CTRL_REGS, 0xFFFFFFFF);$ s" [6 }$ ?& ?( z9 X: ^
McASPPinDirOutputSet(SOC_MCASP_0_CTRL_REGS,MCASP_PIN_AXR(MCASP_XSER_TX));
3 g0 h# ?, d$ b; E; Z& r8 MMcASPPinDirInputSet(SOC_MCASP_0_CTRL_REGS, MCASP_PIN_AFSX
# z  T$ V, ^4 W5 Q| MCASP_PIN_ACLKX
( Z: D9 \5 R0 L; U. v: `0 A| MCASP_PIN_AHCLKX' ]/ @# n7 I3 Y+ _5 M4 {
| MCASP_PIN_AXR(MCASP_XSER_RX));
/* Enable error interrupts for McASP */
9 i2 o* `  B7 K$ E# hMcASPTxIntEnable(SOC_MCASP_0_CTRL_REGS, MCASP_TX_DMAERROR - b/ W$ p7 t3 Y' U9 y
| MCASP_TX_CLKFAIL : G7 C1 l- [! z5 ^
| MCASP_TX_SYNCERROR
0 }+ a* }# c* z  J| MCASP_TX_UNDERRUN);
McASPRxIntEnable(SOC_MCASP_0_CTRL_REGS, MCASP_RX_DMAERROR ( Q+ b6 t# w' f2 |; [7 G
| MCASP_RX_CLKFAIL8 V$ @7 h4 S1 v1 U6 I( ^
| MCASP_RX_SYNCERROR " i' Q3 v0 S/ x8 `* a+ m  n
| MCASP_RX_OVERRUN);$ M1 w( |8 L! r
}
static void I2SDataTxRxActivate(void)
( ?: t* v" M8 Q% I9 ?9 E8 ]- r{
/ b* X% }' C4 m! G- G/* Start the clocks */2 M/ k: O: T. ~1 |
McASPRxClkStart(SOC_MCASP_0_CTRL_REGS, MCASP_RX_CLK_EXTERNAL);
# V3 p) h1 ~0 ^! w' eMcASPTxClkStart(SOC_MCASP_0_CTRL_REGS, MCASP_TX_CLK_INTERNAL);
/* Enable EDMA for the transfer */% P- V9 z4 s3 ~  R1 W" X
EDMA3EnableTransfer(SOC_EDMA30CC_0_REGS, EDMA3_CHA_MCASP0_RX,
* n& J2 B5 U. `  `' aEDMA3_TRIG_MODE_EVENT);& j0 E$ @% D: c7 H+ f& g- L# P
EDMA3EnableTransfer(SOC_EDMA30CC_0_REGS, , t0 A$ h& ^5 M- w# d" Z/ t
EDMA3_CHA_MCASP0_TX, EDMA3_TRIG_MODE_EVENT);
/* Activate the serializers */
. i$ T+ z  x0 F. KMcASPRxSerActivate(SOC_MCASP_0_CTRL_REGS);. O9 b. e% w( |
McASPTxSerActivate(SOC_MCASP_0_CTRL_REGS);
/* make sure that the XDATA bit is cleared to zero */# y) T' R) h! D5 e- n& Q' c9 V
while(McASPTxStatusGet(SOC_MCASP_0_CTRL_REGS) & MCASP_TX_STAT_DATAREADY);
/* Activate the state machines */& |1 Y8 k( I' _' _  _
McASPRxEnable(SOC_MCASP_0_CTRL_REGS);- m. ~, c) i6 d0 a
McASPTxEnable(SOC_MCASP_0_CTRL_REGS);
, I  [" n) ]0 ]* M6 ~( O}
9 ?& }6 x% a" T( d: L
请问:问题出在哪了,时钟按照这样配是否有错。
另外我看XDATA一直是0,接收的rxbuf0,1,2里有一般全是FFFF一半全是0.
  z4 }& w) j  n0 {8 }# T; J" ~





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