Implement RFC 27 amendment: deprecate add_sync_process, not add_process.
				
					
				
			This commit is contained in:
		
							parent
							
								
									2d42d649ee
								
							
						
					
					
						commit
						4014f6429c
					
				|  | @ -80,7 +80,6 @@ class Simulator: | |||
|                             .format(process)) | ||||
|         return process | ||||
| 
 | ||||
|     @deprecated("The `add_process` method is deprecated per RFC 27. Use `add_testbench` instead.") | ||||
|     def add_process(self, process): | ||||
|         process = self._check_process(process) | ||||
|         def wrapper(): | ||||
|  | @ -89,6 +88,7 @@ class Simulator: | |||
|             yield from process() | ||||
|         self._engine.add_coroutine_process(wrapper, default_cmd=None) | ||||
| 
 | ||||
|     @deprecated("The `add_sync_process` method is deprecated per RFC 47. Use `add_process` or `add_testbench` instead.") | ||||
|     def add_sync_process(self, process, *, domain="sync"): | ||||
|         process = self._check_process(process) | ||||
|         def wrapper(): | ||||
|  | @ -107,25 +107,6 @@ class Simulator: | |||
|                 except StopIteration: | ||||
|                     break | ||||
|                 try: | ||||
|                     if isinstance(command, (Settle, Delay, Tick)): | ||||
|                         frame = generator.gi_frame | ||||
|                         module_globals = frame.f_globals | ||||
|                         if '__name__' in module_globals: | ||||
|                             module = module_globals['__name__'] | ||||
|                         else: | ||||
|                             module = "<string>" | ||||
|                         # If the warning action is "error", this call will throw the warning, and | ||||
|                         # the try block will redirect it into the generator. | ||||
|                         warnings.warn_explicit( | ||||
|                             f"Using `{command.__class__.__name__}` is deprecated within " | ||||
|                             f"`add_sync_process` per RFC 27; use `add_testbench` instead.", | ||||
|                             DeprecationWarning, | ||||
|                             filename=frame.f_code.co_filename, | ||||
|                             lineno=frame.f_lineno, | ||||
|                             module=module, | ||||
|                             registry=module_globals.setdefault("__warningregistry__", {}), | ||||
|                             module_globals=module_globals, | ||||
|                         ) | ||||
|                     result = yield command | ||||
|                     exception = None | ||||
|                 except Exception as e: | ||||
|  |  | |||
|  | @ -29,9 +29,8 @@ Apply the following changes to code written against Amaranth 0.4 to migrate it t | |||
| * Replace uses of ``Value.matches()`` with no patterns with ``Const(1)`` | ||||
| * Update uses of ``amaranth.utils.log2_int(need_pow2=False)`` to :func:`amaranth.utils.ceil_log2` | ||||
| * Update uses of ``amaranth.utils.log2_int(need_pow2=True)`` to :func:`amaranth.utils.exact_log2` | ||||
| * Update uses of ``Simulator.add_process`` to ``Simulator.add_testbench`` | ||||
| * Convert uses of ``Simulator.add_sync_process`` used as testbenches to ``Simulator.add_testbench`` | ||||
| * Convert uses of ``yield Tick()`` within remaining ``Simulator.add_sync_process`` to plain ``yield`` | ||||
| * Convert other uses of ``Simulator.add_sync_process`` to ``Simulator.add_process`` | ||||
| 
 | ||||
| 
 | ||||
| Implemented RFCs | ||||
|  | @ -81,7 +80,7 @@ Toolchain changes | |||
| 
 | ||||
| * Added: ``Simulator.add_testbench``. (`RFC 27`_) | ||||
| * Deprecated: ``Settle`` simulation command. (`RFC 27`_) | ||||
| * Deprecated: ``Simulator.add_process``. (`RFC 27`_) | ||||
| * Deprecated: ``Simulator.add_sync_process``. (`RFC 27`_) | ||||
| * Removed: (deprecated in 0.4) use of mixed-case toolchain environment variable names, such as ``NMIGEN_ENV_Diamond`` or ``AMARANTH_ENV_Diamond``; use upper-case environment variable names, such as ``AMARANTH_ENV_DIAMOND``. | ||||
| 
 | ||||
