Commit 8f211df3 authored by Damien George's avatar Damien George

stm32/mboot/fwupdate.py: Refactor update_mpy with support for STATUS.

Changes are:
- refactor to use new _create_element function
- support extended version of MOUNT element with block size
- support STATUS element
Signed-off-by: default avatarDamien George <damien@micropython.org>
parent bd7110a3
# Update Mboot or MicroPython from a .dfu.gz file on the board's filesystem # Update Mboot or MicroPython from a .dfu.gz file on the board's filesystem
# MIT license; Copyright (c) 2019-2020 Damien P. George # MIT license; Copyright (c) 2019-2020 Damien P. George
from micropython import const
import struct, time import struct, time
import uzlib, machine, stm import uzlib, machine, stm
...@@ -9,6 +10,12 @@ VFS_FAT = 1 ...@@ -9,6 +10,12 @@ VFS_FAT = 1
VFS_LFS1 = 2 VFS_LFS1 = 2
VFS_LFS2 = 3 VFS_LFS2 = 3
# Constants for creating mboot elements.
_ELEM_TYPE_END = const(1)
_ELEM_TYPE_MOUNT = const(2)
_ELEM_TYPE_FSLOAD = const(3)
_ELEM_TYPE_STATUS = const(4)
FLASH_KEY1 = 0x45670123 FLASH_KEY1 = 0x45670123
FLASH_KEY2 = 0xCDEF89AB FLASH_KEY2 = 0xCDEF89AB
...@@ -156,7 +163,11 @@ def update_mboot(filename): ...@@ -156,7 +163,11 @@ def update_mboot(filename):
print("Programming finished, can now reset or turn off.") print("Programming finished, can now reset or turn off.")
def update_mpy(filename, fs_base, fs_len, fs_type=VFS_FAT): def _create_element(kind, body):
return bytes([kind, len(body)]) + body
def update_mpy(filename, fs_base, fs_len, fs_type=VFS_FAT, fs_blocksize=0, status_addr=None):
# Check firmware is of .dfu or .dfu.gz type # Check firmware is of .dfu or .dfu.gz type
try: try:
with open(filename, "rb") as f: with open(filename, "rb") as f:
...@@ -168,13 +179,20 @@ def update_mpy(filename, fs_base, fs_len, fs_type=VFS_FAT): ...@@ -168,13 +179,20 @@ def update_mpy(filename, fs_base, fs_len, fs_type=VFS_FAT):
print("Firmware must be a .dfu(.gz) file.") print("Firmware must be a .dfu(.gz) file.")
return return
ELEM_TYPE_END = 1 if fs_type in (VFS_LFS1, VFS_LFS2) and not fs_blocksize:
ELEM_TYPE_MOUNT = 2 raise Exception("littlefs requires fs_blocksize parameter")
ELEM_TYPE_FSLOAD = 3
mount_point = 1 mount_point = 1
mount = struct.pack("<BBBBLL", ELEM_TYPE_MOUNT, 10, mount_point, fs_type, fs_base, fs_len) elems = _create_element(
fsup = struct.pack("<BBB", ELEM_TYPE_FSLOAD, 1 + len(filename), mount_point) + bytes( _ELEM_TYPE_MOUNT,
filename, "ascii" struct.pack("<BBLLL", mount_point, fs_type, fs_base, fs_len, fs_blocksize),
)
elems += _create_element(
_ELEM_TYPE_FSLOAD, struct.pack("<B", mount_point) + bytes(filename, "ascii")
) )
end = struct.pack("<BB", ELEM_TYPE_END, 0) if status_addr is not None:
machine.bootloader(mount + fsup + end) # mboot will write 0 to status_addr on succes, or a negative number on failure
machine.mem32[status_addr] = 1
elems += _create_element(_ELEM_TYPE_STATUS, struct.pack("<L", status_addr))
elems += _create_element(_ELEM_TYPE_END, b"")
machine.bootloader(elems)
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment