• Home
  • Line#
  • Scopes#
  • Navigate#
  • Raw
  • Download
1 /*
2  * Copyright © 2018 Google
3  *
4  * Permission is hereby granted, free of charge, to any person obtaining a
5  * copy of this software and associated documentation files (the "Software"),
6  * to deal in the Software without restriction, including without limitation
7  * the rights to use, copy, modify, merge, publish, distribute, sublicense,
8  * and/or sell copies of the Software, and to permit persons to whom the
9  * Software is furnished to do so, subject to the following conditions:
10  *
11  * The above copyright notice and this permission notice (including the next
12  * paragraph) shall be included in all copies or substantial portions of the
13  * Software.
14  *
15  * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
16  * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
17  * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT.  IN NO EVENT SHALL
18  * THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
19  * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING
20  * FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS
21  * IN THE SOFTWARE.
22  *
23  */
24 
25 #ifndef ACO_INTERFACE_H
26 #define ACO_INTERFACE_H
27 
28 #include "nir.h"
29 
30 #include "amd_family.h"
31 
32 #include "aco_shader_info.h"
33 #ifdef __cplusplus
34 extern "C" {
35 #endif
36 
37 struct ac_shader_config;
38 struct aco_shader_info;
39 struct aco_vs_prolog_key;
40 struct aco_ps_epilog_key;
41 
42 struct aco_compiler_statistic_info {
43    char name[32];
44    char desc[64];
45 };
46 
47 typedef void (aco_callback)(void **priv_ptr,
48                             gl_shader_stage stage,
49                             bool is_gs_copy_shader,
50                             const struct ac_shader_config *config,
51                             const char *llvm_ir_str,
52                             unsigned llvm_ir_size,
53                             const char *disasm_str,
54                             unsigned disasm_size,
55                             uint32_t *statistics,
56                             uint32_t stats_size,
57                             uint32_t exec_size,
58                             const uint32_t *code,
59                             uint32_t code_dw);
60 
61 typedef void (aco_shader_part_callback)(void **priv_ptr,
62                                         uint32_t num_sgprs,
63                                         uint32_t num_vgprs,
64                                         uint32_t num_preserved_sgprs,
65                                         const uint32_t *code,
66                                         uint32_t code_size,
67                                         const char *disasm_str,
68                                         uint32_t disasm_size);
69 
70 extern const unsigned aco_num_statistics;
71 extern const struct aco_compiler_statistic_info* aco_statistic_infos;
72 
73 void aco_compile_shader(const struct aco_compiler_options* options,
74                         const struct aco_shader_info* info,
75                         unsigned shader_count, struct nir_shader* const* shaders,
76                         const struct radv_shader_args *args,
77                         aco_callback *build_binary,
78                         void **binary);
79 
80 void aco_compile_vs_prolog(const struct aco_compiler_options* options,
81                            const struct aco_shader_info* info,
82                            const struct aco_vs_prolog_key* key,
83                            const struct radv_shader_args* args,
84                            aco_shader_part_callback *build_prolog,
85                            void **binary);
86 
87 void aco_compile_ps_epilog(const struct aco_compiler_options* options,
88                            const struct aco_shader_info* info,
89                            const struct aco_ps_epilog_key* key,
90                            const struct radv_shader_args* args,
91                            aco_shader_part_callback* build_epilog,
92                            void** binary);
93 
94 uint64_t aco_get_codegen_flags();
95 
96 #ifdef __cplusplus
97 }
98 #endif
99 
100 #endif
101