fixed compilation with no debugger enabled - will be cleaned up later

This commit is contained in:
Stanislav Shwartsman 2020-12-30 16:58:17 +00:00
parent d2896bbd2a
commit a4a2562c8d

View File

@ -42,15 +42,24 @@ void BX_CPU_C::debug_disasm_instruction(bx_address offset)
static char letters[] = "0123456789ABCDEF"; static char letters[] = "0123456789ABCDEF";
unsigned remainsInPage = 0x1000 - PAGE_OFFSET(offset); unsigned remainsInPage = 0x1000 - PAGE_OFFSET(offset);
extern unsigned bx_dbg_disasm_wrapper(bx_bool is_32, bx_bool is_64, bx_address cs_base, bx_address ip, const Bit8u *instr, char *disbuf); extern unsigned bx_dbg_disasm_wrapper(bx_bool is_32, bx_bool is_64, bx_address cs_base, bx_address ip, const Bit8u *instr, char *disbuf);
static disassembler bx_disassemble;
bx_bool valid = dbg_xlate_linear2phy(get_laddr(BX_SEG_REG_CS, offset), &phy_addr); bx_bool valid = dbg_xlate_linear2phy(get_laddr(BX_SEG_REG_CS, offset), &phy_addr);
if (valid) { if (valid) {
BX_MEM(0)->dbg_fetch_mem(BX_CPU_THIS, phy_addr, 16, instr_buf); BX_MEM(0)->dbg_fetch_mem(BX_CPU_THIS, phy_addr, 16, instr_buf);
#if BX_DEBUGGER
unsigned isize = bx_dbg_disasm_wrapper( unsigned isize = bx_dbg_disasm_wrapper(
BX_CPU_THIS_PTR sregs[BX_SEG_REG_CS].cache.u.segment.d_b, BX_CPU_THIS_PTR sregs[BX_SEG_REG_CS].cache.u.segment.d_b,
BX_CPU_THIS_PTR cpu_mode == BX_MODE_LONG_64, BX_CPU_THIS_PTR cpu_mode == BX_MODE_LONG_64,
BX_CPU_THIS_PTR get_segment_base(BX_SEG_REG_CS), offset, BX_CPU_THIS_PTR get_segment_base(BX_SEG_REG_CS), offset,
instr_buf, char_buf+i); instr_buf, char_buf+i);
#else
unsigned isize = bx_disassemble.disasm(
BX_CPU_THIS_PTR sregs[BX_SEG_REG_CS].cache.u.segment.d_b,
BX_CPU_THIS_PTR cpu_mode == BX_MODE_LONG_64,
BX_CPU_THIS_PTR get_segment_base(BX_SEG_REG_CS), offset,
instr_buf, char_buf+i);
#endif
if (isize <= remainsInPage) { if (isize <= remainsInPage) {
i=strlen(char_buf); i=strlen(char_buf);
char_buf[i++] = ' '; char_buf[i++] = ' ';