005-tilegrid/add_tdb.py: added frame check

This solves issue #481. add_tdb.py now checks if all the bits in a same
tag have the same base address and, if that is the case, the first of
them is selected

Signed-off-by: Alessandro Comodi <acomodi@antmicro.com>
This commit is contained in:
Alessandro Comodi 2019-01-10 11:43:53 +01:00
parent 08aaa19551
commit b4ca31cd1e
1 changed files with 19 additions and 4 deletions

View File

@ -52,18 +52,33 @@ def parse_addr(line):
return frame, wordidx, bitidx
def check_frames(frames):
baseaddr = set()
for frame in frames:
baseaddr.add(round(frame / 128))
assert len(baseaddr) == 1, "Multiple base addresses for the same tag"
def load_db(fn):
for l in open(fn, "r"):
l = l.strip()
# FIXME: add offset to name
# IOB_X0Y101.DFRAME:27.DWORD:3.DBIT:3 00020027_003_03
parts = l.split(' ')
# FIXME: need to check that all bits in part have same baseaddr, for now only the first bit is taken
#assert len(parts) == 2, "Unresolved bit: %s" % l
tagstr = parts[0]
addrstr = parts[1]
addrlist = parts[1:]
frames = list()
for addrstr in addrlist:
frame, wordidx, bitidx = parse_addr(addrstr)
frames.append(frame)
# Check the frames base addresses
check_frames(frames)
# Take the first bit in the list
frame, wordidx, bitidx = parse_addr(addrlist[0])
frame, wordidx, bitidx = parse_addr(addrstr)
bitidx_up = False
tparts = tagstr.split('.')