create sata clock (sata_tx/2 for a 32 bits data path)

This commit is contained in:
Florent Kermarrec 2014-09-24 13:55:06 +02:00
parent 7790105913
commit f436069a04

View file

@ -33,6 +33,7 @@ class K7SATAPHYClocking(Module):
self.reset = Signal() self.reset = Signal()
self.transceiver_reset = Signal() self.transceiver_reset = Signal()
self.cd_sata = ClockDomain()
self.cd_sata_tx = ClockDomain() self.cd_sata_tx = ClockDomain()
self.cd_sata_rx = ClockDomain() self.cd_sata_rx = ClockDomain()
@ -48,7 +49,7 @@ class K7SATAPHYClocking(Module):
mmcm_drp = DRP() mmcm_drp = DRP()
mmcm_fb = Signal() mmcm_fb = Signal()
mmcm_clk_i = Signal() mmcm_clk_i = Signal()
mmcm_clk_o = Signal() mmcm_clk0_o = Signal()
self.specials += [ self.specials += [
Instance("BUFG", i_I=refclk, o_O=mmcm_clk_i), Instance("BUFG", i_I=refclk, o_O=mmcm_clk_i),
Instance("MMCME2_ADV", Instance("MMCME2_ADV",
@ -64,9 +65,13 @@ class K7SATAPHYClocking(Module):
i_CLKIN1=mmcm_clk_i, i_CLKFBIN=mmcm_fb, o_CLKFBOUT=mmcm_fb, i_CLKIN1=mmcm_clk_i, i_CLKFBIN=mmcm_fb, o_CLKFBOUT=mmcm_fb,
# CLK0 # CLK0
p_CLKOUT0_DIVIDE_F=4.000, p_CLKOUT0_PHASE=0.000, o_CLKOUT0=mmcm_clk_o, p_CLKOUT0_DIVIDE_F=4.000, p_CLKOUT0_PHASE=0.000, o_CLKOUT0=mmcm_clk0_o,
# CLK1
p_CLKOUT0_DIVIDE_F=8.000, p_CLKOUT0_PHASE=0.000, o_CLKOUT0=mmcm_clk1_o,
), ),
Instance("BUFG", i_I=mmcm_clk_o, o_O=self.cd_sata_tx.clk), Instance("BUFG", i_I=mmcm_clk0_o, o_O=self.cd_sata_tx.clk),
Instance("BUFG", i_I=mmcm_clk1_o, o_O=self.cd_sata.clk),
] ]
# RX clocking # RX clocking
@ -145,6 +150,7 @@ class K7SATAPHYClocking(Module):
self.specials += [ self.specials += [
AsyncResetSynchronizer(self.cd_sata_tx, ~mmcm_locked | ~gtx.txresetdone), AsyncResetSynchronizer(self.cd_sata_tx, ~mmcm_locked | ~gtx.txresetdone),
AsyncResetSynchronizer(self.cd_sata_rx, ~gtx.cplllock | ~gtx.rxphaligndone), AsyncResetSynchronizer(self.cd_sata_rx, ~gtx.cplllock | ~gtx.rxphaligndone),
AsyncResetSynchronizer(self.cd_sata, ResetSignal("sata_tx") | ResetSignal("sata_rx")),
] ]
# Dynamic Reconfiguration # Dynamic Reconfiguration