102 lines
3.9 KiB
C
Raw Normal View History

2017-02-28 05:37:47 +08:00
#include "magiskboot.h"
/********************
Patch Boot Image
*********************/
2017-02-25 03:29:12 +08:00
static void usage(char *arg0) {
2017-04-28 03:15:48 +08:00
fprintf(stderr,
"%s --unpack <bootimg>\n"
" Unpack <bootimg> to kernel, ramdisk.cpio, (second), (dtb) into the\n current directory\n"
"\n"
"%s --repack <origbootimg> [outbootimg]\n"
" Repack kernel, ramdisk.cpio[.ext], second, dtb... from current directory\n"
" to [outbootimg], or new-boot.img if not specified.\n"
" It will compress ramdisk.cpio with the same method used in <origbootimg>\n"
" if exists, or attempt to find ramdisk.cpio.[ext], and repack\n"
" directly with the compressed ramdisk file\n"
"\n"
"%s --hexpatch <file> <hexpattern1> <hexpattern2>\n"
" Search <hexpattern1> in <file>, and replace with <hexpattern2>\n"
"\n"
"%s --cpio-<cmd> <incpio> [flags...] [params...]\n"
" Do cpio related cmds to <incpio> (modifications are done directly)\n Supported commands and params:\n"
" -rm [-r] <entry>\n Remove entry from <incpio>, flag -r to remove recursively\n"
" -mkdir <mode> <entry>\n Create directory as an <entry>\n"
" -add <mode> <entry> <infile>\n Add <infile> as an <entry>; replaces <entry> if already exists\n"
2017-09-09 23:05:50 +08:00
" -mv <from-entry> <to-entry>\n Move <from-entry> to <to-entry>\n"
" -extract <entry> <outfile>\n Extract <entry> to <outfile>\n"
" -test \n Return value: 0/not patched 1/Magisk 2/Other (e.g. phh, SuperSU)\n"
" -patch <KEEPVERITY> <KEEPFORCEENCRYPT>\n Patch cpio for Magisk. KEEP**** are true/false values\n"
" -backup <origcpio>\n Create ramdisk backups into <incpio> from <origcpio>\n"
" -restore\n Restore ramdisk from ramdisk backup within <incpio>\n"
" -stocksha1\n Get stock boot SHA1 recorded within <incpio>\n"
2017-04-28 03:15:48 +08:00
"\n"
"%s --compress[=method] <infile> [outfile]\n"
" Compress <infile> with [method] (default: gzip), optionally to [outfile]\n Supported methods: "
, arg0, arg0, arg0, arg0, arg0);
for (int i = 0; SUP_LIST[i]; ++i)
fprintf(stderr, "%s ", SUP_LIST[i]);
fprintf(stderr,
"\n"
"\n"
"%s --decompress <infile> [outfile]\n"
" Detect method and decompress <infile>, optionally to [outfile]\n Supported methods: "
, arg0);
for (int i = 0; SUP_LIST[i]; ++i)
fprintf(stderr, "%s ", SUP_LIST[i]);
fprintf(stderr,
"\n"
"\n"
"%s --sha1 <file>\n"
" Print the SHA1 checksum for <file>\n"
"\n"
"%s --cleanup\n"
" Cleanup the current working directory\n"
"\n"
, arg0, arg0);
2017-03-08 00:54:23 +08:00
2017-02-25 03:29:12 +08:00
exit(1);
}
2017-02-24 14:58:44 +08:00
int main(int argc, char *argv[]) {
2017-07-18 11:53:28 +08:00
fprintf(stderr, "MagiskBoot v" xstr(MAGISK_VERSION) "(" xstr(MAGISK_VER_CODE) ") (by topjohnwu) - Boot Image Modification Tool\n\n");
2017-03-08 00:54:23 +08:00
if (argc > 1 && strcmp(argv[1], "--cleanup") == 0) {
cleanup();
2017-03-10 04:08:17 +08:00
} else if (argc > 2 && strcmp(argv[1], "--sha1") == 0) {
char sha1[21], *buf;
size_t size;
2017-09-12 15:27:28 +08:00
mmap_ro(argv[2], (void **) &buf, &size);
2017-03-10 04:08:17 +08:00
SHA1(sha1, buf, size);
for (int i = 0; i < 20; ++i)
2017-07-25 02:02:19 +08:00
printf("%02x", sha1[i]);
printf("\n");
2017-03-10 04:08:17 +08:00
munmap(buf, size);
2017-03-08 00:54:23 +08:00
} else if (argc > 2 && strcmp(argv[1], "--unpack") == 0) {
unpack(argv[2]);
} else if (argc > 2 && strcmp(argv[1], "--repack") == 0) {
repack(argv[2], argc > 3 ? argv[3] : NEW_BOOT);
} else if (argc > 2 && strcmp(argv[1], "--decompress") == 0) {
decomp_file(argv[2], argc > 3 ? argv[3] : NULL);
2017-03-08 00:54:23 +08:00
} else if (argc > 2 && strncmp(argv[1], "--compress", 10) == 0) {
char *method;
method = strchr(argv[1], '=');
if (method == NULL) method = "gzip";
else method++;
comp_file(method, argv[2], argc > 3 ? argv[3] : NULL);
2017-03-08 00:54:23 +08:00
} else if (argc > 4 && strcmp(argv[1], "--hexpatch") == 0) {
hexpatch(argv[2], argv[3], argv[4]);
2017-03-10 04:08:17 +08:00
} else if (argc > 2 && strncmp(argv[1], "--cpio", 6) == 0) {
2017-03-08 00:54:23 +08:00
char *command;
command = strchr(argv[1] + 2, '-');
if (command == NULL) usage(argv[0]);
2017-03-10 04:08:17 +08:00
else ++command;
if (cpio_commands(command, argc - 2, argv + 2)) usage(argv[0]);
2017-03-08 00:54:23 +08:00
} else {
usage(argv[0]);
}
2017-02-25 03:29:12 +08:00
2017-03-08 00:54:23 +08:00
return 0;
2017-02-24 14:58:44 +08:00
}