| 
 | ||||
|  |  | |||
|  | @ -23,12 +23,12 @@ print(verilog.convert(ctr, ports=[ctr.o, ctr.en])) | |||
| sim = Simulator(ctr) | ||||
| sim.add_clock(1e-6) | ||||
| def ce_proc(): | ||||
|     yield; yield; yield | ||||
|     yield Tick(); yield Tick(); yield Tick() | ||||
|     yield ctr.en.eq(1) | ||||
|     yield; yield; yield | ||||
|     yield Tick(); yield Tick(); yield Tick() | ||||
|     yield ctr.en.eq(0) | ||||
|     yield; yield; yield | ||||
|     yield Tick(); yield Tick(); yield Tick() | ||||
|     yield ctr.en.eq(1) | ||||
| sim.add_sync_process(ce_proc) | ||||
| sim.add_testbench(ce_proc) | ||||
| with sim.write_vcd("ctrl.vcd", "ctrl.gtkw", traces=[ctr.en, ctr.v, ctr.o]): | ||||
|     sim.run_until(100e-6, run_passive=True) | ||||
|  |  | |||
|  | @ -26,13 +26,13 @@ class FFSynchronizerTestCase(FHDLTestCase): | |||
|         def process(): | ||||
|             self.assertEqual((yield o), 0) | ||||
|             yield i.eq(1) | ||||
|             yield | ||||
|             yield Tick() | ||||
|             self.assertEqual((yield o), 0) | ||||
|             yield | ||||
|             yield Tick() | ||||
|             self.assertEqual((yield o), 0) | ||||
|             yield | ||||
|             yield Tick() | ||||
|             self.assertEqual((yield o), 1) | ||||
|         sim.add_sync_process(process) | ||||
|         sim.add_process(process) | ||||
|         sim.run() | ||||
| 
 | ||||
|     def test_reset_value(self): | ||||
|  | @ -45,13 +45,13 @@ class FFSynchronizerTestCase(FHDLTestCase): | |||
|         def process(): | ||||
|             self.assertEqual((yield o), 1) | ||||
|             yield i.eq(0) | ||||
|             yield | ||||
|             yield Tick() | ||||
|             self.assertEqual((yield o), 1) | ||||
|             yield | ||||
|             yield Tick() | ||||
|             self.assertEqual((yield o), 1) | ||||
|             yield | ||||
|             yield Tick() | ||||
|             self.assertEqual((yield o), 0) | ||||
|         sim.add_sync_process(process) | ||||
|         sim.add_process(process) | ||||
|         sim.run() | ||||
| 
 | ||||
| 
 | ||||
|  | @ -221,17 +221,17 @@ class PulseSynchronizerTestCase(FHDLTestCase): | |||
|             yield ps.i.eq(0) | ||||
|             # TODO: think about reset | ||||
|             for n in range(5): | ||||
|                 yield | ||||
|                 yield Tick() | ||||
|             # Make sure no pulses are generated in quiescent state | ||||
|             for n in range(3): | ||||
|                 yield | ||||
|                 yield Tick() | ||||
|                 self.assertEqual((yield ps.o), 0) | ||||
|             # Check conservation of pulses | ||||
|             accum = 0 | ||||
|             for n in range(10): | ||||
|                 yield ps.i.eq(1 if n < 4 else 0) | ||||
|                 yield | ||||
|                 yield Tick() | ||||
|                 accum += yield ps.o | ||||
|             self.assertEqual(accum, 4) | ||||
|         sim.add_sync_process(process) | ||||
|         sim.add_process(process) | ||||
|         sim.run() | ||||
|  |  | |||
|  | @ -243,13 +243,13 @@ class CRCTestCase(unittest.TestCase): | |||
|                     yield crc.start.eq(word == b"1") | ||||
|                     yield crc.data.eq(word) | ||||
|                     yield crc.valid.eq(1) | ||||
|                     yield | ||||
|                     yield Tick() | ||||
|                 yield crc.valid.eq(0) | ||||
|                 yield | ||||
|                 yield Tick() | ||||
|                 self.assertEqual((yield crc.crc), check) | ||||
| 
 | ||||
