summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorPali Rohár <pali.rohar@gmail.com>2012-06-23 13:09:44 +0200
committerPali Rohár <pali.rohar@gmail.com>2012-06-23 13:09:44 +0200
commitb4575a40fc30474920f4f867944cfd3fb7aa876c (patch)
treec9d7d64530efa54f5f3846794c0bbb66f9452691
parent8bc521f3e5e83fddc08a031aa7cf7499514ee732 (diff)
download0xFFFF-b4575a40fc30474920f4f867944cfd3fb7aa876c.tar.bz2
Rename hwrev to hwrevs and fix unpacking fiasco images. hwrevs do not have to be separated by nullterm if size of hwrev is 8.
-rw-r--r--src/fiasco.c32
-rw-r--r--src/main.h6
2 files changed, 24 insertions, 14 deletions
diff --git a/src/fiasco.c b/src/fiasco.c
index 7fccc4b..960a1de 100644
--- a/src/fiasco.c
+++ b/src/fiasco.c
@@ -125,7 +125,7 @@ int openfiasco(const char *name, const char *piece_grep, int v)
/* XXX this is not ok */
//printf("BUF8: %02x\n", buf[8]);
memset(header.device, 0, sizeof(header.device));
- memset(header.hwrev, 0, sizeof(header.hwrev));
+ memset(header.hwrevs, 0, sizeof(header.hwrevs));
memset(header.version, 0, sizeof(header.version));
if (header.layout) {
free(header.layout);
@@ -151,6 +151,11 @@ int openfiasco(const char *name, const char *piece_grep, int v)
pdata = data;
pdataend = data+i;
while(pdata<pdataend) {
+ char buf2[9];
+ if (buf[8] == '2' && pdata != data) {
+ memset(buf2, 0, 9);
+ strncpy(buf2, (char *)pdata, 8);
+ }
if (v) {
printf(" ");
if (buf[8] == '1') printf("version");
@@ -158,7 +163,9 @@ int openfiasco(const char *name, const char *piece_grep, int v)
else if (buf[8] == '2' && pdata != data) printf("hw revision");
else if (buf[8] == '3') printf("layout");
else printf("data");
- if (buf[8] != '3' && buf[8] != '/')
+ if (buf[8] == '2' && pdata != data)
+ printf(": %s\n", buf2);
+ else if (buf[8] != '3' && buf[8] != '/')
printf(": %s\n", pdata);
else
printf(": (not printing)\n");
@@ -167,19 +174,22 @@ int openfiasco(const char *name, const char *piece_grep, int v)
strcpy(header.version, (char *)pdata);
} else if (buf[8] == '2' && pdata == data) {
strcpy(header.device, (char *)pdata);
- } else if (buf[8] == '2' && pdata != data) {
- if (header.hwrev[0] == 0)
- strcpy(header.hwrev, (char *)pdata);
+ } else if (buf[8] == '2' && pdata != data) {
+ if (header.hwrevs[0] == 0)
+ strcpy(header.hwrevs, buf2);
else {
- strcat(header.hwrev, ",");
- strcat(header.hwrev, (char *)pdata);
+ strcat(header.hwrevs, ",");
+ strcat(header.hwrevs, buf2);
}
} else if (buf[8] == '3') {
if (header.layout) free(header.layout);
header.layout = malloc(strlen((char*)pdata)+1);
if (header.layout) strcpy(header.layout, (char *)pdata);
}
- pdata = pdata+strlen((char*)pdata)+1;
+ if (buf[8] == '2' && pdata != data && strlen((char *)pdata) > 8)
+ pdata += 8;
+ else
+ pdata += strlen((char*)pdata)+1;
for(;*pdata=='\0' && pdata<pdataend; pdata++);
}
} else {
@@ -195,9 +205,9 @@ int openfiasco(const char *name, const char *piece_grep, int v)
strcat(header.name, "-");
strcat(header.name, header.device);
}
- if (header.hwrev[0]) {
+ if (header.hwrevs[0]) {
strcat(header.name, "-");
- strcat(header.name, header.hwrev);
+ strcat(header.name, header.hwrevs);
}
if (header.version[0]) {
strcat(header.name, "-");
@@ -208,7 +218,7 @@ int openfiasco(const char *name, const char *piece_grep, int v)
if (v) {
printf(" version: %s\n", header.version);
printf(" device: %s\n", header.device);
- printf(" hwrev: %s\n", header.hwrev);
+ printf(" hwrevs: %s\n", header.hwrevs);
printf(" name: %s\n", header.name);
printf(" body-at: 0x%08x\n", (unsigned int)off);
}
diff --git a/src/main.h b/src/main.h
index f2c5824..42c45e4 100644
--- a/src/main.h
+++ b/src/main.h
@@ -103,11 +103,11 @@ enum {
struct header_t {
int fd;
char fwname[128];
- char version[128];
+ char name[128];
char type[128];
char device[16];
- char hwrev[128];
- char name[128];
+ char hwrevs[128];
+ char version[128];
unsigned short hash;
unsigned int size;
unsigned char *data;