hdl.mem: allow omitting memory simulation logic.
Trying to transform very large arrays is slow.
This commit is contained in:
		
							parent
							
								
									d47c1f8a8a
								
							
						
					
					
						commit
						f05bd2a137
					
				|  | @ -6,7 +6,7 @@ from .ir import Instance | ||||||
| 
 | 
 | ||||||
| 
 | 
 | ||||||
| class Memory: | class Memory: | ||||||
|     def __init__(self, width, depth, init=None, name=None): |     def __init__(self, width, depth, init=None, name=None, simulate=True): | ||||||
|         if not isinstance(width, int) or width < 0: |         if not isinstance(width, int) or width < 0: | ||||||
|             raise TypeError("Memory width must be a non-negative integer, not '{!r}'" |             raise TypeError("Memory width must be a non-negative integer, not '{!r}'" | ||||||
|                             .format(width)) |                             .format(width)) | ||||||
|  | @ -29,6 +29,7 @@ class Memory: | ||||||
| 
 | 
 | ||||||
|         # Array of signals for simulation. |         # Array of signals for simulation. | ||||||
|         self._array = Array() |         self._array = Array() | ||||||
|  |         if simulate: | ||||||
|             for addr in range(self.depth): |             for addr in range(self.depth): | ||||||
|                 self._array.append(Signal(self.width, name="{}({})".format(name, addr))) |                 self._array.append(Signal(self.width, name="{}({})".format(name, addr))) | ||||||
| 
 | 
 | ||||||
|  | @ -45,7 +46,7 @@ class Memory: | ||||||
|             raise ValueError("Memory initialization value count exceed memory depth ({} > {})" |             raise ValueError("Memory initialization value count exceed memory depth ({} > {})" | ||||||
|                              .format(len(self.init), self.depth)) |                              .format(len(self.init), self.depth)) | ||||||
| 
 | 
 | ||||||
|         for addr in range(self.depth): |         for addr in range(len(self._array)): | ||||||
|             if addr < len(self._init): |             if addr < len(self._init): | ||||||
|                 self._array[addr].reset = self._init[addr] |                 self._array[addr].reset = self._init[addr] | ||||||
|             else: |             else: | ||||||
|  |  | ||||||
		Loading…
	
		Reference in a new issue
	
	 whitequark
						whitequark