Mercurial > repos > blastem
annotate dis.c @ 2212:71b0cb7c34a6
Fix PSG white noise LSFR tap
author | Michael Pavone <pavone@retrodev.com> |
---|---|
date | Sun, 28 Aug 2022 22:49:26 -0700 |
parents | 4c265d2f6c88 |
children | 53411df7fc71 |
rev | line source |
---|---|
467
140af5509ce7
Added copyright notice to source files and added GPL license text in COPYING
Mike Pavone <pavone@retrodev.com>
parents:
197
diff
changeset
|
1 /* |
140af5509ce7
Added copyright notice to source files and added GPL license text in COPYING
Mike Pavone <pavone@retrodev.com>
parents:
197
diff
changeset
|
2 Copyright 2013 Michael Pavone |
631
de6f00204fa2
Add support for disassembling VOS program modules
Michael Pavone <pavone@retrodev.com>
parents:
467
diff
changeset
|
3 This file is part of BlastEm. |
467
140af5509ce7
Added copyright notice to source files and added GPL license text in COPYING
Mike Pavone <pavone@retrodev.com>
parents:
197
diff
changeset
|
4 BlastEm is free software distributed under the terms of the GNU General Public License version 3 or greater. See COPYING for full license text. |
140af5509ce7
Added copyright notice to source files and added GPL license text in COPYING
Mike Pavone <pavone@retrodev.com>
parents:
197
diff
changeset
|
5 */ |
2
5df303bf72e6
Improve 68K instruction decoding. Add simple disassembler.
Mike Pavone <pavone@retrodev.com>
parents:
diff
changeset
|
6 #include "68kinst.h" |
5df303bf72e6
Improve 68K instruction decoding. Add simple disassembler.
Mike Pavone <pavone@retrodev.com>
parents:
diff
changeset
|
7 #include <stdio.h> |
5df303bf72e6
Improve 68K instruction decoding. Add simple disassembler.
Mike Pavone <pavone@retrodev.com>
parents:
diff
changeset
|
8 #include <stdlib.h> |
631
de6f00204fa2
Add support for disassembling VOS program modules
Michael Pavone <pavone@retrodev.com>
parents:
467
diff
changeset
|
9 #include <string.h> |
805 | 10 #include <stdarg.h> |
947
d29722e3359c
Allow specification of named labels as command line arguments to the 68K disassembler
Michael Pavone <pavone@retrodev.com>
parents:
805
diff
changeset
|
11 #include <ctype.h> |
631
de6f00204fa2
Add support for disassembling VOS program modules
Michael Pavone <pavone@retrodev.com>
parents:
467
diff
changeset
|
12 #include "vos_program_module.h" |
de6f00204fa2
Add support for disassembling VOS program modules
Michael Pavone <pavone@retrodev.com>
parents:
467
diff
changeset
|
13 #include "tern.h" |
947
d29722e3359c
Allow specification of named labels as command line arguments to the 68K disassembler
Michael Pavone <pavone@retrodev.com>
parents:
805
diff
changeset
|
14 #include "util.h" |
2206
4c265d2f6c88
Minor refactor of 68K disassembler
Michael Pavone <pavone@retrodev.com>
parents:
2146
diff
changeset
|
15 #include "disasm.h" |
631
de6f00204fa2
Add support for disassembling VOS program modules
Michael Pavone <pavone@retrodev.com>
parents:
467
diff
changeset
|
16 |
2206
4c265d2f6c88
Minor refactor of 68K disassembler
Michael Pavone <pavone@retrodev.com>
parents:
2146
diff
changeset
|
17 int headless; |
4c265d2f6c88
Minor refactor of 68K disassembler
Michael Pavone <pavone@retrodev.com>
parents:
2146
diff
changeset
|
18 void render_errorbox(char *title, char *message) {} |
4c265d2f6c88
Minor refactor of 68K disassembler
Michael Pavone <pavone@retrodev.com>
parents:
2146
diff
changeset
|
19 void render_warnbox(char *title, char *message) {} |
4c265d2f6c88
Minor refactor of 68K disassembler
Michael Pavone <pavone@retrodev.com>
parents:
2146
diff
changeset
|
20 void render_infobox(char *title, char *message) {} |
631
de6f00204fa2
Add support for disassembling VOS program modules
Michael Pavone <pavone@retrodev.com>
parents:
467
diff
changeset
|
21 |
2206
4c265d2f6c88
Minor refactor of 68K disassembler
Michael Pavone <pavone@retrodev.com>
parents:
2146
diff
changeset
|
22 void check_reference(disasm_context *context, m68kinst * inst, m68k_op_info * op) |
134 | 23 { |
24 switch(op->addr_mode) | |
25 { | |
26 case MODE_PC_DISPLACE: | |
2206
4c265d2f6c88
Minor refactor of 68K disassembler
Michael Pavone <pavone@retrodev.com>
parents:
2146
diff
changeset
|
27 reference(context, inst->address + 2 + op->params.regs.displacement); |
134 | 28 break; |
29 case MODE_ABSOLUTE: | |
30 case MODE_ABSOLUTE_SHORT: | |
2206
4c265d2f6c88
Minor refactor of 68K disassembler
Michael Pavone <pavone@retrodev.com>
parents:
2146
diff
changeset
|
31 reference(context, op->params.immed); |
134 | 32 break; |
33 } | |
34 } | |
35 | |
634
4a6ec64acd79
Better support for labels sourced from VOS program module header
Michael Pavone <pavone@retrodev.com>
parents:
633
diff
changeset
|
36 int label_fun(char *dst, uint32_t address, void * data) |
4a6ec64acd79
Better support for labels sourced from VOS program module header
Michael Pavone <pavone@retrodev.com>
parents:
633
diff
changeset
|
37 { |
2206
4c265d2f6c88
Minor refactor of 68K disassembler
Michael Pavone <pavone@retrodev.com>
parents:
2146
diff
changeset
|
38 disasm_context *context = data; |
4c265d2f6c88
Minor refactor of 68K disassembler
Michael Pavone <pavone@retrodev.com>
parents:
2146
diff
changeset
|
39 label_def *def = find_label(context, address); |
4c265d2f6c88
Minor refactor of 68K disassembler
Michael Pavone <pavone@retrodev.com>
parents:
2146
diff
changeset
|
40 if (def && def->num_labels) { |
4c265d2f6c88
Minor refactor of 68K disassembler
Michael Pavone <pavone@retrodev.com>
parents:
2146
diff
changeset
|
41 return sprintf(dst, "%s", def->labels[0]); |
634
4a6ec64acd79
Better support for labels sourced from VOS program module header
Michael Pavone <pavone@retrodev.com>
parents:
633
diff
changeset
|
42 } |
2206
4c265d2f6c88
Minor refactor of 68K disassembler
Michael Pavone <pavone@retrodev.com>
parents:
2146
diff
changeset
|
43 return m68k_default_label_fun(dst, address, NULL); |
947
d29722e3359c
Allow specification of named labels as command line arguments to the 68K disassembler
Michael Pavone <pavone@retrodev.com>
parents:
805
diff
changeset
|
44 } |
d29722e3359c
Allow specification of named labels as command line arguments to the 68K disassembler
Michael Pavone <pavone@retrodev.com>
parents:
805
diff
changeset
|
45 |
2132
7451f970ee66
Add some weak labels for a few exception vectors in disassembler
Michael Pavone <pavone@retrodev.com>
parents:
2110
diff
changeset
|
46 typedef struct { |
7451f970ee66
Add some weak labels for a few exception vectors in disassembler
Michael Pavone <pavone@retrodev.com>
parents:
2110
diff
changeset
|
47 uint32_t address_off; |
7451f970ee66
Add some weak labels for a few exception vectors in disassembler
Michael Pavone <pavone@retrodev.com>
parents:
2110
diff
changeset
|
48 uint32_t address_end; |
7451f970ee66
Add some weak labels for a few exception vectors in disassembler
Michael Pavone <pavone@retrodev.com>
parents:
2110
diff
changeset
|
49 uint16_t *buffer; |
7451f970ee66
Add some weak labels for a few exception vectors in disassembler
Michael Pavone <pavone@retrodev.com>
parents:
2110
diff
changeset
|
50 } rom_def; |
7451f970ee66
Add some weak labels for a few exception vectors in disassembler
Michael Pavone <pavone@retrodev.com>
parents:
2110
diff
changeset
|
51 |
7451f970ee66
Add some weak labels for a few exception vectors in disassembler
Michael Pavone <pavone@retrodev.com>
parents:
2110
diff
changeset
|
52 uint16_t fetch(uint32_t address, void *data) |
7451f970ee66
Add some weak labels for a few exception vectors in disassembler
Michael Pavone <pavone@retrodev.com>
parents:
2110
diff
changeset
|
53 { |
7451f970ee66
Add some weak labels for a few exception vectors in disassembler
Michael Pavone <pavone@retrodev.com>
parents:
2110
diff
changeset
|
54 rom_def *rom = data; |
7451f970ee66
Add some weak labels for a few exception vectors in disassembler
Michael Pavone <pavone@retrodev.com>
parents:
2110
diff
changeset
|
55 if (address >= rom->address_off && address < rom->address_end) { |
7451f970ee66
Add some weak labels for a few exception vectors in disassembler
Michael Pavone <pavone@retrodev.com>
parents:
2110
diff
changeset
|
56 return rom->buffer[((address & 0xFFFFFF) - rom->address_off) >> 1]; |
7451f970ee66
Add some weak labels for a few exception vectors in disassembler
Michael Pavone <pavone@retrodev.com>
parents:
2110
diff
changeset
|
57 } |
7451f970ee66
Add some weak labels for a few exception vectors in disassembler
Michael Pavone <pavone@retrodev.com>
parents:
2110
diff
changeset
|
58 return 0; |
7451f970ee66
Add some weak labels for a few exception vectors in disassembler
Michael Pavone <pavone@retrodev.com>
parents:
2110
diff
changeset
|
59 } |
7451f970ee66
Add some weak labels for a few exception vectors in disassembler
Michael Pavone <pavone@retrodev.com>
parents:
2110
diff
changeset
|
60 |
2206
4c265d2f6c88
Minor refactor of 68K disassembler
Michael Pavone <pavone@retrodev.com>
parents:
2146
diff
changeset
|
61 void print_label_def(char *key, tern_val val, uint8_t valtype, void *data) |
4c265d2f6c88
Minor refactor of 68K disassembler
Michael Pavone <pavone@retrodev.com>
parents:
2146
diff
changeset
|
62 { |
4c265d2f6c88
Minor refactor of 68K disassembler
Michael Pavone <pavone@retrodev.com>
parents:
2146
diff
changeset
|
63 rom_def *rom = data; |
4c265d2f6c88
Minor refactor of 68K disassembler
Michael Pavone <pavone@retrodev.com>
parents:
2146
diff
changeset
|
64 label_def *label = val.ptrval; |
4c265d2f6c88
Minor refactor of 68K disassembler
Michael Pavone <pavone@retrodev.com>
parents:
2146
diff
changeset
|
65 uint32_t address = label->full_address & 0xFFFFFFF; |
4c265d2f6c88
Minor refactor of 68K disassembler
Michael Pavone <pavone@retrodev.com>
parents:
2146
diff
changeset
|
66 if (address >= rom->address_off && address < rom->address_end) { |
4c265d2f6c88
Minor refactor of 68K disassembler
Michael Pavone <pavone@retrodev.com>
parents:
2146
diff
changeset
|
67 return; |
4c265d2f6c88
Minor refactor of 68K disassembler
Michael Pavone <pavone@retrodev.com>
parents:
2146
diff
changeset
|
68 } |
4c265d2f6c88
Minor refactor of 68K disassembler
Michael Pavone <pavone@retrodev.com>
parents:
2146
diff
changeset
|
69 if (!label->referenced) { |
4c265d2f6c88
Minor refactor of 68K disassembler
Michael Pavone <pavone@retrodev.com>
parents:
2146
diff
changeset
|
70 return; |
4c265d2f6c88
Minor refactor of 68K disassembler
Michael Pavone <pavone@retrodev.com>
parents:
2146
diff
changeset
|
71 } |
4c265d2f6c88
Minor refactor of 68K disassembler
Michael Pavone <pavone@retrodev.com>
parents:
2146
diff
changeset
|
72 if (label->num_labels) { |
4c265d2f6c88
Minor refactor of 68K disassembler
Michael Pavone <pavone@retrodev.com>
parents:
2146
diff
changeset
|
73 for (int i = 0; i < label->num_labels; i++) |
4c265d2f6c88
Minor refactor of 68K disassembler
Michael Pavone <pavone@retrodev.com>
parents:
2146
diff
changeset
|
74 { |
4c265d2f6c88
Minor refactor of 68K disassembler
Michael Pavone <pavone@retrodev.com>
parents:
2146
diff
changeset
|
75 printf("%s equ $%X\n", label->labels[i], label->full_address); |
4c265d2f6c88
Minor refactor of 68K disassembler
Michael Pavone <pavone@retrodev.com>
parents:
2146
diff
changeset
|
76 } |
4c265d2f6c88
Minor refactor of 68K disassembler
Michael Pavone <pavone@retrodev.com>
parents:
2146
diff
changeset
|
77 } else { |
4c265d2f6c88
Minor refactor of 68K disassembler
Michael Pavone <pavone@retrodev.com>
parents:
2146
diff
changeset
|
78 printf("ADR_%X equ $%X\n", label->full_address, label->full_address); |
4c265d2f6c88
Minor refactor of 68K disassembler
Michael Pavone <pavone@retrodev.com>
parents:
2146
diff
changeset
|
79 } |
4c265d2f6c88
Minor refactor of 68K disassembler
Michael Pavone <pavone@retrodev.com>
parents:
2146
diff
changeset
|
80 } |
4c265d2f6c88
Minor refactor of 68K disassembler
Michael Pavone <pavone@retrodev.com>
parents:
2146
diff
changeset
|
81 |
2
5df303bf72e6
Improve 68K instruction decoding. Add simple disassembler.
Mike Pavone <pavone@retrodev.com>
parents:
diff
changeset
|
82 int main(int argc, char ** argv) |
5df303bf72e6
Improve 68K instruction decoding. Add simple disassembler.
Mike Pavone <pavone@retrodev.com>
parents:
diff
changeset
|
83 { |
5df303bf72e6
Improve 68K instruction decoding. Add simple disassembler.
Mike Pavone <pavone@retrodev.com>
parents:
diff
changeset
|
84 long filesize; |
2091
36a9cf4db65f
Fix some disassembler bugs introduced with Sega CD changes
Michael Pavone <pavone@retrodev.com>
parents:
2085
diff
changeset
|
85 unsigned short *filebuf = NULL; |
2
5df303bf72e6
Improve 68K instruction decoding. Add simple disassembler.
Mike Pavone <pavone@retrodev.com>
parents:
diff
changeset
|
86 char disbuf[1024]; |
5df303bf72e6
Improve 68K instruction decoding. Add simple disassembler.
Mike Pavone <pavone@retrodev.com>
parents:
diff
changeset
|
87 m68kinst instbuf; |
5df303bf72e6
Improve 68K instruction decoding. Add simple disassembler.
Mike Pavone <pavone@retrodev.com>
parents:
diff
changeset
|
88 unsigned short * cur; |
631
de6f00204fa2
Add support for disassembling VOS program modules
Michael Pavone <pavone@retrodev.com>
parents:
467
diff
changeset
|
89 |
632
80e111b48d4b
Add -r option to indicate VOS program module contains a 68K reset vector
Michael Pavone <pavone@retrodev.com>
parents:
631
diff
changeset
|
90 uint8_t labels = 0, addr = 0, only = 0, vos = 0, reset = 0; |
2206
4c265d2f6c88
Minor refactor of 68K disassembler
Michael Pavone <pavone@retrodev.com>
parents:
2146
diff
changeset
|
91 disasm_context *context = create_68000_disasm(); |
4c265d2f6c88
Minor refactor of 68K disassembler
Michael Pavone <pavone@retrodev.com>
parents:
2146
diff
changeset
|
92 |
631
de6f00204fa2
Add support for disassembling VOS program modules
Michael Pavone <pavone@retrodev.com>
parents:
467
diff
changeset
|
93 |
1078
c4bfbf55d418
Added some hacky support for specifying a start offset in 68K disassembler
Michael Pavone <pavone@retrodev.com>
parents:
947
diff
changeset
|
94 uint32_t address_off = 0, address_end; |
2105
1bda10d60b29
Add some enhancements for disassembling Main CPU Sega CD code
Michael Pavone <pavone@retrodev.com>
parents:
2102
diff
changeset
|
95 uint8_t do_cd_labels = 0, main_cpu = 0; |
134 | 96 for(uint8_t opt = 2; opt < argc; ++opt) { |
97 if (argv[opt][0] == '-') { | |
197
7c227a8ec53d
Add instruction address logging to translator and support for reading an address log to the disassembler
Mike Pavone <pavone@retrodev.com>
parents:
164
diff
changeset
|
98 FILE * address_log; |
134 | 99 switch (argv[opt][1]) |
100 { | |
101 case 'l': | |
102 labels = 1; | |
103 break; | |
104 case 'a': | |
105 addr = 1; | |
106 break; | |
151
6b593ea0ed90
Implement MULU/MULS and DIVU/DIVS
Mike Pavone <pavone@retrodev.com>
parents:
148
diff
changeset
|
107 case 'o': |
6b593ea0ed90
Implement MULU/MULS and DIVU/DIVS
Mike Pavone <pavone@retrodev.com>
parents:
148
diff
changeset
|
108 only = 1; |
6b593ea0ed90
Implement MULU/MULS and DIVU/DIVS
Mike Pavone <pavone@retrodev.com>
parents:
148
diff
changeset
|
109 break; |
631
de6f00204fa2
Add support for disassembling VOS program modules
Michael Pavone <pavone@retrodev.com>
parents:
467
diff
changeset
|
110 case 'v': |
de6f00204fa2
Add support for disassembling VOS program modules
Michael Pavone <pavone@retrodev.com>
parents:
467
diff
changeset
|
111 vos = 1; |
de6f00204fa2
Add support for disassembling VOS program modules
Michael Pavone <pavone@retrodev.com>
parents:
467
diff
changeset
|
112 break; |
632
80e111b48d4b
Add -r option to indicate VOS program module contains a 68K reset vector
Michael Pavone <pavone@retrodev.com>
parents:
631
diff
changeset
|
113 case 'r': |
80e111b48d4b
Add -r option to indicate VOS program module contains a 68K reset vector
Michael Pavone <pavone@retrodev.com>
parents:
631
diff
changeset
|
114 reset = 1; |
80e111b48d4b
Add -r option to indicate VOS program module contains a 68K reset vector
Michael Pavone <pavone@retrodev.com>
parents:
631
diff
changeset
|
115 break; |
2085
1ff67ce37085
Add some Sega CD specific enhancements to disassembler
Michael Pavone <pavone@retrodev.com>
parents:
2044
diff
changeset
|
116 case 'c': |
1ff67ce37085
Add some Sega CD specific enhancements to disassembler
Michael Pavone <pavone@retrodev.com>
parents:
2044
diff
changeset
|
117 do_cd_labels = 1; |
1ff67ce37085
Add some Sega CD specific enhancements to disassembler
Michael Pavone <pavone@retrodev.com>
parents:
2044
diff
changeset
|
118 break; |
2105
1bda10d60b29
Add some enhancements for disassembling Main CPU Sega CD code
Michael Pavone <pavone@retrodev.com>
parents:
2102
diff
changeset
|
119 case 'm': |
1bda10d60b29
Add some enhancements for disassembling Main CPU Sega CD code
Michael Pavone <pavone@retrodev.com>
parents:
2102
diff
changeset
|
120 main_cpu = 1; |
1bda10d60b29
Add some enhancements for disassembling Main CPU Sega CD code
Michael Pavone <pavone@retrodev.com>
parents:
2102
diff
changeset
|
121 break; |
1078
c4bfbf55d418
Added some hacky support for specifying a start offset in 68K disassembler
Michael Pavone <pavone@retrodev.com>
parents:
947
diff
changeset
|
122 case 's': |
c4bfbf55d418
Added some hacky support for specifying a start offset in 68K disassembler
Michael Pavone <pavone@retrodev.com>
parents:
947
diff
changeset
|
123 opt++; |
c4bfbf55d418
Added some hacky support for specifying a start offset in 68K disassembler
Michael Pavone <pavone@retrodev.com>
parents:
947
diff
changeset
|
124 if (opt >= argc) { |
c4bfbf55d418
Added some hacky support for specifying a start offset in 68K disassembler
Michael Pavone <pavone@retrodev.com>
parents:
947
diff
changeset
|
125 fputs("-s must be followed by an offset\n", stderr); |
c4bfbf55d418
Added some hacky support for specifying a start offset in 68K disassembler
Michael Pavone <pavone@retrodev.com>
parents:
947
diff
changeset
|
126 exit(1); |
c4bfbf55d418
Added some hacky support for specifying a start offset in 68K disassembler
Michael Pavone <pavone@retrodev.com>
parents:
947
diff
changeset
|
127 } |
c4bfbf55d418
Added some hacky support for specifying a start offset in 68K disassembler
Michael Pavone <pavone@retrodev.com>
parents:
947
diff
changeset
|
128 address_off = strtol(argv[opt], NULL, 0); |
c4bfbf55d418
Added some hacky support for specifying a start offset in 68K disassembler
Michael Pavone <pavone@retrodev.com>
parents:
947
diff
changeset
|
129 break; |
197
7c227a8ec53d
Add instruction address logging to translator and support for reading an address log to the disassembler
Mike Pavone <pavone@retrodev.com>
parents:
164
diff
changeset
|
130 case 'f': |
7c227a8ec53d
Add instruction address logging to translator and support for reading an address log to the disassembler
Mike Pavone <pavone@retrodev.com>
parents:
164
diff
changeset
|
131 opt++; |
7c227a8ec53d
Add instruction address logging to translator and support for reading an address log to the disassembler
Mike Pavone <pavone@retrodev.com>
parents:
164
diff
changeset
|
132 if (opt >= argc) { |
7c227a8ec53d
Add instruction address logging to translator and support for reading an address log to the disassembler
Mike Pavone <pavone@retrodev.com>
parents:
164
diff
changeset
|
133 fputs("-f must be followed by a filename\n", stderr); |
7c227a8ec53d
Add instruction address logging to translator and support for reading an address log to the disassembler
Mike Pavone <pavone@retrodev.com>
parents:
164
diff
changeset
|
134 exit(1); |
7c227a8ec53d
Add instruction address logging to translator and support for reading an address log to the disassembler
Mike Pavone <pavone@retrodev.com>
parents:
164
diff
changeset
|
135 } |
7c227a8ec53d
Add instruction address logging to translator and support for reading an address log to the disassembler
Mike Pavone <pavone@retrodev.com>
parents:
164
diff
changeset
|
136 address_log = fopen(argv[opt], "r"); |
7c227a8ec53d
Add instruction address logging to translator and support for reading an address log to the disassembler
Mike Pavone <pavone@retrodev.com>
parents:
164
diff
changeset
|
137 if (!address_log) { |
7c227a8ec53d
Add instruction address logging to translator and support for reading an address log to the disassembler
Mike Pavone <pavone@retrodev.com>
parents:
164
diff
changeset
|
138 fprintf(stderr, "Failed to open %s for reading\n", argv[opt]); |
7c227a8ec53d
Add instruction address logging to translator and support for reading an address log to the disassembler
Mike Pavone <pavone@retrodev.com>
parents:
164
diff
changeset
|
139 exit(1); |
7c227a8ec53d
Add instruction address logging to translator and support for reading an address log to the disassembler
Mike Pavone <pavone@retrodev.com>
parents:
164
diff
changeset
|
140 } |
7c227a8ec53d
Add instruction address logging to translator and support for reading an address log to the disassembler
Mike Pavone <pavone@retrodev.com>
parents:
164
diff
changeset
|
141 while (fgets(disbuf, sizeof(disbuf), address_log)) { |
7c227a8ec53d
Add instruction address logging to translator and support for reading an address log to the disassembler
Mike Pavone <pavone@retrodev.com>
parents:
164
diff
changeset
|
142 if (disbuf[0]) { |
947
d29722e3359c
Allow specification of named labels as command line arguments to the 68K disassembler
Michael Pavone <pavone@retrodev.com>
parents:
805
diff
changeset
|
143 char *end; |
d29722e3359c
Allow specification of named labels as command line arguments to the 68K disassembler
Michael Pavone <pavone@retrodev.com>
parents:
805
diff
changeset
|
144 uint32_t address = strtol(disbuf, &end, 16); |
197
7c227a8ec53d
Add instruction address logging to translator and support for reading an address log to the disassembler
Mike Pavone <pavone@retrodev.com>
parents:
164
diff
changeset
|
145 if (address) { |
2206
4c265d2f6c88
Minor refactor of 68K disassembler
Michael Pavone <pavone@retrodev.com>
parents:
2146
diff
changeset
|
146 defer_disasm(context, address); |
947
d29722e3359c
Allow specification of named labels as command line arguments to the 68K disassembler
Michael Pavone <pavone@retrodev.com>
parents:
805
diff
changeset
|
147 if (*end == '=') { |
2206
4c265d2f6c88
Minor refactor of 68K disassembler
Michael Pavone <pavone@retrodev.com>
parents:
2146
diff
changeset
|
148 add_label(context, strip_ws(end+1), address); |
4c265d2f6c88
Minor refactor of 68K disassembler
Michael Pavone <pavone@retrodev.com>
parents:
2146
diff
changeset
|
149 } else { |
4c265d2f6c88
Minor refactor of 68K disassembler
Michael Pavone <pavone@retrodev.com>
parents:
2146
diff
changeset
|
150 reference(context, address); |
947
d29722e3359c
Allow specification of named labels as command line arguments to the 68K disassembler
Michael Pavone <pavone@retrodev.com>
parents:
805
diff
changeset
|
151 } |
197
7c227a8ec53d
Add instruction address logging to translator and support for reading an address log to the disassembler
Mike Pavone <pavone@retrodev.com>
parents:
164
diff
changeset
|
152 } |
7c227a8ec53d
Add instruction address logging to translator and support for reading an address log to the disassembler
Mike Pavone <pavone@retrodev.com>
parents:
164
diff
changeset
|
153 } |
7c227a8ec53d
Add instruction address logging to translator and support for reading an address log to the disassembler
Mike Pavone <pavone@retrodev.com>
parents:
164
diff
changeset
|
154 } |
1594
137dbd05ceab
Fix some issues identified by cppcheck
Michael Pavone <pavone@retrodev.com>
parents:
1078
diff
changeset
|
155 fclose(address_log); |
134 | 156 } |
151
6b593ea0ed90
Implement MULU/MULS and DIVU/DIVS
Mike Pavone <pavone@retrodev.com>
parents:
148
diff
changeset
|
157 } else { |
947
d29722e3359c
Allow specification of named labels as command line arguments to the 68K disassembler
Michael Pavone <pavone@retrodev.com>
parents:
805
diff
changeset
|
158 char *end; |
d29722e3359c
Allow specification of named labels as command line arguments to the 68K disassembler
Michael Pavone <pavone@retrodev.com>
parents:
805
diff
changeset
|
159 uint32_t address = strtol(argv[opt], &end, 16); |
2206
4c265d2f6c88
Minor refactor of 68K disassembler
Michael Pavone <pavone@retrodev.com>
parents:
2146
diff
changeset
|
160 defer_disasm(context, address); |
947
d29722e3359c
Allow specification of named labels as command line arguments to the 68K disassembler
Michael Pavone <pavone@retrodev.com>
parents:
805
diff
changeset
|
161 if (*end == '=') { |
2206
4c265d2f6c88
Minor refactor of 68K disassembler
Michael Pavone <pavone@retrodev.com>
parents:
2146
diff
changeset
|
162 add_label(context, end+1, address); |
4c265d2f6c88
Minor refactor of 68K disassembler
Michael Pavone <pavone@retrodev.com>
parents:
2146
diff
changeset
|
163 } else { |
4c265d2f6c88
Minor refactor of 68K disassembler
Michael Pavone <pavone@retrodev.com>
parents:
2146
diff
changeset
|
164 reference(context, address); |
947
d29722e3359c
Allow specification of named labels as command line arguments to the 68K disassembler
Michael Pavone <pavone@retrodev.com>
parents:
805
diff
changeset
|
165 } |
134 | 166 } |
167 } | |
631
de6f00204fa2
Add support for disassembling VOS program modules
Michael Pavone <pavone@retrodev.com>
parents:
467
diff
changeset
|
168 FILE * f = fopen(argv[1], "rb"); |
de6f00204fa2
Add support for disassembling VOS program modules
Michael Pavone <pavone@retrodev.com>
parents:
467
diff
changeset
|
169 fseek(f, 0, SEEK_END); |
de6f00204fa2
Add support for disassembling VOS program modules
Michael Pavone <pavone@retrodev.com>
parents:
467
diff
changeset
|
170 filesize = ftell(f); |
de6f00204fa2
Add support for disassembling VOS program modules
Michael Pavone <pavone@retrodev.com>
parents:
467
diff
changeset
|
171 fseek(f, 0, SEEK_SET); |
de6f00204fa2
Add support for disassembling VOS program modules
Michael Pavone <pavone@retrodev.com>
parents:
467
diff
changeset
|
172 |
de6f00204fa2
Add support for disassembling VOS program modules
Michael Pavone <pavone@retrodev.com>
parents:
467
diff
changeset
|
173 char int_key[MAX_INT_KEY_SIZE]; |
2091
36a9cf4db65f
Fix some disassembler bugs introduced with Sega CD changes
Michael Pavone <pavone@retrodev.com>
parents:
2085
diff
changeset
|
174 uint8_t is_scd_iso = 0; |
2206
4c265d2f6c88
Minor refactor of 68K disassembler
Michael Pavone <pavone@retrodev.com>
parents:
2146
diff
changeset
|
175 uint8_t has_manual_defs = !!context->deferred; |
631
de6f00204fa2
Add support for disassembling VOS program modules
Michael Pavone <pavone@retrodev.com>
parents:
467
diff
changeset
|
176 if (vos) |
2
5df303bf72e6
Improve 68K instruction decoding. Add simple disassembler.
Mike Pavone <pavone@retrodev.com>
parents:
diff
changeset
|
177 { |
631
de6f00204fa2
Add support for disassembling VOS program modules
Michael Pavone <pavone@retrodev.com>
parents:
467
diff
changeset
|
178 vos_program_module header; |
de6f00204fa2
Add support for disassembling VOS program modules
Michael Pavone <pavone@retrodev.com>
parents:
467
diff
changeset
|
179 vos_read_header(f, &header); |
de6f00204fa2
Add support for disassembling VOS program modules
Michael Pavone <pavone@retrodev.com>
parents:
467
diff
changeset
|
180 vos_read_alloc_module_map(f, &header); |
de6f00204fa2
Add support for disassembling VOS program modules
Michael Pavone <pavone@retrodev.com>
parents:
467
diff
changeset
|
181 address_off = header.user_boundary; |
de6f00204fa2
Add support for disassembling VOS program modules
Michael Pavone <pavone@retrodev.com>
parents:
467
diff
changeset
|
182 address_end = address_off + filesize - 0x1000; |
2206
4c265d2f6c88
Minor refactor of 68K disassembler
Michael Pavone <pavone@retrodev.com>
parents:
2146
diff
changeset
|
183 defer_disasm(context, header.main_entry_link.code_address); |
4c265d2f6c88
Minor refactor of 68K disassembler
Michael Pavone <pavone@retrodev.com>
parents:
2146
diff
changeset
|
184 add_label(context, "main_entry_link", header.main_entry_link.code_address); |
631
de6f00204fa2
Add support for disassembling VOS program modules
Michael Pavone <pavone@retrodev.com>
parents:
467
diff
changeset
|
185 for (int i = 0; i < header.n_modules; i++) |
de6f00204fa2
Add support for disassembling VOS program modules
Michael Pavone <pavone@retrodev.com>
parents:
467
diff
changeset
|
186 { |
632
80e111b48d4b
Add -r option to indicate VOS program module contains a 68K reset vector
Michael Pavone <pavone@retrodev.com>
parents:
631
diff
changeset
|
187 if (!reset || header.module_map_entries[i].code_address != header.user_boundary) |
80e111b48d4b
Add -r option to indicate VOS program module contains a 68K reset vector
Michael Pavone <pavone@retrodev.com>
parents:
631
diff
changeset
|
188 { |
2206
4c265d2f6c88
Minor refactor of 68K disassembler
Michael Pavone <pavone@retrodev.com>
parents:
2146
diff
changeset
|
189 defer_disasm(context, header.module_map_entries[i].code_address); |
632
80e111b48d4b
Add -r option to indicate VOS program module contains a 68K reset vector
Michael Pavone <pavone@retrodev.com>
parents:
631
diff
changeset
|
190 } |
2206
4c265d2f6c88
Minor refactor of 68K disassembler
Michael Pavone <pavone@retrodev.com>
parents:
2146
diff
changeset
|
191 add_label(context, header.module_map_entries[i].name.str, header.module_map_entries[i].code_address); |
631
de6f00204fa2
Add support for disassembling VOS program modules
Michael Pavone <pavone@retrodev.com>
parents:
467
diff
changeset
|
192 } |
de6f00204fa2
Add support for disassembling VOS program modules
Michael Pavone <pavone@retrodev.com>
parents:
467
diff
changeset
|
193 fseek(f, 0x1000, SEEK_SET); |
de6f00204fa2
Add support for disassembling VOS program modules
Michael Pavone <pavone@retrodev.com>
parents:
467
diff
changeset
|
194 filebuf = malloc(filesize - 0x1000); |
de6f00204fa2
Add support for disassembling VOS program modules
Michael Pavone <pavone@retrodev.com>
parents:
467
diff
changeset
|
195 if (fread(filebuf, 2, (filesize - 0x1000)/2, f) != (filesize - 0x1000)/2) |
de6f00204fa2
Add support for disassembling VOS program modules
Michael Pavone <pavone@retrodev.com>
parents:
467
diff
changeset
|
196 { |
de6f00204fa2
Add support for disassembling VOS program modules
Michael Pavone <pavone@retrodev.com>
parents:
467
diff
changeset
|
197 fprintf(stderr, "Failure while reading file %s\n", argv[1]); |
de6f00204fa2
Add support for disassembling VOS program modules
Michael Pavone <pavone@retrodev.com>
parents:
467
diff
changeset
|
198 } |
de6f00204fa2
Add support for disassembling VOS program modules
Michael Pavone <pavone@retrodev.com>
parents:
467
diff
changeset
|
199 fclose(f); |
de6f00204fa2
Add support for disassembling VOS program modules
Michael Pavone <pavone@retrodev.com>
parents:
467
diff
changeset
|
200 for(cur = filebuf; cur - filebuf < ((filesize - 0x1000)/2); ++cur) |
de6f00204fa2
Add support for disassembling VOS program modules
Michael Pavone <pavone@retrodev.com>
parents:
467
diff
changeset
|
201 { |
de6f00204fa2
Add support for disassembling VOS program modules
Michael Pavone <pavone@retrodev.com>
parents:
467
diff
changeset
|
202 *cur = (*cur >> 8) | (*cur << 8); |
de6f00204fa2
Add support for disassembling VOS program modules
Michael Pavone <pavone@retrodev.com>
parents:
467
diff
changeset
|
203 } |
632
80e111b48d4b
Add -r option to indicate VOS program module contains a 68K reset vector
Michael Pavone <pavone@retrodev.com>
parents:
631
diff
changeset
|
204 if (reset) |
80e111b48d4b
Add -r option to indicate VOS program module contains a 68K reset vector
Michael Pavone <pavone@retrodev.com>
parents:
631
diff
changeset
|
205 { |
2206
4c265d2f6c88
Minor refactor of 68K disassembler
Michael Pavone <pavone@retrodev.com>
parents:
2146
diff
changeset
|
206 defer_disasm(context, filebuf[2] << 16 | filebuf[3]); |
4c265d2f6c88
Minor refactor of 68K disassembler
Michael Pavone <pavone@retrodev.com>
parents:
2146
diff
changeset
|
207 add_label(context, "reset", filebuf[2] << 16 | filebuf[3]); |
632
80e111b48d4b
Add -r option to indicate VOS program module contains a 68K reset vector
Michael Pavone <pavone@retrodev.com>
parents:
631
diff
changeset
|
208 } |
2085
1ff67ce37085
Add some Sega CD specific enhancements to disassembler
Michael Pavone <pavone@retrodev.com>
parents:
2044
diff
changeset
|
209 } else if (filesize > 0x1000) { |
1ff67ce37085
Add some Sega CD specific enhancements to disassembler
Michael Pavone <pavone@retrodev.com>
parents:
2044
diff
changeset
|
210 long boot_size = filesize > (32*1024) ? 32*1024 : filesize; |
1ff67ce37085
Add some Sega CD specific enhancements to disassembler
Michael Pavone <pavone@retrodev.com>
parents:
2044
diff
changeset
|
211 filebuf = malloc(boot_size); |
1ff67ce37085
Add some Sega CD specific enhancements to disassembler
Michael Pavone <pavone@retrodev.com>
parents:
2044
diff
changeset
|
212 if (fread(filebuf, 1, boot_size, f) != boot_size) { |
631
de6f00204fa2
Add support for disassembling VOS program modules
Michael Pavone <pavone@retrodev.com>
parents:
467
diff
changeset
|
213 fprintf(stderr, "Failure while reading file %s\n", argv[1]); |
2085
1ff67ce37085
Add some Sega CD specific enhancements to disassembler
Michael Pavone <pavone@retrodev.com>
parents:
2044
diff
changeset
|
214 return 1; |
631
de6f00204fa2
Add support for disassembling VOS program modules
Michael Pavone <pavone@retrodev.com>
parents:
467
diff
changeset
|
215 } |
2091
36a9cf4db65f
Fix some disassembler bugs introduced with Sega CD changes
Michael Pavone <pavone@retrodev.com>
parents:
2085
diff
changeset
|
216 is_scd_iso = !memcmp("SEGADISCSYSTEM ", filebuf, 0x10); |
2085
1ff67ce37085
Add some Sega CD specific enhancements to disassembler
Michael Pavone <pavone@retrodev.com>
parents:
2044
diff
changeset
|
217 if (!is_scd_iso && !memcmp("SEGADISCSYSTEM ", filebuf + 0x8, 0x10)) { |
1ff67ce37085
Add some Sega CD specific enhancements to disassembler
Michael Pavone <pavone@retrodev.com>
parents:
2044
diff
changeset
|
218 is_scd_iso = 1; |
1ff67ce37085
Add some Sega CD specific enhancements to disassembler
Michael Pavone <pavone@retrodev.com>
parents:
2044
diff
changeset
|
219 uint32_t end = 16 * 2352; |
1ff67ce37085
Add some Sega CD specific enhancements to disassembler
Michael Pavone <pavone@retrodev.com>
parents:
2044
diff
changeset
|
220 if (end > filesize) { |
1ff67ce37085
Add some Sega CD specific enhancements to disassembler
Michael Pavone <pavone@retrodev.com>
parents:
2044
diff
changeset
|
221 end = (filesize / 2352) * 2352; |
1ff67ce37085
Add some Sega CD specific enhancements to disassembler
Michael Pavone <pavone@retrodev.com>
parents:
2044
diff
changeset
|
222 } |
1ff67ce37085
Add some Sega CD specific enhancements to disassembler
Michael Pavone <pavone@retrodev.com>
parents:
2044
diff
changeset
|
223 for(uint32_t offset = 0x10, dst_offset = 0; offset < end; offset += 2352, dst_offset += 2048) |
1ff67ce37085
Add some Sega CD specific enhancements to disassembler
Michael Pavone <pavone@retrodev.com>
parents:
2044
diff
changeset
|
224 { |
1ff67ce37085
Add some Sega CD specific enhancements to disassembler
Michael Pavone <pavone@retrodev.com>
parents:
2044
diff
changeset
|
225 memmove(filebuf + dst_offset/2, filebuf + offset/2, 2048); |
1ff67ce37085
Add some Sega CD specific enhancements to disassembler
Michael Pavone <pavone@retrodev.com>
parents:
2044
diff
changeset
|
226 } |
1ff67ce37085
Add some Sega CD specific enhancements to disassembler
Michael Pavone <pavone@retrodev.com>
parents:
2044
diff
changeset
|
227 boot_size = (end / 2352) * 2048; |
631
de6f00204fa2
Add support for disassembling VOS program modules
Michael Pavone <pavone@retrodev.com>
parents:
467
diff
changeset
|
228 } |
2085
1ff67ce37085
Add some Sega CD specific enhancements to disassembler
Michael Pavone <pavone@retrodev.com>
parents:
2044
diff
changeset
|
229 if (is_scd_iso) { |
2105
1bda10d60b29
Add some enhancements for disassembling Main CPU Sega CD code
Michael Pavone <pavone@retrodev.com>
parents:
2102
diff
changeset
|
230 fclose(f); |
2085
1ff67ce37085
Add some Sega CD specific enhancements to disassembler
Michael Pavone <pavone@retrodev.com>
parents:
2044
diff
changeset
|
231 for(cur = filebuf; cur - filebuf < (boot_size/2); ++cur) |
1ff67ce37085
Add some Sega CD specific enhancements to disassembler
Michael Pavone <pavone@retrodev.com>
parents:
2044
diff
changeset
|
232 { |
1ff67ce37085
Add some Sega CD specific enhancements to disassembler
Michael Pavone <pavone@retrodev.com>
parents:
2044
diff
changeset
|
233 *cur = (*cur >> 8) | (*cur << 8); |
1ff67ce37085
Add some Sega CD specific enhancements to disassembler
Michael Pavone <pavone@retrodev.com>
parents:
2044
diff
changeset
|
234 } |
2105
1bda10d60b29
Add some enhancements for disassembling Main CPU Sega CD code
Michael Pavone <pavone@retrodev.com>
parents:
2102
diff
changeset
|
235 if (main_cpu) { |
1bda10d60b29
Add some enhancements for disassembling Main CPU Sega CD code
Michael Pavone <pavone@retrodev.com>
parents:
2102
diff
changeset
|
236 uint32_t main_start = 0x200; |
1bda10d60b29
Add some enhancements for disassembling Main CPU Sega CD code
Michael Pavone <pavone@retrodev.com>
parents:
2102
diff
changeset
|
237 uint32_t extra_start = filebuf[0x30/2] << 16 | filebuf[0x32/2]; |
1bda10d60b29
Add some enhancements for disassembling Main CPU Sega CD code
Michael Pavone <pavone@retrodev.com>
parents:
2102
diff
changeset
|
238 uint32_t main_end = (filebuf[0x34/2] << 16 | filebuf[0x36/2]) + extra_start; |
1bda10d60b29
Add some enhancements for disassembling Main CPU Sega CD code
Michael Pavone <pavone@retrodev.com>
parents:
2102
diff
changeset
|
239 if (main_end > boot_size) { |
1bda10d60b29
Add some enhancements for disassembling Main CPU Sega CD code
Michael Pavone <pavone@retrodev.com>
parents:
2102
diff
changeset
|
240 main_end = boot_size; |
1bda10d60b29
Add some enhancements for disassembling Main CPU Sega CD code
Michael Pavone <pavone@retrodev.com>
parents:
2102
diff
changeset
|
241 } |
1bda10d60b29
Add some enhancements for disassembling Main CPU Sega CD code
Michael Pavone <pavone@retrodev.com>
parents:
2102
diff
changeset
|
242 address_off = 0xFF0000; |
1bda10d60b29
Add some enhancements for disassembling Main CPU Sega CD code
Michael Pavone <pavone@retrodev.com>
parents:
2102
diff
changeset
|
243 address_end = address_off + main_end-main_start; |
1bda10d60b29
Add some enhancements for disassembling Main CPU Sega CD code
Michael Pavone <pavone@retrodev.com>
parents:
2102
diff
changeset
|
244 filebuf += main_start / 2; |
2206
4c265d2f6c88
Minor refactor of 68K disassembler
Michael Pavone <pavone@retrodev.com>
parents:
2146
diff
changeset
|
245 add_label(context, "start", 0xFF0000); |
2105
1bda10d60b29
Add some enhancements for disassembling Main CPU Sega CD code
Michael Pavone <pavone@retrodev.com>
parents:
2102
diff
changeset
|
246 if (!has_manual_defs || !only) { |
2206
4c265d2f6c88
Minor refactor of 68K disassembler
Michael Pavone <pavone@retrodev.com>
parents:
2146
diff
changeset
|
247 defer_disasm(context, 0xFF0000); |
2105
1bda10d60b29
Add some enhancements for disassembling Main CPU Sega CD code
Michael Pavone <pavone@retrodev.com>
parents:
2102
diff
changeset
|
248 } |
2110
f1238ffb30a3
Some very minor Sega CD disassembler improvements
Michael Pavone <pavone@retrodev.com>
parents:
2105
diff
changeset
|
249 uint32_t user_start; |
f1238ffb30a3
Some very minor Sega CD disassembler improvements
Michael Pavone <pavone@retrodev.com>
parents:
2105
diff
changeset
|
250 if (filebuf[0xA/2] == 0x57A) { |
f1238ffb30a3
Some very minor Sega CD disassembler improvements
Michael Pavone <pavone@retrodev.com>
parents:
2105
diff
changeset
|
251 //US |
f1238ffb30a3
Some very minor Sega CD disassembler improvements
Michael Pavone <pavone@retrodev.com>
parents:
2105
diff
changeset
|
252 user_start = 0xFF0584; |
f1238ffb30a3
Some very minor Sega CD disassembler improvements
Michael Pavone <pavone@retrodev.com>
parents:
2105
diff
changeset
|
253 } else if (filebuf[0xA/2] == 0x564) { |
f1238ffb30a3
Some very minor Sega CD disassembler improvements
Michael Pavone <pavone@retrodev.com>
parents:
2105
diff
changeset
|
254 //EU |
f1238ffb30a3
Some very minor Sega CD disassembler improvements
Michael Pavone <pavone@retrodev.com>
parents:
2105
diff
changeset
|
255 user_start = 0xFF056E; |
f1238ffb30a3
Some very minor Sega CD disassembler improvements
Michael Pavone <pavone@retrodev.com>
parents:
2105
diff
changeset
|
256 } else { |
f1238ffb30a3
Some very minor Sega CD disassembler improvements
Michael Pavone <pavone@retrodev.com>
parents:
2105
diff
changeset
|
257 //JP |
f1238ffb30a3
Some very minor Sega CD disassembler improvements
Michael Pavone <pavone@retrodev.com>
parents:
2105
diff
changeset
|
258 user_start = 0xFF0156; |
f1238ffb30a3
Some very minor Sega CD disassembler improvements
Michael Pavone <pavone@retrodev.com>
parents:
2105
diff
changeset
|
259 } |
2206
4c265d2f6c88
Minor refactor of 68K disassembler
Michael Pavone <pavone@retrodev.com>
parents:
2146
diff
changeset
|
260 add_label(context, "user_start", user_start); |
2105
1bda10d60b29
Add some enhancements for disassembling Main CPU Sega CD code
Michael Pavone <pavone@retrodev.com>
parents:
2102
diff
changeset
|
261 do_cd_labels = 1; |
1bda10d60b29
Add some enhancements for disassembling Main CPU Sega CD code
Michael Pavone <pavone@retrodev.com>
parents:
2102
diff
changeset
|
262 } else { |
1bda10d60b29
Add some enhancements for disassembling Main CPU Sega CD code
Michael Pavone <pavone@retrodev.com>
parents:
2102
diff
changeset
|
263 uint32_t sub_start =filebuf[0x40/2] << 16 | filebuf[0x42/2]; |
2146
0c0d4233d826
Fix SP end address in disassembler
Michael Pavone <pavone@retrodev.com>
parents:
2132
diff
changeset
|
264 uint32_t sub_end = sub_start + (filebuf[0x44/2] << 16 | filebuf[0x46/2]); |
2105
1bda10d60b29
Add some enhancements for disassembling Main CPU Sega CD code
Michael Pavone <pavone@retrodev.com>
parents:
2102
diff
changeset
|
265 if (sub_start > (boot_size - 0x20)) { |
1bda10d60b29
Add some enhancements for disassembling Main CPU Sega CD code
Michael Pavone <pavone@retrodev.com>
parents:
2102
diff
changeset
|
266 fprintf(stderr, "System Program start offset is %X, but image is only %X bytes\n", sub_start, (uint32_t)boot_size); |
1bda10d60b29
Add some enhancements for disassembling Main CPU Sega CD code
Michael Pavone <pavone@retrodev.com>
parents:
2102
diff
changeset
|
267 return 1; |
1bda10d60b29
Add some enhancements for disassembling Main CPU Sega CD code
Michael Pavone <pavone@retrodev.com>
parents:
2102
diff
changeset
|
268 } |
1bda10d60b29
Add some enhancements for disassembling Main CPU Sega CD code
Michael Pavone <pavone@retrodev.com>
parents:
2102
diff
changeset
|
269 if (sub_end > boot_size) { |
1bda10d60b29
Add some enhancements for disassembling Main CPU Sega CD code
Michael Pavone <pavone@retrodev.com>
parents:
2102
diff
changeset
|
270 sub_end = boot_size; |
2085
1ff67ce37085
Add some Sega CD specific enhancements to disassembler
Michael Pavone <pavone@retrodev.com>
parents:
2044
diff
changeset
|
271 } |
2105
1bda10d60b29
Add some enhancements for disassembling Main CPU Sega CD code
Michael Pavone <pavone@retrodev.com>
parents:
2102
diff
changeset
|
272 uint32_t offset_start = (filebuf[(sub_start + 0x18)/2] << 16 | filebuf[(sub_start + 0x1A)/2]) + sub_start; |
1bda10d60b29
Add some enhancements for disassembling Main CPU Sega CD code
Michael Pavone <pavone@retrodev.com>
parents:
2102
diff
changeset
|
273 for(uint32_t cur = offset_start, index = 0; cur < sub_end && filebuf[cur/2]; cur+=2, ++index) |
1bda10d60b29
Add some enhancements for disassembling Main CPU Sega CD code
Michael Pavone <pavone@retrodev.com>
parents:
2102
diff
changeset
|
274 { |
1bda10d60b29
Add some enhancements for disassembling Main CPU Sega CD code
Michael Pavone <pavone@retrodev.com>
parents:
2102
diff
changeset
|
275 uint32_t offset = offset_start + filebuf[cur/2]; |
1bda10d60b29
Add some enhancements for disassembling Main CPU Sega CD code
Michael Pavone <pavone@retrodev.com>
parents:
2102
diff
changeset
|
276 if (offset >= boot_size) { |
1bda10d60b29
Add some enhancements for disassembling Main CPU Sega CD code
Michael Pavone <pavone@retrodev.com>
parents:
2102
diff
changeset
|
277 break; |
1bda10d60b29
Add some enhancements for disassembling Main CPU Sega CD code
Michael Pavone <pavone@retrodev.com>
parents:
2102
diff
changeset
|
278 } |
1bda10d60b29
Add some enhancements for disassembling Main CPU Sega CD code
Michael Pavone <pavone@retrodev.com>
parents:
2102
diff
changeset
|
279 static const char* fixed_names[3] = { |
1bda10d60b29
Add some enhancements for disassembling Main CPU Sega CD code
Michael Pavone <pavone@retrodev.com>
parents:
2102
diff
changeset
|
280 "init", |
1bda10d60b29
Add some enhancements for disassembling Main CPU Sega CD code
Michael Pavone <pavone@retrodev.com>
parents:
2102
diff
changeset
|
281 "main", |
1bda10d60b29
Add some enhancements for disassembling Main CPU Sega CD code
Michael Pavone <pavone@retrodev.com>
parents:
2102
diff
changeset
|
282 "int_2" |
1bda10d60b29
Add some enhancements for disassembling Main CPU Sega CD code
Michael Pavone <pavone@retrodev.com>
parents:
2102
diff
changeset
|
283 }; |
1bda10d60b29
Add some enhancements for disassembling Main CPU Sega CD code
Michael Pavone <pavone@retrodev.com>
parents:
2102
diff
changeset
|
284 char namebuf[32]; |
1bda10d60b29
Add some enhancements for disassembling Main CPU Sega CD code
Michael Pavone <pavone@retrodev.com>
parents:
2102
diff
changeset
|
285 const char *name; |
1bda10d60b29
Add some enhancements for disassembling Main CPU Sega CD code
Michael Pavone <pavone@retrodev.com>
parents:
2102
diff
changeset
|
286 if (index < 3) { |
1bda10d60b29
Add some enhancements for disassembling Main CPU Sega CD code
Michael Pavone <pavone@retrodev.com>
parents:
2102
diff
changeset
|
287 name = fixed_names[index]; |
1bda10d60b29
Add some enhancements for disassembling Main CPU Sega CD code
Michael Pavone <pavone@retrodev.com>
parents:
2102
diff
changeset
|
288 } else { |
1bda10d60b29
Add some enhancements for disassembling Main CPU Sega CD code
Michael Pavone <pavone@retrodev.com>
parents:
2102
diff
changeset
|
289 name = namebuf; |
1bda10d60b29
Add some enhancements for disassembling Main CPU Sega CD code
Michael Pavone <pavone@retrodev.com>
parents:
2102
diff
changeset
|
290 sprintf(namebuf, "usercall%u", index); |
1bda10d60b29
Add some enhancements for disassembling Main CPU Sega CD code
Michael Pavone <pavone@retrodev.com>
parents:
2102
diff
changeset
|
291 } |
1bda10d60b29
Add some enhancements for disassembling Main CPU Sega CD code
Michael Pavone <pavone@retrodev.com>
parents:
2102
diff
changeset
|
292 uint32_t address = 0x6000 + offset - sub_start; |
2206
4c265d2f6c88
Minor refactor of 68K disassembler
Michael Pavone <pavone@retrodev.com>
parents:
2146
diff
changeset
|
293 add_label(context, name, address); |
2105
1bda10d60b29
Add some enhancements for disassembling Main CPU Sega CD code
Michael Pavone <pavone@retrodev.com>
parents:
2102
diff
changeset
|
294 if (!has_manual_defs || !only) { |
2206
4c265d2f6c88
Minor refactor of 68K disassembler
Michael Pavone <pavone@retrodev.com>
parents:
2146
diff
changeset
|
295 defer_disasm(context, address); |
2105
1bda10d60b29
Add some enhancements for disassembling Main CPU Sega CD code
Michael Pavone <pavone@retrodev.com>
parents:
2102
diff
changeset
|
296 } |
2085
1ff67ce37085
Add some Sega CD specific enhancements to disassembler
Michael Pavone <pavone@retrodev.com>
parents:
2044
diff
changeset
|
297 } |
2105
1bda10d60b29
Add some enhancements for disassembling Main CPU Sega CD code
Michael Pavone <pavone@retrodev.com>
parents:
2102
diff
changeset
|
298 |
1bda10d60b29
Add some enhancements for disassembling Main CPU Sega CD code
Michael Pavone <pavone@retrodev.com>
parents:
2102
diff
changeset
|
299 do_cd_labels = 1; |
1bda10d60b29
Add some enhancements for disassembling Main CPU Sega CD code
Michael Pavone <pavone@retrodev.com>
parents:
2102
diff
changeset
|
300 filebuf += sub_start / 2; |
1bda10d60b29
Add some enhancements for disassembling Main CPU Sega CD code
Michael Pavone <pavone@retrodev.com>
parents:
2102
diff
changeset
|
301 address_off = 0x6000; |
1bda10d60b29
Add some enhancements for disassembling Main CPU Sega CD code
Michael Pavone <pavone@retrodev.com>
parents:
2102
diff
changeset
|
302 address_end = sub_end-sub_start + address_off; |
2085
1ff67ce37085
Add some Sega CD specific enhancements to disassembler
Michael Pavone <pavone@retrodev.com>
parents:
2044
diff
changeset
|
303 } |
2091
36a9cf4db65f
Fix some disassembler bugs introduced with Sega CD changes
Michael Pavone <pavone@retrodev.com>
parents:
2085
diff
changeset
|
304 } |
36a9cf4db65f
Fix some disassembler bugs introduced with Sega CD changes
Michael Pavone <pavone@retrodev.com>
parents:
2085
diff
changeset
|
305 } |
36a9cf4db65f
Fix some disassembler bugs introduced with Sega CD changes
Michael Pavone <pavone@retrodev.com>
parents:
2085
diff
changeset
|
306 if (!vos && !is_scd_iso) { |
36a9cf4db65f
Fix some disassembler bugs introduced with Sega CD changes
Michael Pavone <pavone@retrodev.com>
parents:
2085
diff
changeset
|
307 if (filebuf) { |
2085
1ff67ce37085
Add some Sega CD specific enhancements to disassembler
Michael Pavone <pavone@retrodev.com>
parents:
2044
diff
changeset
|
308 if (filesize > (32*1024)) { |
2091
36a9cf4db65f
Fix some disassembler bugs introduced with Sega CD changes
Michael Pavone <pavone@retrodev.com>
parents:
2085
diff
changeset
|
309 filebuf = realloc(filebuf, filesize); |
2085
1ff67ce37085
Add some Sega CD specific enhancements to disassembler
Michael Pavone <pavone@retrodev.com>
parents:
2044
diff
changeset
|
310 fseek(f, 32*1024, SEEK_SET); |
1ff67ce37085
Add some Sega CD specific enhancements to disassembler
Michael Pavone <pavone@retrodev.com>
parents:
2044
diff
changeset
|
311 uint32_t to_read = filesize/2 - 16*1024; |
2091
36a9cf4db65f
Fix some disassembler bugs introduced with Sega CD changes
Michael Pavone <pavone@retrodev.com>
parents:
2085
diff
changeset
|
312 if (fread(filebuf + 16*1024, 2, to_read, f) != to_read) |
2085
1ff67ce37085
Add some Sega CD specific enhancements to disassembler
Michael Pavone <pavone@retrodev.com>
parents:
2044
diff
changeset
|
313 { |
1ff67ce37085
Add some Sega CD specific enhancements to disassembler
Michael Pavone <pavone@retrodev.com>
parents:
2044
diff
changeset
|
314 fprintf(stderr, "Failure while reading file %s\n", argv[1]); |
1ff67ce37085
Add some Sega CD specific enhancements to disassembler
Michael Pavone <pavone@retrodev.com>
parents:
2044
diff
changeset
|
315 } |
1ff67ce37085
Add some Sega CD specific enhancements to disassembler
Michael Pavone <pavone@retrodev.com>
parents:
2044
diff
changeset
|
316 } |
2091
36a9cf4db65f
Fix some disassembler bugs introduced with Sega CD changes
Michael Pavone <pavone@retrodev.com>
parents:
2085
diff
changeset
|
317 } else { |
36a9cf4db65f
Fix some disassembler bugs introduced with Sega CD changes
Michael Pavone <pavone@retrodev.com>
parents:
2085
diff
changeset
|
318 filebuf = malloc(filesize); |
36a9cf4db65f
Fix some disassembler bugs introduced with Sega CD changes
Michael Pavone <pavone@retrodev.com>
parents:
2085
diff
changeset
|
319 if (fread(filebuf, 2, filesize/2, f) != filesize/2) |
2085
1ff67ce37085
Add some Sega CD specific enhancements to disassembler
Michael Pavone <pavone@retrodev.com>
parents:
2044
diff
changeset
|
320 { |
2091
36a9cf4db65f
Fix some disassembler bugs introduced with Sega CD changes
Michael Pavone <pavone@retrodev.com>
parents:
2085
diff
changeset
|
321 fprintf(stderr, "Failure while reading file %s\n", argv[1]); |
2085
1ff67ce37085
Add some Sega CD specific enhancements to disassembler
Michael Pavone <pavone@retrodev.com>
parents:
2044
diff
changeset
|
322 } |
2091
36a9cf4db65f
Fix some disassembler bugs introduced with Sega CD changes
Michael Pavone <pavone@retrodev.com>
parents:
2085
diff
changeset
|
323 } |
36a9cf4db65f
Fix some disassembler bugs introduced with Sega CD changes
Michael Pavone <pavone@retrodev.com>
parents:
2085
diff
changeset
|
324 address_end = address_off + filesize; |
36a9cf4db65f
Fix some disassembler bugs introduced with Sega CD changes
Michael Pavone <pavone@retrodev.com>
parents:
2085
diff
changeset
|
325 fclose(f); |
36a9cf4db65f
Fix some disassembler bugs introduced with Sega CD changes
Michael Pavone <pavone@retrodev.com>
parents:
2085
diff
changeset
|
326 for(cur = filebuf; cur - filebuf < (filesize/2); ++cur) |
36a9cf4db65f
Fix some disassembler bugs introduced with Sega CD changes
Michael Pavone <pavone@retrodev.com>
parents:
2085
diff
changeset
|
327 { |
36a9cf4db65f
Fix some disassembler bugs introduced with Sega CD changes
Michael Pavone <pavone@retrodev.com>
parents:
2085
diff
changeset
|
328 *cur = (*cur >> 8) | (*cur << 8); |
36a9cf4db65f
Fix some disassembler bugs introduced with Sega CD changes
Michael Pavone <pavone@retrodev.com>
parents:
2085
diff
changeset
|
329 } |
36a9cf4db65f
Fix some disassembler bugs introduced with Sega CD changes
Michael Pavone <pavone@retrodev.com>
parents:
2085
diff
changeset
|
330 if (!address_off) { |
2206
4c265d2f6c88
Minor refactor of 68K disassembler
Michael Pavone <pavone@retrodev.com>
parents:
2146
diff
changeset
|
331 process_m68k_vectors(context, filebuf, context->deferred && only); |
631
de6f00204fa2
Add support for disassembling VOS program modules
Michael Pavone <pavone@retrodev.com>
parents:
467
diff
changeset
|
332 } |
2
5df303bf72e6
Improve 68K instruction decoding. Add simple disassembler.
Mike Pavone <pavone@retrodev.com>
parents:
diff
changeset
|
333 } |
2085
1ff67ce37085
Add some Sega CD specific enhancements to disassembler
Michael Pavone <pavone@retrodev.com>
parents:
2044
diff
changeset
|
334 if (do_cd_labels) { |
2105
1bda10d60b29
Add some enhancements for disassembling Main CPU Sega CD code
Michael Pavone <pavone@retrodev.com>
parents:
2102
diff
changeset
|
335 if (main_cpu) { |
2206
4c265d2f6c88
Minor refactor of 68K disassembler
Michael Pavone <pavone@retrodev.com>
parents:
2146
diff
changeset
|
336 add_segacd_maincpu_labels(context); |
2105
1bda10d60b29
Add some enhancements for disassembling Main CPU Sega CD code
Michael Pavone <pavone@retrodev.com>
parents:
2102
diff
changeset
|
337 } else { |
2206
4c265d2f6c88
Minor refactor of 68K disassembler
Michael Pavone <pavone@retrodev.com>
parents:
2146
diff
changeset
|
338 add_segacd_subcpu_labels(context); |
2105
1bda10d60b29
Add some enhancements for disassembling Main CPU Sega CD code
Michael Pavone <pavone@retrodev.com>
parents:
2102
diff
changeset
|
339 } |
2085
1ff67ce37085
Add some Sega CD specific enhancements to disassembler
Michael Pavone <pavone@retrodev.com>
parents:
2044
diff
changeset
|
340 } |
631
de6f00204fa2
Add support for disassembling VOS program modules
Michael Pavone <pavone@retrodev.com>
parents:
467
diff
changeset
|
341 uint32_t size, tmp_addr; |
139
cce22fb4c450
Properly support references to odd addresses in label generation in disassembler. Add labels for start and interrupts.
Mike Pavone <pavone@retrodev.com>
parents:
134
diff
changeset
|
342 uint32_t address; |
2132
7451f970ee66
Add some weak labels for a few exception vectors in disassembler
Michael Pavone <pavone@retrodev.com>
parents:
2110
diff
changeset
|
343 rom_def rom = { |
7451f970ee66
Add some weak labels for a few exception vectors in disassembler
Michael Pavone <pavone@retrodev.com>
parents:
2110
diff
changeset
|
344 .address_off = address_off, |
7451f970ee66
Add some weak labels for a few exception vectors in disassembler
Michael Pavone <pavone@retrodev.com>
parents:
2110
diff
changeset
|
345 .address_end = address_end, |
7451f970ee66
Add some weak labels for a few exception vectors in disassembler
Michael Pavone <pavone@retrodev.com>
parents:
2110
diff
changeset
|
346 .buffer = filebuf |
7451f970ee66
Add some weak labels for a few exception vectors in disassembler
Michael Pavone <pavone@retrodev.com>
parents:
2110
diff
changeset
|
347 }; |
7451f970ee66
Add some weak labels for a few exception vectors in disassembler
Michael Pavone <pavone@retrodev.com>
parents:
2110
diff
changeset
|
348 uint8_t valid_address; |
2206
4c265d2f6c88
Minor refactor of 68K disassembler
Michael Pavone <pavone@retrodev.com>
parents:
2146
diff
changeset
|
349 while(context->deferred) { |
44
ec71370820f2
Add logic for following control flow based on logic in the translator
Mike Pavone <pavone@retrodev.com>
parents:
20
diff
changeset
|
350 do { |
2132
7451f970ee66
Add some weak labels for a few exception vectors in disassembler
Michael Pavone <pavone@retrodev.com>
parents:
2110
diff
changeset
|
351 valid_address = 0; |
2206
4c265d2f6c88
Minor refactor of 68K disassembler
Michael Pavone <pavone@retrodev.com>
parents:
2146
diff
changeset
|
352 address = context->deferred->address; |
4c265d2f6c88
Minor refactor of 68K disassembler
Michael Pavone <pavone@retrodev.com>
parents:
2146
diff
changeset
|
353 if (!is_visited(context, address)) { |
4c265d2f6c88
Minor refactor of 68K disassembler
Michael Pavone <pavone@retrodev.com>
parents:
2146
diff
changeset
|
354 address &= context->address_mask; |
2132
7451f970ee66
Add some weak labels for a few exception vectors in disassembler
Michael Pavone <pavone@retrodev.com>
parents:
2110
diff
changeset
|
355 if (address < address_end && address >= address_off) { |
7451f970ee66
Add some weak labels for a few exception vectors in disassembler
Michael Pavone <pavone@retrodev.com>
parents:
2110
diff
changeset
|
356 valid_address = 1; |
2206
4c265d2f6c88
Minor refactor of 68K disassembler
Michael Pavone <pavone@retrodev.com>
parents:
2146
diff
changeset
|
357 address = context->deferred->address; |
2091
36a9cf4db65f
Fix some disassembler bugs introduced with Sega CD changes
Michael Pavone <pavone@retrodev.com>
parents:
2085
diff
changeset
|
358 } |
44
ec71370820f2
Add logic for following control flow based on logic in the translator
Mike Pavone <pavone@retrodev.com>
parents:
20
diff
changeset
|
359 } |
2206
4c265d2f6c88
Minor refactor of 68K disassembler
Michael Pavone <pavone@retrodev.com>
parents:
2146
diff
changeset
|
360 deferred_addr *tmpd = context->deferred; |
4c265d2f6c88
Minor refactor of 68K disassembler
Michael Pavone <pavone@retrodev.com>
parents:
2146
diff
changeset
|
361 context->deferred = context->deferred->next; |
44
ec71370820f2
Add logic for following control flow based on logic in the translator
Mike Pavone <pavone@retrodev.com>
parents:
20
diff
changeset
|
362 free(tmpd); |
2206
4c265d2f6c88
Minor refactor of 68K disassembler
Michael Pavone <pavone@retrodev.com>
parents:
2146
diff
changeset
|
363 } while(context->deferred && !valid_address); |
2132
7451f970ee66
Add some weak labels for a few exception vectors in disassembler
Michael Pavone <pavone@retrodev.com>
parents:
2110
diff
changeset
|
364 if (!valid_address) { |
44
ec71370820f2
Add logic for following control flow based on logic in the translator
Mike Pavone <pavone@retrodev.com>
parents:
20
diff
changeset
|
365 break; |
ec71370820f2
Add logic for following control flow based on logic in the translator
Mike Pavone <pavone@retrodev.com>
parents:
20
diff
changeset
|
366 } |
ec71370820f2
Add logic for following control flow based on logic in the translator
Mike Pavone <pavone@retrodev.com>
parents:
20
diff
changeset
|
367 for(;;) { |
2206
4c265d2f6c88
Minor refactor of 68K disassembler
Michael Pavone <pavone@retrodev.com>
parents:
2146
diff
changeset
|
368 if ((address & context->address_mask) > address_end || address < address_off) { |
48
0bdda50c7364
Don't try to disassemble addresses beyond the end of the cartridge
Mike Pavone <pavone@retrodev.com>
parents:
47
diff
changeset
|
369 break; |
0bdda50c7364
Don't try to disassemble addresses beyond the end of the cartridge
Mike Pavone <pavone@retrodev.com>
parents:
47
diff
changeset
|
370 } |
2206
4c265d2f6c88
Minor refactor of 68K disassembler
Michael Pavone <pavone@retrodev.com>
parents:
2146
diff
changeset
|
371 visit(context, address); |
2132
7451f970ee66
Add some weak labels for a few exception vectors in disassembler
Michael Pavone <pavone@retrodev.com>
parents:
2110
diff
changeset
|
372 address = m68k_decode(fetch, &rom, &instbuf, address); |
111 | 373 //m68k_disasm(&instbuf, disbuf); |
374 //printf("%X: %s\n", instbuf.address, disbuf); | |
2206
4c265d2f6c88
Minor refactor of 68K disassembler
Michael Pavone <pavone@retrodev.com>
parents:
2146
diff
changeset
|
375 check_reference(context, &instbuf, &(instbuf.src)); |
4c265d2f6c88
Minor refactor of 68K disassembler
Michael Pavone <pavone@retrodev.com>
parents:
2146
diff
changeset
|
376 check_reference(context, &instbuf, &(instbuf.dst)); |
148
4a400aec81bb
Bail out of disassembly of a particular stream when we hit an invalid instruction
Mike Pavone <pavone@retrodev.com>
parents:
139
diff
changeset
|
377 if (instbuf.op == M68K_ILLEGAL || instbuf.op == M68K_RTS || instbuf.op == M68K_RTE || instbuf.op == M68K_INVALID) { |
44
ec71370820f2
Add logic for following control flow based on logic in the translator
Mike Pavone <pavone@retrodev.com>
parents:
20
diff
changeset
|
378 break; |
164
afbfb0ac0256
Small fix to disassembler
Mike Pavone <pavone@retrodev.com>
parents:
151
diff
changeset
|
379 } |
afbfb0ac0256
Small fix to disassembler
Mike Pavone <pavone@retrodev.com>
parents:
151
diff
changeset
|
380 if (instbuf.op == M68K_BCC || instbuf.op == M68K_DBCC || instbuf.op == M68K_BSR) { |
2206
4c265d2f6c88
Minor refactor of 68K disassembler
Michael Pavone <pavone@retrodev.com>
parents:
2146
diff
changeset
|
381 tmp_addr = instbuf.address + 2 + instbuf.src.params.immed; |
4c265d2f6c88
Minor refactor of 68K disassembler
Michael Pavone <pavone@retrodev.com>
parents:
2146
diff
changeset
|
382 reference(context, tmp_addr); |
44
ec71370820f2
Add logic for following control flow based on logic in the translator
Mike Pavone <pavone@retrodev.com>
parents:
20
diff
changeset
|
383 if (instbuf.op == M68K_BCC && instbuf.extra.cond == COND_TRUE) { |
2206
4c265d2f6c88
Minor refactor of 68K disassembler
Michael Pavone <pavone@retrodev.com>
parents:
2146
diff
changeset
|
384 address = tmp_addr; |
4c265d2f6c88
Minor refactor of 68K disassembler
Michael Pavone <pavone@retrodev.com>
parents:
2146
diff
changeset
|
385 if (is_visited(context, address)) { |
44
ec71370820f2
Add logic for following control flow based on logic in the translator
Mike Pavone <pavone@retrodev.com>
parents:
20
diff
changeset
|
386 break; |
ec71370820f2
Add logic for following control flow based on logic in the translator
Mike Pavone <pavone@retrodev.com>
parents:
20
diff
changeset
|
387 } |
ec71370820f2
Add logic for following control flow based on logic in the translator
Mike Pavone <pavone@retrodev.com>
parents:
20
diff
changeset
|
388 } else { |
2206
4c265d2f6c88
Minor refactor of 68K disassembler
Michael Pavone <pavone@retrodev.com>
parents:
2146
diff
changeset
|
389 defer_disasm(context, tmp_addr); |
44
ec71370820f2
Add logic for following control flow based on logic in the translator
Mike Pavone <pavone@retrodev.com>
parents:
20
diff
changeset
|
390 } |
ec71370820f2
Add logic for following control flow based on logic in the translator
Mike Pavone <pavone@retrodev.com>
parents:
20
diff
changeset
|
391 } else if(instbuf.op == M68K_JMP) { |
80
7b1e16e981ef
Fix bug in disassembler that caused it to disassemble addresses it shouldn't
Mike Pavone <pavone@retrodev.com>
parents:
48
diff
changeset
|
392 if (instbuf.src.addr_mode == MODE_ABSOLUTE || instbuf.src.addr_mode == MODE_ABSOLUTE_SHORT) { |
44
ec71370820f2
Add logic for following control flow based on logic in the translator
Mike Pavone <pavone@retrodev.com>
parents:
20
diff
changeset
|
393 address = instbuf.src.params.immed; |
2206
4c265d2f6c88
Minor refactor of 68K disassembler
Michael Pavone <pavone@retrodev.com>
parents:
2146
diff
changeset
|
394 if (is_visited(context, address)) { |
44
ec71370820f2
Add logic for following control flow based on logic in the translator
Mike Pavone <pavone@retrodev.com>
parents:
20
diff
changeset
|
395 break; |
ec71370820f2
Add logic for following control flow based on logic in the translator
Mike Pavone <pavone@retrodev.com>
parents:
20
diff
changeset
|
396 } |
564
316facea756d
Fix PC displacement mode check in disassembler so that jmps involving a register are handled correctly
Michael Pavone <pavone@retrodev.com>
parents:
467
diff
changeset
|
397 } else if (instbuf.src.addr_mode == MODE_PC_DISPLACE) { |
114
e821b6fde0e4
Allow jmp/jsr to follow pc-relative addresses in disassembler
Mike Pavone <pavone@retrodev.com>
parents:
111
diff
changeset
|
398 address = instbuf.src.params.regs.displacement + instbuf.address + 2; |
2206
4c265d2f6c88
Minor refactor of 68K disassembler
Michael Pavone <pavone@retrodev.com>
parents:
2146
diff
changeset
|
399 if (is_visited(context, address)) { |
114
e821b6fde0e4
Allow jmp/jsr to follow pc-relative addresses in disassembler
Mike Pavone <pavone@retrodev.com>
parents:
111
diff
changeset
|
400 break; |
e821b6fde0e4
Allow jmp/jsr to follow pc-relative addresses in disassembler
Mike Pavone <pavone@retrodev.com>
parents:
111
diff
changeset
|
401 } |
44
ec71370820f2
Add logic for following control flow based on logic in the translator
Mike Pavone <pavone@retrodev.com>
parents:
20
diff
changeset
|
402 } else { |
ec71370820f2
Add logic for following control flow based on logic in the translator
Mike Pavone <pavone@retrodev.com>
parents:
20
diff
changeset
|
403 break; |
ec71370820f2
Add logic for following control flow based on logic in the translator
Mike Pavone <pavone@retrodev.com>
parents:
20
diff
changeset
|
404 } |
ec71370820f2
Add logic for following control flow based on logic in the translator
Mike Pavone <pavone@retrodev.com>
parents:
20
diff
changeset
|
405 } else if(instbuf.op == M68K_JSR) { |
80
7b1e16e981ef
Fix bug in disassembler that caused it to disassemble addresses it shouldn't
Mike Pavone <pavone@retrodev.com>
parents:
48
diff
changeset
|
406 if (instbuf.src.addr_mode == MODE_ABSOLUTE || instbuf.src.addr_mode == MODE_ABSOLUTE_SHORT) { |
2206
4c265d2f6c88
Minor refactor of 68K disassembler
Michael Pavone <pavone@retrodev.com>
parents:
2146
diff
changeset
|
407 defer_disasm(context, instbuf.src.params.immed); |
164
afbfb0ac0256
Small fix to disassembler
Mike Pavone <pavone@retrodev.com>
parents:
151
diff
changeset
|
408 } else if (instbuf.src.addr_mode == MODE_PC_DISPLACE) { |
2206
4c265d2f6c88
Minor refactor of 68K disassembler
Michael Pavone <pavone@retrodev.com>
parents:
2146
diff
changeset
|
409 defer_disasm(context, instbuf.src.params.regs.displacement + instbuf.address + 2); |
44
ec71370820f2
Add logic for following control flow based on logic in the translator
Mike Pavone <pavone@retrodev.com>
parents:
20
diff
changeset
|
410 } |
ec71370820f2
Add logic for following control flow based on logic in the translator
Mike Pavone <pavone@retrodev.com>
parents:
20
diff
changeset
|
411 } |
ec71370820f2
Add logic for following control flow based on logic in the translator
Mike Pavone <pavone@retrodev.com>
parents:
20
diff
changeset
|
412 } |
ec71370820f2
Add logic for following control flow based on logic in the translator
Mike Pavone <pavone@retrodev.com>
parents:
20
diff
changeset
|
413 } |
134 | 414 if (labels) { |
2206
4c265d2f6c88
Minor refactor of 68K disassembler
Michael Pavone <pavone@retrodev.com>
parents:
2146
diff
changeset
|
415 tern_foreach(context->labels, print_label_def, &rom); |
134 | 416 puts(""); |
417 } | |
633
a759f4e38488
Fix translation of 68K address to buffer location when address_off != 0
Michael Pavone <pavone@retrodev.com>
parents:
632
diff
changeset
|
418 for (address = address_off; address < address_end; address+=2) { |
2206
4c265d2f6c88
Minor refactor of 68K disassembler
Michael Pavone <pavone@retrodev.com>
parents:
2146
diff
changeset
|
419 if (is_visited(context, address)) { |
2132
7451f970ee66
Add some weak labels for a few exception vectors in disassembler
Michael Pavone <pavone@retrodev.com>
parents:
2110
diff
changeset
|
420 m68k_decode(fetch, &rom, &instbuf, address); |
134 | 421 if (labels) { |
2206
4c265d2f6c88
Minor refactor of 68K disassembler
Michael Pavone <pavone@retrodev.com>
parents:
2146
diff
changeset
|
422 m68k_disasm_labels(&instbuf, disbuf, label_fun, context); |
4c265d2f6c88
Minor refactor of 68K disassembler
Michael Pavone <pavone@retrodev.com>
parents:
2146
diff
changeset
|
423 label_def *label = find_label(context, address); |
4c265d2f6c88
Minor refactor of 68K disassembler
Michael Pavone <pavone@retrodev.com>
parents:
2146
diff
changeset
|
424 if (label) { |
4c265d2f6c88
Minor refactor of 68K disassembler
Michael Pavone <pavone@retrodev.com>
parents:
2146
diff
changeset
|
425 if (label->num_labels) { |
4c265d2f6c88
Minor refactor of 68K disassembler
Michael Pavone <pavone@retrodev.com>
parents:
2146
diff
changeset
|
426 for (int i = 0; i < label->num_labels; i++) |
4c265d2f6c88
Minor refactor of 68K disassembler
Michael Pavone <pavone@retrodev.com>
parents:
2146
diff
changeset
|
427 { |
4c265d2f6c88
Minor refactor of 68K disassembler
Michael Pavone <pavone@retrodev.com>
parents:
2146
diff
changeset
|
428 printf("%s:\n", label->labels[i]); |
4c265d2f6c88
Minor refactor of 68K disassembler
Michael Pavone <pavone@retrodev.com>
parents:
2146
diff
changeset
|
429 } |
4c265d2f6c88
Minor refactor of 68K disassembler
Michael Pavone <pavone@retrodev.com>
parents:
2146
diff
changeset
|
430 } else { |
4c265d2f6c88
Minor refactor of 68K disassembler
Michael Pavone <pavone@retrodev.com>
parents:
2146
diff
changeset
|
431 printf("ADR_%X:\n", label->full_address); |
631
de6f00204fa2
Add support for disassembling VOS program modules
Michael Pavone <pavone@retrodev.com>
parents:
467
diff
changeset
|
432 } |
134 | 433 } |
434 if (addr) { | |
435 printf("\t%s\t;%X\n", disbuf, instbuf.address); | |
436 } else { | |
437 printf("\t%s\n", disbuf); | |
438 } | |
439 } else { | |
440 m68k_disasm(&instbuf, disbuf); | |
441 printf("%X: %s\n", instbuf.address, disbuf); | |
442 } | |
44
ec71370820f2
Add logic for following control flow based on logic in the translator
Mike Pavone <pavone@retrodev.com>
parents:
20
diff
changeset
|
443 } |
ec71370820f2
Add logic for following control flow based on logic in the translator
Mike Pavone <pavone@retrodev.com>
parents:
20
diff
changeset
|
444 } |
2
5df303bf72e6
Improve 68K instruction decoding. Add simple disassembler.
Mike Pavone <pavone@retrodev.com>
parents:
diff
changeset
|
445 return 0; |
5df303bf72e6
Improve 68K instruction decoding. Add simple disassembler.
Mike Pavone <pavone@retrodev.com>
parents:
diff
changeset
|
446 } |