1# Copyright © 2017 Intel Corporation 2 3# Permission is hereby granted, free of charge, to any person obtaining a copy 4# of this software and associated documentation files (the "Software"), to deal 5# in the Software without restriction, including without limitation the rights 6# to use, copy, modify, merge, publish, distribute, sublicense, and/or sell 7# copies of the Software, and to permit persons to whom the Software is 8# furnished to do so, subject to the following conditions: 9 10# The above copyright notice and this permission notice shall be included in 11# all copies or substantial portions of the Software. 12 13# THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR 14# IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, 15# FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE 16# AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER 17# LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, 18# OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE 19# SOFTWARE. 20 21files_addrlib = files( 22 'inc/addrinterface.h', 23 'inc/addrtypes.h', 24 'src/addrinterface.cpp', 25 'src/core/addrcommon.h', 26 'src/core/addrelemlib.cpp', 27 'src/core/addrelemlib.h', 28 'src/core/addrlib.cpp', 29 'src/core/addrlib.h', 30 'src/core/addrlib1.cpp', 31 'src/core/addrlib1.h', 32 'src/core/addrlib2.cpp', 33 'src/core/addrlib2.h', 34 'src/core/addrobject.cpp', 35 'src/core/addrobject.h', 36 'src/core/coord.cpp', 37 'src/core/coord.h', 38 'src/gfx9/gfx9addrlib.cpp', 39 'src/gfx9/gfx9addrlib.h', 40 'src/gfx10/gfx10addrlib.cpp', 41 'src/gfx10/gfx10addrlib.h', 42 'src/gfx10/gfx10SwizzlePattern.h', 43 'src/gfx11/gfx11addrlib.cpp', 44 'src/gfx11/gfx11addrlib.h', 45 'src/gfx11/gfx11SwizzlePattern.h', 46 'src/amdgpu_asic_addr.h', 47 'src/chip/gfx10/gfx10_gb_reg.h', 48 'src/chip/gfx11/gfx11_gb_reg.h', 49 'src/chip/gfx9/gfx9_gb_reg.h', 50 'src/chip/r800/si_gb_reg.h', 51 'src/r800/ciaddrlib.cpp', 52 'src/r800/ciaddrlib.h', 53 'src/r800/egbaddrlib.cpp', 54 'src/r800/egbaddrlib.h', 55 'src/r800/siaddrlib.cpp', 56 'src/r800/siaddrlib.h', 57) 58 59# Skip the addrlib definition of ADDR_FASTCALL so as not to use regparm. 60cpp_args_addrlib = ['-DADDR_FASTCALL='] 61 62if host_machine.endian() == 'little' 63 cpp_args_addrlib += '-DLITTLEENDIAN_CPU' 64else 65 cpp_args_addrlib += '-DBIGENDIAN_CPU' 66endif 67 68cpp_args_addrlib += cpp.get_supported_arguments( 69 ['-Wno-unused-variable', '-Wno-unused-local-typedefs', 70 '-Wno-unused-but-set-variable', '-Wno-maybe-uninitialized', 71 '-Wno-self-assign'] 72) 73 74libamdgpu_addrlib = static_library( 75 'addrlib', 76 files_addrlib, 77 include_directories : [ 78 include_directories( 79 'inc', 'src', 'src/core', 'src/chip/gfx9', 'src/chip/r800', 80 'src/chip/gfx10', 'src/chip/gfx11', 81 ), 82 inc_amd_common, inc_include, inc_src, inc_mapi, inc_mesa, inc_gallium, inc_gallium_aux, 83 ], 84 cpp_args : cpp_args_addrlib, 85 gnu_symbol_visibility : 'hidden', 86) 87