1# Copyright © 2017 Intel Corporation 2# SPDX-License-Identifier: MIT 3 4files_addrlib = files( 5 'inc/addrinterface.h', 6 'inc/addrtypes.h', 7 'src/addrinterface.cpp', 8 'src/core/addrcommon.h', 9 'src/core/addrelemlib.cpp', 10 'src/core/addrelemlib.h', 11 'src/core/addrlib.cpp', 12 'src/core/addrlib.h', 13 'src/core/addrlib1.cpp', 14 'src/core/addrlib1.h', 15 'src/core/addrlib2.cpp', 16 'src/core/addrlib2.h', 17 'src/core/addrlib3.cpp', 18 'src/core/addrlib3.h', 19 'src/core/addrobject.cpp', 20 'src/core/addrobject.h', 21 'src/core/addrswizzler.cpp', 22 'src/core/addrswizzler.h', 23 'src/core/coord.cpp', 24 'src/core/coord.h', 25 'src/gfx9/gfx9addrlib.cpp', 26 'src/gfx9/gfx9addrlib.h', 27 'src/gfx10/gfx10addrlib.cpp', 28 'src/gfx10/gfx10addrlib.h', 29 'src/gfx10/gfx10SwizzlePattern.h', 30 'src/gfx11/gfx11addrlib.cpp', 31 'src/gfx11/gfx11addrlib.h', 32 'src/gfx11/gfx11SwizzlePattern.h', 33 'src/gfx12/gfx12addrlib.cpp', 34 'src/gfx12/gfx12addrlib.h', 35 'src/gfx12/gfx12SwizzlePattern.h', 36 'src/amdgpu_asic_addr.h', 37 'src/chip/gfx10/gfx10_gb_reg.h', 38 'src/chip/gfx11/gfx11_gb_reg.h', 39 'src/chip/gfx12/gfx12_gb_reg.h', 40 'src/chip/gfx9/gfx9_gb_reg.h', 41 'src/chip/r800/si_gb_reg.h', 42 'src/r800/ciaddrlib.cpp', 43 'src/r800/ciaddrlib.h', 44 'src/r800/egbaddrlib.cpp', 45 'src/r800/egbaddrlib.h', 46 'src/r800/siaddrlib.cpp', 47 'src/r800/siaddrlib.h', 48) 49 50# Skip the addrlib definition of ADDR_FASTCALL so as not to use regparm. 51cpp_args_addrlib = ['-DADDR_FASTCALL='] 52 53if host_machine.endian() == 'little' 54 cpp_args_addrlib += '-DLITTLEENDIAN_CPU' 55else 56 cpp_args_addrlib += '-DBIGENDIAN_CPU' 57endif 58 59if with_mesa_ndebug 60 cpp_args_addrlib += '-DDEBUG=0' 61else 62 cpp_args_addrlib += '-DDEBUG=1' 63endif 64 65cpp_args_addrlib += cpp.get_supported_arguments( 66 ['-Wno-unused-variable', '-Wno-unused-local-typedefs', 67 '-Wno-unused-but-set-variable', '-Wno-maybe-uninitialized', 68 '-Wno-self-assign', '/wd4189', '-Wno-uninitialized'] 69) 70 71libamdgpu_addrlib = static_library( 72 'addrlib', 73 files_addrlib, 74 include_directories : [ 75 include_directories( 76 'inc', 'src', 'src/core', 'src/chip/gfx9', 'src/chip/r800', 77 'src/chip/gfx10', 'src/chip/gfx11', 'src/chip/gfx12', 78 ), 79 inc_amd_common, inc_include, inc_src 80 ], 81 cpp_args : cpp_args_addrlib, 82 gnu_symbol_visibility : 'hidden', 83) 84