mirror of
https://github.com/enjoy-digital/litex.git
synced 2025-01-04 09:52:26 -05:00
liteeth/phy/gmii: fix clock generation for mii mode (clock_pads.tx is an input)
This commit is contained in:
parent
3710afe7fe
commit
afa9b889ae
2 changed files with 15 additions and 7 deletions
|
@ -40,16 +40,24 @@ class LiteEthPHYGMIIRX(Module):
|
|||
self.comb += source.eop.eq(eop)
|
||||
|
||||
class LiteEthPHYGMIICRG(Module, AutoCSR):
|
||||
def __init__(self, clock_pads, pads, with_hw_init_reset):
|
||||
def __init__(self, clock_pads, pads, with_hw_init_reset, mii_mode=0):
|
||||
self._reset = CSRStorage()
|
||||
###
|
||||
self.clock_domains.cd_eth_rx = ClockDomain()
|
||||
self.clock_domains.cd_eth_tx = ClockDomain()
|
||||
self.specials += DDROutput(1, 0, clock_pads.gtx, ClockSignal("eth_tx"))
|
||||
self.comb += [
|
||||
self.cd_eth_rx.clk.eq(clock_pads.rx), # Let the synthesis tool insert
|
||||
self.cd_eth_tx.clk.eq(self.cd_eth_rx.clk) # the appropriate clock buffer
|
||||
]
|
||||
|
||||
# RX : Let the synthesis tool insert the appropriate clock buffer
|
||||
self.comb += self.cd_eth_rx.clk.eq(clock_pads.rx)
|
||||
|
||||
# TX : GMII: Drive clock_pads.gtx, clock_pads.tx unused
|
||||
# MII: Use PHY clock_pads.tx as eth_tx_clk, do not drive clock_pads.gtx
|
||||
self.specials += DDROutput(1, mii_mode, clock_pads.gtx, ClockSignal("eth_tx"))
|
||||
# XXX Xilinx specific, replace BUFGMUX with a generic clock buffer?
|
||||
self.specials += Instance("BUFGMUX",
|
||||
i_I0=self.cd_eth_rx.clk,
|
||||
i_I1=clock_pads.tx,
|
||||
i_S=mii_mode,
|
||||
o_O=self.cd_eth_tx.clk)
|
||||
|
||||
if with_hw_init_reset:
|
||||
reset = Signal()
|
||||
|
|
|
@ -94,7 +94,7 @@ class LiteEthPHYGMIIMII(Module, AutoCSR):
|
|||
self._mode = CSRStorage()
|
||||
mode = self._mode.storage
|
||||
# Note: we can use GMII CRG since it also handles tx clock pad used for MII
|
||||
self.submodules.crg = LiteEthPHYGMIICRG(clock_pads, pads, with_hw_init_reset)
|
||||
self.submodules.crg = LiteEthPHYGMIICRG(clock_pads, pads, with_hw_init_reset, mode==modes["MII"])
|
||||
self.submodules.clock_counter = LiteEthGMIIMIIClockCounter()
|
||||
self.submodules.tx = RenameClockDomains(LiteEthPHYGMIIMIITX(pads, mode), "eth_tx")
|
||||
self.submodules.rx = RenameClockDomains(LiteEthPHYGMIIMIIRX(pads, mode), "eth_rx")
|
||||
|
|
Loading…
Reference in a new issue