1*61046927SAndroid Build Coastguard Worker /* 2*61046927SAndroid Build Coastguard Worker * Copyright 2024 Intel Corporation 3*61046927SAndroid Build Coastguard Worker * SPDX-License-Identifier: MIT 4*61046927SAndroid Build Coastguard Worker */ 5*61046927SAndroid Build Coastguard Worker 6*61046927SAndroid Build Coastguard Worker #ifndef BRW_DISASM_H 7*61046927SAndroid Build Coastguard Worker #define BRW_DISASM_H 8*61046927SAndroid Build Coastguard Worker 9*61046927SAndroid Build Coastguard Worker #include <stdio.h> 10*61046927SAndroid Build Coastguard Worker #include <stdbool.h> 11*61046927SAndroid Build Coastguard Worker 12*61046927SAndroid Build Coastguard Worker #ifdef __cplusplus 13*61046927SAndroid Build Coastguard Worker extern "C" { 14*61046927SAndroid Build Coastguard Worker #endif 15*61046927SAndroid Build Coastguard Worker 16*61046927SAndroid Build Coastguard Worker struct brw_isa_info; 17*61046927SAndroid Build Coastguard Worker struct brw_inst; 18*61046927SAndroid Build Coastguard Worker 19*61046927SAndroid Build Coastguard Worker const struct brw_label *brw_find_label(const struct brw_label *root, int offset); 20*61046927SAndroid Build Coastguard Worker void brw_create_label(struct brw_label **labels, int offset, void *mem_ctx); 21*61046927SAndroid Build Coastguard Worker int brw_disassemble_inst(FILE *file, const struct brw_isa_info *isa, 22*61046927SAndroid Build Coastguard Worker const struct brw_inst *inst, bool is_compacted, 23*61046927SAndroid Build Coastguard Worker int offset, const struct brw_label *root_label); 24*61046927SAndroid Build Coastguard Worker const struct 25*61046927SAndroid Build Coastguard Worker brw_label *brw_label_assembly(const struct brw_isa_info *isa, 26*61046927SAndroid Build Coastguard Worker const void *assembly, int start, int end, 27*61046927SAndroid Build Coastguard Worker void *mem_ctx); 28*61046927SAndroid Build Coastguard Worker void brw_disassemble_with_labels(const struct brw_isa_info *isa, 29*61046927SAndroid Build Coastguard Worker const void *assembly, int start, int end, FILE *out); 30*61046927SAndroid Build Coastguard Worker void brw_disassemble(const struct brw_isa_info *isa, 31*61046927SAndroid Build Coastguard Worker const void *assembly, int start, int end, 32*61046927SAndroid Build Coastguard Worker const struct brw_label *root_label, FILE *out); 33*61046927SAndroid Build Coastguard Worker int brw_disassemble_find_end(const struct brw_isa_info *isa, 34*61046927SAndroid Build Coastguard Worker const void *assembly, int start); 35*61046927SAndroid Build Coastguard Worker void brw_disassemble_with_errors(const struct brw_isa_info *isa, 36*61046927SAndroid Build Coastguard Worker const void *assembly, int start, FILE *out); 37*61046927SAndroid Build Coastguard Worker 38*61046927SAndroid Build Coastguard Worker const char *brw_lsc_op_to_string(unsigned op); 39*61046927SAndroid Build Coastguard Worker const char *brw_lsc_addr_surftype_to_string(unsigned t); 40*61046927SAndroid Build Coastguard Worker const char *brw_lsc_data_size_to_string(unsigned s); 41*61046927SAndroid Build Coastguard Worker 42*61046927SAndroid Build Coastguard Worker #ifdef __cplusplus 43*61046927SAndroid Build Coastguard Worker } /* extern "C" */ 44*61046927SAndroid Build Coastguard Worker #endif 45*61046927SAndroid Build Coastguard Worker 46*61046927SAndroid Build Coastguard Worker #endif /* BRW_DISASM_H */ 47