|             sim = Simulator(crc) | ||||
|             sim.add_sync_process(process) | ||||
|             sim.add_testbench(process) | ||||
|             sim.add_clock(1e-6) | ||||
|             sim.run() | ||||
| 
 | ||||
|  | @ -283,18 +283,18 @@ class CRCTestCase(unittest.TestCase): | |||
| 
 | ||||
|                 def process(): | ||||
|                     yield crc.start.eq(1) | ||||
|                     yield | ||||
|                     yield Tick() | ||||
|                     yield crc.start.eq(0) | ||||
|                     for word in words: | ||||
|                         yield crc.data.eq(word) | ||||
|                         yield crc.valid.eq(1) | ||||
|                         yield | ||||
|                         yield Tick() | ||||
|                     yield crc.valid.eq(0) | ||||
|                     yield | ||||
|                     yield Tick() | ||||
|                     self.assertEqual((yield crc.crc), check) | ||||
| 
 | ||||
|                 sim = Simulator(crc) | ||||
|                 sim.add_sync_process(process) | ||||
|                 sim.add_testbench(process) | ||||
|                 sim.add_clock(1e-6) | ||||
|                 sim.run() | ||||
| 
 | ||||
|  | @ -334,17 +334,17 @@ class CRCTestCase(unittest.TestCase): | |||
| 
 | ||||
|             def process(): | ||||
|                 yield crc.start.eq(1) | ||||
|                 yield | ||||
|                 yield Tick() | ||||
|                 yield crc.start.eq(0) | ||||
|                 for word in words: | ||||
|                     yield crc.data.eq(word) | ||||
|                     yield crc.valid.eq(1) | ||||
|                     yield | ||||
|                     yield Tick() | ||||
|                 yield crc.valid.eq(0) | ||||
|                 yield | ||||
|                 yield Tick() | ||||
|                 self.assertTrue((yield crc.match_detected)) | ||||
| 
 | ||||
|             sim = Simulator(crc) | ||||
|             sim.add_sync_process(process) | ||||
|             sim.add_testbench(process) | ||||
|             sim.add_clock(1e-6) | ||||
|             sim.run() | ||||
|  |  | |||
|  | @ -325,7 +325,7 @@ class AsyncFIFOSimCase(FHDLTestCase): | |||
|             for i in range(10): | ||||
|                 yield fifo.w_data.eq(i) | ||||
|                 yield fifo.w_en.eq(1) | ||||
|                 yield | ||||
|                 yield Tick() | ||||
| 
 | ||||
|                 if (i - ff_syncronizer_latency) > 0: | ||||
|                     self.assertEqual((yield fifo.r_level), i - ff_syncronizer_latency) | ||||
|  | @ -334,7 +334,7 @@ class AsyncFIFOSimCase(FHDLTestCase): | |||
| 
 | ||||
|         simulator = Simulator(fifo) | ||||
|         simulator.add_clock(100e-6) | ||||
|         simulator.add_sync_process(testbench) | ||||
|         simulator.add_process(testbench) | ||||
|         simulator.run() | ||||
| 
 | ||||
|     def check_async_fifo_level(self, fifo, fill_in, expected_level, read=False): | ||||
|  | @ -344,10 +344,9 @@ class AsyncFIFOSimCase(FHDLTestCase): | |||
|             for i in range(fill_in): | ||||
|                 yield fifo.w_data.eq(i) | ||||
|                 yield fifo.w_en.eq(1) | ||||
|                 yield | ||||
|                 yield Tick("write") | ||||
|             yield fifo.w_en.eq(0) | ||||
|             yield | ||||
|             yield | ||||
|             yield Tick ("write") | ||||
|             self.assertEqual((yield fifo.w_level), expected_level) | ||||
|             yield write_done.eq(1) | ||||
| 
 | ||||
