// Copyright © 2024 Rot127 // SPDX-License-Identifier: BSD-3 #ifndef TEST_DETAIL_M68K_H #define TEST_DETAIL_M68K_H #include "test_compare.h" #include #include typedef struct { char *base_reg; char *index_reg; char *in_base_reg; tbool index_size; // -1 == word, 1 == long int16_t disp; uint32_t in_disp; uint32_t out_disp; uint8_t scale; uint8_t bitfield; uint8_t width; uint8_t offset; } TestDetailM68KOpMem; static const cyaml_schema_field_t test_detail_m68k_op_mem_mapping_schema[] = { CYAML_FIELD_INT("disp", CYAML_FLAG_OPTIONAL, TestDetailM68KOpMem, disp), CYAML_FIELD_STRING_PTR( "base_reg", CYAML_FLAG_POINTER | CYAML_FLAG_OPTIONAL, TestDetailM68KOpMem, base_reg, 0, CYAML_UNLIMITED), CYAML_FIELD_STRING_PTR( "index_reg", CYAML_FLAG_POINTER | CYAML_FLAG_OPTIONAL, TestDetailM68KOpMem, index_reg, 0, CYAML_UNLIMITED), CYAML_FIELD_STRING_PTR( "in_base_reg", CYAML_FLAG_POINTER | CYAML_FLAG_OPTIONAL, TestDetailM68KOpMem, in_base_reg, 0, CYAML_UNLIMITED), CYAML_FIELD_INT("index_size", CYAML_FLAG_POINTER | CYAML_FLAG_OPTIONAL, TestDetailM68KOpMem, index_size), CYAML_FIELD_INT("disp", CYAML_FLAG_OPTIONAL, TestDetailM68KOpMem, disp), CYAML_FIELD_UINT("in_disp", CYAML_FLAG_OPTIONAL, TestDetailM68KOpMem, in_disp), CYAML_FIELD_UINT("out_disp", CYAML_FLAG_OPTIONAL, TestDetailM68KOpMem, out_disp), CYAML_FIELD_UINT("scale", CYAML_FLAG_OPTIONAL, TestDetailM68KOpMem, scale), CYAML_FIELD_UINT("bitfield", CYAML_FLAG_OPTIONAL, TestDetailM68KOpMem, bitfield), CYAML_FIELD_UINT("width", CYAML_FLAG_OPTIONAL, TestDetailM68KOpMem, width), CYAML_FIELD_UINT("offset", CYAML_FLAG_OPTIONAL, TestDetailM68KOpMem, offset), CYAML_FIELD_END }; typedef struct { char *type; char *address_mode; char *reg; char *reg_pair_0; char *reg_pair_1; uint64_t imm; int32_t br_disp; uint8_t br_disp_size; uint32_t register_bits; double dimm; float simm; TestDetailM68KOpMem *mem; } TestDetailM68KOp; static const cyaml_schema_value_t test_detail_m68k_op_sys_psr_schema = { CYAML_VALUE_STRING(CYAML_FLAG_POINTER, char, 0, CYAML_UNLIMITED), }; static const cyaml_schema_field_t test_detail_m68k_op_mapping_schema[] = { CYAML_FIELD_STRING_PTR("type", CYAML_FLAG_POINTER | CYAML_FLAG_OPTIONAL, TestDetailM68KOp, type, 0, CYAML_UNLIMITED), CYAML_FIELD_STRING_PTR( "address_mode", CYAML_FLAG_POINTER | CYAML_FLAG_OPTIONAL, TestDetailM68KOp, address_mode, 0, CYAML_UNLIMITED), CYAML_FIELD_STRING_PTR("reg", CYAML_FLAG_POINTER | CYAML_FLAG_OPTIONAL, TestDetailM68KOp, reg, 0, CYAML_UNLIMITED), CYAML_FIELD_STRING_PTR( "reg_pair_0", CYAML_FLAG_POINTER | CYAML_FLAG_OPTIONAL, TestDetailM68KOp, reg_pair_0, 0, CYAML_UNLIMITED), CYAML_FIELD_STRING_PTR( "reg_pair_1", CYAML_FLAG_POINTER | CYAML_FLAG_OPTIONAL, TestDetailM68KOp, reg_pair_1, 0, CYAML_UNLIMITED), CYAML_FIELD_INT("imm", CYAML_FLAG_OPTIONAL, TestDetailM68KOp, imm), CYAML_FIELD_INT("br_disp", CYAML_FLAG_OPTIONAL, TestDetailM68KOp, br_disp), CYAML_FIELD_UINT("br_disp_size", CYAML_FLAG_OPTIONAL, TestDetailM68KOp, br_disp_size), CYAML_FIELD_UINT("register_bits", CYAML_FLAG_OPTIONAL, TestDetailM68KOp, register_bits), CYAML_FIELD_FLOAT("dimm", CYAML_FLAG_OPTIONAL, TestDetailM68KOp, dimm), CYAML_FIELD_FLOAT("simm", CYAML_FLAG_OPTIONAL, TestDetailM68KOp, simm), CYAML_FIELD_MAPPING_PTR("mem", CYAML_FLAG_OPTIONAL, TestDetailM68KOp, mem, test_detail_m68k_op_mem_mapping_schema), CYAML_FIELD_END }; static const cyaml_schema_value_t test_detail_m68k_op_schema = { CYAML_VALUE_MAPPING(CYAML_FLAG_POINTER, TestDetailM68KOp, test_detail_m68k_op_mapping_schema), }; typedef struct { char *op_size_type; char *op_size_fpu; char *op_size_cpu; TestDetailM68KOp **operands; uint32_t operands_count; } TestDetailM68K; static const cyaml_schema_field_t test_detail_m68k_mapping_schema[] = { CYAML_FIELD_STRING_PTR( "op_size_type", CYAML_FLAG_POINTER | CYAML_FLAG_OPTIONAL, TestDetailM68K, op_size_type, 0, CYAML_UNLIMITED), CYAML_FIELD_STRING_PTR("op_size_fpu", CYAML_FLAG_POINTER | CYAML_FLAG_OPTIONAL, TestDetailM68K, op_size_fpu, 0, CYAML_UNLIMITED), CYAML_FIELD_STRING_PTR("op_size_cpu", CYAML_FLAG_POINTER | CYAML_FLAG_OPTIONAL, TestDetailM68K, op_size_cpu, 0, CYAML_UNLIMITED), CYAML_FIELD_SEQUENCE( "operands", CYAML_FLAG_POINTER | CYAML_FLAG_OPTIONAL, TestDetailM68K, operands, &test_detail_m68k_op_schema, 0, CYAML_UNLIMITED), // 0-MAX options CYAML_FIELD_END }; TestDetailM68K *test_detail_m68k_new(); TestDetailM68K *test_detail_m68k_clone(TestDetailM68K *detail); void test_detail_m68k_free(TestDetailM68K *detail); TestDetailM68KOp *test_detail_m68k_op_new(); TestDetailM68KOp *test_detail_m68k_op_clone(TestDetailM68KOp *detail); void test_detail_m68k_op_free(TestDetailM68KOp *detail); TestDetailM68KOpMem *test_detail_m68k_op_mem_new(); TestDetailM68KOpMem *test_detail_m68k_op_mem_clone(TestDetailM68KOpMem *detail); void test_detail_m68k_op_mem_free(TestDetailM68KOpMem *detail); bool test_expected_m68k(csh *handle, cs_m68k *actual, TestDetailM68K *expected); #endif // TEST_DETAIL_M68K_H