1# Copyright © 2017 Dylan Baker 2# SPDX-License-Identifier: MIT 3 4si_tracepoints = custom_target( 5 'si_tracepoints.[ch]', 6 input: 'si_tracepoints.py', 7 output: ['si_tracepoints.c', 'si_tracepoints_perfetto.h', 'si_tracepoints.h'], 8 command: [ 9 prog_python, '@INPUT@', 10 '-p', join_paths(dir_source_root, 'src/util/perf/'), 11 '-C', '@OUTPUT0@', 12 '--perfetto-hdr', '@OUTPUT1@', 13 '-H', '@OUTPUT2@' 14 ], 15 depend_files: u_trace_py, 16) 17 18idep_si_tracepoints = declare_dependency( 19 sources: si_tracepoints, 20) 21 22files_libradeonsi = files( 23 'driinfo_radeonsi.h', 24 'gfx10_shader_ngg.c', 25 'gfx11_query.c', 26 'si_barrier.c', 27 'si_blit.c', 28 'si_buffer.c', 29 'si_build_pm4.h', 30 'si_clear.c', 31 'si_compute.c', 32 'si_compute_blit.c', 33 'si_cp_dma.c', 34 'si_cp_reg_shadowing.c', 35 'si_cp_utils.c', 36 'si_debug.c', 37 'si_descriptors.c', 38 'si_fence.c', 39 'si_get.c', 40 'si_gfx_cs.c', 41 'si_gpu_load.c', 42 'si_perfcounter.c', 43 'si_pipe.c', 44 'si_pipe.h', 45 'si_pm4.c', 46 'si_pm4.h', 47 'si_public.h', 48 'si_query.c', 49 'si_query.h', 50 'si_nir_lower_abi.c', 51 'si_nir_lower_resource.c', 52 'si_nir_lower_vs_inputs.c', 53 'si_nir_optim.c', 54 'si_sdma_copy_image.c', 55 'si_shader.c', 56 'si_shader.h', 57 'si_shader_aco.c', 58 'si_shader_info.c', 59 'si_shader_internal.h', 60 'si_shader_nir.c', 61 'si_shaderlib_nir.c', 62 'si_sqtt.c', 63 'si_state.c', 64 'si_state.h', 65 'si_state_binning.c', 66 'si_state_msaa.c', 67 'si_state_shaders.cpp', 68 'si_state_streamout.c', 69 'si_state_viewport.c', 70 'si_test_blit_perf.c', 71 'si_test_dma_perf.c', 72 'si_test_image_copy_region.c', 73 'si_texture.c', 74 'si_utrace.c', 75 'si_utrace.h', 76 'si_uvd.c', 77 'si_vpe.c', 78 'si_vpe.h', 79 'pspdecryptionparam.h', 80 'radeon_uvd.c', 81 'radeon_uvd.h', 82 'radeon_uvd_enc.c', 83 'radeon_uvd_enc.h', 84 'radeon_uvd_enc_1_1.c', 85 'radeon_vce.c', 86 'radeon_vce.h', 87 'radeon_vce_40_2_2.c', 88 'radeon_vce_50.c', 89 'radeon_vce_52.c', 90 'radeon_vcn.h', 91 'radeon_vcn.c', 92 'radeon_vcn_dec.c', 93 'radeon_vcn_dec.h', 94 'radeon_vcn_dec_jpeg.c', 95 'radeon_vcn_enc.c', 96 'radeon_vcn_enc.h', 97 'radeon_vcn_enc_1_2.c', 98 'radeon_vcn_enc_2_0.c', 99 'radeon_vcn_enc_3_0.c', 100 'radeon_vcn_enc_4_0.c', 101 'radeon_vcn_enc_5_0.c', 102 'radeon_video.c', 103 'radeon_video.h', 104) 105 106radeonsi_include_dirs = [inc_src, inc_include, inc_gallium, inc_gallium_aux, inc_amd_common, 107 inc_amd_common_llvm, inc_gallium_drivers, inc_compiler, inc_amd, inc_amd_vpe] 108radeonsi_deps = [dep_llvm, dep_clock, dep_libdrm_radeon, idep_nir_headers, idep_amdgfxregs_h, idep_mesautil, idep_aco, idep_u_tracepoints, idep_si_tracepoints] 109 110if with_perfetto 111 radeonsi_deps += dep_perfetto 112endif 113 114files_libradeonsi += ['si_perfetto.cpp', 'si_perfetto.h'] 115 116amd_common_libs = [libamd_common] 117 118if amd_with_llvm 119 files_libradeonsi += files( 120 'si_shader_llvm.c', 121 'si_shader_llvm.h', 122 'si_shader_llvm_gs.c', 123 'si_shader_llvm_ps.c', 124 'si_shader_llvm_tess.c', 125 ) 126 127 radeonsi_include_dirs += [inc_amd_common_llvm] 128 radeonsi_deps += [dep_llvm] 129 amd_common_libs += [libamd_common_llvm] 130endif 131 132radeonsi_gfx_libs = [] 133foreach ver : ['6', '7', '8', '9', '10', '103', '11', '115', '12'] 134 radeonsi_gfx_libs += static_library( 135 'radeonsi_gfx@0@'.format(ver), 136 ['si_state_draw.cpp'], 137 include_directories : radeonsi_include_dirs, 138 cpp_args : ['-DGFX_VER=@0@'.format(ver)], 139 gnu_symbol_visibility : 'hidden', 140 dependencies : radeonsi_deps, 141 ) 142endforeach 143 144libradeonsi = static_library( 145 'radeonsi', 146 [files_libradeonsi, sid_tables_h], 147 include_directories : radeonsi_include_dirs, 148 gnu_symbol_visibility : 'hidden', 149 dependencies : radeonsi_deps, 150) 151 152driver_radeonsi = declare_dependency( 153 compile_args : '-DGALLIUM_RADEONSI', 154 link_with : radeonsi_gfx_libs + [ 155 libradeonsi, libradeonwinsys, libamdgpuwinsys, libamd_common, libamd_common_llvm, libvpe 156 ], 157 dependencies : idep_nir, 158) 159