annotate lwlink/tags/1.0/src/objdump.c @ 136:72d8c84a8734

Release 1.0
author lost
date Tue, 27 Jan 2009 05:54:10 +0000
parents
children
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
136
72d8c84a8734 Release 1.0
lost
parents:
diff changeset
1 /*
72d8c84a8734 Release 1.0
lost
parents:
diff changeset
2 objdump.c
72d8c84a8734 Release 1.0
lost
parents:
diff changeset
3 Copyright © 2009 William Astle
72d8c84a8734 Release 1.0
lost
parents:
diff changeset
4
72d8c84a8734 Release 1.0
lost
parents:
diff changeset
5 This file is part of LWLINK
72d8c84a8734 Release 1.0
lost
parents:
diff changeset
6
72d8c84a8734 Release 1.0
lost
parents:
diff changeset
7 LWLINK is free software: you can redistribute it and/or modify it under the
72d8c84a8734 Release 1.0
lost
parents:
diff changeset
8 terms of the GNU General Public License as published by the Free Software
72d8c84a8734 Release 1.0
lost
parents:
diff changeset
9 Foundation, either version 3 of the License, or (at your option) any later
72d8c84a8734 Release 1.0
lost
parents:
diff changeset
10 version.
72d8c84a8734 Release 1.0
lost
parents:
diff changeset
11
72d8c84a8734 Release 1.0
lost
parents:
diff changeset
12 This program is distributed in the hope that it will be useful, but WITHOUT
72d8c84a8734 Release 1.0
lost
parents:
diff changeset
13 ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
72d8c84a8734 Release 1.0
lost
parents:
diff changeset
14 FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
72d8c84a8734 Release 1.0
lost
parents:
diff changeset
15 more details.
72d8c84a8734 Release 1.0
lost
parents:
diff changeset
16
72d8c84a8734 Release 1.0
lost
parents:
diff changeset
17 You should have received a copy of the GNU General Public License along with
72d8c84a8734 Release 1.0
lost
parents:
diff changeset
18 this program. If not, see <http://www.gnu.org/licenses/>.
72d8c84a8734 Release 1.0
lost
parents:
diff changeset
19
72d8c84a8734 Release 1.0
lost
parents:
diff changeset
20
72d8c84a8734 Release 1.0
lost
parents:
diff changeset
21 A standalone program to dump an object file in a text form to stdout
72d8c84a8734 Release 1.0
lost
parents:
diff changeset
22
72d8c84a8734 Release 1.0
lost
parents:
diff changeset
23 */
72d8c84a8734 Release 1.0
lost
parents:
diff changeset
24
72d8c84a8734 Release 1.0
lost
parents:
diff changeset
25 #include <stdio.h>
72d8c84a8734 Release 1.0
lost
parents:
diff changeset
26 #include <stdlib.h>
72d8c84a8734 Release 1.0
lost
parents:
diff changeset
27
72d8c84a8734 Release 1.0
lost
parents:
diff changeset
28 #include "util.h"
72d8c84a8734 Release 1.0
lost
parents:
diff changeset
29
72d8c84a8734 Release 1.0
lost
parents:
diff changeset
30 #ifdef HAVE_CONFIG_H
72d8c84a8734 Release 1.0
lost
parents:
diff changeset
31 #include "config.h"
72d8c84a8734 Release 1.0
lost
parents:
diff changeset
32 #endif
72d8c84a8734 Release 1.0
lost
parents:
diff changeset
33
72d8c84a8734 Release 1.0
lost
parents:
diff changeset
34 void read_lwobj16v0(unsigned char *filedata, long filesize);
72d8c84a8734 Release 1.0
lost
parents:
diff changeset
35
72d8c84a8734 Release 1.0
lost
parents:
diff changeset
36 /*
72d8c84a8734 Release 1.0
lost
parents:
diff changeset
37 The logic of reading the entire file into memory is simple. All the symbol
72d8c84a8734 Release 1.0
lost
parents:
diff changeset
38 names in the file are NUL terminated strings and can be used directly without
72d8c84a8734 Release 1.0
lost
parents:
diff changeset
39 making additional copies.
72d8c84a8734 Release 1.0
lost
parents:
diff changeset
40 */
72d8c84a8734 Release 1.0
lost
parents:
diff changeset
41 int main(int argc, char **argv)
72d8c84a8734 Release 1.0
lost
parents:
diff changeset
42 {
72d8c84a8734 Release 1.0
lost
parents:
diff changeset
43 int i;
72d8c84a8734 Release 1.0
lost
parents:
diff changeset
44 long size;
72d8c84a8734 Release 1.0
lost
parents:
diff changeset
45 FILE *f;
72d8c84a8734 Release 1.0
lost
parents:
diff changeset
46 long bread;
72d8c84a8734 Release 1.0
lost
parents:
diff changeset
47 unsigned char *filedata;
72d8c84a8734 Release 1.0
lost
parents:
diff changeset
48
72d8c84a8734 Release 1.0
lost
parents:
diff changeset
49 if (argc != 2)
72d8c84a8734 Release 1.0
lost
parents:
diff changeset
50 {
72d8c84a8734 Release 1.0
lost
parents:
diff changeset
51 fprintf(stderr, "Must specify exactly one input file.\n");
72d8c84a8734 Release 1.0
lost
parents:
diff changeset
52 exit(1);
72d8c84a8734 Release 1.0
lost
parents:
diff changeset
53 }
72d8c84a8734 Release 1.0
lost
parents:
diff changeset
54
72d8c84a8734 Release 1.0
lost
parents:
diff changeset
55 f = fopen(argv[1], "rb");
72d8c84a8734 Release 1.0
lost
parents:
diff changeset
56 if (!f)
72d8c84a8734 Release 1.0
lost
parents:
diff changeset
57 {
72d8c84a8734 Release 1.0
lost
parents:
diff changeset
58 fprintf(stderr, "Can't open file %s:", argv[1]);
72d8c84a8734 Release 1.0
lost
parents:
diff changeset
59 perror("");
72d8c84a8734 Release 1.0
lost
parents:
diff changeset
60 exit(1);
72d8c84a8734 Release 1.0
lost
parents:
diff changeset
61 }
72d8c84a8734 Release 1.0
lost
parents:
diff changeset
62 fseek(f, 0, SEEK_END);
72d8c84a8734 Release 1.0
lost
parents:
diff changeset
63 size = ftell(f);
72d8c84a8734 Release 1.0
lost
parents:
diff changeset
64 rewind(f);
72d8c84a8734 Release 1.0
lost
parents:
diff changeset
65
72d8c84a8734 Release 1.0
lost
parents:
diff changeset
66 filedata = lw_malloc(size);
72d8c84a8734 Release 1.0
lost
parents:
diff changeset
67
72d8c84a8734 Release 1.0
lost
parents:
diff changeset
68 bread = fread(filedata, 1, size, f);
72d8c84a8734 Release 1.0
lost
parents:
diff changeset
69 if (bread < size)
72d8c84a8734 Release 1.0
lost
parents:
diff changeset
70 {
72d8c84a8734 Release 1.0
lost
parents:
diff changeset
71 fprintf(stderr, "Short read on file %s (%ld/%ld):", argv[1], bread, size);
72d8c84a8734 Release 1.0
lost
parents:
diff changeset
72 perror("");
72d8c84a8734 Release 1.0
lost
parents:
diff changeset
73 exit(1);
72d8c84a8734 Release 1.0
lost
parents:
diff changeset
74 }
72d8c84a8734 Release 1.0
lost
parents:
diff changeset
75
72d8c84a8734 Release 1.0
lost
parents:
diff changeset
76 fclose(f);
72d8c84a8734 Release 1.0
lost
parents:
diff changeset
77
72d8c84a8734 Release 1.0
lost
parents:
diff changeset
78 if (!memcmp(filedata, "LWOBJ16", 8))
72d8c84a8734 Release 1.0
lost
parents:
diff changeset
79 {
72d8c84a8734 Release 1.0
lost
parents:
diff changeset
80 // read v0 LWOBJ16 file
72d8c84a8734 Release 1.0
lost
parents:
diff changeset
81 read_lwobj16v0(filedata, size);
72d8c84a8734 Release 1.0
lost
parents:
diff changeset
82 }
72d8c84a8734 Release 1.0
lost
parents:
diff changeset
83 else
72d8c84a8734 Release 1.0
lost
parents:
diff changeset
84 {
72d8c84a8734 Release 1.0
lost
parents:
diff changeset
85 fprintf(stderr, "%s: unknown file format\n", argv[1]);
72d8c84a8734 Release 1.0
lost
parents:
diff changeset
86 exit(1);
72d8c84a8734 Release 1.0
lost
parents:
diff changeset
87 }
72d8c84a8734 Release 1.0
lost
parents:
diff changeset
88 exit(0);
72d8c84a8734 Release 1.0
lost
parents:
diff changeset
89 }
72d8c84a8734 Release 1.0
lost
parents:
diff changeset
90
72d8c84a8734 Release 1.0
lost
parents:
diff changeset
91 // this macro is used to bail out if we run off the end of the file data
72d8c84a8734 Release 1.0
lost
parents:
diff changeset
92 // while parsing - it keeps the code below cleaner
72d8c84a8734 Release 1.0
lost
parents:
diff changeset
93 #define NEXTBYTE() do { cc++; if (cc > filesize) { fprintf(stderr, "***invalid file format\n"); exit(1); } } while (0)
72d8c84a8734 Release 1.0
lost
parents:
diff changeset
94 // this macro is used to refer to the current byte in the stream
72d8c84a8734 Release 1.0
lost
parents:
diff changeset
95 #define CURBYTE() (filedata[cc < filesize ? cc : filesize - 1])
72d8c84a8734 Release 1.0
lost
parents:
diff changeset
96 // this one will leave the input pointer past the trailing NUL
72d8c84a8734 Release 1.0
lost
parents:
diff changeset
97 #define CURSTR() read_lwobj16v0_str(&cc, &filedata, filesize)
72d8c84a8734 Release 1.0
lost
parents:
diff changeset
98 unsigned char *read_lwobj16v0_str(long *cc1, unsigned char **filedata1, long filesize)
72d8c84a8734 Release 1.0
lost
parents:
diff changeset
99 {
72d8c84a8734 Release 1.0
lost
parents:
diff changeset
100 int cc = *cc1;
72d8c84a8734 Release 1.0
lost
parents:
diff changeset
101 unsigned char *filedata = *filedata1;
72d8c84a8734 Release 1.0
lost
parents:
diff changeset
102 unsigned char *fp;
72d8c84a8734 Release 1.0
lost
parents:
diff changeset
103 fp = &CURBYTE();
72d8c84a8734 Release 1.0
lost
parents:
diff changeset
104 while (CURBYTE())
72d8c84a8734 Release 1.0
lost
parents:
diff changeset
105 NEXTBYTE();
72d8c84a8734 Release 1.0
lost
parents:
diff changeset
106 NEXTBYTE();
72d8c84a8734 Release 1.0
lost
parents:
diff changeset
107 *cc1 = cc;
72d8c84a8734 Release 1.0
lost
parents:
diff changeset
108 *filedata1 = filedata;
72d8c84a8734 Release 1.0
lost
parents:
diff changeset
109 return fp;
72d8c84a8734 Release 1.0
lost
parents:
diff changeset
110 }
72d8c84a8734 Release 1.0
lost
parents:
diff changeset
111 // the function below can be switched to dealing with data coming from a
72d8c84a8734 Release 1.0
lost
parents:
diff changeset
112 // source other than an in-memory byte pool by adjusting the input data
72d8c84a8734 Release 1.0
lost
parents:
diff changeset
113 // in "fn" and the above two macros
72d8c84a8734 Release 1.0
lost
parents:
diff changeset
114 void read_lwobj16v0(unsigned char *filedata, long filesize)
72d8c84a8734 Release 1.0
lost
parents:
diff changeset
115 {
72d8c84a8734 Release 1.0
lost
parents:
diff changeset
116 unsigned char *fp;
72d8c84a8734 Release 1.0
lost
parents:
diff changeset
117 long cc;
72d8c84a8734 Release 1.0
lost
parents:
diff changeset
118 int val;
72d8c84a8734 Release 1.0
lost
parents:
diff changeset
119 int bss;
72d8c84a8734 Release 1.0
lost
parents:
diff changeset
120
72d8c84a8734 Release 1.0
lost
parents:
diff changeset
121 static char *opernames[] = {
72d8c84a8734 Release 1.0
lost
parents:
diff changeset
122 "?",
72d8c84a8734 Release 1.0
lost
parents:
diff changeset
123 "PLUS",
72d8c84a8734 Release 1.0
lost
parents:
diff changeset
124 "MINUS",
72d8c84a8734 Release 1.0
lost
parents:
diff changeset
125 "TIMES",
72d8c84a8734 Release 1.0
lost
parents:
diff changeset
126 "DIVIDE",
72d8c84a8734 Release 1.0
lost
parents:
diff changeset
127 "MOD",
72d8c84a8734 Release 1.0
lost
parents:
diff changeset
128 "INTDIV",
72d8c84a8734 Release 1.0
lost
parents:
diff changeset
129 "BWAND",
72d8c84a8734 Release 1.0
lost
parents:
diff changeset
130 "BWOR",
72d8c84a8734 Release 1.0
lost
parents:
diff changeset
131 "BWXOR",
72d8c84a8734 Release 1.0
lost
parents:
diff changeset
132 "AND",
72d8c84a8734 Release 1.0
lost
parents:
diff changeset
133 "OR",
72d8c84a8734 Release 1.0
lost
parents:
diff changeset
134 "NEG",
72d8c84a8734 Release 1.0
lost
parents:
diff changeset
135 "COM"
72d8c84a8734 Release 1.0
lost
parents:
diff changeset
136 };
72d8c84a8734 Release 1.0
lost
parents:
diff changeset
137 static const int numopers = 13;
72d8c84a8734 Release 1.0
lost
parents:
diff changeset
138
72d8c84a8734 Release 1.0
lost
parents:
diff changeset
139 // start reading *after* the magic number
72d8c84a8734 Release 1.0
lost
parents:
diff changeset
140 cc = 8;
72d8c84a8734 Release 1.0
lost
parents:
diff changeset
141
72d8c84a8734 Release 1.0
lost
parents:
diff changeset
142 while (1)
72d8c84a8734 Release 1.0
lost
parents:
diff changeset
143 {
72d8c84a8734 Release 1.0
lost
parents:
diff changeset
144 bss = 0;
72d8c84a8734 Release 1.0
lost
parents:
diff changeset
145
72d8c84a8734 Release 1.0
lost
parents:
diff changeset
146 // bail out if no more sections
72d8c84a8734 Release 1.0
lost
parents:
diff changeset
147 if (!(CURBYTE()))
72d8c84a8734 Release 1.0
lost
parents:
diff changeset
148 break;
72d8c84a8734 Release 1.0
lost
parents:
diff changeset
149
72d8c84a8734 Release 1.0
lost
parents:
diff changeset
150 fp = CURSTR();
72d8c84a8734 Release 1.0
lost
parents:
diff changeset
151
72d8c84a8734 Release 1.0
lost
parents:
diff changeset
152 printf("SECTION %s\n", fp);
72d8c84a8734 Release 1.0
lost
parents:
diff changeset
153
72d8c84a8734 Release 1.0
lost
parents:
diff changeset
154 // read flags
72d8c84a8734 Release 1.0
lost
parents:
diff changeset
155 while (CURBYTE())
72d8c84a8734 Release 1.0
lost
parents:
diff changeset
156 {
72d8c84a8734 Release 1.0
lost
parents:
diff changeset
157 switch (CURBYTE())
72d8c84a8734 Release 1.0
lost
parents:
diff changeset
158 {
72d8c84a8734 Release 1.0
lost
parents:
diff changeset
159 case 0x01:
72d8c84a8734 Release 1.0
lost
parents:
diff changeset
160 printf(" FLAG: BSS\n");
72d8c84a8734 Release 1.0
lost
parents:
diff changeset
161 bss = 1;
72d8c84a8734 Release 1.0
lost
parents:
diff changeset
162 break;
72d8c84a8734 Release 1.0
lost
parents:
diff changeset
163
72d8c84a8734 Release 1.0
lost
parents:
diff changeset
164 default:
72d8c84a8734 Release 1.0
lost
parents:
diff changeset
165 printf(" FLAG: %02X (unknown)\n", CURBYTE());
72d8c84a8734 Release 1.0
lost
parents:
diff changeset
166 break;
72d8c84a8734 Release 1.0
lost
parents:
diff changeset
167 }
72d8c84a8734 Release 1.0
lost
parents:
diff changeset
168 NEXTBYTE();
72d8c84a8734 Release 1.0
lost
parents:
diff changeset
169 }
72d8c84a8734 Release 1.0
lost
parents:
diff changeset
170 // skip NUL terminating flags
72d8c84a8734 Release 1.0
lost
parents:
diff changeset
171 NEXTBYTE();
72d8c84a8734 Release 1.0
lost
parents:
diff changeset
172
72d8c84a8734 Release 1.0
lost
parents:
diff changeset
173 printf(" Local symbols:\n");
72d8c84a8734 Release 1.0
lost
parents:
diff changeset
174 // now parse the local symbol table
72d8c84a8734 Release 1.0
lost
parents:
diff changeset
175 while (CURBYTE())
72d8c84a8734 Release 1.0
lost
parents:
diff changeset
176 {
72d8c84a8734 Release 1.0
lost
parents:
diff changeset
177 fp = CURSTR();
72d8c84a8734 Release 1.0
lost
parents:
diff changeset
178
72d8c84a8734 Release 1.0
lost
parents:
diff changeset
179 // fp is the symbol name
72d8c84a8734 Release 1.0
lost
parents:
diff changeset
180 val = (CURBYTE()) << 8;
72d8c84a8734 Release 1.0
lost
parents:
diff changeset
181 NEXTBYTE();
72d8c84a8734 Release 1.0
lost
parents:
diff changeset
182 val |= (CURBYTE());
72d8c84a8734 Release 1.0
lost
parents:
diff changeset
183 NEXTBYTE();
72d8c84a8734 Release 1.0
lost
parents:
diff changeset
184 // val is now the symbol value
72d8c84a8734 Release 1.0
lost
parents:
diff changeset
185
72d8c84a8734 Release 1.0
lost
parents:
diff changeset
186 printf(" %s=%04X\n", fp, val);
72d8c84a8734 Release 1.0
lost
parents:
diff changeset
187
72d8c84a8734 Release 1.0
lost
parents:
diff changeset
188 }
72d8c84a8734 Release 1.0
lost
parents:
diff changeset
189 // skip terminating NUL
72d8c84a8734 Release 1.0
lost
parents:
diff changeset
190 NEXTBYTE();
72d8c84a8734 Release 1.0
lost
parents:
diff changeset
191
72d8c84a8734 Release 1.0
lost
parents:
diff changeset
192 printf(" Exported symbols\n");
72d8c84a8734 Release 1.0
lost
parents:
diff changeset
193
72d8c84a8734 Release 1.0
lost
parents:
diff changeset
194 // now parse the exported symbol table
72d8c84a8734 Release 1.0
lost
parents:
diff changeset
195 while (CURBYTE())
72d8c84a8734 Release 1.0
lost
parents:
diff changeset
196 {
72d8c84a8734 Release 1.0
lost
parents:
diff changeset
197 fp = CURSTR();
72d8c84a8734 Release 1.0
lost
parents:
diff changeset
198
72d8c84a8734 Release 1.0
lost
parents:
diff changeset
199 // fp is the symbol name
72d8c84a8734 Release 1.0
lost
parents:
diff changeset
200 val = (CURBYTE()) << 8;
72d8c84a8734 Release 1.0
lost
parents:
diff changeset
201 NEXTBYTE();
72d8c84a8734 Release 1.0
lost
parents:
diff changeset
202 val |= (CURBYTE());
72d8c84a8734 Release 1.0
lost
parents:
diff changeset
203 NEXTBYTE();
72d8c84a8734 Release 1.0
lost
parents:
diff changeset
204 // val is now the symbol value
72d8c84a8734 Release 1.0
lost
parents:
diff changeset
205
72d8c84a8734 Release 1.0
lost
parents:
diff changeset
206 printf(" %s=%04X\n", fp, val);
72d8c84a8734 Release 1.0
lost
parents:
diff changeset
207 }
72d8c84a8734 Release 1.0
lost
parents:
diff changeset
208 // skip terminating NUL
72d8c84a8734 Release 1.0
lost
parents:
diff changeset
209 NEXTBYTE();
72d8c84a8734 Release 1.0
lost
parents:
diff changeset
210
72d8c84a8734 Release 1.0
lost
parents:
diff changeset
211 // now parse the incomplete references and make a list of
72d8c84a8734 Release 1.0
lost
parents:
diff changeset
212 // external references that need resolution
72d8c84a8734 Release 1.0
lost
parents:
diff changeset
213 printf(" Incomplete references\n");
72d8c84a8734 Release 1.0
lost
parents:
diff changeset
214 while (CURBYTE())
72d8c84a8734 Release 1.0
lost
parents:
diff changeset
215 {
72d8c84a8734 Release 1.0
lost
parents:
diff changeset
216 printf(" (");
72d8c84a8734 Release 1.0
lost
parents:
diff changeset
217 // parse the expression
72d8c84a8734 Release 1.0
lost
parents:
diff changeset
218 while (CURBYTE())
72d8c84a8734 Release 1.0
lost
parents:
diff changeset
219 {
72d8c84a8734 Release 1.0
lost
parents:
diff changeset
220 int tt = CURBYTE();
72d8c84a8734 Release 1.0
lost
parents:
diff changeset
221 NEXTBYTE();
72d8c84a8734 Release 1.0
lost
parents:
diff changeset
222 switch (tt)
72d8c84a8734 Release 1.0
lost
parents:
diff changeset
223 {
72d8c84a8734 Release 1.0
lost
parents:
diff changeset
224 case 0x01:
72d8c84a8734 Release 1.0
lost
parents:
diff changeset
225 // 16 bit integer
72d8c84a8734 Release 1.0
lost
parents:
diff changeset
226 tt = CURBYTE() << 8;
72d8c84a8734 Release 1.0
lost
parents:
diff changeset
227 NEXTBYTE();
72d8c84a8734 Release 1.0
lost
parents:
diff changeset
228 tt |= CURBYTE();
72d8c84a8734 Release 1.0
lost
parents:
diff changeset
229 NEXTBYTE();
72d8c84a8734 Release 1.0
lost
parents:
diff changeset
230 // normalize for negatives...
72d8c84a8734 Release 1.0
lost
parents:
diff changeset
231 if (tt > 0x7fff)
72d8c84a8734 Release 1.0
lost
parents:
diff changeset
232 tt -= 0x10000;
72d8c84a8734 Release 1.0
lost
parents:
diff changeset
233 printf(" I16=%d", tt);
72d8c84a8734 Release 1.0
lost
parents:
diff changeset
234 break;
72d8c84a8734 Release 1.0
lost
parents:
diff changeset
235
72d8c84a8734 Release 1.0
lost
parents:
diff changeset
236 case 0x02:
72d8c84a8734 Release 1.0
lost
parents:
diff changeset
237 // external symbol reference
72d8c84a8734 Release 1.0
lost
parents:
diff changeset
238 printf(" ES=%s", CURSTR());
72d8c84a8734 Release 1.0
lost
parents:
diff changeset
239 break;
72d8c84a8734 Release 1.0
lost
parents:
diff changeset
240
72d8c84a8734 Release 1.0
lost
parents:
diff changeset
241 case 0x03:
72d8c84a8734 Release 1.0
lost
parents:
diff changeset
242 // internal symbol reference
72d8c84a8734 Release 1.0
lost
parents:
diff changeset
243 printf(" IS=%s", CURSTR());
72d8c84a8734 Release 1.0
lost
parents:
diff changeset
244 break;
72d8c84a8734 Release 1.0
lost
parents:
diff changeset
245
72d8c84a8734 Release 1.0
lost
parents:
diff changeset
246 case 0x04:
72d8c84a8734 Release 1.0
lost
parents:
diff changeset
247 // operator
72d8c84a8734 Release 1.0
lost
parents:
diff changeset
248 if (CURBYTE() > 0 && CURBYTE() <= numopers)
72d8c84a8734 Release 1.0
lost
parents:
diff changeset
249 printf(" OP=%s", opernames[CURBYTE()]);
72d8c84a8734 Release 1.0
lost
parents:
diff changeset
250 else
72d8c84a8734 Release 1.0
lost
parents:
diff changeset
251 printf(" OP=?");
72d8c84a8734 Release 1.0
lost
parents:
diff changeset
252 NEXTBYTE();
72d8c84a8734 Release 1.0
lost
parents:
diff changeset
253 break;
72d8c84a8734 Release 1.0
lost
parents:
diff changeset
254
72d8c84a8734 Release 1.0
lost
parents:
diff changeset
255 case 0x05:
72d8c84a8734 Release 1.0
lost
parents:
diff changeset
256 // section base reference (NULL internal reference is
72d8c84a8734 Release 1.0
lost
parents:
diff changeset
257 // the section base address
72d8c84a8734 Release 1.0
lost
parents:
diff changeset
258 printf(" SB");
72d8c84a8734 Release 1.0
lost
parents:
diff changeset
259 break;
72d8c84a8734 Release 1.0
lost
parents:
diff changeset
260
72d8c84a8734 Release 1.0
lost
parents:
diff changeset
261 default:
72d8c84a8734 Release 1.0
lost
parents:
diff changeset
262 printf(" ERR");
72d8c84a8734 Release 1.0
lost
parents:
diff changeset
263 }
72d8c84a8734 Release 1.0
lost
parents:
diff changeset
264 }
72d8c84a8734 Release 1.0
lost
parents:
diff changeset
265 // skip the NUL
72d8c84a8734 Release 1.0
lost
parents:
diff changeset
266 NEXTBYTE();
72d8c84a8734 Release 1.0
lost
parents:
diff changeset
267
72d8c84a8734 Release 1.0
lost
parents:
diff changeset
268 // fetch the offset
72d8c84a8734 Release 1.0
lost
parents:
diff changeset
269 val = CURBYTE() << 8;
72d8c84a8734 Release 1.0
lost
parents:
diff changeset
270 NEXTBYTE();
72d8c84a8734 Release 1.0
lost
parents:
diff changeset
271 val |= CURBYTE() & 0xff;
72d8c84a8734 Release 1.0
lost
parents:
diff changeset
272 NEXTBYTE();
72d8c84a8734 Release 1.0
lost
parents:
diff changeset
273 printf(" ) @ %04X\n", val);
72d8c84a8734 Release 1.0
lost
parents:
diff changeset
274 }
72d8c84a8734 Release 1.0
lost
parents:
diff changeset
275 // skip the NUL terminating the relocations
72d8c84a8734 Release 1.0
lost
parents:
diff changeset
276 NEXTBYTE();
72d8c84a8734 Release 1.0
lost
parents:
diff changeset
277
72d8c84a8734 Release 1.0
lost
parents:
diff changeset
278 // now set code location and size and verify that the file
72d8c84a8734 Release 1.0
lost
parents:
diff changeset
279 // contains data going to the end of the code (if !SECTION_BSS)
72d8c84a8734 Release 1.0
lost
parents:
diff changeset
280 val = CURBYTE() << 8;
72d8c84a8734 Release 1.0
lost
parents:
diff changeset
281 NEXTBYTE();
72d8c84a8734 Release 1.0
lost
parents:
diff changeset
282 val |= CURBYTE();
72d8c84a8734 Release 1.0
lost
parents:
diff changeset
283 NEXTBYTE();
72d8c84a8734 Release 1.0
lost
parents:
diff changeset
284
72d8c84a8734 Release 1.0
lost
parents:
diff changeset
285 printf(" CODE %04X bytes", val);
72d8c84a8734 Release 1.0
lost
parents:
diff changeset
286
72d8c84a8734 Release 1.0
lost
parents:
diff changeset
287 // skip the code if we're not in a BSS section
72d8c84a8734 Release 1.0
lost
parents:
diff changeset
288 if (!bss)
72d8c84a8734 Release 1.0
lost
parents:
diff changeset
289 {
72d8c84a8734 Release 1.0
lost
parents:
diff changeset
290 int i;
72d8c84a8734 Release 1.0
lost
parents:
diff changeset
291 for (i = 0; i < val; i++)
72d8c84a8734 Release 1.0
lost
parents:
diff changeset
292 {
72d8c84a8734 Release 1.0
lost
parents:
diff changeset
293 if (! (i % 16))
72d8c84a8734 Release 1.0
lost
parents:
diff changeset
294 {
72d8c84a8734 Release 1.0
lost
parents:
diff changeset
295 printf("\n %04X ", i);
72d8c84a8734 Release 1.0
lost
parents:
diff changeset
296 }
72d8c84a8734 Release 1.0
lost
parents:
diff changeset
297 printf("%02X", CURBYTE());
72d8c84a8734 Release 1.0
lost
parents:
diff changeset
298 NEXTBYTE();
72d8c84a8734 Release 1.0
lost
parents:
diff changeset
299 }
72d8c84a8734 Release 1.0
lost
parents:
diff changeset
300 }
72d8c84a8734 Release 1.0
lost
parents:
diff changeset
301 printf("\n");
72d8c84a8734 Release 1.0
lost
parents:
diff changeset
302 }
72d8c84a8734 Release 1.0
lost
parents:
diff changeset
303 }