2021-08-22 10:32:05 +01:00
|
|
|
#!/usr/bin/env python
|
|
|
|
import sys, lz4, os
|
|
|
|
from struct import unpack as up
|
|
|
|
|
|
|
|
def lz4_compress(data):
|
|
|
|
try:
|
|
|
|
import lz4.block as block
|
|
|
|
except ImportError:
|
|
|
|
block = lz4.LZ4_compress
|
|
|
|
return block.compress(data, 'high_compression', store_size=False)
|
|
|
|
|
|
|
|
def read_file(fn):
|
|
|
|
with open(fn, 'rb') as f:
|
|
|
|
return f.read()
|
|
|
|
|
|
|
|
def write_file(fn, data):
|
|
|
|
with open(fn, 'wb') as f:
|
|
|
|
f.write(data)
|
|
|
|
|
2021-08-23 02:57:09 +01:00
|
|
|
def get_param_size(soc):
|
|
|
|
return {
|
|
|
|
'erista' : 0x768,
|
|
|
|
'mariko' : 0x838,
|
|
|
|
}[soc]
|
|
|
|
|
2021-08-22 10:32:05 +01:00
|
|
|
def main(argc, argv):
|
|
|
|
if argc != 1:
|
|
|
|
print('Usage: %s' % argv[0])
|
|
|
|
return 1
|
|
|
|
params = {
|
|
|
|
'erista' : {},
|
|
|
|
'mariko' : {},
|
|
|
|
}
|
2021-08-23 02:57:09 +01:00
|
|
|
compressed_params = {
|
|
|
|
'erista' : {},
|
|
|
|
'mariko' : {},
|
|
|
|
}
|
2021-08-22 10:32:05 +01:00
|
|
|
for fn in os.listdir('sdram_params/bin'):
|
|
|
|
assert fn.startswith('sdram_params_') and fn.endswith('.bin')
|
|
|
|
(_sdram, _params, soc, _id_bin) = tuple(fn.split('_'))
|
|
|
|
param_id = int(_id_bin[:-len('.bin')])
|
|
|
|
assert soc in params.keys()
|
2021-08-23 02:57:09 +01:00
|
|
|
uncompressed = read_file(os.path.join('sdram_params/bin', fn))
|
|
|
|
assert len(uncompressed) == get_param_size(soc)
|
|
|
|
params[soc][param_id] = uncompressed
|
|
|
|
for soc in ('erista', 'mariko'):
|
|
|
|
empty_params = '\x00' * get_param_size(soc)
|
|
|
|
for param_id in xrange(0, max(params[soc].keys()) + 4, 2):
|
|
|
|
param_id_l = param_id
|
|
|
|
param_id_h = param_id + 1
|
|
|
|
if param_id_l in params[soc] or param_id_h in params[soc]:
|
|
|
|
print soc, param_id_l, param_id_h
|
|
|
|
param_l = params[soc][param_id_l] if param_id_l in params[soc] else empty_params
|
|
|
|
param_h = params[soc][param_id_h] if param_id_h in params[soc] else empty_params
|
|
|
|
compressed = lz4_compress(param_l + param_h)
|
|
|
|
compressed_params[soc][(param_id_l, param_id_h)] = compressed
|
|
|
|
write_file(os.path.join('sdram_params/lz', 'sdram_params_%s_%d_%d.lz4' % (soc, param_id_l, param_id_h)), compressed)
|
2021-08-24 05:15:51 +01:00
|
|
|
with open('source/sdram/fusee_sdram_params.inc', 'w') as f:
|
2021-08-22 10:32:05 +01:00
|
|
|
f.write('%s\n' % "/*")
|
|
|
|
f.write('%s\n' % " * Copyright (c) 2018-2020 Atmosph\xc3re-NX")
|
|
|
|
f.write('%s\n' % " *")
|
|
|
|
f.write('%s\n' % " * This program is free software; you can redistribute it and/or modify it")
|
|
|
|
f.write('%s\n' % " * under the terms and conditions of the GNU General Public License,")
|
|
|
|
f.write('%s\n' % " * version 2, as published by the Free Software Foundation.")
|
|
|
|
f.write('%s\n' % " *")
|
|
|
|
f.write('%s\n' % " * This program is distributed in the hope it will be useful, but WITHOUT")
|
|
|
|
f.write('%s\n' % " * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or")
|
|
|
|
f.write('%s\n' % " * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for")
|
|
|
|
f.write('%s\n' % " * more details.")
|
|
|
|
f.write('%s\n' % " *")
|
|
|
|
f.write('%s\n' % " * You should have received a copy of the GNU General Public License")
|
|
|
|
f.write('%s\n' % " * along with this program. If not, see <http://www.gnu.org/licenses/>.")
|
|
|
|
f.write('%s\n' % " */")
|
|
|
|
f.write('\n')
|
|
|
|
for soc in ('Erista', 'Mariko'):
|
2021-08-23 02:57:09 +01:00
|
|
|
for (param_id_l, param_id_h) in sorted(compressed_params[soc.lower()].keys(), key=lambda (l, h): l):
|
|
|
|
compressed = compressed_params[soc.lower()][(param_id_l, param_id_h)]
|
|
|
|
f.write('%s\n' % ('constexpr inline const u8 SdramParams%s%d_%d[0x%03X] = {' % (soc, param_id_l, param_id_h, len(compressed))))
|
2021-08-22 10:32:05 +01:00
|
|
|
while compressed:
|
|
|
|
block = compressed[:0x10]
|
|
|
|
compressed = compressed[0x10:]
|
|
|
|
f.write(' %s\n' % (', '.join('0x%02X' % ord(c) for c in block) + ','))
|
|
|
|
f.write('};\n\n')
|
2021-08-23 02:57:09 +01:00
|
|
|
f.write('%s\n' % ('constexpr inline const u8 * const SdramParams%s%d = SdramParams%s%d_%d;' % (soc, param_id_l, soc, param_id_l, param_id_h)))
|
|
|
|
f.write('%s\n' % ('constexpr inline const size_t SdramParamsSize%s%d = sizeof(SdramParams%s%d_%d);' % (soc, param_id_l, soc, param_id_l, param_id_h)))
|
|
|
|
f.write('\n')
|
|
|
|
f.write('%s\n' % ('constexpr inline const u8 * const SdramParams%s%d = SdramParams%s%d_%d;' % (soc, param_id_h, soc, param_id_l, param_id_h)))
|
|
|
|
f.write('%s\n' % ('constexpr inline const size_t SdramParamsSize%s%d = sizeof(SdramParams%s%d_%d);' % (soc, param_id_h, soc, param_id_l, param_id_h)))
|
|
|
|
f.write('\n')
|
2021-08-22 10:32:05 +01:00
|
|
|
return 0
|
|
|
|
|
|
|
|
if __name__ == '__main__':
|
|
|
|
sys.exit(main(len(sys.argv), sys.argv))
|