1 # Copyright © 2016 Red Hat.
2 # Copyright © 2016 Mauro Rossi <issor.oruam@gmail.com>
4 # Permission is hereby granted, free of charge, to any person obtaining a
5 # copy of this software and associated documentation files (the "Software"),
6 # to deal in the Software without restriction, including without limitation
7 # the rights to use, copy, modify, merge, publish, distribute, sublicense,
8 # and/or sell copies of the Software, and to permit persons to whom the
9 # Software is furnished to do so, subject to the following conditions:
11 # The above copyright notice and this permission notice (including the next
12 # paragraph) shall be included in all copies or substantial portions of the
15 # THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
16 # IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
17 # FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL
18 # THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
19 # LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING
20 # FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS
23 ifeq ($(MESA_ENABLE_LLVM
),true
)
25 # ---------------------------------------
26 # Build libmesa_amd_common
27 # ---------------------------------------
31 LOCAL_MODULE
:= libmesa_amd_common
35 $(AMD_COMMON_LLVM_FILES
) \
38 LOCAL_CFLAGS
+= -DFORCE_BUILD_AMDGPU
# instructs LLVM to declare LLVMInitializeAMDGPU* functions
41 LOCAL_MODULE_CLASS
:= STATIC_LIBRARIES
42 intermediates
:= $(call local-generated-sources-dir
)
43 LOCAL_GENERATED_SOURCES
:= $(addprefix $(intermediates
)/, $(AMD_GENERATED_FILES
))
45 SID_TABLES
:= $(LOCAL_PATH
)/common
/sid_tables.py
47 SID_TABLES_INPUTS
:= \
48 $(LOCAL_PATH
)/common
/sid.h \
49 $(LOCAL_PATH
)/registers
/amdgfxregs.json \
50 $(LOCAL_PATH
)/registers
/pkt3.json \
51 $(LOCAL_PATH
)/registers
/gfx10.json \
52 $(LOCAL_PATH
)/registers
/gfx10-rsrc.json
54 $(intermediates
)/common
/sid_tables.h
: $(SID_TABLES
) $(SID_TABLES_INPUTS
)
56 @echo
"Gen Header: $(PRIVATE_MODULE) <= $(notdir $(@))"
57 $(hide
) $(MESA_PYTHON2
) $(SID_TABLES
) $(SID_TABLES_INPUTS
) > $@ ||
($(RM
) $@
; false
)
59 AMDGFXREGS
:= $(LOCAL_PATH
)/registers
/makeregheader.py
61 AMDGFXREGS_INPUTS
:= \
62 $(LOCAL_PATH
)/registers
/amdgfxregs.json \
63 $(LOCAL_PATH
)/registers
/pkt3.json \
64 $(LOCAL_PATH
)/registers
/gfx10.json \
65 $(LOCAL_PATH
)/registers
/gfx10-rsrc.json
67 $(intermediates
)/common
/amdgfxregs.h
: $(AMDGFXREGS
) $(AMDGFXREGS_INPUTS
)
69 @echo
"Gen Header: $(PRIVATE_MODULE) <= $(notdir $(@))"
70 $(hide
) $(MESA_PYTHON2
) $(AMDGFXREGS
) $(AMDGFXREGS_INPUTS
) --sort address
--guard AMDGFXREGS_H
> $@ ||
($(RM
) $@
; false
)
72 GEN10_FORMAT_TABLE_INPUTS
:= \
73 $(MESA_TOP
)/src
/util
/format
/u_format.csv \
74 $(MESA_TOP
)/src
/amd
/registers
/gfx10-rsrc.json
76 GEN10_FORMAT_TABLE_DEP
:= \
77 $(MESA_TOP
)/src
/amd
/registers
/regdb.py
79 GEN10_FORMAT_TABLE
:= $(LOCAL_PATH
)/common
/gfx10_format_table.py
81 $(intermediates
)/common
/gfx10_format_table.c
: $(GEN10_FORMAT_TABLE
) $(GEN10_FORMAT_TABLE_INPUTS
) $(GEN10_FORMAT_TABLE_DEP
)
83 @echo
"Gen Header: $(PRIVATE_MODULE) <= $(notdir $(@))"
84 $(hide
) $(MESA_PYTHON2
) $(GEN10_FORMAT_TABLE
) $(GEN10_FORMAT_TABLE_INPUTS
) > $@ ||
($(RM
) $@
; false
)
89 $(MESA_TOP
)/src
/amd
/common \
90 $(MESA_TOP
)/src
/amd
/llvm \
91 $(MESA_TOP
)/src
/compiler \
92 $(call generated-sources-dir-for
,STATIC_LIBRARIES
,libmesa_nir
,,)/nir \
93 $(MESA_TOP
)/src
/gallium
/include \
94 $(MESA_TOP
)/src
/gallium
/auxiliary \
95 $(MESA_TOP
)/src
/mesa \
96 $(intermediates
)/common
98 LOCAL_EXPORT_C_INCLUDE_DIRS
:= \
99 $(LOCAL_PATH
)/common \
101 $(intermediates
)/common
103 LOCAL_SHARED_LIBRARIES
:= \
106 LOCAL_STATIC_LIBRARIES
:= \
109 LOCAL_WHOLE_STATIC_LIBRARIES
:= \
112 $(call mesa-build-with-llvm
)
114 include $(MESA_COMMON_MK
)
115 include $(BUILD_STATIC_LIBRARY
)
117 endif # MESA_ENABLE_LLVM == true