Merge pull request #248 from mcmasterg/parsedb

parsedb tool, pushdb uses parsedb
This commit is contained in:
John McMaster 2018-11-12 16:43:35 -08:00 committed by GitHub
commit 014b84741d
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
5 changed files with 77 additions and 16 deletions

View File

@ -71,3 +71,23 @@ def db_root_arg(parser):
db_root_kwargs['required'] = False
db_root_kwargs['default'] = os.path.join(database_dir, database)
parser.add_argument('--db-root', help="Database root.", **db_root_kwargs)
def parse_db_line(line):
parts = line.split()
# Ex: CLBLL_L.SLICEL_X0.AMUX.A5Q
assert len(parts), "Empty line"
tag = parts[0]
assert re.match(r'[A-Z0-9_.]+',
tag), "Invalid tag name: %s, line: %s" % (tag, line)
orig_bits = line.replace(tag + " ", "")
# <0 candidates> etc
if "<" in orig_bits:
return tag, set(), orig_bits
# Ex: !30_06 !30_08 !30_11 30_07
bits = frozenset(parts[1:])
for bit in bits:
assert re.match(
r'[!]*[0-9][0-9]_[0-9][0-9]', bit), "Invalid bit: %s" % bit
return tag, bits, None

View File

@ -17,20 +17,6 @@ clb_int_zero_db = [
]
def parse_line(line):
parts = line.split()
# Ex: CLBLL_L.SLICEL_X0.AMUX.A5Q
tag = parts[0]
orig_bits = line.replace(tag + " ", "")
# <0 candidates> etc
if "<" in orig_bits:
return tag, set(), orig_bits
# Ex: !30_06 !30_08 !30_11 30_07
bits = set(parts[1:])
return tag, bits, None
def zero_range(bits, wordmin, wordmax):
"""
If any bits occur wordmin <= word <= wordmax,
@ -134,7 +120,7 @@ def add_zero_bits(fn_in, fn_out, zero_db, clb_int=False, verbose=False):
if line == llast:
continue
tag, bits, mode = parse_line(line)
tag, bits, mode = util.parse_db_line(line)
assert mode not in (
"<const0>",
"<const1>"), "Entries must be resolved. line: %s" % (line, )
@ -146,6 +132,7 @@ def add_zero_bits(fn_in, fn_out, zero_db, clb_int=False, verbose=False):
"""
if clb_int:
zero_range(bits, 22, 25)
bits = set(bits)
zero_groups(
tag, bits, zero_db, strict=not clb_int, verbose=verbose)

View File

@ -26,4 +26,5 @@ export XRAY_BITS2FASM="python3 ${XRAY_UTILS_DIR}/bits2fasm.py"
export XRAY_FASM2FRAMES="python3 ${XRAY_UTILS_DIR}/fasm2frames.py"
export XRAY_BITTOOL="${XRAY_TOOLS_DIR}/bittool"
export XRAY_BLOCKWIDTH="python3 ${XRAY_UTILS_DIR}/blockwidth.py"
export XRAY_PARSEDB="python3 ${XRAY_UTILS_DIR}/parsedb.py"

View File

@ -71,6 +71,6 @@ esac
touch "$db"
sort -u "$tmp1" "$db" | grep -v '<.*>' > "$tmp2" || true
mv "$tmp2" "$db"
${XRAY_PARSEDB} --strict "$tmp2" "$db"
rm -f "$tmp1"

53
utils/parsedb.py Executable file
View File

@ -0,0 +1,53 @@
#!/usr/bin/env python3
from prjxray import util
def run(fnin, fnout=None, strict=False, verbose=False):
lines = open(fnin, 'r').read().split('\n')
tags = set()
bitss = set()
for line in lines:
line = line.strip()
if line == '':
continue
tag, bits, mode = util.parse_db_line(line)
if strict:
assert not mode, "strict: got ill defined line: %s" % (line, )
assert tag not in tags, "strict: got duplicate tag %s (ex: %s)" % (
tag, line)
assert bits not in bitss, "strict: got duplicate bits %s (ex: %s)" % (
bits, line)
tags.add(tag)
bitss.add(bits)
if fnout:
with open(fnout, "w") as fout:
for line in sorted(lines):
line = line.strip()
if line == '':
continue
fout.write(line + '\n')
def main():
import argparse
parser = argparse.ArgumentParser(
description="Parse a db, check for consistency")
util.db_root_arg(parser)
parser.add_argument('--verbose', action='store_true', help='')
parser.add_argument(
'--strict',
action='store_true',
help='Complain on unresolved entries (ex: <0 candidates>, <const0>)')
parser.add_argument('fin', help='')
parser.add_argument('fout', nargs='?', help='')
args = parser.parse_args()
run(args.fin, args.fout, strict=args.strict, verbose=args.verbose)
if __name__ == '__main__':
main()