diff options
| author | Dmitry Rokosov <ddrokosov@salutedevices.com> | 2024-10-17 17:12:08 +0300 | 
|---|---|---|
| committer | Mattijs Korpershoek <mkorpershoek@baylibre.com> | 2024-10-24 09:45:55 +0200 | 
| commit | b523b4d2c32f07ca0793bb0f926b02ecb0556cc6 (patch) | |
| tree | ed9eb1796905d7c8eac63f4bbb8e5636d3299ac9 /cmd | |
| parent | a8ca7d46ea744381185c0bf70cbdf4db7dc734b7 (diff) | |
treewide: bcb: move ab_select command to bcb subcommands
To enhance code organization, it is beneficial to consolidate all A/B
BCB management routines into a single super-command.
The 'bcb' command is an excellent candidate for this purpose.
This patch integrates the separate 'ab_select' command into the 'bcb'
group as the 'ab_select' subcommand, maintaining the same parameter list
for consistency.
Signed-off-by: Dmitry Rokosov <ddrokosov@salutedevices.com>
Reviewed-by: Mattijs Korpershoek <mkorpershoek@baylibre.com>
Tested-by: Mattijs Korpershoek <mkorpershoek@baylibre.com> # vim3_android
Link: https://lore.kernel.org/r/20241017-android_ab_master-v5-3-43bfcc096d95@salutedevices.com
Signed-off-by: Mattijs Korpershoek <mkorpershoek@baylibre.com>
Diffstat (limited to 'cmd')
| -rw-r--r-- | cmd/Kconfig | 14 | ||||
| -rw-r--r-- | cmd/Makefile | 1 | ||||
| -rw-r--r-- | cmd/ab_select.c | 66 | ||||
| -rw-r--r-- | cmd/bcb.c | 63 | 
4 files changed, 63 insertions, 81 deletions
| diff --git a/cmd/Kconfig b/cmd/Kconfig index 3ee70f31b14..40485be192f 100644 --- a/cmd/Kconfig +++ b/cmd/Kconfig @@ -1782,20 +1782,6 @@ config CMD_XXD  endmenu -menu "Android support commands" - -config CMD_AB_SELECT -	bool "ab_select" -	depends on ANDROID_AB -	help -	  On Android devices with more than one boot slot (multiple copies of -	  the kernel and system images) this provides a command to select which -	  slot should be used to boot from and register the boot attempt. This -	  is used by the new A/B update model where one slot is updated in the -	  background while running from the other slot. - -endmenu -  if NET || NET_LWIP  menuconfig CMD_NET diff --git a/cmd/Makefile b/cmd/Makefile index 3c5bd56e912..7fe2044aab7 100644 --- a/cmd/Makefile +++ b/cmd/Makefile @@ -17,7 +17,6 @@ obj-$(CONFIG_CMD_2048) += 2048.o  obj-$(CONFIG_CMD_ACPI) += acpi.o  obj-$(CONFIG_CMD_ADDRMAP) += addrmap.o  obj-$(CONFIG_CMD_AES) += aes.o -obj-$(CONFIG_CMD_AB_SELECT) += ab_select.o  obj-$(CONFIG_CMD_ADC) += adc.o  obj-$(CONFIG_CMD_ARMFLASH) += armflash.o  obj-$(CONFIG_BLK) += blk_common.o diff --git a/cmd/ab_select.c b/cmd/ab_select.c deleted file mode 100644 index 7c178c728ca..00000000000 --- a/cmd/ab_select.c +++ /dev/null @@ -1,66 +0,0 @@ -// SPDX-License-Identifier: BSD-2-Clause -/* - * Copyright (C) 2017 The Android Open Source Project - */ - -#include <android_ab.h> -#include <command.h> -#include <env.h> -#include <part.h> - -static int do_ab_select(struct cmd_tbl *cmdtp, int flag, int argc, -			char *const argv[]) -{ -	int ret; -	struct blk_desc *dev_desc; -	struct disk_partition part_info; -	char slot[2]; -	bool dec_tries = true; - -	if (argc < 4) -		return CMD_RET_USAGE; - -	for (int i = 4; i < argc; i++) { -		if (strcmp(argv[i], "--no-dec") == 0) { -			dec_tries = false; -		} else { -			return CMD_RET_USAGE; -		} -	} - -	/* Lookup the "misc" partition from argv[2] and argv[3] */ -	if (part_get_info_by_dev_and_name_or_num(argv[2], argv[3], -						 &dev_desc, &part_info, -						 false) < 0) { -		return CMD_RET_FAILURE; -	} - -	ret = ab_select_slot(dev_desc, &part_info, dec_tries); -	if (ret < 0) { -		printf("Android boot failed, error %d.\n", ret); -		return CMD_RET_FAILURE; -	} - -	/* Android standard slot names are 'a', 'b', ... */ -	slot[0] = BOOT_SLOT_NAME(ret); -	slot[1] = '\0'; -	env_set(argv[1], slot); -	printf("ANDROID: Booting slot: %s\n", slot); -	return CMD_RET_SUCCESS; -} - -U_BOOT_CMD(ab_select, 5, 0, do_ab_select, -	   "Select the slot used to boot from and register the boot attempt.", -	   "<slot_var_name> <interface> <dev[:part|#part_name]> [--no-dec]\n" -	   "    - Load the slot metadata from the partition 'part' on\n" -	   "      device type 'interface' instance 'dev' and store the active\n" -	   "      slot in the 'slot_var_name' variable. This also updates the\n" -	   "      Android slot metadata with a boot attempt, which can cause\n" -	   "      successive calls to this function to return a different result\n" -	   "      if the returned slot runs out of boot attempts.\n" -	   "    - If 'part_name' is passed, preceded with a # instead of :, the\n" -	   "      partition name whose label is 'part_name' will be looked up in\n" -	   "      the partition table. This is commonly the \"misc\" partition.\n" -           "    - If '--no-dec' is set, the number of tries remaining will not\n" -           "      decremented for the selected boot slot\n" -); diff --git a/cmd/bcb.c b/cmd/bcb.c index 98b2a71087a..2854408e566 100644 --- a/cmd/bcb.c +++ b/cmd/bcb.c @@ -8,6 +8,7 @@  #include <android_bootloader_message.h>  #include <bcb.h>  #include <command.h> +#include <android_ab.h>  #include <display_options.h>  #include <log.h>  #include <part.h> @@ -376,6 +377,48 @@ void bcb_reset(void)  	__bcb_reset();  } +__maybe_unused static int do_bcb_ab_select(struct cmd_tbl *cmdtp, +					   int flag, int argc, +					   char * const argv[]) +{ +	int ret; +	struct blk_desc *dev_desc; +	struct disk_partition part_info; +	char slot[2]; +	bool dec_tries = true; + +	if (argc < 4) +		return CMD_RET_USAGE; + +	for (int i = 4; i < argc; i++) { +		if (strcmp(argv[i], "--no-dec") == 0) +			dec_tries = false; +		else +			return CMD_RET_USAGE; +	} + +	/* Lookup the "misc" partition from argv[2] and argv[3] */ +	if (part_get_info_by_dev_and_name_or_num(argv[2], argv[3], +						 &dev_desc, &part_info, +						 false) < 0) { +		return CMD_RET_FAILURE; +	} + +	ret = ab_select_slot(dev_desc, &part_info, dec_tries); +	if (ret < 0) { +		printf("Android boot failed, error %d.\n", ret); +		return CMD_RET_FAILURE; +	} + +	/* Android standard slot names are 'a', 'b', ... */ +	slot[0] = BOOT_SLOT_NAME(ret); +	slot[1] = '\0'; +	env_set(argv[1], slot); +	printf("ANDROID: Booting slot: %s\n", slot); + +	return CMD_RET_SUCCESS; +} +  U_BOOT_LONGHELP(bcb,  	"load <interface> <dev> <part>  - load  BCB from <interface> <dev>:<part>\n"  	"load <dev> <part>              - load  BCB from mmc <dev>:<part>\n" @@ -385,6 +428,23 @@ U_BOOT_LONGHELP(bcb,  	"bcb dump  <field>              - dump  BCB <field>\n"  	"bcb store                      - store BCB back to <interface>\n"  	"\n" +#if IS_ENABLED(CONFIG_ANDROID_AB) +	"bcb ab_select -\n" +	"    Select the slot used to boot from and register the boot attempt.\n" +	"    <slot_var_name> <interface> <dev[:part|#part_name]> [--no-dec]\n" +	"    - Load the slot metadata from the partition 'part' on\n" +	"      device type 'interface' instance 'dev' and store the active\n" +	"      slot in the 'slot_var_name' variable. This also updates the\n" +	"      Android slot metadata with a boot attempt, which can cause\n" +	"      successive calls to this function to return a different result\n" +	"      if the returned slot runs out of boot attempts.\n" +	"    - If 'part_name' is passed, preceded with a # instead of :, the\n" +	"      partition name whose label is 'part_name' will be looked up in\n" +	"      the partition table. This is commonly the \"misc\" partition.\n" +	"    - If '--no-dec' is set, the number of tries remaining will not\n" +	"      decremented for the selected boot slot\n" +	"\n" +#endif  	"Legend:\n"  	"<interface> - storage device interface (virtio, mmc, etc)\n"  	"<dev>       - storage device index containing the BCB partition\n" @@ -406,4 +466,7 @@ U_BOOT_CMD_WITH_SUBCMDS(bcb,  	U_BOOT_SUBCMD_MKENT(test, 4, 1, do_bcb_test),  	U_BOOT_SUBCMD_MKENT(dump, 2, 1, do_bcb_dump),  	U_BOOT_SUBCMD_MKENT(store, 1, 1, do_bcb_store), +#if IS_ENABLED(CONFIG_ANDROID_AB) +	U_BOOT_SUBCMD_MKENT(ab_select, 5, 1, do_bcb_ab_select), +#endif  ); | 
