core/led: simplify LedChaser (to have the same user interface than GPIOOut).
authorFlorent Kermarrec <florent@enjoy-digital.fr>
Fri, 8 May 2020 20:13:47 +0000 (22:13 +0200)
committerFlorent Kermarrec <florent@enjoy-digital.fr>
Fri, 8 May 2020 20:13:47 +0000 (22:13 +0200)
litex/soc/cores/led.py

index 727000e0b423da4a84bc239aca709d5002e297d7..54c1d2a0833d0ee478d1b15ababa779a23f1c094 100644 (file)
@@ -8,27 +8,26 @@ from litex.soc.interconnect.csr import *
 
 # Led Chaser ---------------------------------------------------------------------------------------
 
+_CHASER_MODE  = 0
+_CONTROL_MODE = 1
+
 class LedChaser(Module, AutoCSR):
     def __init__(self, pads, sys_clk_freq, period=1e0):
-        self.control  = CSRStorage(fields=[
-            CSRField("mode", size=2, values=[
-                ("``0b0``", "Chaser mode."),
-                ("``0b1``", "CPU mode."),
-            ])
-        ])
-        self.value = CSRStorage(len(pads), description="Control value when in CPU mode.")
+        self._out = CSRStorage(len(pads), description="Led Output(s) Control.")
 
         # # #
 
-        n      = len(pads)
-        chaser = Signal(n)
-        timer  = WaitTimer(int(period*sys_clk_freq/(2*n)))
+        n         = len(pads)
+        chaser    = Signal(n)
+        mode      = Signal(reset=_CHASER_MODE)
+        timer     = WaitTimer(int(period*sys_clk_freq/(2*n)))
         self.submodules += timer
         self.comb += timer.wait.eq(~timer.done)
         self.sync += If(timer.done, chaser.eq(Cat(~chaser[-1], chaser)))
+        self.sync += If(self._out.re, mode.eq(_CONTROL_MODE))
         self.comb += [
-            If(self.control.fields.mode,
-                pads.eq(self.value.storage)
+            If(mode == _CONTROL_MODE,
+                pads.eq(self._out.storage)
             ).Else(
                 pads.eq(chaser)
             )