-
Notifications
You must be signed in to change notification settings - Fork 34
/
Copy pathsf_nod.c
105 lines (92 loc) · 3.92 KB
/
sf_nod.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
#include "gimglib.h"
static void dump_node_data (unsigned char *ptr, int length)
{
}
static void dump_road_data (unsigned char *ptr, int length)
{
while (length >= 6) {
printf("type=0x%02x, ptr=0x%02x%02x%02x, bits=%3d, ?=0x%02x",
ptr[0], ptr[3], ptr[2], ptr[1], ptr[4], ptr[5]);
if (ptr[4] > 0)
printf(", bfield=%s", dump_unknown_bytes(ptr + 6, (ptr[4] + 7) / 8));
printf("\n");
ptr += 6 + (ptr[4] + 7) / 8;
length -= 6 + (ptr[4] + 7) / 8;
}
}
static void dump_boundary_nodes (unsigned char *ptr, int length, int recsize)
{
if (recsize < 9) {
printf("Error: NOD3 boundry nodes's recsize %d is less than 9\n", recsize);
return;
}
for (; length >= recsize; ptr += recsize, length -= recsize) {
printf("e=%d(%s), n=%d(%s), off=0x%x",
bytes_to_sint24(ptr), sint24_to_lng(bytes_to_sint24(ptr)),
bytes_to_sint24(ptr+3), sint24_to_lat(bytes_to_sint24(ptr+3)),
bytes_to_sint24(ptr+6));
if (recsize > 9)
printf(", ?=%s", dump_unknown_bytes(ptr+9, recsize - 9));
printf("\n");
}
}
void dump_nod (struct subfile_struct *sf)
{
struct garmin_nod *header = (struct garmin_nod *)sf->header;
int progress = 0;
assert(sf->typeid == ST_NOD);
dump_comm(sf->header);
printf("=== NOD HEADER ===\n");
if (header->comm.hlen < 0x3f)
goto headerfini;
progress = 0x3f;
printf("NOD1 Node Data: reloff=0x%x absoff=0x%x size=0x%x\n",
header->nod1_offset, sf->offset + header->nod1_offset, header->nod1_length);
printf("nod_bits, align: {0x%x 0x%x 0x%x 0x%x}, %d\n",
header->nod_bits[0], header->nod_bits[1], header->nod_bits[2], header->nod_bits[3], header->align);
printf("unknown_022: %d\n", header->unknown_022);
printf("roadptrsize: %d\n", header->roadptrsize);
printf("NOD2 Road Data: reloff=0x%x absoff=0x%x size=0x%x\n",
header->nod2_offset, sf->offset + header->nod2_offset, header->nod2_length);
printf("unknown_02d: 0x%x\n", header->unknown_02d);
printf("NOD3 Boundary Node: reloff=0x%x absoff=0x%x size=0x%x recsize=0x%x\n",
header->nod3_offset, sf->offset + header->nod3_offset, header->nod3_length, header->nod3_recsize);
printf("unknown_03c: 0x%x\n", header->unknown_03c);
if (header->comm.hlen < 0x7f)
goto headerfini;
progress = 0x7f;
printf("NOD4: reloff=0x%x absoff=0x%x size=0x%x\n",
header->nod4_offset, sf->offset + header->nod4_offset, header->nod4_length);
printf("unknown_047: 0x%x\n", header->unknown_047);
printf("unknown_04b: 0x%x\n", header->unknown_04b);
printf("unknown_04f: 0x%x\n", header->unknown_04f);
printf("unknown_053: 0x%x\n", header->unknown_053);
printf("unknown_057: 0x%x\n", header->unknown_057);
printf("unknown_05b: %s\n",
dump_unknown_bytes(header->unknown_05b, sizeof(header->unknown_05b)));
printf("NOD5: reloff=0x%x absoff=0x%x size=0x%x recsize=0x%x\n",
header->nod5_offset, sf->offset + header->nod5_offset, header->nod5_length, header->nod5_recsize);
printf("NOD6: reloff=0x%x absoff=0x%x size=0x%x recsize=0x%x\n",
header->nod6_offset, sf->offset + header->nod6_offset, header->nod6_length, header->nod6_recsize);
printf("unknown_07b: 0x%x\n", header->unknown_07b);
headerfini:
if (header->comm.hlen > progress)
printf("from 0x%x to 0x%x (0x%x bytes): %s\n",
progress, header->comm.hlen - 1,
header->comm.hlen - progress,
dump_unknown_bytes((uint8_t *)header + progress, header->comm.hlen - progress));
if (header->nod1_length) {
printf("=== NODE DATA ===\n");
dump_node_data(sf->base + header->nod1_offset, header->nod1_length);
}
if (header->nod2_length) {
printf("=== ROAD DATA ===\n");
dump_road_data(sf->base + header->nod2_offset, header->nod2_length);
}
if (header->nod3_length) {
printf("=== BOUNDARY NODES ===\n");
dump_boundary_nodes(sf->base + header->nod3_offset,
header->nod3_length, header->nod3_recsize);
}
return;
}