diff options
author | Jeremy Compostella <jeremy.compostella@intel.com> | 2014-08-16 05:17:12 +0000 |
---|---|---|
committer | Android Git Automerger <android-git-automerger@android.com> | 2014-08-16 05:17:12 +0000 |
commit | 310db6890396577079d0cfbfa095e80faed471d7 (patch) | |
tree | f290accb6456b9aace46ec9ea6608b97cffb483b /fastboot | |
parent | 84a248ce27bc4e4155ee2f86f8a7038cab8d3b0b (diff) | |
parent | a42adff905600219cbf5ef217d2b46670225aca3 (diff) | |
download | system_core-310db6890396577079d0cfbfa095e80faed471d7.zip system_core-310db6890396577079d0cfbfa095e80faed471d7.tar.gz system_core-310db6890396577079d0cfbfa095e80faed471d7.tar.bz2 |
am a42adff9: fastboot: add the support of the second stage image [DO NOT MERGE]
* commit 'a42adff905600219cbf5ef217d2b46670225aca3':
fastboot: add the support of the second stage image [DO NOT MERGE]
Diffstat (limited to 'fastboot')
-rw-r--r-- | fastboot/fastboot.c | 45 |
1 files changed, 32 insertions, 13 deletions
diff --git a/fastboot/fastboot.c b/fastboot/fastboot.c index 64a52b5..03b3177 100644 --- a/fastboot/fastboot.c +++ b/fastboot/fastboot.c @@ -298,8 +298,9 @@ void usage(void) " Can override the fs type and/or\n" " size the bootloader reports.\n" " getvar <variable> display a bootloader variable\n" - " boot <kernel> [ <ramdisk> ] download and boot kernel\n" - " flash:raw boot <kernel> [ <ramdisk> ] create bootimage and flash it\n" + " boot <kernel> [ <ramdisk> [ <second> ] ] download and boot kernel\n" + " flash:raw boot <kernel> [ <ramdisk> [ <second> ] ] create bootimage and \n" + " flash it\n" " devices list all connected devices\n" " continue continue with autoboot\n" " reboot reboot device normally\n" @@ -327,10 +328,11 @@ void usage(void) } void *load_bootable_image(const char *kernel, const char *ramdisk, - unsigned *sz, const char *cmdline) + const char *secondstage, unsigned *sz, + const char *cmdline) { - void *kdata = 0, *rdata = 0; - unsigned ksize = 0, rsize = 0; + void *kdata = 0, *rdata = 0, *sdata = 0; + unsigned ksize = 0, rsize = 0, ssize = 0; void *bdata; unsigned bsize; @@ -366,10 +368,18 @@ void *load_bootable_image(const char *kernel, const char *ramdisk, } } + if (secondstage) { + sdata = load_file(secondstage, &ssize); + if(sdata == 0) { + fprintf(stderr,"cannot load '%s': %s\n", secondstage, strerror(errno)); + return 0; + } + } + fprintf(stderr,"creating boot image...\n"); bdata = mkbootimg(kdata, ksize, kernel_offset, rdata, rsize, ramdisk_offset, - 0, 0, second_offset, + sdata, ssize, second_offset, page_size, base_addr, tags_offset, &bsize); if(bdata == 0) { fprintf(stderr,"failed to create boot.img\n"); @@ -1147,6 +1157,7 @@ int main(int argc, char **argv) } else if(!strcmp(*argv, "boot")) { char *kname = 0; char *rname = 0; + char *sname = 0; skip(1); if (argc > 0) { kname = argv[0]; @@ -1156,7 +1167,11 @@ int main(int argc, char **argv) rname = argv[0]; skip(1); } - data = load_bootable_image(kname, rname, &sz, cmdline); + if (argc > 0) { + sname = argv[0]; + skip(1); + } + data = load_bootable_image(kname, rname, sname, &sz, cmdline); if (data == 0) return 1; fb_queue_download("boot.img", data, sz); fb_queue_command("boot", "booting"); @@ -1180,14 +1195,18 @@ int main(int argc, char **argv) char *pname = argv[1]; char *kname = argv[2]; char *rname = 0; + char *sname = 0; require(3); - if(argc > 3) { - rname = argv[3]; - skip(4); - } else { - skip(3); + skip(3); + if (argc > 0) { + rname = argv[0]; + skip(1); + } + if (argc > 0) { + sname = argv[0]; + skip(1); } - data = load_bootable_image(kname, rname, &sz, cmdline); + data = load_bootable_image(kname, rname, sname, &sz, cmdline); if (data == 0) die("cannot load bootable image"); fb_queue_flash(pname, data, sz); } else if(!strcmp(*argv, "flashall")) { |