From 85fdbfb35437f5ab8a449235f2c86f410770925f Mon Sep 17 00:00:00 2001 From: pancake Date: Mon, 8 Oct 2007 00:25:56 +0200 Subject: * Finally implement the support for the FIASCO firmware format * Up version to 0.3 * Alphabetically order the help message flags * Cleaner short help message * Pseudo-api for creating firmwares (not yet finished) * Add '-F' flag to flash from a fiasco image --- src/fiasco.c | 268 +++++++++++++++++++++++++++++++++++++++-------------------- 1 file changed, 180 insertions(+), 88 deletions(-) (limited to 'src/fiasco.c') diff --git a/src/fiasco.c b/src/fiasco.c index 31198dd..d31c846 100644 --- a/src/fiasco.c +++ b/src/fiasco.c @@ -16,119 +16,211 @@ * along with this program. If not, see . */ -#include "main.h" #include #include #include +#include #include #include #include -#include +#include +#include "main.h" -#warning The FIASCO format is not yet fully implemented. +void (*fiasco_callback)(struct header_t *header) = NULL; -off_t piece_header_to_size(unsigned char *header) +int openfiasco(char *name) { - off_t sz = 0; - sz += header[0x15+3]; - sz += header[0x15+2] << 8; - sz += header[0x15+1] << 16; - sz += header[0x15+0] << 24; - return sz; -} + struct header_t header; + unsigned char buf[128]; + unsigned char data[128]; + unsigned int namelen; + int i; + int fd = open(name, O_RDONLY); -int piece_header_is_valid(unsigned char *header) -{ - if (header[0]=='T' && header[1]=='\x02') + if (fd == -1) { + fprintf(stderr, "Cannot open %s\n", name); return 1; + } + + /* read header */ + read(fd, buf, 5); + if (buf[0] != 0xb4) { + printf("Invalid header\n"); + return close(fd); + } + memcpy(&namelen,buf+1,4); + namelen = ntohl(namelen); + if (namelen>128) { + printf("Stupid length at header. Is this a joke?\n"); + return close(fd); + } + memset(buf,'\0', 128); + read(fd, buf, namelen); + // 6 first bytes are unknown + // buf 00 00 00 VERSION e8 0e +// printf("6Bytes: %02x %02x %02x %02x %02x %02x\n", +// buf[0], buf[1], buf[2], buf[3], buf[4], buf[5]); + printf("Fiasco version: %2d\n", buf[3]); + strcpy(header.fwname, buf+6); + for(i=6;i'0' && buf[8] < '9') { + if (read(fd, data, 1)<1) + break; + i = data[0]; + if (read(fd, data, i)name); + printf("DATA: %02x\n", header->data[0]); +} - // print version header - if (read(fd, version, 55) != 55) { - printf("Error reading fiasco version.\n"); - goto __fiasco_read_image_end; +int main(int argc, char **argv) +{ + if (argc!=2) { + printf("Usage: unfiasco [file]\n"); + return 1; } - printf("# Fiasco header information:\n"); - printf("# ==========================\n"); - printf("# firmware type: %s\n", version); - version2 = version+strlen((char *)version)+3; - if (*version2=='.') - printf("firmware version: (null) (old firmware? no version string found?)\n"); - else printf("firmware version: %s\n", version2); - - // pieces: - // after the version2 string starts the header-body loop love - lseek(fd, 0xf + strlen(version2) + strlen(version), SEEK_SET); - do { - char piece_header[30]; - char description[256]; - unsigned char desc_len; - char *name; - off_t size; - off_t tmp = lseek(fd, 0, SEEK_CUR); - - size = read(fd, piece_header, 30); - if (size != 30) { - fprintf(stderr, "Unexpected end of file\n"); - break; - } - dump_bytes(piece_header,30); - if (!piece_header_is_valid(piece_header)) { - fprintf(stderr, "Oops. Invalid piece header.\n"); - break; - } - size = piece_header_to_size(piece_header); - name = piece_header_to_name(piece_header); - printf("# %s is %lld bytes\n", name, size); - - read(fd, description, 255); - printf("# version: %s\n", description); - /* lseek foreach subimage */ - lseek(fd, tmp, SEEK_SET); - lseek(fd, strlen(description) + 0x20, SEEK_CUR); - printf("rsc '%s' %lld '%s.bin' 0 %lld\n", file, lseek(fd,0,SEEK_CUR), name, size); - lseek(fd, size, SEEK_CUR); - } while(1); - - //printf("Image '%s', size %d bytes.\n", image, size); - -__fiasco_read_image_end: +/* + fd = fiasco_new("myfiasco", "pancake-edition"); + fiasco_add(fd, "kernel", "zImage", "2.6.22"); close(fd); - return 0; +*/ + +// fiasco_callback = &my_callback; + + return openfiasco(argv[1]); } +#endif -- cgit v1.2.3