mirror of
https://github.com/enjoy-digital/usb3_pipe.git
synced 2025-01-04 10:18:41 +08:00
training: add enable signals
This commit is contained in:
parent
b138f0fc2e
commit
8a876f9414
@ -181,7 +181,9 @@ class PollingFSM(FSM):
|
|||||||
self.act("LFPS",
|
self.act("LFPS",
|
||||||
serdes.rx_align.eq(1),
|
serdes.rx_align.eq(1),
|
||||||
lfps_unit.tx_polling.eq(1),
|
lfps_unit.tx_polling.eq(1),
|
||||||
|
If(lfps_unit.rx_polling,
|
||||||
NextState("RX-EQ"), # LFPS handshake.
|
NextState("RX-EQ"), # LFPS handshake.
|
||||||
|
),
|
||||||
#self.exit_to_compliance_mode.eq(1), # First LFPS timeout.
|
#self.exit_to_compliance_mode.eq(1), # First LFPS timeout.
|
||||||
#self.exit_to_ss_disabled.eq(1), # Subsequent LFPS timeouts (Dev) or directed (DS).
|
#self.exit_to_ss_disabled.eq(1), # Subsequent LFPS timeouts (Dev) or directed (DS).
|
||||||
#self.exit_to_rx_detect.eq(1), # Subsequent LFPS timeouts (DS).
|
#self.exit_to_rx_detect.eq(1), # Subsequent LFPS timeouts (DS).
|
||||||
@ -191,6 +193,8 @@ class PollingFSM(FSM):
|
|||||||
# RxEQ State -------------------------------------------------------------------------------
|
# RxEQ State -------------------------------------------------------------------------------
|
||||||
self.act("RX-EQ",
|
self.act("RX-EQ",
|
||||||
serdes.rx_align.eq(1),
|
serdes.rx_align.eq(1),
|
||||||
|
lfps_unit.tx_polling.eq(1),
|
||||||
|
ts_unit.rx_enable.eq(1),
|
||||||
If(ts_unit.rx_tseq,
|
If(ts_unit.rx_tseq,
|
||||||
NextState("ACTIVE"), # TSEQ transmitted.
|
NextState("ACTIVE"), # TSEQ transmitted.
|
||||||
),
|
),
|
||||||
@ -200,6 +204,7 @@ class PollingFSM(FSM):
|
|||||||
|
|
||||||
# Active State -----------------------------------------------------------------------------
|
# Active State -----------------------------------------------------------------------------
|
||||||
self.act("ACTIVE",
|
self.act("ACTIVE",
|
||||||
|
ts_unit.rx_enable.eq(1),
|
||||||
If(ts_unit.rx_ts1 | ts_unit.rx_ts2,
|
If(ts_unit.rx_ts1 | ts_unit.rx_ts2,
|
||||||
NextState("CONFIGURATION"), # 8 consecutiive TS1 or TS2 received.
|
NextState("CONFIGURATION"), # 8 consecutiive TS1 or TS2 received.
|
||||||
),
|
),
|
||||||
@ -210,6 +215,8 @@ class PollingFSM(FSM):
|
|||||||
|
|
||||||
# Configuration State ----------------------------------------------------------------------
|
# Configuration State ----------------------------------------------------------------------
|
||||||
self.act("CONFIGURATION",
|
self.act("CONFIGURATION",
|
||||||
|
ts_unit.rx_enable.eq(1),
|
||||||
|
ts_unit.tx_enable.eq(1),
|
||||||
ts_unit.tx_ts2.eq(1),
|
ts_unit.tx_ts2.eq(1),
|
||||||
If(ts_unit.rx_ts2,
|
If(ts_unit.rx_ts2,
|
||||||
NextState("IDLE"), # TS2 handshake.
|
NextState("IDLE"), # TS2 handshake.
|
||||||
@ -248,7 +255,6 @@ class LTSSM(Module):
|
|||||||
serdes = serdes,
|
serdes = serdes,
|
||||||
lfps_unit = lfps_unit,
|
lfps_unit = lfps_unit,
|
||||||
ts_unit = ts_unit)
|
ts_unit = ts_unit)
|
||||||
self.comb += self.polling_fsm.reset.eq(lfps_unit.rx_polling)
|
|
||||||
|
|
||||||
# LTSSM FSM --------------------------------------------------------------------------------
|
# LTSSM FSM --------------------------------------------------------------------------------
|
||||||
self.submodules.ltssm_fsm = LTSSMFSM()
|
self.submodules.ltssm_fsm = LTSSMFSM()
|
||||||
|
@ -177,9 +177,12 @@ class TSGenerator(Module):
|
|||||||
|
|
||||||
class TSUnit(Module):
|
class TSUnit(Module):
|
||||||
def __init__(self, serdes):
|
def __init__(self, serdes):
|
||||||
|
self.rx_enable = Signal() # i
|
||||||
self.rx_tseq = Signal() # o
|
self.rx_tseq = Signal() # o
|
||||||
self.rx_ts1 = Signal() # o
|
self.rx_ts1 = Signal() # o
|
||||||
self.rx_ts2 = Signal() # o
|
self.rx_ts2 = Signal() # o
|
||||||
|
|
||||||
|
self.tx_enable = Signal() # i
|
||||||
self.tx_ts2 = Signal() # i
|
self.tx_ts2 = Signal() # i
|
||||||
|
|
||||||
# # #
|
# # #
|
||||||
@ -190,6 +193,7 @@ class TSUnit(Module):
|
|||||||
ts2_checker = TSChecker(ordered_set=TS2, n_ordered_sets=8)
|
ts2_checker = TSChecker(ordered_set=TS2, n_ordered_sets=8)
|
||||||
self.submodules += tseq_checker, ts1_checker, ts2_checker
|
self.submodules += tseq_checker, ts1_checker, ts2_checker
|
||||||
self.comb += [
|
self.comb += [
|
||||||
|
serdes.source.ready.eq(self.rx_enable),
|
||||||
serdes.source.connect(tseq_checker.sink, omit={"ready"}),
|
serdes.source.connect(tseq_checker.sink, omit={"ready"}),
|
||||||
serdes.source.connect(ts1_checker.sink, omit={"ready"}),
|
serdes.source.connect(ts1_checker.sink, omit={"ready"}),
|
||||||
serdes.source.connect(ts2_checker.sink, omit={"ready"}),
|
serdes.source.connect(ts2_checker.sink, omit={"ready"}),
|
||||||
@ -199,8 +203,8 @@ class TSUnit(Module):
|
|||||||
ts2_generator = TSGenerator(ordered_set=TS2, n_ordered_sets=8)
|
ts2_generator = TSGenerator(ordered_set=TS2, n_ordered_sets=8)
|
||||||
self.submodules += ts2_generator
|
self.submodules += ts2_generator
|
||||||
self.comb += [
|
self.comb += [
|
||||||
If(self.tx_ts2,
|
If(self.tx_enable,
|
||||||
ts2_generator.send.eq(1),
|
ts2_generator.send.eq(self.tx_ts2),
|
||||||
ts2_generator.source.connect(serdes.sink),
|
ts2_generator.source.connect(serdes.sink),
|
||||||
)
|
)
|
||||||
]
|
]
|
||||||
|
Loading…
x
Reference in New Issue
Block a user