board/ctrl: add BOARDCTL_SWITCH_BOOT switch boot system support

BOARDIOC_SWITCH_BOOT is required to communicate the boot partition from
userspace (OTA subsystem) to board. It can be used to change the system
boot behavior. So it's useful for A/B boot or even single boot case.

For the board support A/B boot case:
1. Download the new image from the sever
2. Write the new image to the alternative partition
3. Call BOARDCTL_SWITCH_BOOT to the alternative system

For single boot partition case:
1. Download the new image from the sever
2. Call BOARDCTL_SWITCH_BOOT and reboot to a small system
3. Write the new image to the main partition in the small system
4. Call BOARDCTL_SWITCH_BOOT again to the main system

Change-Id: Ifebb495784ecf06842946a249bec64f75dce894f
Signed-off-by: liuhaitao <liuhaitao@xiaomi.com>
This commit is contained in:
liuhaitao 2021-07-20 22:12:28 +08:00 committed by Xiang Xiao
parent 200c86bc92
commit a02f450773
4 changed files with 49 additions and 1 deletions

View File

@ -3389,6 +3389,16 @@ config BOARDCTL_UNIQUEKEY_SIZE
Provides the size of the memory buffer that must be provided by the
caller of board_uniquekey() in which to receive the board unique KEY.
config BOARDCTL_SWITCH_BOOT
bool "Enable switch boot system support"
default n
---help---
BOARDIOC_SWITCH_BOOT is required to communicate the boot partition
from userspace (OTA subsystem) to board for A/B boot or single boot
case. It can be used to change the system boot behavior. For instance,
once a firmware updated successfully, this boardctl can be used to
modify FLASH bank selection.
config BOARDCTL_MKRD
bool "Enable application space creation of RAM disks"
default n

View File

@ -436,6 +436,22 @@ int boardctl(unsigned int cmd, uintptr_t arg)
break;
#endif
#ifdef CONFIG_BOARDCTL_SWITCH_BOOT
/* CMD: BOARDIOC_SWITCH_BOOT
* DESCRIPTION: Used to change the system boot behavior. Switch to
* the updated or specified boot system.
* ARG: Boot system updated or specified
* DEPENDENCIES: Board logic must provide the board_switch_boot()
* interface.
*/
case BOARDIOC_SWITCH_BOOT:
{
ret = board_switch_boot((FAR const char *)arg);
}
break;
#endif
#ifdef CONFIG_BOARDCTL_MKRD
/* CMD: BOARDIOC_MKRD
* DESCRIPTION: Create a RAM disk

View File

@ -310,6 +310,27 @@ int board_uniqueid(FAR uint8_t *uniqueid);
int board_uniquekey(FAR uint8_t *uniquekey);
#endif
/****************************************************************************
* Name: board_switch_boot
*
* Description:
* BOARDIOC_SWITCH_BOOT is required to communicate the boot partition from
* userspace (OTA subsystem) to board, it can be used to change the system
* boot behavior. It's useful for A/B boot or even in the single boot case.
*
* Input Parameters:
* system - The boot system updated or specified
*
* Returned Value:
* Zero (OK) is returned on success. Otherwise a negated errno value is
* returned indicating the nature of the failure.
*
****************************************************************************/
#ifdef CONFIG_BOARDCTL_SWITCH_BOOT
int board_switch_boot(FAR const char *system);
#endif
/****************************************************************************
* Name: board_timerhook
*

View File

@ -201,6 +201,7 @@
#define BOARDIOC_NXTERM_IOCTL _BOARDIOC(0x0010)
#define BOARDIOC_TESTSET _BOARDIOC(0x0011)
#define BOARDIOC_UNIQUEKEY _BOARDIOC(0x0012)
#define BOARDIOC_SWITCH_BOOT _BOARDIOC(0x0013)
/* If CONFIG_BOARDCTL_IOCTL=y, then board-specific commands will be support.
* In this case, all commands not recognized by boardctl() will be forwarded
@ -209,7 +210,7 @@
* User defined board commands may begin with this value:
*/
#define BOARDIOC_USER _BOARDIOC(0x0013)
#define BOARDIOC_USER _BOARDIOC(0x0014)
/****************************************************************************
* Public Type Definitions