Bochs/bochs/bxdisasm.cc

108 lines
3.1 KiB
C++

/////////////////////////////////////////////////////////////////////////
// $Id$
/////////////////////////////////////////////////////////////////////////
//
// Copyright (c) 2014-2020 Stanislav Shwartsman
// Written by Stanislav Shwartsman [sshwarts at sourceforge net]
//
// This library is free software; you can redistribute it and/or
// modify it under the terms of the GNU Lesser General Public
// License as published by the Free Software Foundation; either
// version 2 of the License, or (at your option) any later version.
//
// This library is distributed in the hope that it will be useful,
// but WITHOUT ANY WARRANTY; without even the implied warranty of
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
// Lesser General Public License for more details.
//
// You should have received a copy of the GNU Lesser General Public
// License along with this library; if not, write to the Free Software
// Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA
/////////////////////////////////////////////////////////////////////////
// Compile using:
// g++ -I. -I./instrument/stubs -DBX_STANDALONE_DECODER bxdisasm.cc cpu/decoder/*.cc -o bxdisasm
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#include <ctype.h>
#include "config.h"
#include "cpu/decoder/instr.h"
unsigned char char2byte(unsigned char input)
{
if(input >= '0' && input <= '9')
return input - '0';
if(input >= 'A' && input <= 'F')
return input - 'A' + 10;
if(input >= 'a' && input <= 'f')
return input - 'a' + 10;
return 0; // wrong input, ignore
}
// This function assumes src to be a zero terminated sanitized string with
// an even number of [0-9a-f] characters, and target to be sufficiently large
void hex2bin(Bit8u* target, const char* src, unsigned len)
{
while(len >= 2 && src[0] && src[1])
{
*(target++) = (unsigned) char2byte(src[0])*16 + (unsigned) char2byte(src[1]);
src += 2;
len -= 2;
}
}
int main(int argn, const char **argv)
{
char disbuf[256];
Bit8u ibuf[16] = {0};
bool is_32 = 1, is_64 = 0;
if (argn < 2)
{
printf("Usage: bxdisasm [-16|-32|-64] string-of-instruction-bytes\n");
exit(1);
}
for (int i=1;i<argn;i++) {
if (!strcmp(argv[i], "/16")) {
is_32 = 0;
is_64 = 0;
printf("16 bit mode\n");
continue;
}
if (!strcmp(argv[i], "/32")) {
is_32 = 1;
is_64 = 0;
printf("32 bit mode\n");
continue;
}
if (!strcmp(argv[i], "/64")) {
is_32 = 1;
is_64 = 1;
printf("64 bit mode\n");
continue;
}
const char *p = argv[i];
unsigned len = strlen(p);
if (len > 32) len = 32;
hex2bin(ibuf, p, len);
}
printf("instruction bytes:");
for (int i=0;i<16;i++)
printf("%02x", ibuf[i]);
printf("\n");
bxInstruction_c i;
disasm(ibuf, is_32, is_64, disbuf, &i, 0, 0, BX_DISASM_INTEL);
printf("disasm: %s (opcode handler=%s)\n", disbuf, i.getIaOpcodeName());
disasm(ibuf, is_32, is_64, disbuf, &i, 0, 0, BX_DISASM_GAS);
printf("disasm: %s (opcode handler=%s)\n", disbuf, i.getIaOpcodeName());
}