|  | @ -355,14 +354,14 @@ class AsyncFIFOSimCase(FHDLTestCase): | |||
|             if read: | ||||
|                 yield fifo.r_en.eq(1) | ||||
|             while not (yield write_done): | ||||
|                 yield | ||||
|                 yield Tick("read") | ||||
|             self.assertEqual((yield fifo.r_level), expected_level) | ||||
| 
 | ||||
|         simulator = Simulator(fifo) | ||||
|         simulator.add_clock(100e-6, domain="write") | ||||
|         simulator.add_sync_process(write_process, domain="write") | ||||
|         simulator.add_testbench(write_process) | ||||
|         simulator.add_clock(50e-6, domain="read") | ||||
|         simulator.add_sync_process(read_process, domain="read") | ||||
|         simulator.add_testbench(read_process) | ||||
|         with simulator.write_vcd("test.vcd"): | ||||
|             simulator.run() | ||||
| 
 | ||||
|  |  | |||
|  | @ -435,29 +435,30 @@ class SimulatorIntegrationTestCase(FHDLTestCase): | |||
| 
 | ||||
|     def test_counter_process(self): | ||||
|         self.setUp_counter() | ||||
|         with _ignore_deprecated(): | ||||
|             with self.assertSimulation(self.m) as sim: | ||||
|                 def process(): | ||||
|                     self.assertEqual((yield self.count), 4) | ||||
|         with self.assertSimulation(self.m) as sim: | ||||
|             def process(): | ||||
|                 self.assertEqual((yield self.count), 4) | ||||
|                 yield Delay(1e-6) | ||||
|                 self.assertEqual((yield self.count), 4) | ||||
|                 yield self.sync.clk.eq(1) | ||||
|                 self.assertEqual((yield self.count), 4) | ||||
|                 with _ignore_deprecated(): | ||||
|                     yield Settle() | ||||
|                 self.assertEqual((yield self.count), 5) | ||||
|                 yield Delay(1e-6) | ||||
|                 self.assertEqual((yield self.count), 5) | ||||
|                 yield self.sync.clk.eq(0) | ||||
|                 self.assertEqual((yield self.count), 5) | ||||
|                 with _ignore_deprecated(): | ||||
|                     yield Settle() | ||||
|                 self.assertEqual((yield self.count), 5) | ||||
|                 for _ in range(3): | ||||
|                     yield Delay(1e-6) | ||||
|                     self.assertEqual((yield self.count), 4) | ||||
|                     yield self.sync.clk.eq(1) | ||||
|                     self.assertEqual((yield self.count), 4) | ||||
|                     yield Settle() | ||||
|                     self.assertEqual((yield self.count), 5) | ||||
|                     yield Delay(1e-6) | ||||
|                     self.assertEqual((yield self.count), 5) | ||||
|                     yield self.sync.clk.eq(0) | ||||
|                     self.assertEqual((yield self.count), 5) | ||||
|                     yield Settle() | ||||
|                     self.assertEqual((yield self.count), 5) | ||||
|                     for _ in range(3): | ||||
|                         yield Delay(1e-6) | ||||
|                         yield self.sync.clk.eq(1) | ||||
|                         yield Delay(1e-6) | ||||
|                         yield self.sync.clk.eq(0) | ||||
|                     self.assertEqual((yield self.count), 0) | ||||
|                 sim.add_process(process) | ||||
|                 self.assertEqual((yield self.count), 0) | ||||
|             sim.add_process(process) | ||||
| 
 | ||||
|     def test_counter_clock_and_sync_process(self): | ||||
|         self.setUp_counter() | ||||
|  | @ -472,7 +473,8 @@ class SimulatorIntegrationTestCase(FHDLTestCase): | |||
|                 for _ in range(3): | ||||
|                     yield | ||||
|                 self.assertEqual((yield self.count), 0) | ||||
|             sim.add_sync_process(process) | ||||
|             with _ignore_deprecated(): | ||||
|                 sim.add_sync_process(process) | ||||
| 
 | ||||
