freedreno: a2xx: add ir2 copy propagation
[mesa.git] / src / gallium / drivers / freedreno / meson.build
1 # Copyright © 2017 Rob Clark
2
3 # Permission is hereby granted, free of charge, to any person obtaining a copy
4 # of this software and associated documentation files (the "Software"), to deal
5 # in the Software without restriction, including without limitation the rights
6 # to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
7 # copies of the Software, and to permit persons to whom the Software is
8 # furnished to do so, subject to the following conditions:
9
10 # The above copyright notice and this permission notice shall be included in
11 # all copies or substantial portions of the Software.
12
13 # THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
14 # IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
15 # FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
16 # AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
17 # LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
18 # OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
19 # SOFTWARE.
20
21 files_libfreedreno = files(
22 'disasm.h',
23 'freedreno_batch.c',
24 'freedreno_batch.h',
25 'freedreno_batch_cache.c',
26 'freedreno_batch_cache.h',
27 'freedreno_blitter.c',
28 'freedreno_blitter.h',
29 'freedreno_context.c',
30 'freedreno_context.h',
31 'freedreno_draw.c',
32 'freedreno_draw.h',
33 'freedreno_fence.c',
34 'freedreno_fence.h',
35 'freedreno_gmem.c',
36 'freedreno_gmem.h',
37 'freedreno_perfcntr.h',
38 'freedreno_program.c',
39 'freedreno_program.h',
40 'freedreno_query.c',
41 'freedreno_query.h',
42 'freedreno_query_acc.c',
43 'freedreno_query_acc.h',
44 'freedreno_query_hw.c',
45 'freedreno_query_hw.h',
46 'freedreno_query_sw.c',
47 'freedreno_query_sw.h',
48 'freedreno_resource.c',
49 'freedreno_resource.h',
50 'freedreno_screen.c',
51 'freedreno_screen.h',
52 'freedreno_state.c',
53 'freedreno_state.h',
54 'freedreno_surface.c',
55 'freedreno_surface.h',
56 'freedreno_texture.c',
57 'freedreno_texture.h',
58 'freedreno_util.c',
59 'freedreno_util.h',
60 'a2xx/disasm-a2xx.c',
61 'a2xx/fd2_blend.c',
62 'a2xx/fd2_blend.h',
63 'a2xx/fd2_context.c',
64 'a2xx/fd2_context.h',
65 'a2xx/fd2_draw.c',
66 'a2xx/fd2_draw.h',
67 'a2xx/fd2_emit.c',
68 'a2xx/fd2_emit.h',
69 'a2xx/fd2_gmem.c',
70 'a2xx/fd2_gmem.h',
71 'a2xx/fd2_program.c',
72 'a2xx/fd2_program.h',
73 'a2xx/fd2_rasterizer.c',
74 'a2xx/fd2_rasterizer.h',
75 'a2xx/fd2_resource.c',
76 'a2xx/fd2_resource.h',
77 'a2xx/fd2_screen.c',
78 'a2xx/fd2_screen.h',
79 'a2xx/fd2_texture.c',
80 'a2xx/fd2_texture.h',
81 'a2xx/fd2_util.c',
82 'a2xx/fd2_util.h',
83 'a2xx/fd2_zsa.c',
84 'a2xx/fd2_zsa.h',
85 'a2xx/instr-a2xx.h',
86 'a2xx/ir2.c',
87 'a2xx/ir2.h',
88 'a2xx/ir2_assemble.c',
89 'a2xx/ir2_cp.c',
90 'a2xx/ir2_nir.c',
91 'a2xx/ir2_private.h',
92 'a2xx/ir2_ra.c',
93 'a3xx/fd3_blend.c',
94 'a3xx/fd3_blend.h',
95 'a3xx/fd3_context.c',
96 'a3xx/fd3_context.h',
97 'a3xx/fd3_draw.c',
98 'a3xx/fd3_draw.h',
99 'a3xx/fd3_emit.c',
100 'a3xx/fd3_emit.h',
101 'a3xx/fd3_format.c',
102 'a3xx/fd3_format.h',
103 'a3xx/fd3_gmem.c',
104 'a3xx/fd3_gmem.h',
105 'a3xx/fd3_program.c',
106 'a3xx/fd3_program.h',
107 'a3xx/fd3_query.c',
108 'a3xx/fd3_query.h',
109 'a3xx/fd3_rasterizer.c',
110 'a3xx/fd3_rasterizer.h',
111 'a3xx/fd3_screen.c',
112 'a3xx/fd3_screen.h',
113 'a3xx/fd3_texture.c',
114 'a3xx/fd3_texture.h',
115 'a3xx/fd3_zsa.c',
116 'a3xx/fd3_zsa.h',
117 'a4xx/fd4_blend.c',
118 'a4xx/fd4_blend.h',
119 'a4xx/fd4_context.c',
120 'a4xx/fd4_context.h',
121 'a4xx/fd4_draw.c',
122 'a4xx/fd4_draw.h',
123 'a4xx/fd4_emit.c',
124 'a4xx/fd4_emit.h',
125 'a4xx/fd4_format.c',
126 'a4xx/fd4_format.h',
127 'a4xx/fd4_gmem.c',
128 'a4xx/fd4_gmem.h',
129 'a4xx/fd4_program.c',
130 'a4xx/fd4_program.h',
131 'a4xx/fd4_query.c',
132 'a4xx/fd4_query.h',
133 'a4xx/fd4_rasterizer.c',
134 'a4xx/fd4_rasterizer.h',
135 'a4xx/fd4_screen.c',
136 'a4xx/fd4_screen.h',
137 'a4xx/fd4_texture.c',
138 'a4xx/fd4_texture.h',
139 'a4xx/fd4_zsa.c',
140 'a4xx/fd4_zsa.h',
141 'a5xx/fd5_blend.c',
142 'a5xx/fd5_blend.h',
143 'a5xx/fd5_blitter.c',
144 'a5xx/fd5_blitter.h',
145 'a5xx/fd5_compute.c',
146 'a5xx/fd5_compute.h',
147 'a5xx/fd5_context.c',
148 'a5xx/fd5_context.h',
149 'a5xx/fd5_draw.c',
150 'a5xx/fd5_draw.h',
151 'a5xx/fd5_emit.c',
152 'a5xx/fd5_emit.h',
153 'a5xx/fd5_format.c',
154 'a5xx/fd5_format.h',
155 'a5xx/fd5_gmem.c',
156 'a5xx/fd5_gmem.h',
157 'a5xx/fd5_image.c',
158 'a5xx/fd5_image.h',
159 'a5xx/fd5_perfcntr.c',
160 'a5xx/fd5_program.c',
161 'a5xx/fd5_program.h',
162 'a5xx/fd5_query.c',
163 'a5xx/fd5_query.h',
164 'a5xx/fd5_rasterizer.c',
165 'a5xx/fd5_rasterizer.h',
166 'a5xx/fd5_resource.c',
167 'a5xx/fd5_resource.h',
168 'a5xx/fd5_screen.c',
169 'a5xx/fd5_screen.h',
170 'a5xx/fd5_texture.c',
171 'a5xx/fd5_texture.h',
172 'a5xx/fd5_zsa.c',
173 'a5xx/fd5_zsa.h',
174 'a6xx/fd6_blend.c',
175 'a6xx/fd6_blend.h',
176 'a6xx/fd6_blitter.c',
177 'a6xx/fd6_blitter.h',
178 'a6xx/fd6_context.c',
179 'a6xx/fd6_context.h',
180 'a6xx/fd6_draw.c',
181 'a6xx/fd6_draw.h',
182 'a6xx/fd6_emit.c',
183 'a6xx/fd6_emit.h',
184 'a6xx/fd6_format.c',
185 'a6xx/fd6_format.h',
186 'a6xx/fd6_gmem.c',
187 'a6xx/fd6_gmem.h',
188 'a6xx/fd6_image.c',
189 'a6xx/fd6_image.h',
190 'a6xx/fd6_program.c',
191 'a6xx/fd6_program.h',
192 'a6xx/fd6_query.c',
193 'a6xx/fd6_query.h',
194 'a6xx/fd6_rasterizer.c',
195 'a6xx/fd6_rasterizer.h',
196 'a6xx/fd6_resource.c',
197 'a6xx/fd6_resource.h',
198 'a6xx/fd6_screen.c',
199 'a6xx/fd6_screen.h',
200 'a6xx/fd6_texture.c',
201 'a6xx/fd6_texture.h',
202 'a6xx/fd6_zsa.c',
203 'a6xx/fd6_zsa.h',
204 'ir3/ir3_cache.c',
205 'ir3/ir3_cache.h',
206 'ir3/ir3_gallium.c',
207 'ir3/ir3_gallium.h',
208 )
209
210 freedreno_includes = [
211 inc_src, inc_include, inc_gallium, inc_gallium_aux,
212 inc_freedreno, include_directories('ir3'),
213 ]
214
215 freedreno_c_args = []
216 if cc.has_argument('-Wpacked-bitfield-compat')
217 freedreno_c_args += '-Wno-packed-bitfield-compat'
218 endif
219
220 freedreno_cpp_args = []
221 if cpp.has_argument('-Wpacked-bitfield-compat')
222 freedreno_cpp_args += '-Wno-packed-bitfield-compat'
223 endif
224
225 libfreedreno = static_library(
226 'freedreno',
227 [files_libfreedreno],
228 include_directories : freedreno_includes,
229 c_args : [freedreno_c_args, c_vis_args],
230 cpp_args : [freedreno_cpp_args, cpp_vis_args],
231 dependencies : [dep_libdrm, idep_nir_headers],
232 )
233
234 driver_freedreno = declare_dependency(
235 compile_args : '-DGALLIUM_FREEDRENO',
236 link_with : [
237 libfreedrenowinsys,
238 libfreedreno,
239 libfreedreno_drm,
240 libfreedreno_ir3,
241 ],
242 dependencies : idep_nir,
243 )
244
245 ir3_compiler = executable(
246 'ir3_compiler',
247 'ir3/ir3_cmdline.c',
248 include_directories : freedreno_includes,
249 dependencies : [
250 dep_thread,
251 idep_nir,
252 ],
253 link_with : [
254 libfreedreno,
255 libfreedreno_drm,
256 libfreedreno_ir3,
257 libgallium,
258 libglsl_standalone,
259 libmesa_util,
260 ],
261 build_by_default : with_tools.contains('freedreno'),
262 install : with_tools.contains('freedreno'),
263 )