| // Copyright © 2024 Rot127 <unisono@quyllur.org> |
| // SPDX-License-Identifier: BSD-3 |
| |
| #ifndef TEST_DETAIL_AARCH64_H |
| #define TEST_DETAIL_AARCH64_H |
| |
| #include "test_compare.h" |
| #include <cyaml/cyaml.h> |
| #include <capstone/capstone.h> |
| |
| typedef struct { |
| char *type; |
| char *tile; |
| char *slice_reg; |
| int8_t slice_offset_imm; |
| int8_t slice_offset_ir_first; |
| int8_t slice_offset_ir_offset; |
| bool slice_offset_ir_set; |
| tbool has_range_offset; |
| tbool is_vertical; |
| } TestDetailAArch64SME; |
| |
| static const cyaml_schema_field_t test_detail_aarch64_sme_mapping_schema[] = { |
| CYAML_FIELD_STRING_PTR("type", CYAML_FLAG_POINTER | CYAML_FLAG_OPTIONAL, |
| TestDetailAArch64SME, type, 0, CYAML_UNLIMITED), |
| CYAML_FIELD_STRING_PTR("tile", CYAML_FLAG_POINTER | CYAML_FLAG_OPTIONAL, |
| TestDetailAArch64SME, tile, 0, CYAML_UNLIMITED), |
| CYAML_FIELD_STRING_PTR( |
| "slice_reg", CYAML_FLAG_POINTER | CYAML_FLAG_OPTIONAL, |
| TestDetailAArch64SME, slice_reg, 0, CYAML_UNLIMITED), |
| CYAML_FIELD_INT("slice_offset_imm", CYAML_FLAG_OPTIONAL, |
| TestDetailAArch64SME, slice_offset_imm), |
| CYAML_FIELD_INT("slice_offset_ir_first", CYAML_FLAG_OPTIONAL, |
| TestDetailAArch64SME, slice_offset_ir_first), |
| CYAML_FIELD_INT("slice_offset_ir_offset", CYAML_FLAG_OPTIONAL, |
| TestDetailAArch64SME, slice_offset_ir_offset), |
| CYAML_FIELD_BOOL("slice_offset_ir_set", CYAML_FLAG_OPTIONAL, |
| TestDetailAArch64SME, slice_offset_ir_set), |
| CYAML_FIELD_INT("has_range_offset", CYAML_FLAG_OPTIONAL, |
| TestDetailAArch64SME, has_range_offset), |
| CYAML_FIELD_INT("is_vertical", CYAML_FLAG_OPTIONAL, |
| TestDetailAArch64SME, is_vertical), |
| CYAML_FIELD_END |
| }; |
| |
| typedef struct { |
| char *type; |
| char *sub_type; |
| char *access; |
| |
| char *reg; |
| int64_t imm; |
| char *mem_base; |
| char *mem_index; |
| int32_t mem_disp; |
| |
| int8_t imm_range_first; |
| int8_t imm_range_offset; |
| double fp; |
| bool fp_set; /// Only relevant for SysOps with EXACTFPIMM |
| int sys_raw_val; |
| |
| TestDetailAArch64SME *sme; |
| |
| char *pred_reg; |
| char *pred_vec_select; |
| int32_t pred_imm_index; |
| bool pred_imm_index_set; |
| |
| char *shift_type; |
| uint32_t shift_value; |
| char *ext; |
| |
| char *vas; |
| tbool is_vreg; |
| int vector_index; |
| bool vector_index_is_set; |
| |
| tbool is_list_member; |
| } TestDetailAArch64Op; |
| |
| static const cyaml_schema_field_t test_detail_aarch64_op_mapping_schema[] = { |
| CYAML_FIELD_STRING_PTR("type", CYAML_FLAG_POINTER | CYAML_FLAG_OPTIONAL, |
| TestDetailAArch64Op, type, 0, CYAML_UNLIMITED), |
| CYAML_FIELD_STRING_PTR( |
| "sub_type", CYAML_FLAG_POINTER | CYAML_FLAG_OPTIONAL, |
| TestDetailAArch64Op, sub_type, 0, CYAML_UNLIMITED), |
| CYAML_FIELD_STRING_PTR("access", |
| CYAML_FLAG_POINTER | CYAML_FLAG_OPTIONAL, |
| TestDetailAArch64Op, access, 0, CYAML_UNLIMITED), |
| CYAML_FIELD_STRING_PTR("reg", CYAML_FLAG_POINTER | CYAML_FLAG_OPTIONAL, |
| TestDetailAArch64Op, reg, 0, CYAML_UNLIMITED), |
| CYAML_FIELD_INT("imm", CYAML_FLAG_OPTIONAL, TestDetailAArch64Op, imm), |
| CYAML_FIELD_STRING_PTR( |
| "mem_base", CYAML_FLAG_POINTER | CYAML_FLAG_OPTIONAL, |
| TestDetailAArch64Op, mem_base, 0, CYAML_UNLIMITED), |
| CYAML_FIELD_STRING_PTR( |
| "mem_index", CYAML_FLAG_POINTER | CYAML_FLAG_OPTIONAL, |
| TestDetailAArch64Op, mem_index, 0, CYAML_UNLIMITED), |
| CYAML_FIELD_INT("mem_disp", CYAML_FLAG_OPTIONAL, TestDetailAArch64Op, |
| mem_disp), |
| CYAML_FIELD_INT("imm_range_first", CYAML_FLAG_OPTIONAL, |
| TestDetailAArch64Op, imm_range_first), |
| CYAML_FIELD_INT("imm_range_offset", CYAML_FLAG_OPTIONAL, |
| TestDetailAArch64Op, imm_range_offset), |
| CYAML_FIELD_FLOAT("fp", CYAML_FLAG_OPTIONAL, TestDetailAArch64Op, fp), |
| CYAML_FIELD_BOOL("fp_set", CYAML_FLAG_OPTIONAL, TestDetailAArch64Op, |
| fp_set), |
| CYAML_FIELD_UINT("sys_raw_val", CYAML_FLAG_OPTIONAL, |
| TestDetailAArch64Op, sys_raw_val), |
| CYAML_FIELD_MAPPING_PTR("sme", CYAML_FLAG_OPTIONAL, TestDetailAArch64Op, |
| sme, test_detail_aarch64_sme_mapping_schema), |
| CYAML_FIELD_STRING_PTR( |
| "pred_reg", CYAML_FLAG_POINTER | CYAML_FLAG_OPTIONAL, |
| TestDetailAArch64Op, pred_reg, 0, CYAML_UNLIMITED), |
| CYAML_FIELD_STRING_PTR( |
| "pred_vec_select", CYAML_FLAG_POINTER | CYAML_FLAG_OPTIONAL, |
| TestDetailAArch64Op, pred_vec_select, 0, CYAML_UNLIMITED), |
| CYAML_FIELD_INT("pred_imm_index", CYAML_FLAG_OPTIONAL, |
| TestDetailAArch64Op, pred_imm_index), |
| CYAML_FIELD_BOOL("pred_imm_index_set", CYAML_FLAG_OPTIONAL, |
| TestDetailAArch64Op, pred_imm_index_set), |
| CYAML_FIELD_STRING_PTR( |
| "shift_type", CYAML_FLAG_POINTER | CYAML_FLAG_OPTIONAL, |
| TestDetailAArch64Op, shift_type, 0, CYAML_UNLIMITED), |
| CYAML_FIELD_UINT("shift_value", CYAML_FLAG_OPTIONAL, |
| TestDetailAArch64Op, shift_value), |
| CYAML_FIELD_STRING_PTR("ext", CYAML_FLAG_POINTER | CYAML_FLAG_OPTIONAL, |
| TestDetailAArch64Op, ext, 0, CYAML_UNLIMITED), |
| CYAML_FIELD_STRING_PTR("vas", CYAML_FLAG_POINTER | CYAML_FLAG_OPTIONAL, |
| TestDetailAArch64Op, vas, 0, CYAML_UNLIMITED), |
| CYAML_FIELD_INT("is_vreg", CYAML_FLAG_OPTIONAL, TestDetailAArch64Op, |
| is_vreg), |
| CYAML_FIELD_INT("vector_index", CYAML_FLAG_OPTIONAL, |
| TestDetailAArch64Op, vector_index), |
| CYAML_FIELD_BOOL("vector_index_is_set", CYAML_FLAG_OPTIONAL, |
| TestDetailAArch64Op, vector_index_is_set), |
| CYAML_FIELD_INT("is_list_member", CYAML_FLAG_OPTIONAL, |
| TestDetailAArch64Op, is_list_member), |
| CYAML_FIELD_END |
| }; |
| |
| static const cyaml_schema_value_t test_detail_aarch64_op_schema = { |
| CYAML_VALUE_MAPPING(CYAML_FLAG_POINTER, TestDetailAArch64Op, |
| test_detail_aarch64_op_mapping_schema), |
| }; |
| |
| typedef struct { |
| char *cc; |
| tbool update_flags; |
| tbool post_indexed; |
| TestDetailAArch64Op **operands; |
| uint32_t operands_count; |
| } TestDetailAArch64; |
| |
| static const cyaml_schema_field_t test_detail_aarch64_mapping_schema[] = { |
| CYAML_FIELD_STRING_PTR("cc", CYAML_FLAG_POINTER | CYAML_FLAG_OPTIONAL, |
| TestDetailAArch64, cc, 0, CYAML_UNLIMITED), |
| CYAML_FIELD_INT("update_flags", CYAML_FLAG_OPTIONAL, TestDetailAArch64, |
| update_flags), |
| CYAML_FIELD_INT("post_indexed", CYAML_FLAG_OPTIONAL, TestDetailAArch64, |
| post_indexed), |
| CYAML_FIELD_SEQUENCE( |
| "operands", CYAML_FLAG_POINTER | CYAML_FLAG_OPTIONAL, |
| TestDetailAArch64, operands, &test_detail_aarch64_op_schema, 0, |
| CYAML_UNLIMITED), // 0-MAX options |
| CYAML_FIELD_END |
| }; |
| |
| TestDetailAArch64 *test_detail_aarch64_new(); |
| TestDetailAArch64 *test_detail_aarch64_clone(TestDetailAArch64 *detail); |
| void test_detail_aarch64_free(TestDetailAArch64 *detail); |
| |
| TestDetailAArch64Op *test_detail_aarch64_op_new(); |
| TestDetailAArch64Op *test_detail_aarch64_op_clone(TestDetailAArch64Op *detail); |
| void test_detail_aarch64_op_free(TestDetailAArch64Op *detail); |
| |
| TestDetailAArch64SME *test_detail_aarch64_op_sme_new(); |
| TestDetailAArch64SME * |
| test_detail_aarch64_op_sme_clone(TestDetailAArch64SME *sme); |
| void test_detail_aarch64_op_sme_free(TestDetailAArch64SME *sme); |
| |
| bool test_expected_aarch64(csh *handle, cs_aarch64 *actual, |
| TestDetailAArch64 *expected); |
| |
| #endif // TEST_DETAIL_AARCH64_H |