mirror of
https://github.com/openwrt/openwrt.git
synced 2025-01-25 21:59:32 +00:00
check if firmware is trx and is not too big, before unlocking/erasing/writing anything
SVN-Revision: 1486
This commit is contained in:
parent
7c0bb49b08
commit
8701e1a3d9
@ -54,6 +54,73 @@ struct trx_header {
|
|||||||
uint32_t offsets[3]; /* Offsets of partitions from start of header */
|
uint32_t offsets[3]; /* Offsets of partitions from start of header */
|
||||||
};
|
};
|
||||||
|
|
||||||
|
int
|
||||||
|
trx_check(const char *trxfile, const char *mtd)
|
||||||
|
{
|
||||||
|
struct mtd_info_user mtdInfo;
|
||||||
|
int trxfd, fd;
|
||||||
|
size_t count;
|
||||||
|
struct trx_header trx;
|
||||||
|
struct stat trxstat;
|
||||||
|
|
||||||
|
trxfd = open(trxfile,O_RDONLY);
|
||||||
|
if(trxfd < 0) {
|
||||||
|
fprintf(stderr, "Could not open trx image: %s\n", trxfile);
|
||||||
|
exit(1);
|
||||||
|
}
|
||||||
|
|
||||||
|
if (fstat(trxfd,&trxstat) < 0) {
|
||||||
|
fprintf(stderr, "Could not get trx image file status: %s\n", trxfile);
|
||||||
|
close(trxfd);
|
||||||
|
exit(1);
|
||||||
|
}
|
||||||
|
|
||||||
|
count = read(trxfd, &trx, sizeof(struct trx_header));
|
||||||
|
if (count < sizeof(struct trx_header)) {
|
||||||
|
fprintf(stderr, "Could not trx header, file too small (%ld bytes)\n", count);
|
||||||
|
close(trxfd);
|
||||||
|
exit(1);
|
||||||
|
}
|
||||||
|
|
||||||
|
if (trx.magic != TRX_MAGIC || trx.len < sizeof(struct trx_header)) {
|
||||||
|
fprintf(stderr, "Bad trx header\n");
|
||||||
|
fprintf(stderr, "If this is a firmware in bin format, like some of the\n"
|
||||||
|
"original firmware files are, use following command to convert to trx:\n"
|
||||||
|
"dd if=firmware.bin of=firmware.trx bs=32 skip=1\n");
|
||||||
|
close(trxfd);
|
||||||
|
exit(1);
|
||||||
|
}
|
||||||
|
|
||||||
|
lseek(trxfd, 0, SEEK_SET);
|
||||||
|
|
||||||
|
/* check if image fits to mtd device */
|
||||||
|
|
||||||
|
fd = mtd_open(mtd, O_RDWR);
|
||||||
|
if(fd < 0) {
|
||||||
|
fprintf(stderr, "Could not open mtd device: %s\n", mtd);
|
||||||
|
exit(1);
|
||||||
|
}
|
||||||
|
|
||||||
|
if(ioctl(fd, MEMGETINFO, &mtdInfo)) {
|
||||||
|
fprintf(stderr, "Could not get MTD device info from %s\n", mtd);
|
||||||
|
close(fd);
|
||||||
|
exit(1);
|
||||||
|
}
|
||||||
|
|
||||||
|
if(mtdInfo.size < trxstat.st_size) {
|
||||||
|
fprintf(stderr, "Image too big for partition: %s\n", mtd);
|
||||||
|
close(trxfd);
|
||||||
|
close(fd);
|
||||||
|
exit(1);
|
||||||
|
}
|
||||||
|
|
||||||
|
printf("Writing %s to %s ...\n", trxfile, mtd);
|
||||||
|
|
||||||
|
close(fd);
|
||||||
|
|
||||||
|
return(trxfd);
|
||||||
|
}
|
||||||
|
|
||||||
int
|
int
|
||||||
mtd_unlock(const char *mtd)
|
mtd_unlock(const char *mtd)
|
||||||
{
|
{
|
||||||
@ -146,46 +213,21 @@ mtd_erase(const char *mtd)
|
|||||||
}
|
}
|
||||||
|
|
||||||
int
|
int
|
||||||
mtd_write(const char *trxfile, const char *mtd)
|
mtd_write(int trxfd, const char *mtd)
|
||||||
{
|
{
|
||||||
int fd,trxfd,i;
|
int fd,i;
|
||||||
struct trx_header trx;
|
size_t result,size,written;
|
||||||
size_t count,result,size,written;
|
|
||||||
struct mtd_info_user mtdInfo;
|
struct mtd_info_user mtdInfo;
|
||||||
struct erase_info_user mtdEraseInfo;
|
struct erase_info_user mtdEraseInfo;
|
||||||
struct stat trxstat;
|
|
||||||
unsigned char src[BUFSIZE],dest[BUFSIZE];
|
unsigned char src[BUFSIZE],dest[BUFSIZE];
|
||||||
|
struct stat trxstat;
|
||||||
trxfd = open(trxfile,O_RDONLY);
|
|
||||||
if(trxfd < 0) {
|
|
||||||
fprintf(stderr, "Could not open trx image: %s\n", trxfile);
|
|
||||||
exit(1);
|
|
||||||
}
|
|
||||||
|
|
||||||
if (fstat(trxfd,&trxstat) < 0) {
|
if (fstat(trxfd,&trxstat) < 0) {
|
||||||
fprintf(stderr, "Could not get trx image file status: %s\n", trxfile);
|
fprintf(stderr, "Could not get trx image file status\n");
|
||||||
close(trxfd);
|
close(trxfd);
|
||||||
exit(1);
|
exit(1);
|
||||||
}
|
}
|
||||||
|
|
||||||
count = read(trxfd, &trx, sizeof(struct trx_header));
|
|
||||||
if (count < sizeof(struct trx_header)) {
|
|
||||||
fprintf(stderr, "Could not trx header, file too small (%ld bytes)\n", count);
|
|
||||||
close(trxfd);
|
|
||||||
exit(1);
|
|
||||||
}
|
|
||||||
|
|
||||||
if (trx.magic != TRX_MAGIC || trx.len < sizeof(struct trx_header)) {
|
|
||||||
fprintf(stderr, "Bad trx header\n");
|
|
||||||
fprintf(stderr, "If this is a firmware in bin format, like some of the\n"
|
|
||||||
"original firmware files are, use following command to convert to trx:\n"
|
|
||||||
"dd if=firmware.bin of=firmware.trx bs=32 skip=1\n");
|
|
||||||
close(trxfd);
|
|
||||||
exit(1);
|
|
||||||
}
|
|
||||||
|
|
||||||
lseek(trxfd, 0, SEEK_SET);
|
|
||||||
|
|
||||||
fd = mtd_open(mtd, O_RDWR);
|
fd = mtd_open(mtd, O_RDWR);
|
||||||
if(fd < 0) {
|
if(fd < 0) {
|
||||||
fprintf(stderr, "Could not open mtd device: %s\n", mtd);
|
fprintf(stderr, "Could not open mtd device: %s\n", mtd);
|
||||||
@ -198,14 +240,6 @@ mtd_write(const char *trxfile, const char *mtd)
|
|||||||
exit(1);
|
exit(1);
|
||||||
}
|
}
|
||||||
|
|
||||||
if(mtdInfo.size < trxstat.st_size) {
|
|
||||||
fprintf(stderr, "Image too big for partition: %s\n", mtd);
|
|
||||||
close(trxfd);
|
|
||||||
exit(1);
|
|
||||||
}
|
|
||||||
|
|
||||||
printf("Writing %s to %s ...\n", trxfile, mtd);
|
|
||||||
|
|
||||||
mtdEraseInfo.start = 0;
|
mtdEraseInfo.start = 0;
|
||||||
mtdEraseInfo.length = trxstat.st_size & ~(mtdInfo.erasesize -1);
|
mtdEraseInfo.length = trxstat.st_size & ~(mtdInfo.erasesize -1);
|
||||||
if(trxstat.st_size % mtdInfo.erasesize) mtdEraseInfo.length += mtdInfo.erasesize;
|
if(trxstat.st_size % mtdInfo.erasesize) mtdEraseInfo.length += mtdInfo.erasesize;
|
||||||
@ -257,7 +291,7 @@ void usage(void)
|
|||||||
|
|
||||||
int main (int argc, char **argv)
|
int main (int argc, char **argv)
|
||||||
{
|
{
|
||||||
int ch, i, boot, unlock;
|
int ch, i, boot, unlock, trxfd;
|
||||||
char *erase[MAX_ARGS], *device;
|
char *erase[MAX_ARGS], *device;
|
||||||
enum {
|
enum {
|
||||||
CMD_ERASE,
|
CMD_ERASE,
|
||||||
@ -301,6 +335,8 @@ int main (int argc, char **argv)
|
|||||||
} else if ((strcmp(argv[0], "write") == 0) && (argc == 3)) {
|
} else if ((strcmp(argv[0], "write") == 0) && (argc == 3)) {
|
||||||
cmd = CMD_WRITE;
|
cmd = CMD_WRITE;
|
||||||
device = argv[2];
|
device = argv[2];
|
||||||
|
/* check trx file before erasing or writing anything */
|
||||||
|
trxfd = trx_check(argv[1], device);
|
||||||
} else {
|
} else {
|
||||||
usage();
|
usage();
|
||||||
}
|
}
|
||||||
@ -323,7 +359,7 @@ int main (int argc, char **argv)
|
|||||||
mtd_erase(device);
|
mtd_erase(device);
|
||||||
break;
|
break;
|
||||||
case CMD_WRITE:
|
case CMD_WRITE:
|
||||||
mtd_write(argv[1], device);
|
mtd_write(trxfd, device);
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Loading…
x
Reference in New Issue
Block a user