mirror of
https://github.com/deater/dos33fsprogs.git
synced 2025-01-09 10:30:21 +00:00
305 lines
8.8 KiB
C
305 lines
8.8 KiB
C
#include <stdio.h>
|
|
#include <string.h>
|
|
|
|
static unsigned char out[256];
|
|
|
|
static unsigned char PT3VolumeTable_33_34[]={
|
|
0x0,0x0,0x0,0x0,0x0,0x0,0x0,0x0,0x0,0x0,0x0,0x0,0x0,0x0,0x0,0x0, //0
|
|
0x0,0x0,0x0,0x0,0x0,0x0,0x0,0x0,0x1,0x1,0x1,0x1,0x1,0x1,0x1,0x1, //1
|
|
0x0,0x0,0x0,0x0,0x0,0x0,0x1,0x1,0x1,0x1,0x1,0x2,0x2,0x2,0x2,0x2, //2
|
|
0x0,0x0,0x0,0x0,0x1,0x1,0x1,0x1,0x2,0x2,0x2,0x2,0x3,0x3,0x3,0x3, //3
|
|
0x0,0x0,0x0,0x0,0x1,0x1,0x1,0x2,0x2,0x2,0x3,0x3,0x3,0x4,0x4,0x4, //4
|
|
0x0,0x0,0x0,0x1,0x1,0x1,0x2,0x2,0x3,0x3,0x3,0x4,0x4,0x4,0x5,0x5, //5
|
|
0x0,0x0,0x0,0x1,0x1,0x2,0x2,0x3,0x3,0x3,0x4,0x4,0x5,0x5,0x6,0x6, //6
|
|
0x0,0x0,0x1,0x1,0x2,0x2,0x3,0x3,0x4,0x4,0x5,0x5,0x6,0x6,0x7,0x7, //7
|
|
0x0,0x0,0x1,0x1,0x2,0x2,0x3,0x3,0x4,0x5,0x5,0x6,0x6,0x7,0x7,0x8, //8
|
|
0x0,0x0,0x1,0x1,0x2,0x3,0x3,0x4,0x5,0x5,0x6,0x6,0x7,0x8,0x8,0x9, //9
|
|
0x0,0x0,0x1,0x2,0x2,0x3,0x4,0x4,0x5,0x6,0x6,0x7,0x8,0x8,0x9,0xA, //a
|
|
0x0,0x0,0x1,0x2,0x3,0x3,0x4,0x5,0x6,0x6,0x7,0x8,0x9,0x9,0xA,0xB, //b
|
|
0x0,0x0,0x1,0x2,0x3,0x4,0x4,0x5,0x6,0x7,0x8,0x8,0x9,0xA,0xB,0xC, //c
|
|
0x0,0x0,0x1,0x2,0x3,0x4,0x5,0x6,0x7,0x7,0x8,0x9,0xA,0xB,0xC,0xD, //d
|
|
0x0,0x0,0x1,0x2,0x3,0x4,0x5,0x6,0x7,0x8,0x9,0xA,0xB,0xC,0xD,0xE, //e
|
|
0x0,0x1,0x2,0x3,0x4,0x5,0x6,0x7,0x8,0x9,0xA,0xB,0xC,0xD,0xE,0xF, //f
|
|
};
|
|
|
|
|
|
static unsigned char PT3VolumeTable_35[]={
|
|
0x0,0x0,0x0,0x0,0x0,0x0,0x0,0x0,0x0,0x0,0x0,0x0,0x0,0x0,0x0,0x0,
|
|
0x0,0x0,0x0,0x0,0x0,0x0,0x0,0x0,0x1,0x1,0x1,0x1,0x1,0x1,0x1,0x1,
|
|
0x0,0x0,0x0,0x0,0x1,0x1,0x1,0x1,0x1,0x1,0x1,0x1,0x2,0x2,0x2,0x2,
|
|
0x0,0x0,0x0,0x1,0x1,0x1,0x1,0x1,0x2,0x2,0x2,0x2,0x2,0x3,0x3,0x3,
|
|
0x0,0x0,0x1,0x1,0x1,0x1,0x2,0x2,0x2,0x2,0x3,0x3,0x3,0x3,0x4,0x4,
|
|
0x0,0x0,0x1,0x1,0x1,0x2,0x2,0x2,0x3,0x3,0x3,0x4,0x4,0x4,0x5,0x5,
|
|
0x0,0x0,0x1,0x1,0x2,0x2,0x2,0x3,0x3,0x4,0x4,0x4,0x5,0x5,0x6,0x6,
|
|
0x0,0x0,0x1,0x1,0x2,0x2,0x3,0x3,0x4,0x4,0x5,0x5,0x6,0x6,0x7,0x7,
|
|
0x0,0x1,0x1,0x2,0x2,0x3,0x3,0x4,0x4,0x5,0x5,0x6,0x6,0x7,0x7,0x8,
|
|
0x0,0x1,0x1,0x2,0x2,0x3,0x4,0x4,0x5,0x5,0x6,0x7,0x7,0x8,0x8,0x9,
|
|
0x0,0x1,0x1,0x2,0x3,0x3,0x4,0x5,0x5,0x6,0x7,0x7,0x8,0x9,0x9,0xA,
|
|
0x0,0x1,0x1,0x2,0x3,0x4,0x4,0x5,0x6,0x7,0x7,0x8,0x9,0xA,0xA,0xB,
|
|
0x0,0x1,0x2,0x2,0x3,0x4,0x5,0x6,0x6,0x7,0x8,0x9,0xA,0xA,0xB,0xC,
|
|
0x0,0x1,0x2,0x3,0x3,0x4,0x5,0x6,0x7,0x8,0x9,0xA,0xA,0xB,0xC,0xD,
|
|
0x0,0x1,0x2,0x3,0x4,0x5,0x6,0x7,0x7,0x8,0x9,0xA,0xB,0xC,0xD,0xE,
|
|
0x0,0x1,0x2,0x3,0x4,0x5,0x6,0x7,0x8,0x9,0xA,0xB,0xC,0xD,0xE,0xF,
|
|
};
|
|
|
|
static unsigned char gen1[]={
|
|
// 16 0
|
|
0xf0,
|
|
// 8 0,8 1
|
|
0x70,0x71,
|
|
// 6 0,5 1,5 2
|
|
0x50,0x41,0x42,
|
|
// 4 0,4 1,4 2,4 3
|
|
0x30,0x31,0x32,0x33,
|
|
// 4 0,3 1,3 2,3 3,3 4
|
|
0x30,0x21,0x22,0x23,0x24,
|
|
// 3 0,3 1,2 2,3 3,3 4,2 5
|
|
0x20,0x21,0x12,0x23,0x24,0x15,
|
|
// 3 0,2 1,2 2,3 3,2 4,2 5,2 6
|
|
0x20,0x11,0x12,0x23,0x14,0x15,0x16,
|
|
// 2 0,2 1,2 2,2 3,2 4,2 5,2 6,2 7
|
|
0x10,0x11,0x12,0x13,0x14,0x15,0x16,0x17,
|
|
// 2 0,2 1,2 2,2 3,1 4,2 5,2 6,2 7,1 8
|
|
0x10,0x11,0x12,0x13,0x04,0x15,0x16,0x17,0x08,
|
|
// 2 0,2 1,1 2,2 3,1 4,2 5,2 6,1 7,2 8,1 9
|
|
0x10,0x11,0x02,0x13,0x04,0x15,0x16,0x07,0x18,0x09,
|
|
// 2 0,1 1,2 2,1 3,2 4,1 5,2 6,1 7,2 8,1 9,1 A
|
|
0x10,0x01,0x12,0x03,0x14,0x05,0x16,0x07,0x18,0x09,0x0a,
|
|
// 2 0,1 1,1 2,2 3,1 4,1 5,2 6,1 7,1 8,2 9,1 A,1 B
|
|
0x10,0x01,0x02,0x13,0x04,0x05,0x16,0x07,0x08,0x19,0x0a,0x0b,
|
|
// 2 0,1 1,1 2,1 3,2 4,1 5,1 6,1 7,2 8,1 9,1 A,1 B,1 C
|
|
0x10,0x01,0x02,0x03,0x14,0x05,0x06,0x07,0x18,0x09,0x0a,0x0b,0x0c,
|
|
// 2 0,1 1,1 2,1 3,1 4,1 5,1 6,2 7,1 8,1 9,1 A,1 B,1 C,1 D
|
|
0x10,0x01,0x02,0x03,0x04,0x05,0x06,0x17,0x08,0x09,0x0a,0x0b,0x0c,0x0d,
|
|
// 2 0,1 1,1 2,1 3,1 4,1 5,1 6,1 7,1 8,1 9,1 A,1 B,1 C,1 D,1 E
|
|
0x10,0x01,0x02,0x03,0x04,0x05,0x06,0x07,0x08,0x09,0x0a,0x0b,0x0c,0x0d,0x0e,
|
|
// 1 0,1 1,1 2,1 3,1 4,1 5,1 6,1 7,1 8,1 9,1 A,1 B,1 C,1 D,1 E,1 F
|
|
0x00,0x01,0x02,0x03,0x04,0x05,0x06,0x07,0x08,0x09,0x0a,0x0b,0x0c,0x0d,0x0e,0x0f,
|
|
};
|
|
|
|
static void gen_table_1(void) {
|
|
int total=0,temp,index=0,i;
|
|
|
|
while(total<256) {
|
|
temp=gen1[index];
|
|
for(i=0;i<(temp>>4)+1;i++) {
|
|
out[total]=temp&0xf;
|
|
total++;
|
|
}
|
|
index++;
|
|
}
|
|
}
|
|
|
|
|
|
|
|
static unsigned char gen2[]={
|
|
// 16 0 SKIP this always 0
|
|
|
|
// 8 0,8 1
|
|
// 770 = 111 1,11 00
|
|
0xfc,
|
|
// 6 0,5 1,5 2
|
|
// 544 = 101 1,00 00 -- 400 = 100,0 0000
|
|
0xb0,0x80,
|
|
// 4 0,4 1,4 2,4 3
|
|
// 330 330 = 011 0,11 00 011 0,11 00
|
|
0x6c,0x6c,
|
|
// 4 0,3 1,3 2,3 3,3 4
|
|
// 323 220 = 0110,1011 0100,1000
|
|
0x6b,0x48,
|
|
// 3 0,3 1,2 2,3 3,3 4,2 5
|
|
// 222 222 = 010 0,10 10 010 0,10 10
|
|
0x4a,0x4a,
|
|
// 3 0,2 1,2 2,3 3,2 4,2 5,2 6
|
|
// 212 212 100 = 010 0,01 10 010 0,10 01 00100000
|
|
0x46,0x46,0x20,
|
|
// 2 0,2 1,2 2,2 3,2 4,2 5,2 6,2 7
|
|
// 112 112 110 = 0010,0110 0010,0110 0010,01 00
|
|
0x26,0x26,0x24,
|
|
// 2 0,2 1,2 2,2 3,1 4,2 5,2 6,2 7,1 8
|
|
// 112 102 111 - 0010,0110 0010,0010 0010,0101
|
|
0x26,0x22,0x25,
|
|
// 2 0,2 1,1 2,2 3,1 4,2 5,2 6,1 7,2 8,1 9
|
|
// 111 102 102 000 = 0010,0101 0010,0010 0010,0010 0000,0000
|
|
0x25,0x22,0x22,0x00,
|
|
// 2 0,1 1,2 2,1 3,2 4,1 5,2 6,1 7,2 8,1 9,1 A
|
|
// 102 011 102 000 - 0010,0010 0000,0101 0010,0010 0000,0000
|
|
0x22,0x05,0x22,0x00,
|
|
// 2 0,1 1,1 2, 2 3,1 4,1 5, 2 6,1 7,1 8, 2 9,1 A,1 B
|
|
// 101 101 101 101 = 0010,0001
|
|
0x21,0x21,0x21,0x21,
|
|
// 2 0,1 1,1 2, 1 3,2 4,1 5, 1 6,1 7,2 8, 1 9,1 A,1 B, 1 C
|
|
// 101 011 002 001 000 = 0010,0001 0000,0101 0000,0010 0000,0001 0000,0000
|
|
0x21,0x05,0x02,0x01,0x00,
|
|
// 2 0,1 1,1 2, 1 3,1 4,1 5, 1 6,2 7,1 8, 1 9,1 A,1 B, 1 C,1 D
|
|
// 101 001 011 001 000 = 0010,0001 0000,0001 0000,0101 0000,0001 0000,0000
|
|
0x21,0x01,0x05,0x1,0x0,
|
|
// 2 0,1 1,1 2,1 3,1 4,1 5,1 6,1 7,1 8,1 9,1 A,1 B,1 C,1 D,1 E
|
|
// 101 001 001 001 001 000 = 001 0,00 01 000 000 01
|
|
0x21,0x01,0x01,0x01,0x01,0x00,
|
|
// 1 0,1 1,1 2,1 3,1 4,1 5,1 6,1 7,1 8,1 9,1 A,1 B,1 C,1 D,1 E,1 F
|
|
// 001 001 001 001 001 000 = 000 000 01
|
|
0x01,0x01,0x01,0x01,0x01,0x00,
|
|
};
|
|
|
|
|
|
static unsigned char gen3[]={
|
|
// 16 0 SKIP this always 0
|
|
|
|
|
|
// 8 0,8 1
|
|
// 770 = 111 1,11 00
|
|
0xfc,
|
|
// 4 0,8 1,4 2
|
|
// 370 300 = 011 1,11 00 -- 011,0 0000
|
|
0x7c,0x60,
|
|
// 3 0,5 1,5 2, 3 3
|
|
// 240 420 = 0101,000 1000,1000
|
|
0x50,0x88,
|
|
// 2 0,4 1, 4 2,4 3,2 4
|
|
// 130 332 = 0010,1100, 0110,1110
|
|
0x2c,0x6e,
|
|
// 2 0,3 1,3 2, 3 3,3 4,2 5
|
|
// 123 222 = 001 0,10 11 010 0,10 10
|
|
0x2b,0x4a,
|
|
// 2 0,2 1,3 2, 2 3,3 4,2 5, 2 6
|
|
// 113 122 100 = 001 0,01 11 001 0,10 10 00100000
|
|
0x27,0x2a,0x20,
|
|
// 2 0,2 1,2 2,2 3,2 4,2 5,2 6,2 7
|
|
// 112 112 110 = 0010,0110 0010,0110 0010,01 00
|
|
0x26,0x26,0x24,
|
|
// 1 0,2 1,2 2, 2 3,2 4,2 5, 2 6,2 7,1 8
|
|
// 012 112 111 - 0000,0110 0010,0110 0010,0101
|
|
0x06,0x26,0x25,
|
|
// 1 0,2 1,2 2, 1 3,2 4,2 5, 1 6,2 7,2 8, 1 9
|
|
// 012 012 012 000 = 0000,0110 0000,0000
|
|
0x06,0x06,0x06,0x00,
|
|
// 1 0,2 1,1 2, 2 3,1 4,2 5, 1 6,2 7,1 8, 2 9,1 A
|
|
// 011 102 011 100 - 0000,0101 0010,0010 0010,0010 0010,0000
|
|
0x05,0x22,0x05,0x20,
|
|
// 1 0,2 1,1 2, 1 3,2 4,1 5, 1 6,2 7,1 8, 1 9,2 A,1 B
|
|
// 011 111 011 011 = 0000,0101
|
|
0x05,0x05,0x05,0x05,
|
|
// 1 0,1 1,2 2, 1 3,1 4,1 5, 2 6,1 7,1 8, 1 9,2 A,1 B, 1 C
|
|
// 002 001 101 011 000 = 0000,0010 0000,0001 0010,0001 0000,0101 0000,0000
|
|
0x02,0x01,0x21,0x05,0x00,
|
|
// 1 0,1 1,1 2, 2 3,1 4,1 5, 1 6,1 7,1 8, 1 9,2 A,1 B, 1 C,1 D
|
|
// 001 101 001 011 000 = 0010,0001 0000,0001 0000,0101 0000,0001 0000,0000
|
|
0x01,0x21,0x01,0x05,0x00,
|
|
// 1 0,1 1,1 2, 1 3,1 4,1 5, 1 6,2 7,1 8, 1 9,1 A,1 B, 1 C,1 D,1 E
|
|
// 001 001 011 001 001 000 = 001 0,00 01 000 000 01
|
|
0x01,0x01,0x05,0x01,0x01,0x01,
|
|
|
|
// 1 0,1 1,1 2,1 3,1 4,1 5,1 6,1 7,1 8,1 9,1 A,1 B,1 C,1 D,1 E,1 F
|
|
// 001 001 001 001 001 000 = 000 000 01
|
|
0x01,0x01,0x01,0x01,0x01,0x00,
|
|
};
|
|
|
|
static void gen_table_2(unsigned char *g) {
|
|
|
|
int row=0,column=0,val,index=0,temp,i,total=0;
|
|
|
|
while(row<15) {
|
|
val=0;
|
|
column=0;
|
|
printf("\n");
|
|
while(1) {
|
|
temp=(g[index]>>5)&0x7;
|
|
for(i=0;i<temp+1;i++) {
|
|
out[16+total]=val;
|
|
printf("%x ",val);
|
|
total++;
|
|
column++;
|
|
}
|
|
|
|
if (column>=16) break;
|
|
|
|
val++;
|
|
temp=(g[index]>>2)&0x7;
|
|
for(i=0;i<temp+1;i++) {
|
|
out[16+total]=val;
|
|
printf("%x ",val);
|
|
total++;
|
|
column++;
|
|
}
|
|
|
|
if (column>=16) break;
|
|
|
|
temp=(g[index])&0x3;
|
|
if (temp!=0) {
|
|
val++;
|
|
for(i=0;i<temp;i++) {
|
|
out[16+total]=val;
|
|
printf("%x ",val);
|
|
total++;
|
|
column++;
|
|
}
|
|
}
|
|
val++;
|
|
if (column>=16) break;
|
|
index++;
|
|
}
|
|
index++;
|
|
|
|
row++;
|
|
}
|
|
}
|
|
|
|
|
|
|
|
int main(int argc, char **argv) {
|
|
|
|
|
|
|
|
int i;
|
|
|
|
printf("Default is 256 bytes!\n");
|
|
|
|
|
|
printf("\nNext is %ld bytes\n",sizeof(gen1));
|
|
memset(out,0,256);
|
|
gen_table_1();
|
|
|
|
for(i=0;i<256;i++) {
|
|
if (out[i]!=PT3VolumeTable_33_34[i]) {
|
|
fprintf(stderr,"Mismatch at %d (%x) expected %d got %d!\n",
|
|
i,i,PT3VolumeTable_33_34[i],out[i]);
|
|
return -1;
|
|
}
|
|
}
|
|
|
|
|
|
printf("\nNext is %ld bytes\n",sizeof(gen2));
|
|
memset(out,0,256);
|
|
gen_table_2(gen2);
|
|
|
|
for(i=0;i<256;i++) {
|
|
if (out[i]!=PT3VolumeTable_33_34[i]) {
|
|
fprintf(stderr,"Mismatch at %d (%x) expected %d got %d!\n",
|
|
i,i,PT3VolumeTable_33_34[i],out[i]);
|
|
return -1;
|
|
}
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
printf("\nGNext is %ld bytes\n",sizeof(gen3));
|
|
memset(out,0,256);
|
|
gen_table_2(gen3);
|
|
|
|
for(i=0;i<256;i++) {
|
|
if (out[i]!=PT3VolumeTable_35[i]) {
|
|
fprintf(stderr,"Mismatch at %d (%x) expected %d got %d!\n",
|
|
i,i,PT3VolumeTable_35[i],out[i]);
|
|
return -1;
|
|
}
|
|
}
|
|
|
|
|
|
return 0;
|
|
}
|