2014-11-03 12:54:41 -05:00
|
|
|
from migen.fhdl.std import *
|
2014-11-11 04:19:24 -05:00
|
|
|
from migen.genlib.record import *
|
2014-12-03 10:32:55 -05:00
|
|
|
from migen.flow.actor import *
|
2014-11-03 12:54:41 -05:00
|
|
|
|
2014-11-11 04:19:24 -05:00
|
|
|
primitives = {
|
|
|
|
"ALIGN" : 0x7B4A4ABC,
|
2014-12-03 05:12:26 -05:00
|
|
|
"CONT" : 0X9999AA7C,
|
2014-11-11 04:19:24 -05:00
|
|
|
"SYNC" : 0xB5B5957C,
|
|
|
|
"R_RDY" : 0x4A4A957C,
|
|
|
|
"R_OK" : 0x3535B57C,
|
|
|
|
"R_ERR" : 0x5656B57C,
|
|
|
|
"R_IP" : 0X5555B57C,
|
|
|
|
"X_RDY" : 0x5757B57C,
|
|
|
|
"CONT" : 0x9999AA7C,
|
|
|
|
"WTRM" : 0x5858B57C,
|
|
|
|
"SOF" : 0x3737B57C,
|
|
|
|
"EOF" : 0xD5D5B57C,
|
|
|
|
"HOLD" : 0xD5D5AA7C,
|
2014-12-02 15:34:16 -05:00
|
|
|
"HOLDA" : 0X9595AA7C
|
2014-11-11 04:19:24 -05:00
|
|
|
}
|
|
|
|
|
2014-12-03 05:12:26 -05:00
|
|
|
def is_primitive(dword):
|
|
|
|
for k, v in primitives.items():
|
|
|
|
if dword == v:
|
|
|
|
return True
|
|
|
|
return False
|
|
|
|
|
|
|
|
def decode_primitive(dword):
|
|
|
|
for k, v in primitives.items():
|
|
|
|
if dword == v:
|
|
|
|
return k
|
|
|
|
return ""
|
|
|
|
|
2014-11-11 04:19:24 -05:00
|
|
|
def ones(width):
|
|
|
|
return 2**width-1
|
2014-11-04 11:35:46 -05:00
|
|
|
|
2014-11-11 12:47:34 -05:00
|
|
|
def phy_layout(dw):
|
2014-11-03 12:54:41 -05:00
|
|
|
layout = [
|
2014-11-11 08:54:54 -05:00
|
|
|
("data", dw),
|
|
|
|
("charisk", dw//8),
|
2014-11-03 12:54:41 -05:00
|
|
|
]
|
2014-12-02 13:24:46 -05:00
|
|
|
return EndpointDescription(layout, packetized=False)
|
2014-11-04 11:35:46 -05:00
|
|
|
|
2014-11-11 12:47:34 -05:00
|
|
|
def link_layout(dw):
|
2014-11-04 11:35:46 -05:00
|
|
|
layout = [
|
2014-11-11 08:54:54 -05:00
|
|
|
("d", dw),
|
|
|
|
("error", 1)
|
2014-11-04 11:35:46 -05:00
|
|
|
]
|
2014-12-02 13:24:46 -05:00
|
|
|
return EndpointDescription(layout, packetized=True)
|
2014-12-03 10:32:55 -05:00
|
|
|
|
2014-12-12 08:31:00 -05:00
|
|
|
def transport_tx_layout(dw):
|
2014-12-03 10:32:55 -05:00
|
|
|
layout = [
|
2014-12-11 14:19:14 -05:00
|
|
|
("type", 8),
|
|
|
|
("pm_port", 4),
|
|
|
|
("c", 1),
|
|
|
|
("command", 8),
|
|
|
|
("features", 16),
|
|
|
|
("lba", 48),
|
|
|
|
("device", 8),
|
|
|
|
("count", 16),
|
|
|
|
("icc", 8),
|
|
|
|
("control", 8),
|
2014-12-12 08:31:00 -05:00
|
|
|
("data", dw)
|
2014-12-11 14:19:14 -05:00
|
|
|
]
|
2014-12-12 08:31:00 -05:00
|
|
|
return EndpointDescription(layout, packetized=True)
|
2014-12-11 14:19:14 -05:00
|
|
|
|
2014-12-12 08:31:00 -05:00
|
|
|
def transport_rx_layout(dw):
|
2014-12-11 14:19:14 -05:00
|
|
|
layout = [
|
|
|
|
("type", 8),
|
|
|
|
("pm_port", 4),
|
|
|
|
("i", 1),
|
|
|
|
("status", 8),
|
|
|
|
("error", 8),
|
|
|
|
("lba", 48),
|
|
|
|
("device", 8),
|
|
|
|
("count", 16),
|
2014-12-12 12:16:30 -05:00
|
|
|
("data", dw)
|
|
|
|
]
|
|
|
|
return EndpointDescription(layout, packetized=True)
|
|
|
|
|
|
|
|
def command_tx_layout(dw):
|
|
|
|
layout = [
|
|
|
|
("write", 1),
|
|
|
|
("read", 1),
|
|
|
|
("address", 32),
|
|
|
|
("length", 32),
|
|
|
|
("data", dw)
|
|
|
|
]
|
|
|
|
return EndpointDescription(layout, packetized=True)
|
|
|
|
|
|
|
|
def command_rx_layout(dw):
|
|
|
|
layout = [
|
|
|
|
("write", 1),
|
|
|
|
("read", 1),
|
|
|
|
("success", 1),
|
|
|
|
("failed", 1),
|
2014-12-12 08:31:00 -05:00
|
|
|
("data", dw)
|
2014-12-03 10:32:55 -05:00
|
|
|
]
|
|
|
|
return EndpointDescription(layout, packetized=True)
|