summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorTom Rini <trini@konsulko.com>2024-09-10 07:51:40 -0600
committerTom Rini <trini@konsulko.com>2024-09-10 07:51:40 -0600
commitce1a2630827a1f9ddadb2598ab7936732e6cb723 (patch)
treef470da34de08daa94e5fface0235125123e16132
parent40727391702a1a48c58b0a3c6e69013ff8af6cb2 (diff)
parentcc2f60c13f6aaf1bd277cf10c8b375c2e4a695b7 (diff)
Merge tag 'u-boot-dfu-20240910' of https://source.denx.de/u-boot/custodians/u-boot-dfu
CI: https://source.denx.de/u-boot/custodians/u-boot-dfu/-/pipelines/22302 - Fix ANDROID_AB_BACKUP_OFFSET unit
-rw-r--r--boot/android_ab.c9
-rw-r--r--common/Kconfig3
2 files changed, 9 insertions, 3 deletions
diff --git a/boot/android_ab.c b/boot/android_ab.c
index 143f373aae9..1196a189ed5 100644
--- a/boot/android_ab.c
+++ b/boot/android_ab.c
@@ -139,8 +139,13 @@ static int ab_control_store(struct blk_desc *dev_desc,
{
ulong abc_offset, abc_blocks, ret;
- abc_offset = offset +
- offsetof(struct bootloader_message_ab, slot_suffix) /
+ if (offset % part_info->blksz) {
+ log_err("ANDROID: offset not block aligned\n");
+ return -EINVAL;
+ }
+
+ abc_offset = (offset +
+ offsetof(struct bootloader_message_ab, slot_suffix)) /
part_info->blksz;
abc_blocks = DIV_ROUND_UP(sizeof(struct bootloader_control),
part_info->blksz);
diff --git a/common/Kconfig b/common/Kconfig
index 83c81edac20..e1b8557e0cb 100644
--- a/common/Kconfig
+++ b/common/Kconfig
@@ -986,7 +986,8 @@ config ANDROID_AB_BACKUP_OFFSET
help
If non-zero, a backup bootloader message starting at this offset in
the partition will tried in the event that the primary one (starting
- at offset 0) fails its checksum.
+ at offset 0) fails its checksum. The offset is in bytes and must be
+ multiple of the block size.
endmenu