SummerCart64/fw/cpu/bootloader/bin2sv.py

39 lines
1.0 KiB
Python
Raw Normal View History

2021-08-12 21:07:47 +02:00
#!/usr/bin/env python3
import struct
import sys
binary = None
sv_template = None
sv_code = None
binary_name = sys.argv[1] or 'binary.bin'
template_name = sys.argv[2] or 'binary_template.sv'
code_name = sys.argv[3] or 'binary.sv'
try:
binary = open(binary_name, mode='rb')
sv_template = open(template_name, mode='r')
sv_code = open(code_name, mode='w')
var_name = sv_template.readline().strip()
rom_formatted = ''
index = 0
for line in iter(lambda: binary.read(4), ''):
if (not line):
break
value = format(struct.unpack('<I', line)[0], '08x')
2021-08-15 21:49:02 +02:00
rom_formatted += f'\n {index}: {var_name} = 32\'h{value};'
2021-08-12 21:07:47 +02:00
index += 1
sv_code.write(sv_template.read().format(rom_formatted=rom_formatted))
except Exception as e:
print(f'Unable to convert the code: {e}', file=sys.stderr)
sys.exit(-1)
finally:
if (binary): binary.close()
if (sv_template): sv_template.close()
if (sv_code): sv_code.close()