huangcm
2025-07-01 2af87f2bbd5ba07d377b5a7f0ee0e96053f2d424
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
/* Capstone Disassembler Engine */
/* By Nguyen Anh Quynh <aquynh@gmail.com>, 2013> */
 
#include <stdio.h>
#include <stdlib.h>
 
#include <capstone.h>
 
void print_string_hex(char *comment, unsigned char *str, size_t len);
 
void print_insn_detail_mips(csh handle, cs_insn *ins)
{
   int i;
   cs_mips *mips;
 
   // detail can be NULL on "data" instruction if SKIPDATA option is turned ON
   if (ins->detail == NULL)
       return;
 
   mips = &(ins->detail->mips);
   if (mips->op_count)
       printf("\top_count: %u\n", mips->op_count);
 
   for (i = 0; i < mips->op_count; i++) {
       cs_mips_op *op = &(mips->operands[i]);
       switch((int)op->type) {
           default:
               break;
           case MIPS_OP_REG:
               printf("\t\toperands[%u].type: REG = %s\n", i, cs_reg_name(handle, op->reg));
               break;
           case MIPS_OP_IMM:
               printf("\t\toperands[%u].type: IMM = 0x%" PRIx64 "\n", i, op->imm);
               break;
           case MIPS_OP_MEM:
               printf("\t\toperands[%u].type: MEM\n", i);
               if (op->mem.base != X86_REG_INVALID)
                   printf("\t\t\toperands[%u].mem.base: REG = %s\n",
                           i, cs_reg_name(handle, op->mem.base));
               if (op->mem.disp != 0)
                   printf("\t\t\toperands[%u].mem.disp: 0x%" PRIx64 "\n", i, op->mem.disp);
 
               break;
       }
 
   }
}