2015-02-28 04:27:16 -05:00
|
|
|
from misoclib.tools.litescope.common import *
|
2015-01-25 07:41:09 -05:00
|
|
|
|
2015-04-13 07:18:21 -04:00
|
|
|
|
2015-01-25 10:23:40 -05:00
|
|
|
class LiteScopeTermUnit(Module):
|
2015-04-13 07:09:44 -04:00
|
|
|
def __init__(self, dw):
|
|
|
|
self.dw = dw
|
|
|
|
self.sink = sink = Sink(data_layout(dw))
|
|
|
|
self.source = source = Source(hit_layout())
|
2015-01-25 07:41:09 -05:00
|
|
|
|
2015-04-13 07:09:44 -04:00
|
|
|
self.trig = Signal(dw)
|
|
|
|
self.mask = Signal(dw)
|
2015-04-13 07:46:06 -04:00
|
|
|
|
|
|
|
# # #
|
|
|
|
|
2015-04-13 07:09:44 -04:00
|
|
|
self.comb += [
|
|
|
|
source.stb.eq(sink.stb),
|
|
|
|
source.hit.eq((sink.data & self.mask) == self.trig),
|
|
|
|
sink.ack.eq(source.ack)
|
|
|
|
]
|
2015-01-25 07:41:09 -05:00
|
|
|
|
2015-04-13 07:18:21 -04:00
|
|
|
|
2015-01-25 10:23:40 -05:00
|
|
|
class LiteScopeTerm(LiteScopeTermUnit, AutoCSR):
|
2015-04-13 07:09:44 -04:00
|
|
|
def __init__(self, dw):
|
|
|
|
LiteScopeTermUnit.__init__(self, dw)
|
|
|
|
self._trig = CSRStorage(dw)
|
|
|
|
self._mask = CSRStorage(dw)
|
2015-04-13 07:46:06 -04:00
|
|
|
|
|
|
|
# # #
|
|
|
|
|
2015-04-13 07:09:44 -04:00
|
|
|
self.comb += [
|
|
|
|
self.trig.eq(self._trig.storage),
|
|
|
|
self.mask.eq(self._mask.storage)
|
|
|
|
]
|
2015-01-25 07:41:09 -05:00
|
|
|
|
2015-04-13 07:18:21 -04:00
|
|
|
|
2015-01-25 10:23:40 -05:00
|
|
|
class LiteScopeRangeDetectorUnit(Module):
|
2015-04-13 07:09:44 -04:00
|
|
|
def __init__(self, dw):
|
|
|
|
self.dw = dw
|
|
|
|
self.sink = sink = Sink(data_layout(dw))
|
|
|
|
self.source = source = Source(hit_layout())
|
2015-01-25 07:41:09 -05:00
|
|
|
|
2015-04-13 07:09:44 -04:00
|
|
|
self.low = Signal(dw)
|
|
|
|
self.high = Signal(dw)
|
2015-04-13 07:46:06 -04:00
|
|
|
|
|
|
|
# # #
|
|
|
|
|
2015-04-13 07:09:44 -04:00
|
|
|
self.comb += [
|
|
|
|
source.stb.eq(sink.stb),
|
|
|
|
source.hit.eq((sink.data >= self.low) & (sink.data <= self.high)),
|
|
|
|
sink.ack.eq(source.ack)
|
|
|
|
]
|
2015-01-25 07:41:09 -05:00
|
|
|
|
2015-04-13 07:18:21 -04:00
|
|
|
|
2015-01-25 10:23:40 -05:00
|
|
|
class LiteScopeRangeDetector(LiteScopeRangeDetectorUnit, AutoCSR):
|
2015-04-13 07:09:44 -04:00
|
|
|
def __init__(self, dw):
|
|
|
|
LiteScopeRangeDetectorUnit.__init__(self, dw)
|
|
|
|
self._low = CSRStorage(dw)
|
|
|
|
self._high = CSRStorage(dw)
|
2015-04-13 07:46:06 -04:00
|
|
|
|
|
|
|
# # #
|
|
|
|
|
2015-04-13 07:09:44 -04:00
|
|
|
self.comb += [
|
|
|
|
self.low.eq(self._low.storage),
|
|
|
|
self.high.eq(self._high.storage)
|
|
|
|
]
|
2015-01-25 07:41:09 -05:00
|
|
|
|
2015-04-13 07:18:21 -04:00
|
|
|
|
2015-01-25 10:23:40 -05:00
|
|
|
class LiteScopeEdgeDetectorUnit(Module):
|
2015-04-13 07:09:44 -04:00
|
|
|
def __init__(self, dw):
|
|
|
|
self.dw = dw
|
|
|
|
self.sink = sink = Sink(data_layout(dw))
|
|
|
|
self.source = source = Source(hit_layout())
|
2015-01-25 07:41:09 -05:00
|
|
|
|
2015-04-13 07:09:44 -04:00
|
|
|
self.rising_mask = Signal(dw)
|
|
|
|
self.falling_mask = Signal(dw)
|
|
|
|
self.both_mask = Signal(dw)
|
2015-04-13 07:46:06 -04:00
|
|
|
|
|
|
|
# # #
|
|
|
|
|
2015-08-24 12:15:13 -04:00
|
|
|
self.submodules.buffer = Buffer(self.sink.description)
|
|
|
|
self.comb += Record.connect(self.sink, self.buffer.d)
|
2015-01-25 07:41:09 -05:00
|
|
|
|
2015-04-13 07:09:44 -04:00
|
|
|
rising = Signal(dw)
|
2015-08-24 12:15:13 -04:00
|
|
|
rising.eq(self.rising_mask & sink.data & ~self.buffer.q.data)
|
2015-01-25 07:41:09 -05:00
|
|
|
|
2015-04-13 07:09:44 -04:00
|
|
|
falling = Signal(dw)
|
2015-08-24 12:15:13 -04:00
|
|
|
falling.eq(self.falling_mask & ~sink.data & self.buffer.q.data)
|
2015-01-25 07:41:09 -05:00
|
|
|
|
2015-04-13 07:09:44 -04:00
|
|
|
both = Signal(dw)
|
2015-08-24 12:15:13 -04:00
|
|
|
both.eq(self.both_mask & (rising | falling))
|
2015-01-25 07:41:09 -05:00
|
|
|
|
2015-04-13 07:09:44 -04:00
|
|
|
self.comb += [
|
2015-08-24 12:15:13 -04:00
|
|
|
source.stb.eq(sink.stb & self.buffer.q.stb),
|
|
|
|
self.buffer.q.ack.eq(source.ack),
|
|
|
|
source.hit.eq((rising | falling | both) != 0)
|
2015-04-13 07:09:44 -04:00
|
|
|
]
|
2015-01-25 07:41:09 -05:00
|
|
|
|
2015-04-13 07:18:21 -04:00
|
|
|
|
2015-01-25 10:23:40 -05:00
|
|
|
class LiteScopeEdgeDetector(LiteScopeEdgeDetectorUnit, AutoCSR):
|
2015-04-13 07:09:44 -04:00
|
|
|
def __init__(self, dw):
|
|
|
|
LiteScopeEdgeDetectorUnit.__init__(self, dw)
|
|
|
|
self._rising = CSRStorage(dw)
|
|
|
|
self._falling = CSRStorage(dw)
|
|
|
|
self._both = CSRStorage(dw)
|
2015-04-13 07:46:06 -04:00
|
|
|
|
|
|
|
# # #
|
|
|
|
|
2015-04-13 07:09:44 -04:00
|
|
|
self.comb += [
|
2015-08-24 12:15:13 -04:00
|
|
|
self.rising_mask.eq(self._rising.storage),
|
|
|
|
self.falling_mask.eq(self._falling.storage),
|
|
|
|
self.both_mask.eq(self._both.storage)
|
2015-04-13 07:09:44 -04:00
|
|
|
]
|