mesa/src/amd/compiler/meson.build
Daniel Schürmann 023e78b4d7 aco: add new post-RA scheduler for ILP
Totals from 77247 (97.37% of 79330) affected shaders: (GFX11)

Instrs: 44371374 -> 43215723 (-2.60%); split: -2.64%, +0.03%
CodeSize: 227819532 -> 223188224 (-2.03%); split: -2.06%, +0.03%
Latency: 301016823 -> 290147626 (-3.61%); split: -3.70%, +0.09%
InvThroughput: 48551749 -> 47646212 (-1.87%); split: -1.88%, +0.01%
VClause: 870581 -> 834655 (-4.13%); split: -4.13%, +0.00%
SClause: 1487061 -> 1340851 (-9.83%); split: -9.83%, +0.00%
Part-of: <https://gitlab.freedesktop.org/mesa/mesa/-/merge_requests/25676>
2024-01-06 11:30:42 +00:00

107 lines
3.2 KiB
Meson

# Copyright © 2018 Valve Corporation
# Permission is hereby granted, free of charge, to any person obtaining a copy
# of this software and associated documentation files (the "Software"), to deal
# in the Software without restriction, including without limitation the rights
# to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
# copies of the Software, and to permit persons to whom the Software is
# furnished to do so, subject to the following conditions:
# The above copyright notice and this permission notice shall be included in
# all copies or substantial portions of the Software.
# THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
# IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
# FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
# AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
# LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
# OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
# SOFTWARE.
aco_depends = files('aco_opcodes.py')
aco_opcodes_h = custom_target(
'aco_opcodes.h',
input : 'aco_opcodes_h.py',
output : 'aco_opcodes.h',
command : [prog_python, '@INPUT@'],
capture : true,
depend_files : aco_depends,
)
aco_opcodes_c = custom_target(
'aco_opcodes.cpp',
input : 'aco_opcodes_cpp.py',
output : 'aco_opcodes.cpp',
command : [prog_python, '@INPUT@'],
capture : true,
depend_files : aco_depends,
)
aco_builder_h = custom_target(
'aco_builder.h',
input : 'aco_builder_h.py',
output : 'aco_builder.h',
command : [prog_python, '@INPUT@'],
capture : true,
depend_files : aco_depends,
)
libaco_files = files(
'aco_dead_code_analysis.cpp',
'aco_dominance.cpp',
'aco_instruction_selection.cpp',
'aco_instruction_selection.h',
'aco_instruction_selection_setup.cpp',
'aco_interface.cpp',
'aco_interface.h',
'aco_ir.cpp',
'aco_ir.h',
'aco_assembler.cpp',
'aco_form_hard_clauses.cpp',
'aco_insert_exec_mask.cpp',
'aco_insert_NOPs.cpp',
'aco_insert_waitcnt.cpp',
'aco_reduce_assign.cpp',
'aco_register_allocation.cpp',
'aco_live_var_analysis.cpp',
'aco_lower_phis.cpp',
'aco_lower_to_cssa.cpp',
'aco_lower_to_hw_instr.cpp',
'aco_optimizer.cpp',
'aco_optimizer_postRA.cpp',
'aco_opt_value_numbering.cpp',
'aco_print_asm.cpp',
'aco_print_ir.cpp',
'aco_reindex_ssa.cpp',
'aco_scheduler.cpp',
'aco_scheduler_ilp.cpp',
'aco_spill.cpp',
'aco_ssa_elimination.cpp',
'aco_statistics.cpp',
'aco_util.h',
'aco_validate.cpp',
)
cpp_args_aco = cpp.get_supported_arguments(['-fno-exceptions', '-fno-rtti', '-Wimplicit-fallthrough', '-Wshadow'])
_libaco = static_library(
'aco',
[libaco_files, aco_opcodes_c, aco_opcodes_h, aco_builder_h],
include_directories : [
inc_include, inc_src, inc_amd, inc_amd_common,
],
dependencies : [
dep_llvm, dep_thread, dep_valgrind, idep_nir_headers, idep_amdgfxregs_h, idep_mesautil,
],
gnu_symbol_visibility : 'hidden',
build_by_default : true,
cpp_args : [cpp_args_aco, cpp_msvc_compat_args],
)
# Also link with aco
idep_aco = declare_dependency(
include_directories : include_directories('.'),
link_with : _libaco,
sources : [aco_opcodes_h, aco_builder_h],
)