mirror of
https://github.com/enjoy-digital/litex.git
synced 2025-01-04 09:52:26 -05:00
add fsms to mila for debug
This commit is contained in:
parent
68a7ff6dc2
commit
35050ece9f
2 changed files with 75 additions and 45 deletions
|
@ -63,7 +63,9 @@ class SATALinkTX(Module):
|
||||||
If(self.from_rx.idle,
|
If(self.from_rx.idle,
|
||||||
insert.eq(primitives["SYNC"]),
|
insert.eq(primitives["SYNC"]),
|
||||||
If(scrambler.source.stb & scrambler.source.sop,
|
If(scrambler.source.stb & scrambler.source.sop,
|
||||||
NextState("RDY"),
|
If(self.from_rx.det == primitives["SYNC"],
|
||||||
|
NextState("RDY")
|
||||||
|
)
|
||||||
)
|
)
|
||||||
)
|
)
|
||||||
)
|
)
|
||||||
|
|
116
targets/test.py
116
targets/test.py
|
@ -1,3 +1,5 @@
|
||||||
|
import os
|
||||||
|
|
||||||
from migen.fhdl.std import *
|
from migen.fhdl.std import *
|
||||||
from migen.bank import csrgen
|
from migen.bank import csrgen
|
||||||
from migen.bus import wishbone, csr
|
from migen.bus import wishbone, csr
|
||||||
|
@ -5,6 +7,7 @@ from migen.bus import wishbone2csr
|
||||||
from migen.genlib.resetsync import AsyncResetSynchronizer
|
from migen.genlib.resetsync import AsyncResetSynchronizer
|
||||||
from migen.bank.description import *
|
from migen.bank.description import *
|
||||||
|
|
||||||
|
from miscope import MiLa, Term, UART2Wishbone
|
||||||
from miscope.uart2wishbone import UART2Wishbone
|
from miscope.uart2wishbone import UART2Wishbone
|
||||||
|
|
||||||
from misoclib import identifier
|
from misoclib import identifier
|
||||||
|
@ -174,7 +177,7 @@ class TestDesign(UART2WB, AutoCSR):
|
||||||
}
|
}
|
||||||
csr_map.update(UART2WB.csr_map)
|
csr_map.update(UART2WB.csr_map)
|
||||||
|
|
||||||
def __init__(self, platform, mila=True, export_mila=False):
|
def __init__(self, platform, export_mila=False):
|
||||||
clk_freq = 200*1000000
|
clk_freq = 200*1000000
|
||||||
UART2WB.__init__(self, platform, clk_freq)
|
UART2WB.__init__(self, platform, clk_freq)
|
||||||
self.crg = _CRG(platform)
|
self.crg = _CRG(platform)
|
||||||
|
@ -186,59 +189,84 @@ class TestDesign(UART2WB, AutoCSR):
|
||||||
|
|
||||||
self.clock_leds = ClockLeds(platform)
|
self.clock_leds = ClockLeds(platform)
|
||||||
|
|
||||||
if mila:
|
self.comb += platform.request("user_led", 2).eq(self.sata_phy.crg.ready)
|
||||||
import os
|
self.comb += platform.request("user_led", 3).eq(self.sata_phy.ctrl.ready)
|
||||||
from miscope import MiLa, Term, UART2Wishbone
|
|
||||||
|
|
||||||
trx = self.sata_phy.trx
|
ctrl = self.sata_phy.ctrl
|
||||||
ctrl = self.sata_phy.ctrl
|
|
||||||
crg = self.sata_phy.crg
|
|
||||||
|
|
||||||
debug = (
|
self.command_tx_fsm_state = Signal(4)
|
||||||
ctrl.ready,
|
self.transport_tx_fsm_state = Signal(4)
|
||||||
ctrl.sink.data,
|
self.link_tx_fsm_state = Signal(4)
|
||||||
ctrl.sink.charisk,
|
|
||||||
|
|
||||||
self.sata_phy.source.stb,
|
self.command_rx_fsm_state = Signal(4)
|
||||||
self.sata_phy.source.data,
|
self.command_rx_out_fsm_state = Signal(4)
|
||||||
self.sata_phy.source.charisk,
|
self.transport_rx_fsm_state = Signal(4)
|
||||||
|
self.link_rx_fsm_state = Signal(4)
|
||||||
|
|
||||||
self.sata_phy.sink.stb,
|
debug = (
|
||||||
self.sata_phy.sink.data,
|
ctrl.ready,
|
||||||
self.sata_phy.sink.charisk,
|
ctrl.sink.data,
|
||||||
|
ctrl.sink.charisk,
|
||||||
|
|
||||||
self.sata_phy.datapath.tx.sink.stb,
|
self.sata_phy.source.stb,
|
||||||
self.sata_phy.datapath.tx.sink.data,
|
self.sata_phy.source.data,
|
||||||
self.sata_phy.datapath.tx.sink.charisk,
|
self.sata_phy.source.charisk,
|
||||||
self.sata_phy.datapath.tx.sink.ack,
|
|
||||||
|
|
||||||
self.sata_con.sink.stb,
|
self.sata_phy.sink.stb,
|
||||||
self.sata_con.sink.sop,
|
self.sata_phy.sink.data,
|
||||||
self.sata_con.sink.eop,
|
self.sata_phy.sink.charisk,
|
||||||
self.sata_con.sink.ack,
|
|
||||||
self.sata_con.sink.identify,
|
|
||||||
|
|
||||||
self.sata_con.source.stb,
|
self.sata_phy.datapath.tx.sink.stb,
|
||||||
self.sata_con.source.sop,
|
self.sata_phy.datapath.tx.sink.data,
|
||||||
self.sata_con.source.eop,
|
self.sata_phy.datapath.tx.sink.charisk,
|
||||||
self.sata_con.source.ack,
|
self.sata_phy.datapath.tx.sink.ack,
|
||||||
self.sata_con.source.write,
|
|
||||||
self.sata_con.source.read,
|
|
||||||
self.sata_con.source.identify,
|
|
||||||
self.sata_con.source.success,
|
|
||||||
self.sata_con.source.failed,
|
|
||||||
self.sata_con.source.data
|
|
||||||
)
|
|
||||||
|
|
||||||
self.comb += platform.request("user_led", 2).eq(crg.ready)
|
self.sata_con.sink.stb,
|
||||||
self.comb += platform.request("user_led", 3).eq(ctrl.ready)
|
self.sata_con.sink.sop,
|
||||||
|
self.sata_con.sink.eop,
|
||||||
|
self.sata_con.sink.ack,
|
||||||
|
self.sata_con.sink.identify,
|
||||||
|
|
||||||
self.mila = MiLa(depth=2048, dat=Cat(*debug))
|
self.sata_con.source.stb,
|
||||||
self.mila.add_port(Term)
|
self.sata_con.source.sop,
|
||||||
|
self.sata_con.source.eop,
|
||||||
|
self.sata_con.source.ack,
|
||||||
|
self.sata_con.source.write,
|
||||||
|
self.sata_con.source.read,
|
||||||
|
self.sata_con.source.identify,
|
||||||
|
self.sata_con.source.success,
|
||||||
|
self.sata_con.source.failed,
|
||||||
|
self.sata_con.source.data,
|
||||||
|
|
||||||
if export_mila:
|
self.command_tx_fsm_state,
|
||||||
mila_filename = os.path.join(platform.soc_ext_path, "test", "mila.csv")
|
self.transport_tx_fsm_state,
|
||||||
self.mila.export(self, debug, mila_filename)
|
self.link_tx_fsm_state,
|
||||||
|
|
||||||
|
self.command_rx_fsm_state,
|
||||||
|
self.command_rx_out_fsm_state,
|
||||||
|
self.transport_rx_fsm_state,
|
||||||
|
self.link_rx_fsm_state,
|
||||||
|
)
|
||||||
|
|
||||||
|
self.mila = MiLa(depth=2048, dat=Cat(*debug))
|
||||||
|
self.mila.add_port(Term)
|
||||||
|
|
||||||
|
if export_mila:
|
||||||
|
mila_filename = os.path.join(platform.soc_ext_path, "test", "mila.csv")
|
||||||
|
self.mila.export(self, debug, mila_filename)
|
||||||
|
|
||||||
|
def do_finalize(self):
|
||||||
|
UART2WB.do_finalize(self)
|
||||||
|
self.comb += [
|
||||||
|
self.command_tx_fsm_state.eq(self.sata_con.command.tx.fsm.state),
|
||||||
|
self.transport_tx_fsm_state.eq(self.sata_con.transport.tx.fsm.state),
|
||||||
|
self.link_tx_fsm_state.eq(self.sata_con.link.tx.fsm.state),
|
||||||
|
|
||||||
|
self.command_rx_fsm_state.eq(self.sata_con.command.rx.fsm.state),
|
||||||
|
self.command_rx_out_fsm_state.eq(self.sata_con.command.rx.out_fsm.state),
|
||||||
|
self.transport_rx_fsm_state.eq(self.sata_con.transport.rx.fsm.state),
|
||||||
|
self.link_rx_fsm_state.eq(self.sata_con.link.rx.fsm.state)
|
||||||
|
]
|
||||||
|
|
||||||
#default_subtarget = SimDesign
|
#default_subtarget = SimDesign
|
||||||
default_subtarget = TestDesign
|
default_subtarget = TestDesign
|
Loading…
Reference in a new issue