compat.fhdl.module: implement finalization.
This commit is contained in:
		
							parent
							
								
									b42620e490
								
							
						
					
					
						commit
						22c76e5f90
					
				|  | @ -58,14 +58,12 @@ class _CompatModuleSync(_CompatModuleProxy): | ||||||
|             raise AttributeError("Attempted to assign sync property - use += instead") |             raise AttributeError("Attempted to assign sync property - use += instead") | ||||||
| 
 | 
 | ||||||
| 
 | 
 | ||||||
| class _CompatModuleForwardAttr: | class _CompatModuleSpecials(_CompatModuleProxy): | ||||||
|     @deprecated("TODO") |     @deprecated("TODO") | ||||||
|     def __setattr__(self, name, value): |     def __setattr__(self, name, value): | ||||||
|         self.__iadd__(value) |         self.__iadd__(value) | ||||||
|         setattr(self._cm, name, value) |         setattr(self._cm, name, value) | ||||||
| 
 | 
 | ||||||
| 
 |  | ||||||
| class _CompatModuleSpecials(_CompatModuleProxy, _CompatModuleForwardAttr): |  | ||||||
|     @deprecated("TODO") |     @deprecated("TODO") | ||||||
|     def __iadd__(self, other): |     def __iadd__(self, other): | ||||||
|         self._cm._fragment.specials |= set(_flat_list(other)) |         self._cm._fragment.specials |= set(_flat_list(other)) | ||||||
|  | @ -73,18 +71,23 @@ class _CompatModuleSpecials(_CompatModuleProxy, _CompatModuleForwardAttr): | ||||||
| 
 | 
 | ||||||
| 
 | 
 | ||||||
| class _CompatModuleSubmodules(_CompatModuleProxy): | class _CompatModuleSubmodules(_CompatModuleProxy): | ||||||
|     @deprecated("TODO") |     @deprecated("instead of `self.submodules.<mod> =`, use `m.submodules.<mod> =`") | ||||||
|     def __setattr__(self, name, value): |     def __setattr__(self, name, value): | ||||||
|         self._cm._submodules += [(name, e) for e in _flat_list(value)] |         self._cm._submodules += [(name, e) for e in _flat_list(value)] | ||||||
|         setattr(self._cm, name, value) |         setattr(self._cm, name, value) | ||||||
| 
 | 
 | ||||||
|     @deprecated("TODO") |     @deprecated("instead of `self.submodules +=`, use `m.submodules +=`") | ||||||
|     def __iadd__(self, other): |     def __iadd__(self, other): | ||||||
|         self._cm._submodules += [(None, e) for e in _flat_list(other)] |         self._cm._submodules += [(None, e) for e in _flat_list(other)] | ||||||
|         return self |         return self | ||||||
| 
 | 
 | ||||||
| 
 | 
 | ||||||
| class _CompatModuleClockDomains(_CompatModuleProxy, _CompatModuleForwardAttr): | class _CompatModuleClockDomains(_CompatModuleProxy): | ||||||
|  |     @deprecated("TODO") | ||||||
|  |     def __setattr__(self, name, value): | ||||||
|  |         self.__iadd__(value) | ||||||
|  |         setattr(self._cm, name, value) | ||||||
|  | 
 | ||||||
|     @deprecated("TODO") |     @deprecated("TODO") | ||||||
|     def __iadd__(self, other): |     def __iadd__(self, other): | ||||||
|         self._cm._fragment.clock_domains += _flat_list(other) |         self._cm._fragment.clock_domains += _flat_list(other) | ||||||
|  | @ -92,11 +95,12 @@ class _CompatModuleClockDomains(_CompatModuleProxy, _CompatModuleForwardAttr): | ||||||
| 
 | 
 | ||||||
| 
 | 
 | ||||||
| class CompatModule: | class CompatModule: | ||||||
|  |     # Actually returns nmigen.fhdl.Module, not a Fragment. | ||||||
|     def get_fragment(self): |     def get_fragment(self): | ||||||
|         assert not self.get_fragment_called |         assert not self.get_fragment_called | ||||||
|         self.get_fragment_called = True |         self.get_fragment_called = True | ||||||
|         self.finalize() |         self.finalize() | ||||||
|         return self._fragment |         return self._module | ||||||
| 
 | 
 | ||||||
