xref: /aosp_15_r20/external/mesa3d/src/intel/compiler/brw_disasm.h (revision 6104692788411f58d303aa86923a9ff6ecaded22)
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