|     def test_reset(self): | ||||
|         self.setUp_counter() | ||||
|  | @ -481,14 +483,15 @@ class SimulatorIntegrationTestCase(FHDLTestCase): | |||
|         times = 0 | ||||
|         def process(): | ||||
|             nonlocal times | ||||
|             yield Tick() | ||||
|             self.assertEqual((yield self.count), 4) | ||||
|             yield | ||||
|             yield Tick() | ||||
|             self.assertEqual((yield self.count), 5) | ||||
|             yield | ||||
|             yield Tick() | ||||
|             self.assertEqual((yield self.count), 6) | ||||
|             yield | ||||
|             yield Tick() | ||||
|             times += 1 | ||||
|         sim.add_sync_process(process) | ||||
|         sim.add_process(process) | ||||
|         sim.run() | ||||
|         sim.reset() | ||||
|         sim.run() | ||||
|  | @ -520,19 +523,37 @@ class SimulatorIntegrationTestCase(FHDLTestCase): | |||
|             def process(): | ||||
|                 yield self.a.eq(5) | ||||
|                 yield self.b.eq(1) | ||||
|                 yield | ||||
|                 yield Tick() | ||||
|                 self.assertEqual((yield self.x), 4) | ||||
|                 yield | ||||
|                 yield Tick() | ||||
|                 self.assertEqual((yield self.o), 6) | ||||
|                 yield self.s.eq(1) | ||||
|                 yield | ||||
|                 yield | ||||
|                 yield Tick() | ||||
|                 yield Tick() | ||||
|                 self.assertEqual((yield self.o), 4) | ||||
|                 yield self.s.eq(2) | ||||
|                 yield | ||||
|                 yield | ||||
|                 yield Tick() | ||||
|                 yield Tick() | ||||
|                 self.assertEqual((yield self.o), 0) | ||||
|             sim.add_sync_process(process) | ||||
|             sim.add_process(process) | ||||
| 
 | ||||
|     def test_alu_bench(self): | ||||
|         self.setUp_alu() | ||||
|         with self.assertSimulation(self.m) as sim: | ||||
|             sim.add_clock(1e-6) | ||||
|             def process(): | ||||
|                 yield self.a.eq(5) | ||||
|                 yield self.b.eq(1) | ||||
|                 self.assertEqual((yield self.x), 4) | ||||
|                 yield Tick() | ||||
|                 self.assertEqual((yield self.o), 6) | ||||
|                 yield self.s.eq(1) | ||||
|                 yield Tick() | ||||
|                 self.assertEqual((yield self.o), 4) | ||||
|                 yield self.s.eq(2) | ||||
|                 yield Tick() | ||||
|                 self.assertEqual((yield self.o), 0) | ||||
|             sim.add_testbench(process) | ||||
| 
 | ||||
|     def setUp_clock_phase(self): | ||||
|         self.m = Module() | ||||
|  | @ -543,10 +564,10 @@ class SimulatorIntegrationTestCase(FHDLTestCase): | |||
|         self.check = self.m.domains.check = ClockDomain() | ||||
| 
 | ||||
|         self.expected = [ | ||||
|             [0, 0, 0, 1, 1, 1, 1, 0, 0, 0, 0, 1, 1, 1, 1, 0, 0], | ||||
|             [0, 0, 0, 0, 0, 1, 1, 1, 1, 0, 0, 0, 0, 1, 1, 1, 1], | ||||
|             [0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 0, 0, 0, 0, 1, 1], | ||||
|             [0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 0, 0, 0, 0], | ||||
|             [0, 0, 0, 0, 1, 1, 1, 1, 0, 0, 0, 0, 1, 1, 1, 1, 0, 0], | ||||
|             [0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 0, 0, 0, 0, 1, 1, 1, 1], | ||||
|             [0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 0, 0, 0, 0, 1, 1], | ||||
|             [0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 0, 0, 0, 0], | ||||
|         ] | ||||
| 
 | ||||
|     def test_clock_phase(self): | ||||
|  | @ -567,11 +588,11 @@ class SimulatorIntegrationTestCase(FHDLTestCase): | |||
|                     self.phase270.clk | ||||
|                 ] | ||||
|                 for i in range(16): | ||||
|                     yield | ||||
|                     yield Tick("check") | ||||
|                     for j, c in enumerate(clocks): | ||||
|                         self.assertEqual((yield c), self.expected[j][i]) | ||||
| 
 | ||||
