return (bfd_vma) v;
}
-/* Disassemble this for me please... (debugging). */
-void disas(FILE *out, void *code, unsigned long size, enum disas_type type)
+/* Disassemble this for me please... (debugging). 'flags' is only used
+ for i386: non zero means 16 bit code */
+void disas(FILE *out, void *code, unsigned long size, int is_host, int flags)
{
uint8_t *pc;
int count;
disasm_info.buffer_vma = (unsigned long)code;
disasm_info.buffer_length = size;
- if (type == DISAS_TARGET) {
+ if (is_host) {
#ifdef WORDS_BIGENDIAN
disasm_info.endian = BFD_ENDIAN_BIG;
#else
return;
#endif
} else {
- /* Currently only source supported in x86. */
+#ifdef TARGET_WORDS_BIGENDIAN
+ disasm_info.endian = BFD_ENDIAN_BIG;
+#else
disasm_info.endian = BFD_ENDIAN_LITTLE;
- if (type == DISAS_I386_I386)
+#endif
+#if defined(TARGET_I386)
+ if (!flags)
disasm_info.mach = bfd_mach_i386_i386;
else
disasm_info.mach = bfd_mach_i386_i8086;
print_insn = print_insn_i386;
+#elif defined(TARGET_ARM)
+ print_insn = print_insn_arm;
+#else
+ fprintf(out, "Asm output not supported on this arch\n");
+ return;
+#endif
}
for (pc = code; pc < (uint8_t *)code + size; pc += count) {
#ifdef __arm__
/* since data are included in the code, it is better to
display code data too */
- if (type == DISAS_TARGET) {
+ if (is_host) {
fprintf(out, "%08x ", (int)bfd_getl32((const bfd_byte *)pc));
}
#endif
#ifndef _QEMU_DISAS_H
#define _QEMU_DISAS_H
-enum disas_type {
- DISAS_I386_I386,
- DISAS_I386_I8086,
- DISAS_TARGET, /* whatever host is. */
-};
-
/* Disassemble this for me please... (debugging). */
-void disas(FILE *out, void *code, unsigned long size, enum disas_type type);
+void disas(FILE *out, void *code, unsigned long size, int is_host, int flags);
/* Look up symbol for debugging purpose. Returns "" if unknown. */
const char *lookup_symbol(void *orig_addr);