Message ID | 2b4819f8fa0e8d22630ae7782be8e07766f1eb0a.1591256843.git.roman.kovalivskyi@globallogic.com |
---|---|
State | New |
Headers | show |
Series | Add support for booting into userspace fastboot | expand |
Hi Roman, ??, 4 ???. 2020 ?. ? 10:56, Roman Kovalivskyi <roman.kovalivskyi at globallogic.com>: > > From: Roman Stratiienko <r.stratiienko at gmail.com> > > Android 10 adds support for dynamic partitions and in order to support > this userspace fastboot must be used[1]. New tool fastbootd is > included into recovery. > > Userspace fastboot works from recovery and is launched if: > 1) - Dynamic partitioning is enabled > 2) - Boot control block has 'boot-fastboot' value into command field > The bootloader is expected to load and boot into the recovery image > upon seeing boot-fastboot in the BCB command. Recovery then parses the > BCB message and switches to fastbootd mode[2]. > > Please note that boot script is expected to handle 'boot-fastboot' > command in BCB and load into recovery mode. > > Bootloader must support 'reboot fastboot' command which should reboot > device into userspace fastboot to accomodate those changes[3]. > > Another command that bootloader must support[3] is 'reboot recovery'. This > command should simply reboot device into recovery mode. > > [1] - https://source.android.com/devices/bootloader/fastbootd > [2] - https://source.android.com/devices/bootloader/fastbootd#unified_fastboot_and_recovery > [3] - https://source.android.com/devices/bootloader/fastbootd#modifications_to_the_bootloader > > Signed-off-by: Roman Kovalivskyi <roman.kovalivskyi at globallogic.com> > Signed-off-by: Roman Stratiienko <r.stratiienko at gmail.com> > Change-Id: I9d2bdc9a6f6f31ea98572fe155e1cc8341e9af76 > --- > arch/arm/mach-meson/board-common.c | 6 ++++- > arch/arm/mach-rockchip/board.c | 6 ++++- > board/amazon/kc1/kc1.c | 6 ++++- > board/lg/sniper/sniper.c | 6 ++++- > board/ti/am57xx/board.c | 6 ++++- > board/ti/dra7xx/evm.c | 6 ++++- > drivers/fastboot/fb_command.c | 40 +++++++++++++++++++++++++++++- > drivers/fastboot/fb_common.c | 5 +++- > drivers/usb/gadget/f_fastboot.c | 2 ++ > include/fastboot.h | 13 +++++++++- > net/fastboot.c | 2 ++ > 11 files changed, 89 insertions(+), 9 deletions(-) > > diff --git a/arch/arm/mach-meson/board-common.c b/arch/arm/mach-meson/board-common.c > index 19e5bfd3660c..ffa0ccf003cf 100644 > --- a/arch/arm/mach-meson/board-common.c > +++ b/arch/arm/mach-meson/board-common.c > @@ -5,6 +5,7 @@ > > #include <common.h> > #include <cpu_func.h> > +#include <fastboot.h> > #include <init.h> > #include <net.h> > #include <asm/arch/boot.h> > @@ -153,8 +154,11 @@ int board_late_init(void) > #if CONFIG_IS_ENABLED(FASTBOOT) > static unsigned int reboot_reason = REBOOT_REASON_NORMAL; > > -int fastboot_set_reboot_flag() > +int fastboot_set_reboot_flag(int reason) > { > + if (reason != FASTBOOT_REBOOT_BOOTLOADER) > + return -ENOTSUPP; > + > reboot_reason = REBOOT_REASON_BOOTLOADER; > > printf("Using reboot reason: 0x%x\n", reboot_reason); > diff --git a/arch/arm/mach-rockchip/board.c b/arch/arm/mach-rockchip/board.c > index 430c0cbf41e4..ca9f63bce72c 100644 > --- a/arch/arm/mach-rockchip/board.c > +++ b/arch/arm/mach-rockchip/board.c > @@ -6,6 +6,7 @@ > #include <clk.h> > #include <cpu_func.h> > #include <dm.h> > +#include <fastboot.h> > #include <init.h> > #include <log.h> > #include <ram.h> > @@ -152,8 +153,11 @@ int board_usb_init(int index, enum usb_init_type init) > #endif /* CONFIG_USB_GADGET */ > > #if CONFIG_IS_ENABLED(FASTBOOT) > -int fastboot_set_reboot_flag(void) > +int fastboot_set_reboot_flag(int reason) > { > + if (reason != FASTBOOT_REBOOT_BOOTLOADER) > + return -ENOTSUPP; > + > printf("Setting reboot to fastboot flag ...\n"); > /* Set boot mode to fastboot */ > writel(BOOT_FASTBOOT, CONFIG_ROCKCHIP_BOOT_MODE_REG); > diff --git a/board/amazon/kc1/kc1.c b/board/amazon/kc1/kc1.c > index fb1828ff44da..d61a0db7cb62 100644 > --- a/board/amazon/kc1/kc1.c > +++ b/board/amazon/kc1/kc1.c > @@ -8,6 +8,7 @@ > #include <config.h> > #include <common.h> > #include <env.h> > +#include <fastboot.h> > #include <init.h> > #include <linux/ctype.h> > #include <linux/usb/musb.h> > @@ -163,8 +164,11 @@ void get_board_serial(struct tag_serialnr *serialnr) > omap_die_id_get_board_serial(serialnr); > } > > -int fastboot_set_reboot_flag(void) > +int fastboot_set_reboot_flag(int reason) > { > + if (reason != FASTBOOT_REBOOT_BOOTLOADER) > + return -ENOTSUPP; > + > return omap_reboot_mode_store("b"); > } > > diff --git a/board/lg/sniper/sniper.c b/board/lg/sniper/sniper.c > index 2825eccc035a..cbbe56597e71 100644 > --- a/board/lg/sniper/sniper.c > +++ b/board/lg/sniper/sniper.c > @@ -9,6 +9,7 @@ > #include <common.h> > #include <dm.h> > #include <env.h> > +#include <fastboot.h> > #include <init.h> > #include <linux/ctype.h> > #include <linux/usb/musb.h> > @@ -175,8 +176,11 @@ void reset_misc(void) > omap_reboot_mode_store(reboot_mode); > } > > -int fastboot_set_reboot_flag(void) > +int fastboot_set_reboot_flag(int reason) > { > + if (reason != FASTBOOT_REBOOT_BOOTLOADER) > + return -ENOTSUPP; > + > return omap_reboot_mode_store("b"); > } > > diff --git a/board/ti/am57xx/board.c b/board/ti/am57xx/board.c > index 8720eb87a55d..28c7e890448c 100644 > --- a/board/ti/am57xx/board.c > +++ b/board/ti/am57xx/board.c > @@ -9,6 +9,7 @@ > > #include <common.h> > #include <env.h> > +#include <fastboot.h> > #include <fdt_support.h> > #include <image.h> > #include <init.h> > @@ -1169,8 +1170,11 @@ int board_fit_config_name_match(const char *name) > #endif > > #if CONFIG_IS_ENABLED(FASTBOOT) && !CONFIG_IS_ENABLED(ENV_IS_NOWHERE) > -int fastboot_set_reboot_flag(void) > +int fastboot_set_reboot_flag(int reason) > { > + if (reason != FASTBOOT_REBOOT_BOOTLOADER) > + return -ENOTSUPP; > + > printf("Setting reboot to fastboot flag ...\n"); > env_set("dofastboot", "1"); > env_save(); > diff --git a/board/ti/dra7xx/evm.c b/board/ti/dra7xx/evm.c > index acf7ff169170..aa53a5e8b7e6 100644 > --- a/board/ti/dra7xx/evm.c > +++ b/board/ti/dra7xx/evm.c > @@ -12,6 +12,7 @@ > #include <common.h> > #include <env.h> > #include <fdt_support.h> > +#include <fastboot.h> > #include <image.h> > #include <init.h> > #include <spl.h> > @@ -1050,8 +1051,11 @@ int board_fit_config_name_match(const char *name) > #endif > > #if CONFIG_IS_ENABLED(FASTBOOT) && !CONFIG_IS_ENABLED(ENV_IS_NOWHERE) > -int fastboot_set_reboot_flag(void) > +int fastboot_set_reboot_flag(int reason) > { > + if (reason != FASTBOOT_REBOOT_BOOTLOADER) > + return -ENOTSUPP; > + > printf("Setting reboot to fastboot flag ...\n"); > env_set("dofastboot", "1"); > env_save(); > diff --git a/drivers/fastboot/fb_command.c b/drivers/fastboot/fb_command.c > index 49f6a61c3745..f385aa8e0542 100644 > --- a/drivers/fastboot/fb_command.c > +++ b/drivers/fastboot/fb_command.c > @@ -37,6 +37,8 @@ static void flash(char *, char *); > static void erase(char *, char *); > #endif > static void reboot_bootloader(char *, char *); > +static void reboot_fastbootd(char *, char *); > +static void reboot_recovery(char *, char *); > #if CONFIG_IS_ENABLED(FASTBOOT_CMD_OEM_FORMAT) > static void oem_format(char *, char *); > #endif > @@ -79,6 +81,14 @@ static const struct { > .command = "reboot-bootloader", > .dispatch = reboot_bootloader > }, > + [FASTBOOT_COMMAND_REBOOT_FASTBOOTD] = { > + .command = "reboot-fastboot", > + .dispatch = reboot_fastbootd > + }, > + [FASTBOOT_COMMAND_REBOOT_RECOVERY] = { > + .command = "reboot-recovery", > + .dispatch = reboot_recovery > + }, > [FASTBOOT_COMMAND_SET_ACTIVE] = { > .command = "set_active", > .dispatch = okay > @@ -307,12 +317,40 @@ static void erase(char *cmd_parameter, char *response) > */ > static void reboot_bootloader(char *cmd_parameter, char *response) > { > - if (fastboot_set_reboot_flag()) > + if (fastboot_set_reboot_flag(FASTBOOT_REBOOT_BOOTLOADER)) > fastboot_fail("Cannot set reboot flag", response); > else > fastboot_okay(NULL, response); > } > > +/** > + * reboot_fastbootd() - Sets reboot fastboot flag. > + * > + * @cmd_parameter: Pointer to command parameter > + * @response: Pointer to fastboot response buffer > + */ > +static void reboot_fastbootd(char *cmd_parameter, char *response) > +{ > + if (fastboot_set_reboot_flag(FASTBOOT_REBOOT_FASTBOOTD)) > + fastboot_fail("Cannot set fastboot flag", response); > + else > + fastboot_okay(NULL, response); > +} > + > +/** > + * reboot_recovery() - Sets reboot recovery flag. > + * > + * @cmd_parameter: Pointer to command parameter > + * @response: Pointer to fastboot response buffer > + */ > +static void reboot_recovery(char *cmd_parameter, char *response) > +{ > + if (fastboot_set_reboot_flag(FASTBOOT_REBOOT_RECOVERY)) > + fastboot_fail("Cannot set recovery flag", response); > + else > + fastboot_okay(NULL, response); > +} > + > #if CONFIG_IS_ENABLED(FASTBOOT_CMD_OEM_FORMAT) > /** > * oem_format() - Execute the OEM format command > diff --git a/drivers/fastboot/fb_common.c b/drivers/fastboot/fb_common.c > index c3735a44af74..012a6288c187 100644 > --- a/drivers/fastboot/fb_common.c > +++ b/drivers/fastboot/fb_common.c > @@ -88,8 +88,11 @@ void fastboot_okay(const char *reason, char *response) > * which sets whatever flag your board specific Android bootloader flow > * requires in order to re-enter the bootloader. > */ > -int __weak fastboot_set_reboot_flag(void) > +int __weak fastboot_set_reboot_flag(int reason) > { > + if (reason != FASTBOOT_REBOOT_BOOTLOADER) > + return -ENOTSUPP; > + This check is redundant here. Please remove. > return -ENOSYS; > } > > diff --git a/drivers/usb/gadget/f_fastboot.c b/drivers/usb/gadget/f_fastboot.c > index 384c0f6f6e27..30f7a52087fc 100644 > --- a/drivers/usb/gadget/f_fastboot.c > +++ b/drivers/usb/gadget/f_fastboot.c > @@ -455,6 +455,8 @@ static void rx_handler_command(struct usb_ep *ep, struct usb_request *req) > > case FASTBOOT_COMMAND_REBOOT: > case FASTBOOT_COMMAND_REBOOT_BOOTLOADER: > + case FASTBOOT_COMMAND_REBOOT_FASTBOOTD: > + case FASTBOOT_COMMAND_REBOOT_RECOVERY: > fastboot_func->in_req->complete = compl_do_reset; > break; > } > diff --git a/include/fastboot.h b/include/fastboot.h > index 1933b1d98e3b..1830d859afb6 100644 > --- a/include/fastboot.h > +++ b/include/fastboot.h > @@ -32,6 +32,8 @@ enum { > FASTBOOT_COMMAND_CONTINUE, > FASTBOOT_COMMAND_REBOOT, > FASTBOOT_COMMAND_REBOOT_BOOTLOADER, > + FASTBOOT_COMMAND_REBOOT_FASTBOOTD, > + FASTBOOT_COMMAND_REBOOT_RECOVERY, > FASTBOOT_COMMAND_SET_ACTIVE, > #if CONFIG_IS_ENABLED(FASTBOOT_CMD_OEM_FORMAT) > FASTBOOT_COMMAND_OEM_FORMAT, > @@ -40,6 +42,15 @@ enum { > FASTBOOT_COMMAND_COUNT > }; > > +/** > + * Reboot reasons > + */ > +enum { > + FASTBOOT_REBOOT_BOOTLOADER, > + FASTBOOT_REBOOT_FASTBOOTD, > + FASTBOOT_REBOOT_RECOVERY Please put FASTBOOT_REBOOT_REASON_COUNT at the end of the list. > +}; > + > /** > * fastboot_response() - Writes a response of the form "$tag$reason". > * > @@ -77,7 +88,7 @@ void fastboot_okay(const char *reason, char *response); > * which sets whatever flag your board specific Android bootloader flow > * requires in order to re-enter the bootloader. > */ > -int fastboot_set_reboot_flag(void); > +int fastboot_set_reboot_flag(int reason); > > /** > * fastboot_set_progress_callback() - set progress callback > diff --git a/net/fastboot.c b/net/fastboot.c > index 0c57fb9947df..7e7a601b9fe6 100644 > --- a/net/fastboot.c > +++ b/net/fastboot.c > @@ -227,6 +227,8 @@ static void fastboot_send(struct fastboot_header header, char *fastboot_data, > > case FASTBOOT_COMMAND_REBOOT: > case FASTBOOT_COMMAND_REBOOT_BOOTLOADER: > + case FASTBOOT_COMMAND_REBOOT_FASTBOOTD: > + case FASTBOOT_COMMAND_REBOOT_RECOVERY: > do_reset(NULL, 0, 0, NULL); > break; > } > -- > 2.17.1 >
diff --git a/arch/arm/mach-meson/board-common.c b/arch/arm/mach-meson/board-common.c index 19e5bfd3660c..ffa0ccf003cf 100644 --- a/arch/arm/mach-meson/board-common.c +++ b/arch/arm/mach-meson/board-common.c @@ -5,6 +5,7 @@ #include <common.h> #include <cpu_func.h> +#include <fastboot.h> #include <init.h> #include <net.h> #include <asm/arch/boot.h> @@ -153,8 +154,11 @@ int board_late_init(void) #if CONFIG_IS_ENABLED(FASTBOOT) static unsigned int reboot_reason = REBOOT_REASON_NORMAL; -int fastboot_set_reboot_flag() +int fastboot_set_reboot_flag(int reason) { + if (reason != FASTBOOT_REBOOT_BOOTLOADER) + return -ENOTSUPP; + reboot_reason = REBOOT_REASON_BOOTLOADER; printf("Using reboot reason: 0x%x\n", reboot_reason); diff --git a/arch/arm/mach-rockchip/board.c b/arch/arm/mach-rockchip/board.c index 430c0cbf41e4..ca9f63bce72c 100644 --- a/arch/arm/mach-rockchip/board.c +++ b/arch/arm/mach-rockchip/board.c @@ -6,6 +6,7 @@ #include <clk.h> #include <cpu_func.h> #include <dm.h> +#include <fastboot.h> #include <init.h> #include <log.h> #include <ram.h> @@ -152,8 +153,11 @@ int board_usb_init(int index, enum usb_init_type init) #endif /* CONFIG_USB_GADGET */ #if CONFIG_IS_ENABLED(FASTBOOT) -int fastboot_set_reboot_flag(void) +int fastboot_set_reboot_flag(int reason) { + if (reason != FASTBOOT_REBOOT_BOOTLOADER) + return -ENOTSUPP; + printf("Setting reboot to fastboot flag ...\n"); /* Set boot mode to fastboot */ writel(BOOT_FASTBOOT, CONFIG_ROCKCHIP_BOOT_MODE_REG); diff --git a/board/amazon/kc1/kc1.c b/board/amazon/kc1/kc1.c index fb1828ff44da..d61a0db7cb62 100644 --- a/board/amazon/kc1/kc1.c +++ b/board/amazon/kc1/kc1.c @@ -8,6 +8,7 @@ #include <config.h> #include <common.h> #include <env.h> +#include <fastboot.h> #include <init.h> #include <linux/ctype.h> #include <linux/usb/musb.h> @@ -163,8 +164,11 @@ void get_board_serial(struct tag_serialnr *serialnr) omap_die_id_get_board_serial(serialnr); } -int fastboot_set_reboot_flag(void) +int fastboot_set_reboot_flag(int reason) { + if (reason != FASTBOOT_REBOOT_BOOTLOADER) + return -ENOTSUPP; + return omap_reboot_mode_store("b"); } diff --git a/board/lg/sniper/sniper.c b/board/lg/sniper/sniper.c index 2825eccc035a..cbbe56597e71 100644 --- a/board/lg/sniper/sniper.c +++ b/board/lg/sniper/sniper.c @@ -9,6 +9,7 @@ #include <common.h> #include <dm.h> #include <env.h> +#include <fastboot.h> #include <init.h> #include <linux/ctype.h> #include <linux/usb/musb.h> @@ -175,8 +176,11 @@ void reset_misc(void) omap_reboot_mode_store(reboot_mode); } -int fastboot_set_reboot_flag(void) +int fastboot_set_reboot_flag(int reason) { + if (reason != FASTBOOT_REBOOT_BOOTLOADER) + return -ENOTSUPP; + return omap_reboot_mode_store("b"); } diff --git a/board/ti/am57xx/board.c b/board/ti/am57xx/board.c index 8720eb87a55d..28c7e890448c 100644 --- a/board/ti/am57xx/board.c +++ b/board/ti/am57xx/board.c @@ -9,6 +9,7 @@ #include <common.h> #include <env.h> +#include <fastboot.h> #include <fdt_support.h> #include <image.h> #include <init.h> @@ -1169,8 +1170,11 @@ int board_fit_config_name_match(const char *name) #endif #if CONFIG_IS_ENABLED(FASTBOOT) && !CONFIG_IS_ENABLED(ENV_IS_NOWHERE) -int fastboot_set_reboot_flag(void) +int fastboot_set_reboot_flag(int reason) { + if (reason != FASTBOOT_REBOOT_BOOTLOADER) + return -ENOTSUPP; + printf("Setting reboot to fastboot flag ...\n"); env_set("dofastboot", "1"); env_save(); diff --git a/board/ti/dra7xx/evm.c b/board/ti/dra7xx/evm.c index acf7ff169170..aa53a5e8b7e6 100644 --- a/board/ti/dra7xx/evm.c +++ b/board/ti/dra7xx/evm.c @@ -12,6 +12,7 @@ #include <common.h> #include <env.h> #include <fdt_support.h> +#include <fastboot.h> #include <image.h> #include <init.h> #include <spl.h> @@ -1050,8 +1051,11 @@ int board_fit_config_name_match(const char *name) #endif #if CONFIG_IS_ENABLED(FASTBOOT) && !CONFIG_IS_ENABLED(ENV_IS_NOWHERE) -int fastboot_set_reboot_flag(void) +int fastboot_set_reboot_flag(int reason) { + if (reason != FASTBOOT_REBOOT_BOOTLOADER) + return -ENOTSUPP; + printf("Setting reboot to fastboot flag ...\n"); env_set("dofastboot", "1"); env_save(); diff --git a/drivers/fastboot/fb_command.c b/drivers/fastboot/fb_command.c index 49f6a61c3745..f385aa8e0542 100644 --- a/drivers/fastboot/fb_command.c +++ b/drivers/fastboot/fb_command.c @@ -37,6 +37,8 @@ static void flash(char *, char *); static void erase(char *, char *); #endif static void reboot_bootloader(char *, char *); +static void reboot_fastbootd(char *, char *); +static void reboot_recovery(char *, char *); #if CONFIG_IS_ENABLED(FASTBOOT_CMD_OEM_FORMAT) static void oem_format(char *, char *); #endif @@ -79,6 +81,14 @@ static const struct { .command = "reboot-bootloader", .dispatch = reboot_bootloader }, + [FASTBOOT_COMMAND_REBOOT_FASTBOOTD] = { + .command = "reboot-fastboot", + .dispatch = reboot_fastbootd + }, + [FASTBOOT_COMMAND_REBOOT_RECOVERY] = { + .command = "reboot-recovery", + .dispatch = reboot_recovery + }, [FASTBOOT_COMMAND_SET_ACTIVE] = { .command = "set_active", .dispatch = okay @@ -307,12 +317,40 @@ static void erase(char *cmd_parameter, char *response) */ static void reboot_bootloader(char *cmd_parameter, char *response) { - if (fastboot_set_reboot_flag()) + if (fastboot_set_reboot_flag(FASTBOOT_REBOOT_BOOTLOADER)) fastboot_fail("Cannot set reboot flag", response); else fastboot_okay(NULL, response); } +/** + * reboot_fastbootd() - Sets reboot fastboot flag. + * + * @cmd_parameter: Pointer to command parameter + * @response: Pointer to fastboot response buffer + */ +static void reboot_fastbootd(char *cmd_parameter, char *response) +{ + if (fastboot_set_reboot_flag(FASTBOOT_REBOOT_FASTBOOTD)) + fastboot_fail("Cannot set fastboot flag", response); + else + fastboot_okay(NULL, response); +} + +/** + * reboot_recovery() - Sets reboot recovery flag. + * + * @cmd_parameter: Pointer to command parameter + * @response: Pointer to fastboot response buffer + */ +static void reboot_recovery(char *cmd_parameter, char *response) +{ + if (fastboot_set_reboot_flag(FASTBOOT_REBOOT_RECOVERY)) + fastboot_fail("Cannot set recovery flag", response); + else + fastboot_okay(NULL, response); +} + #if CONFIG_IS_ENABLED(FASTBOOT_CMD_OEM_FORMAT) /** * oem_format() - Execute the OEM format command diff --git a/drivers/fastboot/fb_common.c b/drivers/fastboot/fb_common.c index c3735a44af74..012a6288c187 100644 --- a/drivers/fastboot/fb_common.c +++ b/drivers/fastboot/fb_common.c @@ -88,8 +88,11 @@ void fastboot_okay(const char *reason, char *response) * which sets whatever flag your board specific Android bootloader flow * requires in order to re-enter the bootloader. */ -int __weak fastboot_set_reboot_flag(void) +int __weak fastboot_set_reboot_flag(int reason) { + if (reason != FASTBOOT_REBOOT_BOOTLOADER) + return -ENOTSUPP; + return -ENOSYS; } diff --git a/drivers/usb/gadget/f_fastboot.c b/drivers/usb/gadget/f_fastboot.c index 384c0f6f6e27..30f7a52087fc 100644 --- a/drivers/usb/gadget/f_fastboot.c +++ b/drivers/usb/gadget/f_fastboot.c @@ -455,6 +455,8 @@ static void rx_handler_command(struct usb_ep *ep, struct usb_request *req) case FASTBOOT_COMMAND_REBOOT: case FASTBOOT_COMMAND_REBOOT_BOOTLOADER: + case FASTBOOT_COMMAND_REBOOT_FASTBOOTD: + case FASTBOOT_COMMAND_REBOOT_RECOVERY: fastboot_func->in_req->complete = compl_do_reset; break; } diff --git a/include/fastboot.h b/include/fastboot.h index 1933b1d98e3b..1830d859afb6 100644 --- a/include/fastboot.h +++ b/include/fastboot.h @@ -32,6 +32,8 @@ enum { FASTBOOT_COMMAND_CONTINUE, FASTBOOT_COMMAND_REBOOT, FASTBOOT_COMMAND_REBOOT_BOOTLOADER, + FASTBOOT_COMMAND_REBOOT_FASTBOOTD, + FASTBOOT_COMMAND_REBOOT_RECOVERY, FASTBOOT_COMMAND_SET_ACTIVE, #if CONFIG_IS_ENABLED(FASTBOOT_CMD_OEM_FORMAT) FASTBOOT_COMMAND_OEM_FORMAT, @@ -40,6 +42,15 @@ enum { FASTBOOT_COMMAND_COUNT }; +/** + * Reboot reasons + */ +enum { + FASTBOOT_REBOOT_BOOTLOADER, + FASTBOOT_REBOOT_FASTBOOTD, + FASTBOOT_REBOOT_RECOVERY +}; + /** * fastboot_response() - Writes a response of the form "$tag$reason". * @@ -77,7 +88,7 @@ void fastboot_okay(const char *reason, char *response); * which sets whatever flag your board specific Android bootloader flow * requires in order to re-enter the bootloader. */ -int fastboot_set_reboot_flag(void); +int fastboot_set_reboot_flag(int reason); /** * fastboot_set_progress_callback() - set progress callback diff --git a/net/fastboot.c b/net/fastboot.c index 0c57fb9947df..7e7a601b9fe6 100644 --- a/net/fastboot.c +++ b/net/fastboot.c @@ -227,6 +227,8 @@ static void fastboot_send(struct fastboot_header header, char *fastboot_data, case FASTBOOT_COMMAND_REBOOT: case FASTBOOT_COMMAND_REBOOT_BOOTLOADER: + case FASTBOOT_COMMAND_REBOOT_FASTBOOTD: + case FASTBOOT_COMMAND_REBOOT_RECOVERY: do_reset(NULL, 0, 0, NULL); break; }