|             sim.add_sync_process(proc, domain="check") | ||||
|             sim.add_process(proc) | ||||
| 
 | ||||
|     def setUp_multiclock(self): | ||||
|         self.sys = ClockDomain() | ||||
|  | @ -588,15 +609,15 @@ class SimulatorIntegrationTestCase(FHDLTestCase): | |||
| 
 | ||||
|             def sys_process(): | ||||
|                 yield Passive() | ||||
|                 yield | ||||
|                 yield | ||||
|                 yield Tick("sys") | ||||
|                 yield Tick("sys") | ||||
|                 self.fail() | ||||
|             def pix_process(): | ||||
|                 yield | ||||
|                 yield | ||||
|                 yield | ||||
|             sim.add_sync_process(sys_process, domain="sys") | ||||
|             sim.add_sync_process(pix_process, domain="pix") | ||||
|                 yield Tick("pix") | ||||
|                 yield Tick("pix") | ||||
|                 yield Tick("pix") | ||||
|             sim.add_testbench(sys_process) | ||||
|             sim.add_testbench(pix_process) | ||||
| 
 | ||||
|     def setUp_lhs_rhs(self): | ||||
|         self.i = Signal(8) | ||||
|  | @ -644,7 +665,7 @@ class SimulatorIntegrationTestCase(FHDLTestCase): | |||
|         with self.assertSimulation(Module()) as sim: | ||||
|             with self.assertRaisesRegex(TypeError, | ||||
|                     r"^Cannot add a process 1 because it is not a generator function$"): | ||||
|                 sim.add_sync_process(1) | ||||
|                 sim.add_process(1) | ||||
| 
 | ||||
|     def test_add_process_wrong_generator(self): | ||||
|         with self.assertSimulation(Module()) as sim: | ||||
|  | @ -652,7 +673,7 @@ class SimulatorIntegrationTestCase(FHDLTestCase): | |||
|                     r"^Cannot add a process <.+?> because it is not a generator function$"): | ||||
|                 def process(): | ||||
|                     yield Delay() | ||||
|                 sim.add_sync_process(process()) | ||||
|                 sim.add_process(process()) | ||||
| 
 | ||||
|     def test_add_clock_wrong_twice(self): | ||||
|         m = Module() | ||||
|  | @ -678,31 +699,14 @@ class SimulatorIntegrationTestCase(FHDLTestCase): | |||
| 
 | ||||
|     def test_command_wrong(self): | ||||
|         survived = False | ||||
|         with _ignore_deprecated(): | ||||
|             with self.assertSimulation(Module()) as sim: | ||||
|                 def process(): | ||||
|                     nonlocal survived | ||||
|                     with self.assertRaisesRegex(TypeError, | ||||
|                             r"Received unsupported command 1 from process .+?"): | ||||
|                         yield 1 | ||||
|                     survived = True | ||||
|                 sim.add_process(process) | ||||
|         self.assertTrue(survived) | ||||
| 
 | ||||
|     def test_sync_command_deprecated(self): | ||||
|         survived = False | ||||
|         m = Module() | ||||
|         dummy = Signal() | ||||
|         m.d.sync += dummy.eq(1) | ||||
|         with self.assertSimulation(m) as sim: | ||||
|         with self.assertSimulation(Module()) as sim: | ||||
|             def process(): | ||||
|                 nonlocal survived | ||||
|                 with self.assertWarnsRegex(DeprecationWarning, | ||||
|                         r"Using `Delay` is deprecated within `add_sync_process`"): | ||||
|                     yield Delay(1e-8) | ||||
|                 with self.assertRaisesRegex(TypeError, | ||||
|                         r"Received unsupported command 1 from process .+?"): | ||||
|                     yield 1 | ||||
|                 survived = True | ||||
|             sim.add_sync_process(process) | ||||
|             sim.add_clock(1e-6) | ||||
|             sim.add_process(process) | ||||
|         self.assertTrue(survived) | ||||
| 
 | ||||
