xref: /aosp_15_r20/external/capstone/suite/cstest/src/ppc_detail.c (revision 9a0e4156d50a75a99ec4f1653a0e9602a5d45c18)
1*9a0e4156SSadaf Ebrahimi /* Capstone testing regression */
2*9a0e4156SSadaf Ebrahimi /* By Do Minh Tuan <[email protected]>, 02-2019 */
3*9a0e4156SSadaf Ebrahimi 
4*9a0e4156SSadaf Ebrahimi 
5*9a0e4156SSadaf Ebrahimi #include "factory.h"
6*9a0e4156SSadaf Ebrahimi 
get_bc_name(int bc)7*9a0e4156SSadaf Ebrahimi static const char* get_bc_name(int bc)
8*9a0e4156SSadaf Ebrahimi {
9*9a0e4156SSadaf Ebrahimi 	switch(bc) {
10*9a0e4156SSadaf Ebrahimi 		default:
11*9a0e4156SSadaf Ebrahimi 		case PPC_BC_INVALID:
12*9a0e4156SSadaf Ebrahimi 			return ("invalid");
13*9a0e4156SSadaf Ebrahimi 		case PPC_BC_LT:
14*9a0e4156SSadaf Ebrahimi 			return ("lt");
15*9a0e4156SSadaf Ebrahimi 		case PPC_BC_LE:
16*9a0e4156SSadaf Ebrahimi 			return ("le");
17*9a0e4156SSadaf Ebrahimi 		case PPC_BC_EQ:
18*9a0e4156SSadaf Ebrahimi 			return ("eq");
19*9a0e4156SSadaf Ebrahimi 		case PPC_BC_GE:
20*9a0e4156SSadaf Ebrahimi 			return ("ge");
21*9a0e4156SSadaf Ebrahimi 		case PPC_BC_GT:
22*9a0e4156SSadaf Ebrahimi 			return ("gt");
23*9a0e4156SSadaf Ebrahimi 		case PPC_BC_NE:
24*9a0e4156SSadaf Ebrahimi 			return ("ne");
25*9a0e4156SSadaf Ebrahimi 		case PPC_BC_UN:
26*9a0e4156SSadaf Ebrahimi 			return ("un");
27*9a0e4156SSadaf Ebrahimi 		case PPC_BC_NU:
28*9a0e4156SSadaf Ebrahimi 			return ("nu");
29*9a0e4156SSadaf Ebrahimi 		case PPC_BC_SO:
30*9a0e4156SSadaf Ebrahimi 			return ("so");
31*9a0e4156SSadaf Ebrahimi 		case PPC_BC_NS:
32*9a0e4156SSadaf Ebrahimi 			return ("ns");
33*9a0e4156SSadaf Ebrahimi 	}
34*9a0e4156SSadaf Ebrahimi }
35*9a0e4156SSadaf Ebrahimi 
get_detail_ppc(csh * handle,cs_mode mode,cs_insn * ins)36*9a0e4156SSadaf Ebrahimi char *get_detail_ppc(csh *handle, cs_mode mode, cs_insn *ins)
37*9a0e4156SSadaf Ebrahimi {
38*9a0e4156SSadaf Ebrahimi 	cs_ppc *ppc;
39*9a0e4156SSadaf Ebrahimi 	int i;
40*9a0e4156SSadaf Ebrahimi 	char *result;
41*9a0e4156SSadaf Ebrahimi 
42*9a0e4156SSadaf Ebrahimi 	result = (char *)malloc(sizeof(char));
43*9a0e4156SSadaf Ebrahimi 	result[0] = '\0';
44*9a0e4156SSadaf Ebrahimi 
45*9a0e4156SSadaf Ebrahimi 	if (ins->detail == NULL)
46*9a0e4156SSadaf Ebrahimi 		return result;
47*9a0e4156SSadaf Ebrahimi 
48*9a0e4156SSadaf Ebrahimi 	ppc = &(ins->detail->ppc);
49*9a0e4156SSadaf Ebrahimi 	if (ppc->op_count)
50*9a0e4156SSadaf Ebrahimi 		add_str(&result, " ; op_count: %u", ppc->op_count);
51*9a0e4156SSadaf Ebrahimi 
52*9a0e4156SSadaf Ebrahimi 	for (i = 0; i < ppc->op_count; i++) {
53*9a0e4156SSadaf Ebrahimi 		cs_ppc_op *op = &(ppc->operands[i]);
54*9a0e4156SSadaf Ebrahimi 		switch((int)op->type) {
55*9a0e4156SSadaf Ebrahimi 			default:
56*9a0e4156SSadaf Ebrahimi 				break;
57*9a0e4156SSadaf Ebrahimi 			case PPC_OP_REG:
58*9a0e4156SSadaf Ebrahimi 				add_str(&result, " ; operands[%u].type: REG = %s", i, cs_reg_name(*handle, op->reg));
59*9a0e4156SSadaf Ebrahimi 				break;
60*9a0e4156SSadaf Ebrahimi 			case PPC_OP_IMM:
61*9a0e4156SSadaf Ebrahimi 				add_str(&result, " ; operands[%u].type: IMM = 0x%"PRIx64"", i, op->imm);
62*9a0e4156SSadaf Ebrahimi 				break;
63*9a0e4156SSadaf Ebrahimi 			case PPC_OP_MEM:
64*9a0e4156SSadaf Ebrahimi 				add_str(&result, " ; operands[%u].type: MEM", i);
65*9a0e4156SSadaf Ebrahimi 				if (op->mem.base != PPC_REG_INVALID)
66*9a0e4156SSadaf Ebrahimi 					add_str(&result, " ; operands[%u].mem.base: REG = %s", i, cs_reg_name(*handle, op->mem.base));
67*9a0e4156SSadaf Ebrahimi 				if (op->mem.disp != 0)
68*9a0e4156SSadaf Ebrahimi 					add_str(&result, " ; operands[%u].mem.disp: 0x%x", i, op->mem.disp);
69*9a0e4156SSadaf Ebrahimi 
70*9a0e4156SSadaf Ebrahimi 				break;
71*9a0e4156SSadaf Ebrahimi 			case PPC_OP_CRX:
72*9a0e4156SSadaf Ebrahimi 				add_str(&result, " ; operands[%u].type: CRX", i);
73*9a0e4156SSadaf Ebrahimi 				add_str(&result, " ; operands[%u].crx.scale: %d", i, op->crx.scale);
74*9a0e4156SSadaf Ebrahimi 				add_str(&result, " ; operands[%u].crx.reg: %s", i, cs_reg_name(*handle, op->crx.reg));
75*9a0e4156SSadaf Ebrahimi 				add_str(&result, " ; operands[%u].crx.cond: %s", i, get_bc_name(op->crx.cond));
76*9a0e4156SSadaf Ebrahimi 				break;
77*9a0e4156SSadaf Ebrahimi 		}
78*9a0e4156SSadaf Ebrahimi 	}
79*9a0e4156SSadaf Ebrahimi 
80*9a0e4156SSadaf Ebrahimi 	if (ppc->bc != 0)
81*9a0e4156SSadaf Ebrahimi 		add_str(&result, " ; Branch code: %u", ppc->bc);
82*9a0e4156SSadaf Ebrahimi 
83*9a0e4156SSadaf Ebrahimi 	if (ppc->bh != 0)
84*9a0e4156SSadaf Ebrahimi 		add_str(&result, " ; Branch hint: %u", ppc->bh);
85*9a0e4156SSadaf Ebrahimi 
86*9a0e4156SSadaf Ebrahimi 	if (ppc->update_cr0)
87*9a0e4156SSadaf Ebrahimi 		add_str(&result, " ; Update-CR0: True");
88*9a0e4156SSadaf Ebrahimi 
89*9a0e4156SSadaf Ebrahimi 	return result;
90*9a0e4156SSadaf Ebrahimi }
91*9a0e4156SSadaf Ebrahimi 
92