read/write seems OK with CommandGenerator

This commit is contained in:
Florent Kermarrec 2014-12-23 00:08:22 +01:00
parent 5e513c25c2
commit 6b12782816
4 changed files with 64 additions and 46 deletions

View file

@ -215,6 +215,13 @@ class CommandGenerator(Module, AutoCSR):
NextState("WAIT_WRITE_ACK") NextState("WAIT_WRITE_ACK")
) )
) )
self.sync += [
If(fsm.ongoing("IDLE"),
cnt.eq(0)
).Elif(sata_con.sink.stb & sata_con.sink.stb,
cnt.eq(cnt+1)
)
]
fsm.act("WAIT_WRITE_ACK", fsm.act("WAIT_WRITE_ACK",
# XXX: add check of success / failed # XXX: add check of success / failed
If(sata_con.source.stb & sata_con.source.eop, If(sata_con.source.stb & sata_con.source.eop,
@ -312,16 +319,16 @@ class TestDesign(UART2WB, AutoCSR):
self.sata_con.sink.read, self.sata_con.sink.read,
self.sata_con.sink.identify, self.sata_con.sink.identify,
#self.sata_con.source.stb, self.sata_con.source.stb,
#self.sata_con.source.sop, self.sata_con.source.sop,
#self.sata_con.source.eop, self.sata_con.source.eop,
#self.sata_con.source.ack, self.sata_con.source.ack,
#self.sata_con.source.write, self.sata_con.source.write,
#self.sata_con.source.read, self.sata_con.source.read,
#self.sata_con.source.identify, self.sata_con.source.identify,
#self.sata_con.source.success, self.sata_con.source.success,
#self.sata_con.source.failed, self.sata_con.source.failed,
#self.sata_con.source.data, self.sata_con.source.data,
#self.sata_con.link.source.stb, #self.sata_con.link.source.stb,
#self.sata_con.link.source.sop, #self.sata_con.link.source.sop,
@ -337,19 +344,19 @@ class TestDesign(UART2WB, AutoCSR):
#self.sata_con.link.rx.scrambler.sink.d, #self.sata_con.link.rx.scrambler.sink.d,
#self.sata_con.link.rx.scrambler.sink.error, #self.sata_con.link.rx.scrambler.sink.error,
self.sata_con.link.rx.scrambler.sink.stb, #self.sata_con.link.rx.crc.sink.stb,
self.sata_con.link.rx.scrambler.sink.sop, #self.sata_con.link.rx.crc.sink.sop,
self.sata_con.link.rx.scrambler.sink.eop, #self.sata_con.link.rx.crc.sink.eop,
self.sata_con.link.rx.scrambler.sink.ack, #self.sata_con.link.rx.crc.sink.ack,
self.sata_con.link.rx.scrambler.sink.d, #self.sata_con.link.rx.crc.sink.d,
self.sata_con.link.rx.scrambler.sink.error, #self.sata_con.link.rx.crc.sink.error,
self.sata_con.link.rx.scrambler.source.stb, self.sata_con.link.rx.crc.source.stb,
self.sata_con.link.rx.scrambler.source.sop, self.sata_con.link.rx.crc.source.sop,
self.sata_con.link.rx.scrambler.source.eop, self.sata_con.link.rx.crc.source.eop,
self.sata_con.link.rx.scrambler.source.ack, self.sata_con.link.rx.crc.source.ack,
self.sata_con.link.rx.scrambler.source.d, self.sata_con.link.rx.crc.source.d,
self.sata_con.link.rx.scrambler.source.error, self.sata_con.link.rx.crc.source.error,
self.command_tx_fsm_state, self.command_tx_fsm_state,
self.transport_tx_fsm_state, self.transport_tx_fsm_state,

View file

@ -8,16 +8,19 @@ wb.open()
regs = wb.regs regs = wb.regs
### ###
#trigger0 = mila.sata_con_sink_payload_identify_o*1 cond = {
#mask0 = mila.sata_con_sink_payload_identify_m #"sata_phy_source_source_payload_data" : primitives["R_RDY"],
#"sata_phy_source_source_payload_data" : primitives["R_OK"],
"sata_phy_source_source_payload_data" : primitives["X_RDY"],
}
#trigger0 = mila.sata_phy_source_source_payload_data_o*primitives["R_OK"] trigger = 0
#mask0 = mila.sata_phy_source_source_payload_data_m mask = 0
for k, v in cond.items():
trigger |= getattr(mila, k+"_o")*v
mask |= getattr(mila, k+"_m")
trigger0 = mila.sata_phy_source_source_payload_data_o*primitives["X_RDY"] mila.prog_term(port=0, trigger=trigger, mask=mask)
mask0 = mila.sata_phy_source_source_payload_data_m
mila.prog_term(port=0, trigger=trigger0, mask=mask0)
mila.prog_sum("term") mila.prog_sum("term")
# Trigger / wait / receive # Trigger / wait / receive

View file

@ -8,16 +8,20 @@ wb.open()
regs = wb.regs regs = wb.regs
### ###
#trigger0 = mila.sata_con_sink_payload_read_o*1 cond = {
#mask0 = mila.sata_con_sink_payload_read_m #"sata_phy_source_source_payload_data" : primitives["R_RDY"],
#"sata_phy_source_source_payload_data" : primitives["R_OK"],
#"sata_phy_source_source_payload_data" : primitives["X_RDY"],
"sata_con_source_source_stb" : 1,
}
#trigger0 = mila.sata_phy_source_source_payload_data_o*primitives["R_OK"] trigger = 0
#mask0 = mila.sata_phy_source_source_payload_data_m mask = 0
for k, v in cond.items():
trigger |= getattr(mila, k+"_o")*v
mask |= getattr(mila, k+"_m")
trigger0 = mila.sata_phy_source_source_payload_data_o*primitives["X_RDY"] mila.prog_term(port=0, trigger=trigger, mask=mask)
mask0 = mila.sata_phy_source_source_payload_data_m
mila.prog_term(port=0, trigger=trigger0, mask=mask0)
mila.prog_sum("term") mila.prog_sum("term")
# Trigger / wait / receive # Trigger / wait / receive

View file

@ -8,16 +8,20 @@ wb.open()
regs = wb.regs regs = wb.regs
### ###
#trigger0 = mila.sata_con_sink_payload_write_o*1 cond = {
#mask0 = mila.sata_con_sink_payload_write_m #"sata_phy_source_source_payload_data" : primitives["R_RDY"],
#"sata_phy_source_source_payload_data" : primitives["R_OK"],
#"sata_phy_source_source_payload_data" : primitives["X_RDY"],
"sata_con_source_source_stb" : 1,
}
#trigger0 = mila.sata_phy_source_source_payload_data_o*primitives["R_RDY"] trigger = 0
#mask0 = mila.sata_phy_source_source_payload_data_m mask = 0
for k, v in cond.items():
trigger |= getattr(mila, k+"_o")*v
mask |= getattr(mila, k+"_m")
trigger0 = mila.sata_phy_source_source_payload_data_o*primitives["R_OK"] mila.prog_term(port=0, trigger=trigger, mask=mask)
mask0 = mila.sata_phy_source_source_payload_data_m
mila.prog_term(port=0, trigger=trigger0, mask=mask0)
mila.prog_sum("term") mila.prog_sum("term")
# Trigger / wait / receive # Trigger / wait / receive