|     def test_sync_command_wrong(self): | ||||
|  | @ -717,7 +721,8 @@ class SimulatorIntegrationTestCase(FHDLTestCase): | |||
|                         r"Received unsupported command 1 from process .+?"): | ||||
|                     yield 1 | ||||
|                 survived = True | ||||
|             sim.add_sync_process(process) | ||||
|             with _ignore_deprecated(): | ||||
|                 sim.add_sync_process(process) | ||||
|             sim.add_clock(1e-6) | ||||
|         self.assertTrue(survived) | ||||
| 
 | ||||
|  | @ -762,15 +767,13 @@ class SimulatorIntegrationTestCase(FHDLTestCase): | |||
|         with self.assertSimulation(self.m) as sim: | ||||
|             def process(): | ||||
|                 yield self.rdport.addr.eq(1) | ||||
|                 yield | ||||
|                 yield | ||||
|                 yield Tick() | ||||
|                 self.assertEqual((yield self.rdport.data), 0x55) | ||||
|                 yield self.rdport.addr.eq(2) | ||||
|                 yield | ||||
|                 yield | ||||
|                 yield Tick() | ||||
|                 self.assertEqual((yield self.rdport.data), 0x00) | ||||
|             sim.add_clock(1e-6) | ||||
|             sim.add_sync_process(process) | ||||
|             sim.add_testbench(process) | ||||
| 
 | ||||
|     def test_memory_write(self): | ||||
|         self.setUp_memory() | ||||
|  | @ -779,13 +782,13 @@ class SimulatorIntegrationTestCase(FHDLTestCase): | |||
|                 yield self.wrport.addr.eq(4) | ||||
|                 yield self.wrport.data.eq(0x33) | ||||
|                 yield self.wrport.en.eq(1) | ||||
|                 yield | ||||
|                 yield Tick() | ||||
|                 yield self.wrport.en.eq(0) | ||||
|                 yield self.rdport.addr.eq(4) | ||||
|                 yield | ||||
|                 yield Tick() | ||||
|                 self.assertEqual((yield self.rdport.data), 0x33) | ||||
|             sim.add_clock(1e-6) | ||||
|             sim.add_sync_process(process) | ||||
|             sim.add_testbench(process) | ||||
| 
 | ||||
|     def test_memory_write_granularity(self): | ||||
|         self.setUp_memory(wr_granularity=4) | ||||
|  | @ -864,14 +867,13 @@ class SimulatorIntegrationTestCase(FHDLTestCase): | |||
|         self.m.submodules.rdport = self.rdport = self.memory.read_port() | ||||
|         with self.assertSimulation(self.m) as sim: | ||||
|             def process(): | ||||
|                 yield | ||||
|                 yield Tick() | ||||
|                 self.assertEqual((yield self.rdport.data), 0xaa) | ||||
|                 yield self.rdport.addr.eq(1) | ||||
|                 yield | ||||
|                 yield | ||||
|                 yield Tick() | ||||
|                 self.assertEqual((yield self.rdport.data), 0x55) | ||||
|             sim.add_clock(1e-6) | ||||
|             sim.add_sync_process(process) | ||||
|             sim.add_testbench(process) | ||||
| 
 | ||||
|     def test_comb_bench_process(self): | ||||
|         m = Module() | ||||
|  | @ -1022,11 +1024,11 @@ class SimulatorIntegrationTestCase(FHDLTestCase): | |||
|                 self.assertEqual((yield self.memory[Const(2)]), 0x00) | ||||
|                 yield self.memory[Const(1)].eq(Const(0x33)) | ||||
|                 self.assertEqual((yield self.memory[Const(1)]), 0x55) | ||||
|                 yield | ||||
|                 yield Tick() | ||||
|                 self.assertEqual((yield self.memory[Const(1)]), 0x33) | ||||
| 
 | ||||
|             sim.add_clock(1e-6) | ||||
|             sim.add_sync_process(process) | ||||
|             sim.add_process(process) | ||||
| 
 | ||||
|     def test_vcd_wrong_nonzero_time(self): | ||||
|         s = Signal() | ||||
|  |  | |||
		Loading…
	
		Reference in a new issue
	
	 Wanda
						Wanda