add ability to flash in discontinuous chunks
This commit is contained in:
parent
ed5add37f6
commit
bfa2c604ef
@ -48,7 +48,7 @@ static void __attribute__((noreturn)) task_fatal_error(void) {
|
|||||||
mp_raise_RuntimeError(translate("OTA Update Failed"));
|
mp_raise_RuntimeError(translate("OTA Update Failed"));
|
||||||
}
|
}
|
||||||
|
|
||||||
void common_hal_ota_flash(const void *buf, const size_t len) {
|
void common_hal_ota_flash(const void *buf, const size_t len, const int32_t offset) {
|
||||||
esp_err_t err;
|
esp_err_t err;
|
||||||
|
|
||||||
const esp_partition_t *running = esp_ota_get_running_partition();
|
const esp_partition_t *running = esp_ota_get_running_partition();
|
||||||
@ -108,7 +108,11 @@ void common_hal_ota_flash(const void *buf, const size_t len) {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
err = esp_ota_write( update_handle, buf, len);
|
if (offset == -1) {
|
||||||
|
err = esp_ota_write(update_handle, buf, len);
|
||||||
|
} else {
|
||||||
|
err = esp_ota_write_with_offset(update_handle, buf, len, offset);
|
||||||
|
}
|
||||||
if (err != ESP_OK) {
|
if (err != ESP_OK) {
|
||||||
ESP_LOGE(TAG, "esp_ota_write failed (%s)", esp_err_to_name(err));
|
ESP_LOGE(TAG, "esp_ota_write failed (%s)", esp_err_to_name(err));
|
||||||
task_fatal_error();
|
task_fatal_error();
|
||||||
|
@ -36,14 +36,27 @@ STATIC mp_obj_t ota_finish(void) {
|
|||||||
}
|
}
|
||||||
STATIC MP_DEFINE_CONST_FUN_OBJ_0(ota_finish_obj, ota_finish);
|
STATIC MP_DEFINE_CONST_FUN_OBJ_0(ota_finish_obj, ota_finish);
|
||||||
|
|
||||||
STATIC mp_obj_t ota_flash(mp_obj_t program_binary_in) {
|
STATIC mp_obj_t ota_flash(size_t n_args, const mp_obj_t *pos_args, mp_map_t *kw_args) {
|
||||||
mp_buffer_info_t bufinfo;
|
enum { ARG_binary, ARG_offset };
|
||||||
mp_get_buffer_raise(program_binary_in, &bufinfo, MP_BUFFER_READ);
|
static const mp_arg_t allowed_args[] = {
|
||||||
|
{ MP_QSTR_binary, MP_ARG_OBJ | MP_ARG_REQUIRED },
|
||||||
|
{ MP_QSTR_offset, MP_ARG_INT | MP_ARG_KW_ONLY, {.u_int = -1} },
|
||||||
|
};
|
||||||
|
|
||||||
common_hal_ota_flash(bufinfo.buf, bufinfo.len);
|
mp_arg_val_t args[MP_ARRAY_SIZE(allowed_args)];
|
||||||
|
mp_arg_parse_all(n_args - 1, pos_args + 1, kw_args, MP_ARRAY_SIZE(allowed_args), allowed_args, args);
|
||||||
|
|
||||||
|
if (args[ARG_offset].u_int < -1) {
|
||||||
|
mp_raise_ValueError(translate("offset must be >= 0"));
|
||||||
|
}
|
||||||
|
|
||||||
|
mp_buffer_info_t bufinfo;
|
||||||
|
mp_get_buffer_raise(args[ARG_binary].u_obj, &bufinfo, MP_BUFFER_READ);
|
||||||
|
|
||||||
|
common_hal_ota_flash(bufinfo.buf, bufinfo.len, args[ARG_offset].u_int);
|
||||||
return mp_const_none;
|
return mp_const_none;
|
||||||
}
|
}
|
||||||
STATIC MP_DEFINE_CONST_FUN_OBJ_1(ota_flash_obj, ota_flash);
|
STATIC MP_DEFINE_CONST_FUN_OBJ_KW(ota_flash_obj, 1, ota_flash);
|
||||||
|
|
||||||
STATIC const mp_rom_map_elem_t ota_module_globals_table[] = {
|
STATIC const mp_rom_map_elem_t ota_module_globals_table[] = {
|
||||||
{ MP_ROM_QSTR(MP_QSTR___name__), MP_ROM_QSTR(MP_QSTR_ota) },
|
{ MP_ROM_QSTR(MP_QSTR___name__), MP_ROM_QSTR(MP_QSTR_ota) },
|
||||||
|
@ -30,6 +30,6 @@
|
|||||||
#include "py/runtime.h"
|
#include "py/runtime.h"
|
||||||
|
|
||||||
extern void common_hal_ota_finish(void);
|
extern void common_hal_ota_finish(void);
|
||||||
extern void common_hal_ota_flash(const void *buf, const size_t len);
|
extern void common_hal_ota_flash(const void *buf, const size_t len, const int32_t offset);
|
||||||
|
|
||||||
#endif // MICROPY_INCLUDED_SHARED_BINDINGS_OTA___INIT___H
|
#endif // MICROPY_INCLUDED_SHARED_BINDINGS_OTA___INIT___H
|
||||||
|
Loading…
x
Reference in New Issue
Block a user