command: wip

This commit is contained in:
Florent Kermarrec 2014-12-13 11:33:22 +01:00
parent eb226c1ade
commit 11c99f8377
2 changed files with 50 additions and 15 deletions

View file

@ -11,7 +11,9 @@ regs = {
} }
from_rx = [ from_rx = [
("dma_activate", 1) ("dma_activate", 1),
("data", 1),
("reg_d2h", 1)
] ]
class SATACommandTX(Module): class SATACommandTX(Module):
@ -73,7 +75,7 @@ class SATACommandTX(Module):
transport.sink.data.eq(sink.data), transport.sink.data.eq(sink.data),
sink.ack.eq(transport.sink.ack), sink.ack.eq(transport.sink.ack),
If(sink.stb & sink.ack & sink.eop, If(sink.stb & sink.ack & sink.eop,
NextState("IDLE") NextState("WAIT_REG_D2H")
) )
) )
fsm.act("SEND_READ_DMA_CMD", fsm.act("SEND_READ_DMA_CMD",
@ -85,7 +87,7 @@ class SATACommandTX(Module):
transport.sink.command.eq(regs["READ_DMA_EXT"]), transport.sink.command.eq(regs["READ_DMA_EXT"]),
sink.ack.eq(transport.sink.ack), sink.ack.eq(transport.sink.ack),
If(sink.stb & sink.ack, If(sink.stb & sink.ack,
NextState("IDLE") NextState("WAIT_DATA")
) )
) )
fsm.act("SEND_IDENTIFY_CMD", fsm.act("SEND_IDENTIFY_CMD",
@ -97,6 +99,17 @@ class SATACommandTX(Module):
transport.sink.command.eq(regs["IDENTIFY_DEVICE_DMA"]), transport.sink.command.eq(regs["IDENTIFY_DEVICE_DMA"]),
sink.ack.eq(transport.sink.ack), sink.ack.eq(transport.sink.ack),
If(sink.stb & sink.ack, If(sink.stb & sink.ack,
NextState("WAIT_DATA")
)
)
fsm.act("WAIT_DATA",
If(self.from_rx.data,
NextState("WAIT_REG_D2H")
)
)
fsm.act("WAIT_REG_D2H",
NextState("IDLE"),
If(self.from_rx.reg_d2h,
NextState("IDLE") NextState("IDLE")
) )
) )
@ -108,23 +121,44 @@ class SATACommandRX(Module):
### ###
self.comb += [ def test_type(name):
transport.source.ack.eq(1), return transport.source.type == fis_types[name]
# XXX for test
If(transport.source.stb & (transport.source.type == fis_types["DMA_ACTIVATE_D2H"]), dma_activate = Signal()
self.to_tx.dma_activate.eq(1) data = Signal()
), reg_d2h = Signal()
If(transport.source.stb & (transport.source.type == fis_types["DATA"]),
source.stb.eq(1), self.comb += \
source.sop.eq(transport.source.sop), If(transport.source.stb,
source.eop.eq(transport.source.eop), If(test_type("REG_D2H"),
source.data.eq(transport.source.data), # XXX add checks
reg_d2h.eq(1),
transport.source.ack.eq(1)
).Elif(test_type("DMA_ACTIVATE_D2H"),
# XXX add checks
dma_activate.eq(1),
transport.source.ack.eq(1)
).Elif(test_type("DATA"),
source.stb.eq(1),
source.sop.eq(transport.source.sop),
source.eop.eq(transport.source.eop),
source.data.eq(transport.source.data),
data.eq(source.eop & source.ack),
transport.source.ack.eq(source.ack)
).Else(
transport.source.ack.eq(1)
)
) )
self.comb += [
self.to_tx.dma_activate.eq(dma_activate),
self.to_tx.data.eq(data),
self.to_tx.reg_d2h.eq(reg_d2h)
] ]
class SATACommand(Module): class SATACommand(Module):
def __init__(self, transport): def __init__(self, transport):
self.submodules.tx = SATACommandTX(transport) self.submodules.tx = SATACommandTX(transport)
self.submodules.rx = SATACommandRX(transport) self.submodules.rx = SATACommandRX(transport)
self.sink, self.source = self.tx.sink, self.rx.source
self.comb += self.rx.to_tx.connect(self.tx.from_rx) self.comb += self.rx.to_tx.connect(self.tx.from_rx)
self.sink, self.source = self.tx.sink, self.rx.source

View file

@ -23,6 +23,7 @@ class TB(Module):
def gen_simulation(self, selfp): def gen_simulation(self, selfp):
self.bfm.command.allocate_dma(0x00000000, 64*1024*1024) self.bfm.command.allocate_dma(0x00000000, 64*1024*1024)
self.bfm.command.enable_dma() self.bfm.command.enable_dma()
selfp.command.source.ack = 1
for i in range(100): for i in range(100):
yield yield
for i in range(32): for i in range(32):