int main (int argc, char **argv) { int ch, i, boot, imagefd = 0, force, unlocked; char *erase[MAX_ARGS], *device = NULL; char *fis_layout = NULL; size_t offset = 0, part_offset = 0, dump_len = 0; enum { CMD_ERASE, CMD_WRITE, CMD_UNLOCK, CMD_JFFS2WRITE, CMD_FIXTRX, CMD_FIXSEAMA, CMD_VERIFY, CMD_DUMP, } cmd = -1; erase[0] = NULL; boot = 0; force = 0; buflen = 0; quiet = 0; no_erase = 0; while ((ch = getopt(argc, argv, #ifdef FIS_SUPPORT "F:" #endif "frnqe:d:s:j:p:o:l:")) != -1) switch (ch) { case 'f': force = 1; break; case 'r': boot = 1; break; case 'n': no_erase = 1; break; case 'j': jffs2file = optarg; break; case 's': errno = 0; jffs2_skip_bytes = strtoul(optarg, 0, 0); if (errno) { fprintf(stderr, "-s: illegal numeric string\n"); usage(); } break; case 'q': quiet++; break; case 'e': i = 0; while ((erase[i] != NULL) && ((i + 1) < MAX_ARGS)) i++; erase[i++] = optarg; erase[i] = NULL; break; case 'd': jffs2dir = optarg; break; case 'p': errno = 0; part_offset = strtoul(optarg, 0, 0); if (errno) { fprintf(stderr, "-p: illegal numeric string\n"); usage(); } break; case 'l': errno = 0; dump_len = strtoul(optarg, 0, 0); if (errno) { fprintf(stderr, "-l: illegal numeric string\n"); usage(); } break; case 'o': errno = 0; offset = strtoul(optarg, 0, 0); if (errno) { fprintf(stderr, "-o: illegal numeric string\n"); usage(); } break; #ifdef FIS_SUPPORT case 'F': fis_layout = optarg; break; #endif case '?': default: usage(); } argc -= optind; argv += optind; if (argc < 2) usage(); if ((strcmp(argv[0], "unlock") == 0) && (argc == 2)) { cmd = CMD_UNLOCK; device = argv[1]; } else if ((strcmp(argv[0], "erase") == 0) && (argc == 2)) { cmd = CMD_ERASE; device = argv[1]; } else if (((strcmp(argv[0], "fixtrx") == 0) && (argc == 2)) && mtd_fixtrx) { cmd = CMD_FIXTRX; device = argv[1]; } else if (((strcmp(argv[0], "fixseama") == 0) && (argc == 2)) && mtd_fixseama) { cmd = CMD_FIXSEAMA; device = argv[1]; } else if ((strcmp(argv[0], "verify") == 0) && (argc == 3)) { cmd = CMD_VERIFY; imagefile = argv[1]; device = argv[2]; } else if ((strcmp(argv[0], "dump") == 0) && (argc == 2)) { cmd = CMD_DUMP; device = argv[1]; } else if ((strcmp(argv[0], "write") == 0) && (argc == 3)) { cmd = CMD_WRITE; device = argv[2]; if (strcmp(argv[1], "-") == 0) { imagefile = "<stdin>"; imagefd = 0; } else { imagefile = argv[1]; if ((imagefd = open(argv[1], O_RDONLY)) < 0) { fprintf(stderr, "Couldn't open image file: %s!\n", imagefile); exit(1); } } if (!mtd_check(device)) { fprintf(stderr, "Can't open device for writing!\n"); exit(1); } /* check trx file before erasing or writing anything */ if (!image_check(imagefd, device) && !force) { fprintf(stderr, "Image check failed.\n"); exit(1); } } else if ((strcmp(argv[0], "jffs2write") == 0) && (argc == 3)) { cmd = CMD_JFFS2WRITE; device = argv[2]; imagefile = argv[1]; if (!mtd_check(device)) { fprintf(stderr, "Can't open device for writing!\n"); exit(1); } } else { usage(); } sync(); i = 0; unlocked = 0; while (erase[i] != NULL) { mtd_unlock(erase[i]); mtd_erase(erase[i]); if (strcmp(erase[i], device) == 0) unlocked = 1; i++; } switch (cmd) { case CMD_UNLOCK: if (!unlocked) mtd_unlock(device); break; case CMD_VERIFY: mtd_verify(device, imagefile); break; case CMD_DUMP: mtd_dump(device, offset, dump_len); break; case CMD_ERASE: if (!unlocked) mtd_unlock(device); mtd_erase(device); break; case CMD_WRITE: if (!unlocked) mtd_unlock(device); mtd_write(imagefd, device, fis_layout, part_offset); break; case CMD_JFFS2WRITE: if (!unlocked) mtd_unlock(device); mtd_write_jffs2(device, imagefile, jffs2dir); break; case CMD_FIXTRX: if (mtd_fixtrx) { mtd_fixtrx(device, offset); } case CMD_FIXSEAMA: if (mtd_fixseama) mtd_fixseama(device, 0); break; } sync(); if (boot) do_reboot(); return 0; }
int main (int argc, char **argv) { int ch, i, boot, imagefd = 0, force, unlocked; char *erase[MAX_ARGS], *device = NULL; enum { CMD_ERASE, CMD_WRITE, CMD_UNLOCK, CMD_REFRESH, CMD_JFFS2WRITE } cmd = -1; erase[0] = NULL; boot = 0; force = 0; buflen = 0; quiet = 0; while ((ch = getopt(argc, argv, "frqe:d:j:")) != -1) switch (ch) { case 'f': force = 1; break; case 'r': boot = 1; break; case 'j': jffs2file = optarg; break; case 'q': quiet++; break; case 'e': i = 0; while ((erase[i] != NULL) && ((i + 1) < MAX_ARGS)) i++; erase[i++] = optarg; erase[i] = NULL; break; case 'd': jffs2dir = optarg; break; case '?': default: usage(); } argc -= optind; argv += optind; if (argc < 2) usage(); if ((strcmp(argv[0], "unlock") == 0) && (argc == 2)) { cmd = CMD_UNLOCK; device = argv[1]; } else if ((strcmp(argv[0], "refresh") == 0) && (argc == 2)) { cmd = CMD_REFRESH; device = argv[1]; } else if ((strcmp(argv[0], "erase") == 0) && (argc == 2)) { cmd = CMD_ERASE; device = argv[1]; } else if ((strcmp(argv[0], "write") == 0) && (argc == 3)) { cmd = CMD_WRITE; device = argv[2]; if (strcmp(argv[1], "-") == 0) { imagefile = "<stdin>"; imagefd = 0; } else { imagefile = argv[1]; if ((imagefd = open(argv[1], O_RDONLY)) < 0) { fprintf(stderr, "Couldn't open image file: %s!\n", imagefile); exit(1); } } if (!mtd_check(device)) { fprintf(stderr, "Can't open device for writing!\n"); exit(1); } /* check trx file before erasing or writing anything */ if (!image_check(imagefd, device) && !force) { fprintf(stderr, "Image check failed.\n"); exit(1); } } else if ((strcmp(argv[0], "jffs2write") == 0) && (argc == 3)) { cmd = CMD_JFFS2WRITE; device = argv[2]; imagefile = argv[1]; if (!mtd_check(device)) { fprintf(stderr, "Can't open device for writing!\n"); exit(1); } } else { usage(); } sync(); i = 0; unlocked = 0; while (erase[i] != NULL) { mtd_unlock(erase[i]); mtd_erase(erase[i]); if (strcmp(erase[i], device) == 0) unlocked = 1; i++; } switch (cmd) { case CMD_UNLOCK: if (!unlocked) mtd_unlock(device); break; case CMD_ERASE: if (!unlocked) mtd_unlock(device); mtd_erase(device); break; case CMD_WRITE: if (!unlocked) mtd_unlock(device); mtd_write(imagefd, device); break; case CMD_JFFS2WRITE: if (!unlocked) mtd_unlock(device); mtd_write_jffs2(device, imagefile, jffs2dir); break; case CMD_REFRESH: mtd_refresh(device); break; } sync(); if (boot) do_reboot(); return 0; }
int main (int argc, char **argv) { int ch, i, boot, unlock, imagefd, unlocked, offset, len; char *erase[MAX_ARGS], *device, *imagefile, *tmp; enum { CMD_ERASE, CMD_WRITE, CMD_UNLOCK } cmd; erase[0] = NULL; boot = 0; buflen = 0; quiet = 0; verbose = 0; offset = 0; len = 0; while ((ch = getopt(argc, argv, "vwrqe:o:l:")) != -1) switch (ch) { case 'r': boot = 1; break; case 'q': quiet++; break; case 'e': i = 0; while ((erase[i] != NULL) && ((i + 1) < MAX_ARGS)) i++; erase[i++] = optarg; erase[i] = NULL; break; case 'v': verbose++; break; case 'o': offset = atoi(optarg); break; case 'l': len = atoi(optarg); break; case 'w': write_check++; break; case '?': default: usage(); } argc -= optind; argv += optind; if (argc < 2) usage(); if(len == 0){ len = getFileSize(argv[1]); } if ((strcmp(argv[0], "unlock") == 0) && (argc == 2)) { cmd = CMD_UNLOCK; device = argv[1]; } else if ((strcmp(argv[0], "erase") == 0) && (argc == 2)) { cmd = CMD_ERASE; device = argv[1]; } else if ((strcmp(argv[0], "write") == 0) && (argc == 3)) { cmd = CMD_WRITE; device = argv[2]; if (strcmp(argv[1], "-") == 0) { imagefile = "<stdin>"; imagefd = 0; } else { imagefile = argv[1]; if ((imagefd = open(argv[1], O_RDONLY)) < 0) { fprintf(stderr, "Couldn't open image file: %s!\n", imagefile); exit(1); } } if (!mtd_check(device)) { fprintf(stderr, "Can't open device for writing!\n"); exit(1); } } else { usage(); } sync(); i = 0; unlocked = 0; while (erase[i] != NULL) { if (quiet < 2) fprintf(stderr, "Unlocking %s ...\n", erase[i]); mtd_unlock(erase[i]); if (quiet < 2) fprintf(stderr, "Erasing %s ...\n", erase[i]); mtd_erase(erase[i]); if (strcmp(erase[i], device) == 0) unlocked = 1; i++; } if (!unlocked) { if (quiet < 2) fprintf(stderr, "Unlocking %s ...\n", device); mtd_unlock(device); } switch (cmd) { case CMD_UNLOCK: break; case CMD_ERASE: if (quiet < 2) fprintf(stderr, "Erasing %s ...\n", device); mtd_erase(device); break; case CMD_WRITE: if (quiet < 2) fprintf(stderr, "Writing from %s to %s ... ", imagefile, device); mtd_write(imagefd, offset, len, device); #if 0 //def CONFIG_DUAL_IMAGE if (!strcmp(device, "Kernel")) { printf("Reset stable flag and try coutner.\n"); system("nvram_set uboot Image1Stable 0"); system("nvram_set uboot Image1Try 0"); } #endif if (quiet < 2) fprintf(stderr, "\n"); break; } sync(); if (boot) { fflush(stdout); syscall(SYS_reboot,LINUX_REBOOT_MAGIC1,LINUX_REBOOT_MAGIC2,LINUX_REBOOT_CMD_RESTART,NULL); } return 0; }
int mtd_main(int argc, char **argv) { int ch, i, boot, unlock, imagefd, force, quiet, unlocked; char *erase[MAX_ARGS], *device, *imagefile; enum { CMD_ERASE, CMD_WRITE, CMD_UNLOCK } cmd; erase[0] = NULL; boot = 0; force = 0; buflen = 0; quiet = 0; while ((ch = getopt(argc, argv, "frqe:")) != -1) switch (ch) { case 'f': force = 1; break; case 'r': boot = 1; break; case 'q': quiet++; break; case 'e': i = 0; while ((erase[i] != NULL) && ((i + 1) < MAX_ARGS)) i++; erase[i++] = optarg; erase[i] = NULL; break; case '?': default: usage(); } argc -= optind; argv += optind; if (argc < 2) usage(); if ((strcmp(argv[0], "unlock") == 0) && (argc == 2)) { cmd = CMD_UNLOCK; device = argv[1]; } else if ((strcmp(argv[0], "erase") == 0) && (argc == 2)) { cmd = CMD_ERASE; device = argv[1]; } else if ((strcmp(argv[0], "write") == 0) && (argc == 3)) { cmd = CMD_WRITE; device = argv[2]; if (strcmp(argv[1], "-") == 0) { imagefile = "<stdin>"; imagefd = 0; } else { imagefile = argv[1]; if ((imagefd = open(argv[1], O_RDONLY)) < 0) { fprintf(stderr, "Couldn't open image file: %s!\n", imagefile); exit(1); } } /* * check trx file before erasing or writing anything */ if (!image_check(imagefd, device)) { if ((quiet < 2) || !force) fprintf(stderr, "TRX check failed!\n"); if (!force) exit(1); } else { if (!mtd_check(device)) { fprintf(stderr, "Can't open device for writing!\n"); exit(1); } } } else { usage(); } sync(); i = 0; unlocked = 0; while (erase[i] != NULL) { if (quiet < 2) fprintf(stderr, "Unlocking %s ...\n", erase[i]); mtd_unlock(erase[i]); if (quiet < 2) fprintf(stderr, "Erasing %s ...\n", erase[i]); mtd_erase(erase[i]); if (strcmp(erase[i], device) == 0) unlocked = 1; i++; } if (!unlocked) { if (quiet < 2) fprintf(stderr, "Unlocking %s ...\n", device); mtd_unlock(device); } switch (cmd) { case CMD_UNLOCK: break; case CMD_ERASE: if (quiet < 2) fprintf(stderr, "Erasing %s ...\n", device); mtd_erase(device); break; case CMD_WRITE: if (quiet < 2) fprintf(stderr, "Writing from %s to %s ... ", imagefile, device); mtd_write(imagefd, device, quiet); if (quiet < 2) fprintf(stderr, "\n"); break; } sync(); if (boot) kill(1, 15); // send SIGTERM to init for reboot return 0; }