litex/misoclib/mem/litesata/core/link/cont.py

119 lines
3.5 KiB
Python
Raw Normal View History

from misoclib.mem.litesata.common import *
from misoclib.mem.litesata.core.link.scrambler import Scrambler
2014-12-03 05:12:26 -05:00
2015-04-13 09:12:39 -04:00
2015-01-16 17:52:41 -05:00
class LiteSATACONTInserter(Module):
def __init__(self, description):
self.sink = sink = Sink(description)
self.source = source = Source(description)
2014-12-03 05:12:26 -05:00
2015-04-13 09:55:22 -04:00
# # #
2014-12-03 05:12:26 -05:00
counter = Counter(max=4)
self.submodules += counter
2014-12-03 05:12:26 -05:00
is_data = Signal()
was_data = Signal()
was_hold = Signal()
change = Signal()
self.comb += is_data.eq(sink.charisk == 0)
2014-12-19 05:15:01 -05:00
last_data = Signal(32)
last_primitive = Signal(32)
last_charisk = Signal(4)
self.sync += [
If(sink.stb & source.ack,
last_data.eq(sink.data),
last_charisk.eq(sink.charisk),
If(~is_data,
last_primitive.eq(sink.data),
),
was_data.eq(is_data),
was_hold.eq(last_primitive == primitives["HOLD"])
)
]
self.comb += change.eq(
(sink.data != last_data) |
(sink.charisk != last_charisk) |
is_data
)
2014-12-03 05:12:26 -05:00
# scrambler
scrambler = InsertReset(Scrambler())
self.submodules += scrambler
2014-12-03 05:12:26 -05:00
# Datapath
self.comb += [
Record.connect(sink, source),
If(sink.stb,
If(~change,
2015-04-13 09:44:04 -04:00
counter.ce.eq(sink.ack & (counter.value != 2)),
# insert CONT
If(counter.value == 1,
source.charisk.eq(0b0001),
source.data.eq(primitives["CONT"])
# insert scrambled data for EMI
).Elif(counter.value == 2,
scrambler.ce.eq(sink.ack),
source.charisk.eq(0b0000),
source.data.eq(scrambler.value)
)
).Else(
counter.reset.eq(source.ack),
If(counter.value == 2,
# Reinsert last primitive
If(is_data | (~is_data & was_hold),
source.stb.eq(1),
sink.ack.eq(0),
source.charisk.eq(0b0001),
source.data.eq(last_primitive)
)
)
)
)
]
2014-12-03 05:50:31 -05:00
2015-04-13 09:12:39 -04:00
2015-01-16 17:52:41 -05:00
class LiteSATACONTRemover(Module):
def __init__(self, description):
self.sink = sink = Sink(description)
self.source = source = Source(description)
2014-12-03 05:50:31 -05:00
2015-04-13 09:55:22 -04:00
# # #
2014-12-03 05:50:31 -05:00
is_data = Signal()
is_cont = Signal()
in_cont = Signal()
cont_ongoing = Signal()
2014-12-03 05:50:31 -05:00
self.comb += [
is_data.eq(sink.charisk == 0),
is_cont.eq(~is_data & (sink.data == primitives["CONT"]))
]
self.sync += \
If(sink.stb & sink.ack,
If(is_cont,
in_cont.eq(1)
).Elif(~is_data,
in_cont.eq(0)
)
)
self.comb += cont_ongoing.eq(is_cont | (in_cont & is_data))
2014-12-03 05:50:31 -05:00
# Datapath
last_primitive = Signal(32)
self.sync += [
If(sink.stb & sink.ack,
If(~is_data & ~is_cont,
last_primitive.eq(sink.data)
)
)
]
self.comb += [
Record.connect(sink, source),
If(cont_ongoing,
source.charisk.eq(0b0001),
source.data.eq(last_primitive)
)
]