#include "magiskboot.h" /******************** Patch Boot Image *********************/ static void usage(char *arg0) { fprintf(stderr, "%s --unpack \n" " Unpack to kernel, ramdisk.cpio, (second), (dtb) into the\n current directory\n" "\n" "%s --repack [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 \n" " if exists, or attempt to find ramdisk.cpio.[ext], and repack\n" " directly with the compressed ramdisk file\n" "\n" "%s --hexpatch \n" " Search in , and replace with \n" "\n" "%s --cpio- [flags...] [params...]\n" " Do cpio related cmds to (modifications are done directly)\n Supported commands:\n" " --cpio-rm [-r] \n Remove entry from cpio, flag -r to remove recursively\n" " --cpio-mkdir \n Create directory as an \n" " --cpio-add \n Add as an ; replaces if already exists\n" " --cpio-extract \n Extract to \n" " --cpio-test \n Return value: 0/not patched 1/Magisk 2/Other (e.g. phh, SuperSU)\n" " --cpio-patch \n Patch cpio for Magisk. KEEP**** are true/false values\n" " --cpio-backup \n Create ramdisk backups into from \n" " --cpio-restore \n Restore ramdisk from ramdisk backup within \n" "\n" "%s --compress[=method] [outfile]\n" " Compress 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 [outfile]\n" " Detect method and decompress , 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 \n" " Print the SHA1 checksum for \n" "\n" "%s --cleanup\n" " Cleanup the current working directory\n" "\n" , arg0, arg0); exit(1); } int main(int argc, char *argv[]) { fprintf(stderr, "MagiskBoot v" xstr(MAGISK_VERSION) "(" xstr(MAGISK_VER_CODE) ") (by topjohnwu) - Boot Image Modification Tool\n\n"); if (argc > 1 && strcmp(argv[1], "--cleanup") == 0) { cleanup(); } else if (argc > 2 && strcmp(argv[1], "--sha1") == 0) { char sha1[21], *buf; size_t size; mmap_ro(argv[2], (unsigned char **) &buf, &size); SHA1(sha1, buf, size); for (int i = 0; i < 20; ++i) fprintf(stderr, "%02x", sha1[i]); fprintf(stderr, "\n"); munmap(buf, size); } 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); } 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); } else if (argc > 4 && strcmp(argv[1], "--hexpatch") == 0) { hexpatch(argv[2], argv[3], argv[4]); } else if (argc > 2 && strncmp(argv[1], "--cpio", 6) == 0) { char *command; command = strchr(argv[1] + 2, '-'); if (command == NULL) usage(argv[0]); else ++command; if (cpio_commands(command, argc - 2, argv + 2)) usage(argv[0]); } else { usage(argv[0]); } return 0; }