Add script for merging regs
This commit is contained in:
parent
aa9257548c
commit
332fc1728b
File diff suppressed because it is too large
Load Diff
67
merge_regs.py
Normal file
67
merge_regs.py
Normal 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))
|
Loading…
x
Reference in New Issue
Block a user