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