2024-03-26 05:58:56 +00:00
|
|
|
#include <stdio.h>
|
|
|
|
|
|
|
|
#include <capstone/capstone.h>
|
|
|
|
#include <capstone/platform.h>
|
|
|
|
#include "cstool.h"
|
|
|
|
#include "limits.h"
|
|
|
|
|
|
|
|
void print_insn_detail_hppa(csh handle, cs_insn *ins)
|
|
|
|
{
|
|
|
|
cs_hppa *hppa;
|
|
|
|
cs_regs regs_read, regs_write;
|
|
|
|
uint8_t regs_read_count, regs_write_count;
|
|
|
|
|
|
|
|
if (ins->detail == NULL)
|
|
|
|
return;
|
|
|
|
|
|
|
|
hppa = &ins->detail->hppa;
|
|
|
|
|
|
|
|
printf("\top_count: %u\n", hppa->op_count);
|
|
|
|
for (unsigned i = 0; i < hppa->op_count; i++) {
|
|
|
|
cs_hppa_op *op = &(hppa->operands[i]);
|
|
|
|
uint64_t target_addr;
|
|
|
|
switch (op->type) {
|
|
|
|
case HPPA_OP_REG:
|
|
|
|
printf("\t\toperands[%u].type: REG = %s\n", i,
|
|
|
|
cs_reg_name(handle, op->reg));
|
|
|
|
break;
|
|
|
|
case HPPA_OP_IMM:
|
|
|
|
if (op->imm < 0)
|
|
|
|
printf("\t\toperands[%u].type: IMM = -0x%" PRIx64
|
|
|
|
"\n",
|
|
|
|
i, -(op->imm));
|
|
|
|
else
|
|
|
|
printf("\t\toperands[%u].type: IMM = 0x%" PRIx64
|
|
|
|
"\n",
|
|
|
|
i, op->imm);
|
|
|
|
break;
|
|
|
|
case HPPA_OP_IDX_REG:
|
|
|
|
printf("\t\toperands[%u].type: IDX_REG = %s\n", i,
|
|
|
|
cs_reg_name(handle, op->reg));
|
|
|
|
break;
|
|
|
|
case HPPA_OP_DISP:
|
|
|
|
if (op->imm < 0)
|
|
|
|
printf("\t\toperands[%u].type: DISP = -0x%" PRIx64
|
|
|
|
"\n",
|
|
|
|
i, -(op->imm));
|
|
|
|
else
|
|
|
|
printf("\t\toperands[%u].type: DISP = 0x%" PRIx64
|
|
|
|
"\n",
|
|
|
|
i, op->imm);
|
|
|
|
break;
|
|
|
|
case HPPA_OP_MEM:
|
|
|
|
printf("\t\toperands[%u].type: MEM\n", i);
|
2024-03-29 08:46:00 +00:00
|
|
|
if (op->mem.space != HPPA_REG_INVALID) {
|
2024-03-26 05:58:56 +00:00
|
|
|
printf("\t\t\toperands[%u].mem.space: REG = %s\n",
|
|
|
|
i, cs_reg_name(handle, op->mem.space));
|
|
|
|
}
|
|
|
|
printf("\t\t\toperands[%u].mem.base: REG = %s\n", i,
|
|
|
|
cs_reg_name(handle, op->mem.base));
|
|
|
|
break;
|
|
|
|
case HPPA_OP_TARGET:
|
|
|
|
printf("\t\toperands[%u].type: ", i);
|
|
|
|
target_addr = ins->address + op->imm;
|
|
|
|
printf("TARGET = 0x%" PRIx64 "\n", target_addr);
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
if (!cs_regs_access(handle, ins, regs_read, ®s_read_count,
|
|
|
|
regs_write, ®s_write_count)) {
|
|
|
|
if (regs_read_count) {
|
|
|
|
printf("\tRegisters read:");
|
|
|
|
for (unsigned i = 0; i < regs_read_count; i++)
|
|
|
|
printf(" %s",
|
|
|
|
cs_reg_name(handle, regs_read[i]));
|
|
|
|
printf("\n");
|
|
|
|
}
|
|
|
|
|
|
|
|
if (regs_write_count) {
|
|
|
|
printf("\tRegisters modified:");
|
|
|
|
for (unsigned i = 0; i < regs_write_count; i++)
|
|
|
|
printf(" %s",
|
|
|
|
cs_reg_name(handle, regs_write[i]));
|
|
|
|
printf("\n");
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|