|     def __getattr__(self, name): |     def __getattr__(self, name): | ||||||
|         if name == "comb": |         if name == "comb": | ||||||
|  | @ -128,5 +132,20 @@ class CompatModule: | ||||||
|             raise AttributeError("'{}' object has no attribute '{}'" |             raise AttributeError("'{}' object has no attribute '{}'" | ||||||
|                                  .format(type(self).__name__, name)) |                                  .format(type(self).__name__, name)) | ||||||
| 
 | 
 | ||||||
|  |     def _finalize_submodules(self): | ||||||
|  |         for name, submodule in self._submodules: | ||||||
|  |             if not submodule.get_fragment_called: | ||||||
|  |                 self._module._add_submodule(submodule.get_fragment(), name) | ||||||
|  | 
 | ||||||
|  |     def finalize(self, *args, **kwargs): | ||||||
|  |         if not self.finalized: | ||||||
|  |             self.finalized = True | ||||||
|  |             self._finalize_submodules() | ||||||
|  |             self.do_finalize(*args, **kwargs) | ||||||
|  |             self._finalize_submodules() | ||||||
|  | 
 | ||||||
|  |     def do_finalize(self): | ||||||
|  |         pass | ||||||
|  | 
 | ||||||
| 
 | 
 | ||||||
| Module = CompatModule | Module = CompatModule | ||||||
|  |  | ||||||
|  | @ -545,7 +545,7 @@ class Signal(Value, DUID): | ||||||
|         other : Value |         other : Value | ||||||
|             Object to base this Signal on. |             Object to base this Signal on. | ||||||
|         """ |         """ | ||||||
|         kw = dict(shape=cls.wrap(other).shape()) |         kw = dict(shape=cls.wrap(other).shape(), name=tracer.get_var_name()) | ||||||
|         if isinstance(other, cls): |         if isinstance(other, cls): | ||||||
|             kw.update(reset=other.reset, reset_less=other.reset_less, attrs=other.attrs) |             kw.update(reset=other.reset, reset_less=other.reset_less, attrs=other.attrs) | ||||||
|         kw.update(kwargs) |         kw.update(kwargs) | ||||||
|  |  | ||||||
|  | @ -53,6 +53,8 @@ class _ModuleBuilderRoot: | ||||||
|         if name in ("comb", "sync"): |         if name in ("comb", "sync"): | ||||||
|             raise AttributeError("'{}' object has no attribute '{}'; did you mean 'd.{}'?" |             raise AttributeError("'{}' object has no attribute '{}'; did you mean 'd.{}'?" | ||||||
|                                  .format(type(self).__name__, name, name)) |                                  .format(type(self).__name__, name, name)) | ||||||
|  |         raise AttributeError("'{}' object has no attribute '{}'" | ||||||
|  |                              .format(type(self).__name__, name)) | ||||||
| 
 | 
 | ||||||
| 
 | 
 | ||||||
| class _ModuleBuilderIf(_ModuleBuilderRoot): | class _ModuleBuilderIf(_ModuleBuilderRoot): | ||||||
|  | @ -223,7 +225,7 @@ class Module(_ModuleBuilderRoot): | ||||||
|     def _add_submodule(self, submodule, name=None): |     def _add_submodule(self, submodule, name=None): | ||||||
|         if not hasattr(submodule, "get_fragment"): |         if not hasattr(submodule, "get_fragment"): | ||||||
|             raise TypeError("Trying to add {!r}, which does not have .get_fragment(), as " |             raise TypeError("Trying to add {!r}, which does not have .get_fragment(), as " | ||||||
|                             " a submodule") |                             "a submodule".format(submodule)) | ||||||
|         self._submodules.append((submodule, name)) |         self._submodules.append((submodule, name)) | ||||||
| 
 | 
 | ||||||
|     def lower(self, platform): |     def lower(self, platform): | ||||||
|  | @ -237,3 +239,5 @@ class Module(_ModuleBuilderRoot): | ||||||
|             for lhs_signal in signal._lhs_signals(): |             for lhs_signal in signal._lhs_signals(): | ||||||
|                 fragment.drive(lhs_signal, cd_name) |                 fragment.drive(lhs_signal, cd_name) | ||||||
|         return fragment |         return fragment | ||||||
|  | 
 | ||||||
|  |     get_fragment = lower | ||||||
|  |  | ||||||
		Loading…
	
		Reference in a new issue
	
	 whitequark
						whitequark