diff --git a/nmigen/back/rtlil.py b/nmigen/back/rtlil.py index 90c5ed9a..120a354e 100644 --- a/nmigen/back/rtlil.py +++ b/nmigen/back/rtlil.py @@ -306,10 +306,15 @@ def resolve(self, signal, prefix=None): else: wire_name = signal.name + attrs = dict(signal.attrs) + if signal._enum_class is not None: + attrs["enum_base_type"] = signal._enum_class.__name__ + for value in signal._enum_class: + attrs["enum_value_{:0{}b}".format(value.value, signal.width)] = value.name + wire_curr = self.rtlil.wire(width=signal.width, name=wire_name, port_id=port_id, port_kind=port_kind, - attrs=signal.attrs, - src=src(signal.src_loc)) + attrs=attrs, src=src(signal.src_loc)) if signal in self.driven and self.driven[signal]: wire_next = self.rtlil.wire(width=signal.width, name=wire_curr + "$next", src=src(signal.src_loc)) diff --git a/nmigen/hdl/ast.py b/nmigen/hdl/ast.py index 7e42c2a8..45dab3d0 100644 --- a/nmigen/hdl/ast.py +++ b/nmigen/hdl/ast.py @@ -425,7 +425,7 @@ def matches(self, *patterns): def rotate_left(self, offset): """Rotate left by constant modulo 2**len(self). - + Parameters ---------- offset : int @@ -443,7 +443,7 @@ def rotate_left(self, offset): def rotate_right(self, offset): """Rotate right by constant modulo 2**len(self). - + Parameters ---------- offset : int @@ -922,8 +922,10 @@ def enum_decoder(value): except ValueError: return str(value) self.decoder = enum_decoder + self._enum_class = decoder else: self.decoder = decoder + self._enum_class = None # Not a @classmethod because nmigen.compat requires it. @staticmethod