summaryrefslogtreecommitdiff
path: root/drivers
diff options
context:
space:
mode:
authorStefan Agner <stefan.agner@toradex.com>2017-08-16 11:00:52 -0700
committerStefano Babic <sbabic@denx.de>2017-08-23 10:41:58 +0200
commitccd7a4d2f42df7ebc8fd0fbbd31d5e6534cb590c (patch)
treeba66cdc9e560a8655cbb64bffc2e487fabb334ba /drivers
parent5661f08a71446ab0ffb5bcf595709027e68f10fa (diff)
downloadu-boot-ccd7a4d2f42df7ebc8fd0fbbd31d5e6534cb590c.tar.gz
usb: gadget: sdp: extend images compatible for jumps
Support U-Boot images in SPL so that u-boot.img files can be directly downloaded and executed. Furthermore support U-Boot scripts download and execution in full U-Boot so that custom recovery actions can be downloaded from the host in a third step. Signed-off-by: Stefan Agner <stefan.agner@toradex.com> Reviewed-by: Ɓukasz Majewski <lukma@denx.de> Reviewed-by: Stefano Babic <sbabic@denx.de>
Diffstat (limited to 'drivers')
-rw-r--r--drivers/usb/gadget/f_sdp.c20
1 files changed, 18 insertions, 2 deletions
diff --git a/drivers/usb/gadget/f_sdp.c b/drivers/usb/gadget/f_sdp.c
index 9d82abcd69..0fae66beab 100644
--- a/drivers/usb/gadget/f_sdp.c
+++ b/drivers/usb/gadget/f_sdp.c
@@ -29,6 +29,8 @@
#include <asm/io.h>
#include <g_dnl.h>
#include <sdp.h>
+#include <spl.h>
+#include <image.h>
#include <imximage.h>
#define HID_REPORT_ID_MASK 0x000000ff
@@ -670,8 +672,22 @@ static void sdp_handle_in_ep(void)
sdp_func->state = SDP_STATE_TX_REGISTER_BUSY;
break;
case SDP_STATE_JUMP:
- printf("Checking imxheader at 0x%08x\n", f_sdp->jmp_address);
- status = sdp_jump_imxheader((void *)f_sdp->jmp_address);
+ printf("Jumping to header at 0x%08x\n", sdp_func->jmp_address);
+ status = sdp_jump_imxheader((void *)sdp_func->jmp_address);
+
+ /* If imx header fails, try some U-Boot specific headers */
+ if (status) {
+#ifdef CONFIG_SPL_BUILD
+ /* In SPL, allow jumps to U-Boot images */
+ struct spl_image_info spl_image = {};
+ spl_parse_image_header(&spl_image,
+ (struct image_header *)sdp_func->jmp_address);
+ jump_to_image_no_args(&spl_image);
+#else
+ /* In U-Boot, allow jumps to scripts */
+ source(sdp_func->jmp_address, "script@1");
+#endif
+ }
sdp_func->next_state = SDP_STATE_IDLE;
sdp_func->error_status = status;