m68k disassembler (Paul Brook)
git-svn-id: svn://svn.savannah.nongnu.org/qemu/trunk@1605 c046a42c-6fe2-441c-8c8c-71466251a162
This commit is contained in:
parent
b389dbfb58
commit
48024e4a48
@ -240,6 +240,9 @@ endif
|
|||||||
ifeq ($(findstring arm, $(TARGET_ARCH) $(ARCH)),arm)
|
ifeq ($(findstring arm, $(TARGET_ARCH) $(ARCH)),arm)
|
||||||
LIBOBJS+=arm-dis.o
|
LIBOBJS+=arm-dis.o
|
||||||
endif
|
endif
|
||||||
|
ifeq ($(findstring m68k, $(TARGET_ARCH) $(ARCH)),m68k)
|
||||||
|
LIBOBJS+=m68k-dis.o
|
||||||
|
endif
|
||||||
|
|
||||||
ifeq ($(ARCH),ia64)
|
ifeq ($(ARCH),ia64)
|
||||||
OBJS += ia64-syscall.o
|
OBJS += ia64-syscall.o
|
||||||
|
@ -23,9 +23,6 @@ Software Foundation, 59 Temple Place - Suite 330, Boston, MA
|
|||||||
#include <stdio.h>
|
#include <stdio.h>
|
||||||
#include "dis-asm.h"
|
#include "dis-asm.h"
|
||||||
|
|
||||||
#define ATTRIBUTE_UNUSED __attribute__((unused))
|
|
||||||
#define _(x) x
|
|
||||||
|
|
||||||
/* The opcode table is an array of struct alpha_opcode. */
|
/* The opcode table is an array of struct alpha_opcode. */
|
||||||
|
|
||||||
struct alpha_opcode
|
struct alpha_opcode
|
||||||
|
13
dis-asm.h
13
dis-asm.h
@ -56,6 +56,17 @@ enum bfd_architecture
|
|||||||
#define bfd_mach_m68030 5
|
#define bfd_mach_m68030 5
|
||||||
#define bfd_mach_m68040 6
|
#define bfd_mach_m68040 6
|
||||||
#define bfd_mach_m68060 7
|
#define bfd_mach_m68060 7
|
||||||
|
#define bfd_mach_cpu32 8
|
||||||
|
#define bfd_mach_mcf5200 9
|
||||||
|
#define bfd_mach_mcf5206e 10
|
||||||
|
#define bfd_mach_mcf5307 11
|
||||||
|
#define bfd_mach_mcf5407 12
|
||||||
|
#define bfd_mach_mcf528x 13
|
||||||
|
#define bfd_mach_mcfv4e 14
|
||||||
|
#define bfd_mach_mcf521x 15
|
||||||
|
#define bfd_mach_mcf5249 16
|
||||||
|
#define bfd_mach_mcf547x 17
|
||||||
|
#define bfd_mach_mcf548x 18
|
||||||
bfd_arch_vax, /* DEC Vax */
|
bfd_arch_vax, /* DEC Vax */
|
||||||
bfd_arch_i960, /* Intel 960 */
|
bfd_arch_i960, /* Intel 960 */
|
||||||
/* The order of the following is important.
|
/* The order of the following is important.
|
||||||
@ -417,6 +428,7 @@ extern int generic_symbol_at_address
|
|||||||
(INFO).insn_info_valid = 0
|
(INFO).insn_info_valid = 0
|
||||||
|
|
||||||
#define _(x) x
|
#define _(x) x
|
||||||
|
#define ATTRIBUTE_UNUSED __attribute__((unused))
|
||||||
|
|
||||||
/* from libbfd */
|
/* from libbfd */
|
||||||
|
|
||||||
@ -425,5 +437,6 @@ bfd_vma bfd_getb32 (const bfd_byte *addr);
|
|||||||
bfd_vma bfd_getl16 (const bfd_byte *addr);
|
bfd_vma bfd_getl16 (const bfd_byte *addr);
|
||||||
bfd_vma bfd_getb16 (const bfd_byte *addr);
|
bfd_vma bfd_getb16 (const bfd_byte *addr);
|
||||||
typedef enum bfd_boolean {false, true} boolean;
|
typedef enum bfd_boolean {false, true} boolean;
|
||||||
|
typedef boolean bfd_boolean;
|
||||||
|
|
||||||
#endif /* ! defined (DIS_ASM_H) */
|
#endif /* ! defined (DIS_ASM_H) */
|
||||||
|
6
disas.c
6
disas.c
@ -187,6 +187,8 @@ void target_disas(FILE *out, target_ulong code, target_ulong size, int flags)
|
|||||||
print_insn = print_insn_ppc;
|
print_insn = print_insn_ppc;
|
||||||
#elif defined(TARGET_MIPS)
|
#elif defined(TARGET_MIPS)
|
||||||
print_insn = print_insn_big_mips;
|
print_insn = print_insn_big_mips;
|
||||||
|
#elif defined(TARGET_M68K)
|
||||||
|
print_insn = print_insn_m68k;
|
||||||
#else
|
#else
|
||||||
fprintf(out, "0x" TARGET_FMT_lx
|
fprintf(out, "0x" TARGET_FMT_lx
|
||||||
": Asm output not supported on this arch\n", code);
|
": Asm output not supported on this arch\n", code);
|
||||||
@ -251,6 +253,8 @@ void disas(FILE *out, void *code, unsigned long size)
|
|||||||
print_insn = print_insn_big_mips;
|
print_insn = print_insn_big_mips;
|
||||||
#elif defined(__MIPSEL__)
|
#elif defined(__MIPSEL__)
|
||||||
print_insn = print_insn_little_mips;
|
print_insn = print_insn_little_mips;
|
||||||
|
#elif defined(__m68k__)
|
||||||
|
print_insn = print_insn_m68k;
|
||||||
#else
|
#else
|
||||||
fprintf(out, "0x%lx: Asm output not supported on this arch\n",
|
fprintf(out, "0x%lx: Asm output not supported on this arch\n",
|
||||||
(long) code);
|
(long) code);
|
||||||
@ -374,6 +378,8 @@ void monitor_disas(target_ulong pc, int nb_insn, int is_physical, int flags)
|
|||||||
print_insn = print_insn_ppc;
|
print_insn = print_insn_ppc;
|
||||||
#elif defined(TARGET_MIPS)
|
#elif defined(TARGET_MIPS)
|
||||||
print_insn = print_insn_big_mips;
|
print_insn = print_insn_big_mips;
|
||||||
|
#elif defined(TARGET_M68K)
|
||||||
|
print_insn = print_insn_m68k;
|
||||||
#else
|
#else
|
||||||
term_printf("0x" TARGET_FMT_lx
|
term_printf("0x" TARGET_FMT_lx
|
||||||
": Asm output not supported on this arch\n", pc);
|
": Asm output not supported on this arch\n", pc);
|
||||||
|
5051
m68k-dis.c
Normal file
5051
m68k-dis.c
Normal file
File diff suppressed because it is too large
Load Diff
@ -2155,10 +2155,6 @@ struct mips_opcode *mips_opcodes =
|
|||||||
int bfd_mips_num_opcodes = MIPS_NUM_OPCODES;
|
int bfd_mips_num_opcodes = MIPS_NUM_OPCODES;
|
||||||
#undef MIPS_NUM_OPCODES
|
#undef MIPS_NUM_OPCODES
|
||||||
|
|
||||||
typedef int bfd_boolean;
|
|
||||||
#define TRUE (1)
|
|
||||||
#define FALSE (0)
|
|
||||||
|
|
||||||
/* Mips instructions are at maximum this many bytes long. */
|
/* Mips instructions are at maximum this many bytes long. */
|
||||||
#define INSNLEN 4
|
#define INSNLEN 4
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user