xref: /aosp_15_r20/external/mesa3d/src/amd/compiler/meson.build (revision 6104692788411f58d303aa86923a9ff6ecaded22)
1*61046927SAndroid Build Coastguard Worker# Copyright © 2018 Valve Corporation
2*61046927SAndroid Build Coastguard Worker# SPDX-License-Identifier: MIT
3*61046927SAndroid Build Coastguard Worker
4*61046927SAndroid Build Coastguard Workeraco_depends = files('aco_opcodes.py')
5*61046927SAndroid Build Coastguard Worker
6*61046927SAndroid Build Coastguard Workeraco_opcodes_h = custom_target(
7*61046927SAndroid Build Coastguard Worker  'aco_opcodes.h',
8*61046927SAndroid Build Coastguard Worker  input : 'aco_opcodes_h.py',
9*61046927SAndroid Build Coastguard Worker  output : 'aco_opcodes.h',
10*61046927SAndroid Build Coastguard Worker  command : [prog_python, '@INPUT@'],
11*61046927SAndroid Build Coastguard Worker  capture : true,
12*61046927SAndroid Build Coastguard Worker  depend_files : aco_depends,
13*61046927SAndroid Build Coastguard Worker)
14*61046927SAndroid Build Coastguard Worker
15*61046927SAndroid Build Coastguard Workeraco_opcodes_c = custom_target(
16*61046927SAndroid Build Coastguard Worker  'aco_opcodes.cpp',
17*61046927SAndroid Build Coastguard Worker  input : 'aco_opcodes_cpp.py',
18*61046927SAndroid Build Coastguard Worker  output : 'aco_opcodes.cpp',
19*61046927SAndroid Build Coastguard Worker  command : [prog_python, '@INPUT@'],
20*61046927SAndroid Build Coastguard Worker  capture : true,
21*61046927SAndroid Build Coastguard Worker  depend_files : aco_depends,
22*61046927SAndroid Build Coastguard Worker)
23*61046927SAndroid Build Coastguard Worker
24*61046927SAndroid Build Coastguard Workeraco_builder_h = custom_target(
25*61046927SAndroid Build Coastguard Worker  'aco_builder.h',
26*61046927SAndroid Build Coastguard Worker  input : 'aco_builder_h.py',
27*61046927SAndroid Build Coastguard Worker  output : 'aco_builder.h',
28*61046927SAndroid Build Coastguard Worker  command : [prog_python, '@INPUT@'],
29*61046927SAndroid Build Coastguard Worker  capture : true,
30*61046927SAndroid Build Coastguard Worker  depend_files : aco_depends,
31*61046927SAndroid Build Coastguard Worker)
32*61046927SAndroid Build Coastguard Worker
33*61046927SAndroid Build Coastguard Workerlibaco_files = files(
34*61046927SAndroid Build Coastguard Worker  'aco_dead_code_analysis.cpp',
35*61046927SAndroid Build Coastguard Worker  'aco_dominance.cpp',
36*61046927SAndroid Build Coastguard Worker  'aco_instruction_selection.cpp',
37*61046927SAndroid Build Coastguard Worker  'aco_instruction_selection.h',
38*61046927SAndroid Build Coastguard Worker  'aco_instruction_selection_setup.cpp',
39*61046927SAndroid Build Coastguard Worker  'aco_interface.cpp',
40*61046927SAndroid Build Coastguard Worker  'aco_interface.h',
41*61046927SAndroid Build Coastguard Worker  'aco_ir.cpp',
42*61046927SAndroid Build Coastguard Worker  'aco_ir.h',
43*61046927SAndroid Build Coastguard Worker  'aco_assembler.cpp',
44*61046927SAndroid Build Coastguard Worker  'aco_form_hard_clauses.cpp',
45*61046927SAndroid Build Coastguard Worker  'aco_insert_delay_alu.cpp',
46*61046927SAndroid Build Coastguard Worker  'aco_insert_exec_mask.cpp',
47*61046927SAndroid Build Coastguard Worker  'aco_insert_NOPs.cpp',
48*61046927SAndroid Build Coastguard Worker  'aco_insert_waitcnt.cpp',
49*61046927SAndroid Build Coastguard Worker  'aco_reduce_assign.cpp',
50*61046927SAndroid Build Coastguard Worker  'aco_register_allocation.cpp',
51*61046927SAndroid Build Coastguard Worker  'aco_live_var_analysis.cpp',
52*61046927SAndroid Build Coastguard Worker  'aco_lower_phis.cpp',
53*61046927SAndroid Build Coastguard Worker  'aco_lower_subdword.cpp',
54*61046927SAndroid Build Coastguard Worker  'aco_lower_to_cssa.cpp',
55*61046927SAndroid Build Coastguard Worker  'aco_lower_to_hw_instr.cpp',
56*61046927SAndroid Build Coastguard Worker  'aco_optimizer.cpp',
57*61046927SAndroid Build Coastguard Worker  'aco_optimizer_postRA.cpp',
58*61046927SAndroid Build Coastguard Worker  'aco_opt_value_numbering.cpp',
59*61046927SAndroid Build Coastguard Worker  'aco_print_asm.cpp',
60*61046927SAndroid Build Coastguard Worker  'aco_print_ir.cpp',
61*61046927SAndroid Build Coastguard Worker  'aco_reindex_ssa.cpp',
62*61046927SAndroid Build Coastguard Worker  'aco_scheduler.cpp',
63*61046927SAndroid Build Coastguard Worker  'aco_scheduler_ilp.cpp',
64*61046927SAndroid Build Coastguard Worker  'aco_spill.cpp',
65*61046927SAndroid Build Coastguard Worker  'aco_ssa_elimination.cpp',
66*61046927SAndroid Build Coastguard Worker  'aco_statistics.cpp',
67*61046927SAndroid Build Coastguard Worker  'aco_util.h',
68*61046927SAndroid Build Coastguard Worker  'aco_validate.cpp',
69*61046927SAndroid Build Coastguard Worker)
70*61046927SAndroid Build Coastguard Worker
71*61046927SAndroid Build Coastguard Workercpp_args_aco = cpp.get_supported_arguments(['-fno-exceptions', '-fno-rtti', '-Wimplicit-fallthrough', '-Wshadow'])
72*61046927SAndroid Build Coastguard Worker
73*61046927SAndroid Build Coastguard Worker_libaco = static_library(
74*61046927SAndroid Build Coastguard Worker  'aco',
75*61046927SAndroid Build Coastguard Worker  [libaco_files, aco_opcodes_c, aco_opcodes_h, aco_builder_h],
76*61046927SAndroid Build Coastguard Worker  include_directories : [
77*61046927SAndroid Build Coastguard Worker   inc_include, inc_src, inc_amd, inc_amd_common,
78*61046927SAndroid Build Coastguard Worker  ],
79*61046927SAndroid Build Coastguard Worker  dependencies : [
80*61046927SAndroid Build Coastguard Worker    dep_llvm, dep_thread, dep_valgrind, idep_nir_headers, idep_amdgfxregs_h, idep_mesautil,
81*61046927SAndroid Build Coastguard Worker  ],
82*61046927SAndroid Build Coastguard Worker  gnu_symbol_visibility : 'hidden',
83*61046927SAndroid Build Coastguard Worker  build_by_default : true,
84*61046927SAndroid Build Coastguard Worker  cpp_args : [cpp_args_aco, cpp_msvc_compat_args],
85*61046927SAndroid Build Coastguard Worker)
86*61046927SAndroid Build Coastguard Worker
87*61046927SAndroid Build Coastguard Worker# Also link with aco
88*61046927SAndroid Build Coastguard Workeridep_aco = declare_dependency(
89*61046927SAndroid Build Coastguard Worker  include_directories : include_directories('.'),
90*61046927SAndroid Build Coastguard Worker  link_with : _libaco,
91*61046927SAndroid Build Coastguard Worker  sources : [aco_opcodes_h, aco_builder_h],
92*61046927SAndroid Build Coastguard Worker)
93