2017-01-09 07:38:20 +03:00
|
|
|
#!/usr/bin/env python
|
|
|
|
# esp32ulp_mapgen utility converts a symbol list provided by nm into an export script
|
|
|
|
# for the linker and a header file.
|
|
|
|
#
|
|
|
|
# Copyright (c) 2016-2017 Espressif Systems (Shanghai) PTE LTD.
|
|
|
|
# Distributed under the terms of Apache License v2.0 found in the top-level LICENSE file.
|
|
|
|
|
2020-11-04 23:32:40 +01:00
|
|
|
from __future__ import print_function
|
2021-01-26 10:49:01 +08:00
|
|
|
|
2020-11-04 23:32:40 +01:00
|
|
|
import sys
|
2021-01-26 10:49:01 +08:00
|
|
|
from optparse import OptionParser
|
2017-01-09 07:38:20 +03:00
|
|
|
|
2018-12-04 13:06:46 +01:00
|
|
|
BASE_ADDR = 0x50000000
|
|
|
|
|
2017-01-09 07:38:20 +03:00
|
|
|
|
|
|
|
def gen_ld_h_from_sym(f_sym, f_ld, f_h):
|
2021-01-26 10:49:01 +08:00
|
|
|
f_ld.write('/* Variable definitions for ESP32ULP linker\n')
|
|
|
|
f_ld.write(' * This file is generated automatically by esp32ulp_mapgen.py utility.\n')
|
|
|
|
f_ld.write(' */\n\n')
|
|
|
|
f_h.write('// Variable definitions for ESP32ULP\n')
|
|
|
|
f_h.write('// This file is generated automatically by esp32ulp_mapgen.py utility\n\n')
|
|
|
|
f_h.write('#pragma once\n\n')
|
2018-12-04 13:06:46 +01:00
|
|
|
|
|
|
|
for line in f_sym:
|
2021-01-26 10:49:01 +08:00
|
|
|
name, _, addr_str = line.split(' ', 2)
|
2020-04-17 16:34:56 -03:00
|
|
|
addr = int(addr_str, 16) + BASE_ADDR
|
2021-01-26 10:49:01 +08:00
|
|
|
f_h.write('extern uint32_t ulp_{0};\n'.format(name))
|
|
|
|
f_ld.write('PROVIDE ( ulp_{0} = 0x{1:08x} );\n'.format(name, addr))
|
2020-04-17 16:34:56 -03:00
|
|
|
|
|
|
|
|
|
|
|
def gen_ld_h_from_sym_riscv(f_sym, f_ld, f_h):
|
2021-01-26 10:49:01 +08:00
|
|
|
f_ld.write('/* Variable definitions for ESP32ULP linker\n')
|
|
|
|
f_ld.write(' * This file is generated automatically by esp32ulp_mapgen.py utility.\n')
|
|
|
|
f_ld.write(' */\n\n')
|
|
|
|
f_h.write('// Variable definitions for ESP32ULP\n')
|
|
|
|
f_h.write('// This file is generated automatically by esp32ulp_mapgen.py utility\n\n')
|
|
|
|
f_h.write('#pragma once\n\n')
|
2020-04-17 16:34:56 -03:00
|
|
|
|
|
|
|
for line in f_sym:
|
|
|
|
addr_str, _, name = line.split()
|
2018-12-04 13:06:46 +01:00
|
|
|
addr = int(addr_str, 16) + BASE_ADDR
|
2021-01-26 10:49:01 +08:00
|
|
|
f_h.write('extern uint32_t ulp_{0};\n'.format(name))
|
|
|
|
f_ld.write('PROVIDE ( ulp_{0} = 0x{1:08x} );\n'.format(name, addr))
|
2017-01-09 07:38:20 +03:00
|
|
|
|
|
|
|
|
|
|
|
def main():
|
2020-11-04 23:32:40 +01:00
|
|
|
if sys.version_info[0] < 3:
|
2021-01-26 10:49:01 +08:00
|
|
|
print('WARNING: Support for Python 2 is deprecated and will be removed in future versions.', file=sys.stderr)
|
2020-11-04 23:32:40 +01:00
|
|
|
elif sys.version_info[0] == 3 and sys.version_info[1] < 6:
|
2021-01-26 10:49:01 +08:00
|
|
|
print('WARNING: Python 3 versions older than 3.6 are not supported.', file=sys.stderr)
|
|
|
|
description = ('This application generates .h and .ld files for symbols defined in input file. '
|
|
|
|
'The input symbols file can be generated using nm utility like this: '
|
|
|
|
'esp32-ulp-nm -g -f posix <elf_file> > <symbols_file>')
|
2017-01-09 07:38:20 +03:00
|
|
|
|
|
|
|
parser = OptionParser(description=description)
|
2021-01-26 10:49:01 +08:00
|
|
|
parser.add_option('-s', '--symfile', dest='symfile',
|
|
|
|
help='symbols file name', metavar='SYMFILE')
|
|
|
|
parser.add_option('-o', '--outputfile', dest='outputfile',
|
|
|
|
help='destination .h and .ld files name prefix', metavar='OUTFILE')
|
2017-01-09 07:38:20 +03:00
|
|
|
|
2021-01-26 10:49:01 +08:00
|
|
|
parser.add_option('--riscv', action='store_true', help='use format for ulp riscv .sym file')
|
2020-04-17 16:34:56 -03:00
|
|
|
|
2017-01-09 07:38:20 +03:00
|
|
|
(options, args) = parser.parse_args()
|
|
|
|
if options.symfile is None:
|
|
|
|
parser.print_help()
|
|
|
|
return 1
|
|
|
|
|
|
|
|
if options.outputfile is None:
|
|
|
|
parser.print_help()
|
|
|
|
return 1
|
|
|
|
|
2020-04-17 16:34:56 -03:00
|
|
|
if options.riscv:
|
2021-01-26 10:49:01 +08:00
|
|
|
with open(options.outputfile + '.h', 'w') as f_h, open(options.outputfile + '.ld', 'w') as f_ld, open(options.symfile) as f_sym:
|
2020-04-17 16:34:56 -03:00
|
|
|
gen_ld_h_from_sym_riscv(f_sym, f_ld, f_h)
|
|
|
|
return 0
|
|
|
|
|
2021-01-26 10:49:01 +08:00
|
|
|
with open(options.outputfile + '.h', 'w') as f_h, open(options.outputfile + '.ld', 'w') as f_ld, open(options.symfile) as f_sym:
|
2017-01-09 07:38:20 +03:00
|
|
|
gen_ld_h_from_sym(f_sym, f_ld, f_h)
|
|
|
|
return 0
|
|
|
|
|
2018-12-04 13:06:46 +01:00
|
|
|
|
2021-01-26 10:49:01 +08:00
|
|
|
if __name__ == '__main__':
|
2018-12-04 13:06:46 +01:00
|
|
|
exit(main())
|