• Home
  • Line#
  • Scopes#
  • Navigate#
  • Raw
  • Download
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