AP_HAL_ChibiOS: use @ROMFS/defaults.parm rather than apj_tool for defaul parms
This commit is contained in:
parent
486cbb7890
commit
c4a342f0af
@ -39,6 +39,11 @@ public:
|
|||||||
bool run_debug_shell(AP_HAL::BetterStream *stream) override { return false; }
|
bool run_debug_shell(AP_HAL::BetterStream *stream) override { return false; }
|
||||||
uint32_t available_memory() override;
|
uint32_t available_memory() override;
|
||||||
|
|
||||||
|
// get path to custom defaults file for AP_Param
|
||||||
|
const char* get_custom_defaults_file() const override {
|
||||||
|
return "@ROMFS/defaults.parm";
|
||||||
|
}
|
||||||
|
|
||||||
// Special Allocation Routines
|
// Special Allocation Routines
|
||||||
void *malloc_type(size_t size, AP_HAL::Util::Memory_Type mem_type) override;
|
void *malloc_type(size_t size, AP_HAL::Util::Memory_Type mem_type) override;
|
||||||
void free_type(void *ptr, size_t size, AP_HAL::Util::Memory_Type mem_type) override;
|
void free_type(void *ptr, size_t size, AP_HAL::Util::Memory_Type mem_type) override;
|
||||||
|
@ -33,6 +33,10 @@ class ChibiOSHWDef(object):
|
|||||||
self.default_params_filepath = default_params_filepath
|
self.default_params_filepath = default_params_filepath
|
||||||
self.quiet = quiet
|
self.quiet = quiet
|
||||||
|
|
||||||
|
# if true then parameters will be appended in special apj-tool
|
||||||
|
# section at end of binary:
|
||||||
|
self.force_apj_default_parameters = False
|
||||||
|
|
||||||
self.default_gpio = ['INPUT', 'FLOATING']
|
self.default_gpio = ['INPUT', 'FLOATING']
|
||||||
|
|
||||||
self.vtypes = []
|
self.vtypes = []
|
||||||
@ -2520,6 +2524,9 @@ Please run: Tools/scripts/build_bootloaders.py %s
|
|||||||
if not self.is_periph_fw():
|
if not self.is_periph_fw():
|
||||||
self.romfs["hwdef.dat"] = hwdat
|
self.romfs["hwdef.dat"] = hwdat
|
||||||
|
|
||||||
|
def write_define(self, f, name, value):
|
||||||
|
f.write(f"#define {name} {value}\n")
|
||||||
|
|
||||||
def write_hwdef_header(self, outfilename):
|
def write_hwdef_header(self, outfilename):
|
||||||
'''write hwdef header file'''
|
'''write hwdef header file'''
|
||||||
self.progress("Writing hwdef setup in %s" % outfilename)
|
self.progress("Writing hwdef setup in %s" % outfilename)
|
||||||
@ -2582,6 +2589,11 @@ Please run: Tools/scripts/build_bootloaders.py %s
|
|||||||
|
|
||||||
self.write_peripheral_enable(f)
|
self.write_peripheral_enable(f)
|
||||||
|
|
||||||
|
if os.path.exists(self.processed_defaults_filepath()):
|
||||||
|
self.write_define(f, 'AP_PARAM_DEFAULTS_FILE_PARSING_ENABLED', 1)
|
||||||
|
else:
|
||||||
|
self.write_define(f, 'AP_PARAM_DEFAULTS_FILE_PARSING_ENABLED', 0)
|
||||||
|
|
||||||
if self.mcu_series.startswith("STM32H7"):
|
if self.mcu_series.startswith("STM32H7"):
|
||||||
# add in ADC3 on H7 to get MCU temperature and reference voltage
|
# add in ADC3 on H7 to get MCU temperature and reference voltage
|
||||||
self.periph_list.append('ADC3')
|
self.periph_list.append('ADC3')
|
||||||
@ -2827,14 +2839,14 @@ Please run: Tools/scripts/build_bootloaders.py %s
|
|||||||
|
|
||||||
if defaults_abspath is None:
|
if defaults_abspath is None:
|
||||||
self.progress("No default parameter file found")
|
self.progress("No default parameter file found")
|
||||||
return
|
return False
|
||||||
|
|
||||||
content = self.get_processed_defaults_file(defaults_abspath)
|
content = self.get_processed_defaults_file(defaults_abspath)
|
||||||
|
|
||||||
with open(filepath, "w") as processed_defaults_fh:
|
with open(filepath, "w") as processed_defaults_fh:
|
||||||
processed_defaults_fh.write(content)
|
processed_defaults_fh.write(content)
|
||||||
|
|
||||||
self.env_vars['DEFAULT_PARAMETERS'] = filepath
|
return True
|
||||||
|
|
||||||
def write_env_py(self, filename):
|
def write_env_py(self, filename):
|
||||||
'''write out env.py for environment variables to control the build process'''
|
'''write out env.py for environment variables to control the build process'''
|
||||||
@ -3046,7 +3058,6 @@ Please run: Tools/scripts/build_bootloaders.py %s
|
|||||||
if result:
|
if result:
|
||||||
self.intdefines[result.group(1)] = int(result.group(2))
|
self.intdefines[result.group(1)] = int(result.group(2))
|
||||||
|
|
||||||
|
|
||||||
def progress(self, message):
|
def progress(self, message):
|
||||||
if self.quiet:
|
if self.quiet:
|
||||||
return
|
return
|
||||||
@ -3141,6 +3152,31 @@ Please run: Tools/scripts/build_bootloaders.py %s
|
|||||||
|
|
||||||
self.add_firmware_defaults_from_file(f, "defaults_normal.h", "normal")
|
self.add_firmware_defaults_from_file(f, "defaults_normal.h", "normal")
|
||||||
|
|
||||||
|
def processed_defaults_filepath(self):
|
||||||
|
return os.path.join(self.outdir, "processed_defaults.parm")
|
||||||
|
|
||||||
|
def write_default_parameters(self):
|
||||||
|
'''handle default parameters'''
|
||||||
|
|
||||||
|
if self.is_bootloader_fw():
|
||||||
|
return
|
||||||
|
|
||||||
|
if self.is_io_fw():
|
||||||
|
return
|
||||||
|
|
||||||
|
filepath = self.processed_defaults_filepath()
|
||||||
|
if not self.write_processed_defaults_file(filepath):
|
||||||
|
return
|
||||||
|
|
||||||
|
if self.get_config('FORCE_APJ_DEFAULT_PARAMETERS', default=False):
|
||||||
|
# set env variable so that post-processing in waf uses
|
||||||
|
# apj-tool to append parameters to image:
|
||||||
|
if os.path.exists(filepath):
|
||||||
|
self.env_vars['DEFAULT_PARAMETERS'] = filepath
|
||||||
|
return
|
||||||
|
|
||||||
|
self.romfs_add('defaults.parm', filepath)
|
||||||
|
|
||||||
def run(self):
|
def run(self):
|
||||||
|
|
||||||
# process input file
|
# process input file
|
||||||
@ -3156,6 +3192,9 @@ Please run: Tools/scripts/build_bootloaders.py %s
|
|||||||
# build a list for peripherals for DMA resolver
|
# build a list for peripherals for DMA resolver
|
||||||
self.periph_list = self.build_peripheral_list()
|
self.periph_list = self.build_peripheral_list()
|
||||||
|
|
||||||
|
# write out a default parameters file, decide how to use it:
|
||||||
|
self.write_default_parameters()
|
||||||
|
|
||||||
# write out hw.dat for ROMFS
|
# write out hw.dat for ROMFS
|
||||||
self.write_all_lines(os.path.join(self.outdir, "hw.dat"))
|
self.write_all_lines(os.path.join(self.outdir, "hw.dat"))
|
||||||
|
|
||||||
@ -3174,9 +3213,6 @@ Please run: Tools/scripts/build_bootloaders.py %s
|
|||||||
# exist in the same directory as the ldscript.ld file we generate.
|
# exist in the same directory as the ldscript.ld file we generate.
|
||||||
self.copy_common_linkerscript(self.outdir)
|
self.copy_common_linkerscript(self.outdir)
|
||||||
|
|
||||||
if not self.is_bootloader_fw():
|
|
||||||
self.write_processed_defaults_file(os.path.join(self.outdir, "processed_defaults.parm"))
|
|
||||||
|
|
||||||
self.write_env_py(os.path.join(self.outdir, "env.py"))
|
self.write_env_py(os.path.join(self.outdir, "env.py"))
|
||||||
|
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user