transport: define FIS layouts

This commit is contained in:
Florent Kermarrec 2014-12-03 16:32:55 +01:00
parent ddd4b65f44
commit 6e6243e983
5 changed files with 130 additions and 7 deletions

View file

@ -47,18 +47,18 @@ class SATACONTInserter(Module):
)
)
# scranbler (between CONT and next primitive)
# scrambler (between CONT and next primitive)
scrambler = Scrambler()
self.submodules += scrambler
self.comb += [
scrambler.reset.eq(ResetSignal()), #XXX: should be on COMINIT / COMRESET
scrambler.ce.eq(scrambler_insert & self.source.stb & self.source.ack)
scrambler.reset.eq(ResetSignal()), #XXX: should be reseted on COMINIT / COMRESET
scrambler.ce.eq(scrambler_insert & source.stb & source.ack)
]
# Datapath
self.comb += [
Record.connect(sink, source),
If(self.sink.stb,
If(sink.stb,
If(cont_insert,
source.charisk.eq(0b0001),
source.data.eq(primitives["CONT"])
@ -109,7 +109,7 @@ class SATACONTRemover(Module):
self.comb += [
Record.connect(sink, source),
If(cont_ongoing,
self.source.charisk.eq(0b0001),
self.source.data.eq(last_primitive)
source.charisk.eq(0b0001),
source.data.eq(last_primitive)
)
]

View file

@ -1,6 +1,6 @@
from migen.fhdl.std import *
from migen.genlib.record import *
from migen.flow.actor import EndpointDescription, Sink, Source
from migen.flow.actor import *
primitives = {
"ALIGN" : 0x7B4A4ABC,
@ -47,3 +47,15 @@ def link_layout(dw):
("error", 1)
]
return EndpointDescription(layout, packetized=True)
def transport_tx_layout(dw):
layout = [
("d", dw)
]
return EndpointDescription(layout, packetized=True)
def transport_rx_layout(dw):
layout = [
("d", dw)
]
return EndpointDescription(layout, packetized=True)

View file

@ -0,0 +1,15 @@
from lib.sata.std import *
from lib.sata.transport.std import *
class SATATransportLayerTX(Module):
def __init__(self):
self.sink = Sink(transport_layout(32))
class SATATransportLayerRX(Module):
def __init__(self):
self.sink = Sink(transport_layout(32))
class SATATransportLayer(Module):
def __init__(self):
self.submodules.tx = SATATransportLayerTX()
self.submodules.rx = SATATransportLayerRX()

96
lib/sata/transport/std.py Normal file
View file

@ -0,0 +1,96 @@
fis_types = {
"REG_H2D": 0x27,
"REG_D2H": 0x34,
"DMA_ACTIVATE_D2H": 0x39,
"DMA_SETUP": 0x41,
"DATA": 0x46,
"PIO_SETUP_D2H": 0x5F
}
class FISField():
def __init__(self, dword, offset, width):
self.dword = dword
self.offset = offset
self.width = width
fis_reg_h2d_len = 5
fis_reg_h2d_layout = {
"type": FISField(0, 0, 8),
"pm_port": FISField(0, 8, 4),
"c": FISField(0, 15, 1),
"command": FISField(0, 16, 8),
"features_lsb": FISField(0, 24, 8),
"lba_lsb": FISField(1, 0, 24),
"device": FISField(1, 24, 0),
"lba_msb": FISField(2, 0, 24),
"features_msb": FISField(2, 24, 8),
"count": FISField(3, 0, 16),
"icc": FISField(3, 16, 8),
"control": FISField(3, 24, 8)
}
fis_reg_d2h_len = 5
fis_reg_d2h_layout = {
"type": FISField(0, 0, 8),
"pm_port": FISField(0, 8, 4),
"i": FISField(0, 14, 1),
"status": FISField(0, 16, 8),
"error": FISField(0, 24, 8),
"lba_lsb": FISField(1, 0, 24),
"device": FISField(1, 24, 0),
"lba_msb": FISField(2, 0, 24),
"count": FISField(3, 0, 16)
}
fis_dma_activate_d2h_len = 1
fis_dma_activate_d2h_layout = {
"type": FISField(0, 0, 8),
"pm_port": FISField(0, 8, 4)
}
fis_dma_setup_len = 7
fis_dma_setup_layout = {
"type": FISField(0, 0, 8),
"pm_port": FISField(0, 8, 4),
"d": FISField(0, 13, 1),
"i": FISField(0, 14, 1),
"a": FISField(0, 15, 1),
"dma_buffer_id_low": FISField(1, 0, 32),
"dma_buffer_id_high": FISField(2, 0, 32),
"dma_buffer_offset": FISField(4, 0, 32),
"dma_transfer_count": FISField(4, 0, 32)
}
fis_data_layout = {
"type": FISField(0, 0, 8)
}
fis_pio_setup_d2h_len = 5
fis_pio_setup_d2h_layout = {
"type": FISField(0, 0, 8),
"pm_port": FISField(0, 8, 4),
"d": FISField(0, 13, 1),
"i": FISField(0, 14, 1),
"status": FISField(0, 16, 8),
"error": FISField(0, 24, 8),
"lba_lsb": FISField(1, 0, 24),
"device": FISField(1, 24, 0),
"lba_msb": FISField(2, 0, 24),
"count": FISField(3, 0, 16),
"e_status": FISField(3, 24, 8),
"transfer_count": FISField(4, 0, 16)
}