Add script for merging regs

This commit is contained in:
Ulf Lilleengen 2021-06-03 14:02:53 +02:00
parent aa9257548c
commit 332fc1728b
2 changed files with 2096 additions and 4348 deletions

File diff suppressed because it is too large Load Diff

67
merge_regs.py Normal file
View File

@ -0,0 +1,67 @@
import xmltodict
import yaml
import re
import json
import sys
import os
from collections import OrderedDict
from glob import glob
def item_key(a):
return int(a["byte_offset"])
def field_key(a):
return int(a["bit_offset"])
def block_items(origin, new):
newarr=[]
sorted(origin, key=item_key)
sorted(new, key=item_key)
for val in origin:
for newval in new:
if val["name"] == newval["name"] and val["byte_offset"] == newval["byte_offset"] and val["fieldset"] == newval["fieldset"]:
newarr.append(newval)
return newarr
def reg_fields(origin, new):
newarr=[]
sorted(origin, key=field_key)
sorted(new, key=field_key)
for val in origin:
for newval in new:
if val["name"] == newval["name"] and val["bit_offset"] == newval["bit_offset"]:
newarr.append(newval)
return newarr
def merge_dicts(origin, new):
merged={}
for k, v in origin.items():
if k in new:
if type(v) is dict:
merged[k] = merge_dicts(v, new[k])
elif type(v) is list:
if k == "items":
merged[k] = block_items(v, new[k])
if k == "fields":
merged[k] = reg_fields(v, new[k])
else:
merged[k] = v
return merged
first=True
reg_map={}
for regfile in sys.argv[1:]:
print("Loading", regfile)
with open(regfile, 'r') as f:
y = yaml.load(f, Loader=yaml.SafeLoader)
if not reg_map:
reg_map = y
else:
reg_map = merge_dicts(reg_map, y)
with open('regs_merged.yaml', 'w') as f:
f.write(yaml.dump(reg_map))