mirror of
https://github.com/ArduPilot/ardupilot
synced 2025-01-24 01:28:29 -04:00
Tools: only produce _with_bl.hex not *.hex for vehicle firmware
if we are producing _with_bl.hex then don't also build *.hex as it can confuse users who think they should flash *.hex with a DFU flashing tool
This commit is contained in:
parent
973e70ab3c
commit
cd0f3e144a
@ -411,7 +411,10 @@ def chibios_firmware(self):
|
|||||||
bootloader_bin = self.bld.srcnode.make_node("Tools/bootloaders/%s_bl.bin" % self.env.BOARD)
|
bootloader_bin = self.bld.srcnode.make_node("Tools/bootloaders/%s_bl.bin" % self.env.BOARD)
|
||||||
if self.bld.env.HAVE_INTEL_HEX:
|
if self.bld.env.HAVE_INTEL_HEX:
|
||||||
if os.path.exists(bootloader_bin.abspath()):
|
if os.path.exists(bootloader_bin.abspath()):
|
||||||
hex_target = self.bld.bldnode.find_or_declare('bin/' + link_output.change_ext('.hex').name)
|
if int(self.bld.env.FLASH_RESERVE_START_KB) > 0:
|
||||||
|
hex_target = self.bld.bldnode.find_or_declare('bin/' + link_output.change_ext('_with_bl.hex').name)
|
||||||
|
else:
|
||||||
|
hex_target = self.bld.bldnode.find_or_declare('bin/' + link_output.change_ext('.hex').name)
|
||||||
hex_task = self.create_task('build_intel_hex', src=[bin_target[0], bootloader_bin], tgt=hex_target)
|
hex_task = self.create_task('build_intel_hex', src=[bin_target[0], bootloader_bin], tgt=hex_target)
|
||||||
hex_task.set_run_after(cleanup_task)
|
hex_task.set_run_after(cleanup_task)
|
||||||
else:
|
else:
|
||||||
|
@ -39,13 +39,14 @@ with_bl = blimage + appimage
|
|||||||
|
|
||||||
tmpfile = hexfile + ".tmp"
|
tmpfile = hexfile + ".tmp"
|
||||||
|
|
||||||
open(tmpfile, "wb").write(appimage)
|
# we either write a _with_bl.hex or a .hex. We don't write both as users get
|
||||||
|
# confused if offered a arducopter.hex and try to flash it with INAV DFU
|
||||||
intelhex.bin2hex(tmpfile, hexfile, offset=(0x08000000 + reserve_kb*1024))
|
# flashing tool, not realising it has to be flashed at the correct flash offset
|
||||||
|
|
||||||
if reserve_kb > 0:
|
if reserve_kb > 0:
|
||||||
open(tmpfile, "wb").write(with_bl)
|
open(tmpfile, "wb").write(with_bl)
|
||||||
intelhex.bin2hex(tmpfile, hex_with_bl, offset=0x08000000)
|
intelhex.bin2hex(tmpfile, hex_with_bl, offset=0x08000000)
|
||||||
|
else:
|
||||||
|
open(tmpfile, "wb").write(appimage)
|
||||||
|
intelhex.bin2hex(tmpfile, hexfile, offset=(0x08000000 + reserve_kb*1024))
|
||||||
|
|
||||||
os.unlink(tmpfile)
|
os.unlink(tmpfile)
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user