forked from sickcodes/dumpifs
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathexMifsLzo.c
107 lines (95 loc) · 3.06 KB
/
exMifsLzo.c
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
#include <stdio.h>
#include <stdlib.h>
#include <lzo/lzo1z.h>
typedef struct
{
unsigned int offset;
unsigned int size;
} BLOCKINFO;
static BLOCKINFO *blockInfo[40];
static BLOCKINFO **currBlockInfo = blockInfo;
static void addBlockInfo(BLOCKINFO *blk)
{
*currBlockInfo = blk;
currBlockInfo++;
}
int main(int argc, char **argv)
{
FILE *fp, *fpOut;
char buffer[0x200];
unsigned int total=0;
if(3 > argc)
{
printf("Usage %s <src lzo> <dest> [offset]\n", argv[0]);
return 0;
}
fp = fopen(argv[1], "r");
fpOut = fopen(argv[2], "w+");
if(fp){
int blockSize;
unsigned int totalSize;
int v2 = 0, maxBlkSize;
int inputPtr = (int) fp;
int nextImgPtr = (int)buffer;
int v7 = 0;
int StartOffset = 0x800; // Start offset of real content
unsigned int v10[6];
int *origImgStart = (int*)buffer;
int contentOffset;
int *pRead;
BLOCKINFO **readBlk;
if(4 == argc)
StartOffset=atoi(argv[3]);
fread(buffer, 1, sizeof(buffer), fp);
pRead = buffer;
printf("Test... *((int*)pRead + 1) = %x, *((int*)pRead + 2) = %x\n", *((int*)pRead + 1), *((int*)pRead + 2));
printf("Type=%c%c%c%c\n", (char)buffer[0], (char)buffer[1], (char)buffer[2], (char)buffer[3]);
printf("Buffer @0x%X\n", (unsigned int)buffer);
contentOffset = *((unsigned int *)buffer + 1);
totalSize = *((unsigned int *)buffer + 2);
printf("contentOffset=0x%x @ 0x%X %d blocks. totalSize=%d(%x) @ 0x%X\n", contentOffset, (unsigned int *)buffer + 1, (unsigned int) totalSize, (unsigned int) totalSize, (unsigned int *)buffer + 2);
for(pRead = (int*)&buffer[8];pRead < (buffer+sizeof(buffer));pRead++)
{
int gap, unitSize;
BLOCKINFO *blk = (BLOCKINFO*) malloc(sizeof(BLOCKINFO));
if(0 == *pRead) break;
v2++;
unitSize = ((0x200 - (*pRead & 0x1ff)) + *pRead);
blk->offset = v7 + StartOffset;
blk->size = *pRead;
//printf("%d, unitSize=0x%x, offset=0x%x\n", *pRead, unitSize, v7 + 2048);
addBlockInfo(blk);
v7 += unitSize;
}
printf("Block count=%d Total Size=%d + 2048=%d (%x)\n", v2, v7, v7+2048, v7+2048);
v7=0;maxBlkSize=0;
if(lzo_init() != LZO_E_OK) {
error(1, "decompression init failure");
return 0;
}
for(readBlk=blockInfo;readBlk!=currBlockInfo;readBlk++)
{
char *extractBuffer = (char*)malloc((*readBlk)->size * 10);
char *buf = (char*) malloc((*readBlk)->size);
unsigned out_len = 0;
printf("Blk#%02d bs=0x%x, offset=0x%x\n", v7++, (*readBlk)->size, (*readBlk)->offset);
fseek(fp, (*readBlk)->offset, SEEK_SET);
if(maxBlkSize < (*readBlk)->size)
maxBlkSize = (*readBlk)->size;
if(0<fread(buf, 1, (*readBlk)->size, fp))
{
//printf("lzo1z_decompress(buf(%x), (*readBlk)->size=%d, extractBuffer(%x), ", buf, (*readBlk)->size, extractBuffer);
lzo1z_decompress(buf, (*readBlk)->size, extractBuffer, &out_len, NULL);
printf("out_len=%d, NULL);\n", out_len);
fwrite(extractBuffer, 1, out_len, fpOut);
}
free(*readBlk);
free(extractBuffer);
//free(buf);
//printf("Next\n");
}
fclose(fp);
fclose(fpOut);
printf("Max block size is %d (0x%x)\n", maxBlkSize, maxBlkSize);
}
}