aboutsummaryrefslogtreecommitdiffstats
path: root/backends/smt2/witness.py
diff options
context:
space:
mode:
authorJannis Harder <me@jix.one>2023-01-10 17:04:06 +0100
committerJannis Harder <me@jix.one>2023-01-11 18:07:16 +0100
commit7ddec5093f09640db0f502dfa341c25e4028563f (patch)
treeb37cd73756a4822ab403696de3333ea14eaea1cb /backends/smt2/witness.py
parent636b9f27052ef67192ee55a862c31e57a1ccad79 (diff)
downloadyosys-7ddec5093f09640db0f502dfa341c25e4028563f.tar.gz
yosys-7ddec5093f09640db0f502dfa341c25e4028563f.tar.bz2
yosys-7ddec5093f09640db0f502dfa341c25e4028563f.zip
sim: Improvements and fixes for yw cosim
* Fixed $cover handling * Improved sparse memory handling when writing traces * JSON summary output
Diffstat (limited to 'backends/smt2/witness.py')
-rw-r--r--backends/smt2/witness.py71
1 files changed, 48 insertions, 23 deletions
diff --git a/backends/smt2/witness.py b/backends/smt2/witness.py
index 14cf61fd7..8d0cc8112 100644
--- a/backends/smt2/witness.py
+++ b/backends/smt2/witness.py
@@ -316,6 +316,7 @@ def wit2yw(input, mapfile, output):
if current_t > t:
t = current_t
values = WitnessValues()
+ array_inits = set()
frames.append(values)
line = next(input, None)
@@ -327,39 +328,63 @@ def wit2yw(input, mapfile, output):
line = next(input, None)
btor_sig = btor_map.data[mode][int(tokens[0])]
+ btor_sigs = [btor_sig]
if btor_sig is None:
continue
if isinstance(btor_sig, dict):
addr = tokens[1]
- if not addr.startswith('[') or not addr.endswith(']'):
+ if not addr.startswith('['):
+ addr = '[*]'
+ value = tokens[1]
+ else:
+ value = tokens[2]
+ if not addr.endswith(']'):
raise click.ClickException(f"{input_name}: expected address in BTOR witness file")
- addr = int(addr[1:-1], 2)
+ path = btor_sig["path"]
+ width = btor_sig["width"]
+ size = btor_sig["size"]
+ if addr == '[*]':
+ btor_sigs = [
+ [{
+ "path": (*path, f"\\[{addr}]"),
+ "width": width,
+ "offset": 0,
+ }]
+ for addr in range(size)
+ if (path, addr) not in array_inits
+ ]
+ array_inits.update((path, addr) for addr in range(size))
+ else:
+ addr = int(addr[1:-1], 2)
+
+ if addr < 0 or addr >= size:
+ raise click.ClickException(f"{input_name}: out of bounds address in BTOR witness file")
+
+ array_inits.add((path, addr))
+ btor_sig = [{
+ "path": (*path, f"\\[{addr}]"),
+ "width": width,
+ "offset": 0,
+ }]
+ btor_sigs = [btor_sig]
+ else:
+ value = tokens[1]
- if addr < 0 or addr >= btor_sig["size"]:
- raise click.ClickException(f"{input_name}: out of bounds address in BTOR witness file")
+ for btor_sig in btor_sigs:
+ value_bits = iter(reversed(value))
- btor_sig = [{
- "path": (*btor_sig["path"], f"\\[{addr}]"),
- "width": btor_sig["width"],
- "offset": 0,
- }]
+ for chunk in btor_sig:
+ offset = chunk["offset"]
+ path = chunk["path"]
+ for i in range(offset, offset + chunk["width"]):
+ key = (path, i)
+ bits[key] = mode == "inputs"
+ values[key] = next(value_bits)
- signal_value = iter(reversed(tokens[2]))
- else:
- signal_value = iter(reversed(tokens[1]))
-
- for chunk in btor_sig:
- offset = chunk["offset"]
- path = chunk["path"]
- for i in range(offset, offset + chunk["width"]):
- key = (path, i)
- bits[key] = mode == "inputs"
- values[key] = next(signal_value)
-
- if next(signal_value, None) is not None:
- raise click.ClickException(f"{input_name}: excess bits in BTOR witness file")
+ if next(value_bits, None) is not None:
+ raise click.ClickException(f"{input_name}: excess bits in BTOR witness file")
if line is None: