mirror of
https://github.com/enjoy-digital/litex.git
synced 2025-01-04 09:52:26 -05:00
39 lines
1.1 KiB
Python
39 lines
1.1 KiB
Python
# This file is Copyright (c) 2013-2015 Sebastien Bourdeauducq <sb@m-labs.hk>
|
|
# License: BSD
|
|
|
|
|
|
from migen import *
|
|
|
|
from litex.soc.interconnect.csr import *
|
|
from litex.soc.interconnect.csr_eventmanager import *
|
|
|
|
|
|
class Timer(Module, AutoCSR):
|
|
def __init__(self, width=32):
|
|
self._load = CSRStorage(width)
|
|
self._reload = CSRStorage(width)
|
|
self._en = CSRStorage()
|
|
self._update_value = CSR()
|
|
self._value = CSRStatus(width)
|
|
|
|
self.submodules.ev = EventManager()
|
|
self.ev.zero = EventSourceProcess()
|
|
self.ev.finalize()
|
|
|
|
###
|
|
|
|
value = Signal(width)
|
|
self.sync += [
|
|
If(self._en.storage,
|
|
If(value == 0,
|
|
# set reload to 0 to disable reloading
|
|
value.eq(self._reload.storage)
|
|
).Else(
|
|
value.eq(value - 1)
|
|
)
|
|
).Else(
|
|
value.eq(self._load.storage)
|
|
),
|
|
If(self._update_value.re, self._value.status.eq(value))
|
|
]
|
|
self.comb += self.ev.zero.trigger.eq(value != 0)
|