Mem: speed up log_fancy by using make_sim_state_dict()
authorJacob Lifshay <programmerjake@gmail.com>
Sun, 3 Dec 2023 08:46:01 +0000 (00:46 -0800)
committerLuke Kenneth Casson Leighton <lkcl@lkcl.net>
Fri, 22 Dec 2023 19:26:22 +0000 (19:26 +0000)
src/openpower/decoder/isa/mem.py

index a5867f3d3bfa7d4623d75d72b0b8a75aaafcdeae..c4744b879f0bd693be95b24fba3ee7004e20ef97 100644 (file)
@@ -268,10 +268,10 @@ class MemCommon:
             return bytearray(line_size)
         mem_lines = defaultdict(make_line)
         subword_range = range(1 << self.word_log2)
-        for k in self.word_idxs():
-            addr = k << self.word_log2
-            for _ in subword_range:
-                v = self.ld(addr, width=1, reason=_ReadReason.Dump)
+        words = self.make_sim_state_dict()
+        for addr, word in words.items():
+            for i in subword_range:
+                v = (word >> i * 8) & 0xFF
                 mem_lines[addr >> log2_line_size][addr & subline_mask] = v
                 addr += 1