android: amd/common/gfx10: add register JSON
[mesa.git] / src / amd / Android.common.mk
1 # Copyright © 2016 Red Hat.
2 # Copyright © 2016 Mauro Rossi <issor.oruam@gmail.com>
3 #
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:
10 #
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
13 # Software.
14 #
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
21 # IN THE SOFTWARE.
22
23 # ---------------------------------------
24 # Build libmesa_amd_common
25 # ---------------------------------------
26
27 include $(CLEAR_VARS)
28
29 LOCAL_MODULE := libmesa_amd_common
30
31 LOCAL_SRC_FILES := \
32 $(AMD_COMMON_FILES) \
33 $(AMD_COMPILER_FILES) \
34 $(AMD_DEBUG_FILES) \
35 $(AMD_NIR_FILES)
36
37 LOCAL_CFLAGS += -DFORCE_BUILD_AMDGPU # instructs LLVM to declare LLVMInitializeAMDGPU* functions
38
39 # generate sources
40 LOCAL_MODULE_CLASS := STATIC_LIBRARIES
41 intermediates := $(call local-generated-sources-dir)
42 LOCAL_GENERATED_SOURCES := $(addprefix $(intermediates)/, $(AMD_GENERATED_FILES))
43
44 SID_TABLES := $(LOCAL_PATH)/common/sid_tables.py
45
46 SID_TABLES_INPUTS := \
47 $(LOCAL_PATH)/common/sid.h \
48 $(LOCAL_PATH)/registers/amdgfxregs.json \
49 $(LOCAL_PATH)/registers/pkt3.json \
50 $(LOCAL_PATH)/registers/gfx10.json \
51 $(LOCAL_PATH)/registers/gfx10-rsrc.json
52
53 $(intermediates)/common/sid_tables.h: $(SID_TABLES) $(SID_TABLES_INPUTS)
54 @mkdir -p $(dir $@)
55 @echo "Gen Header: $(PRIVATE_MODULE) <= $(notdir $(@))"
56 $(hide) $(MESA_PYTHON2) $(SID_TABLES) $(SID_TABLES_INPUTS) > $@ || ($(RM) $@; false)
57
58 AMDGFXREGS := $(LOCAL_PATH)/registers/makeregheader.py
59
60 AMDGFXREGS_INPUTS := \
61 $(LOCAL_PATH)/registers/amdgfxregs.json \
62 $(LOCAL_PATH)/registers/pkt3.json \
63 $(LOCAL_PATH)/registers/gfx10.json \
64 $(LOCAL_PATH)/registers/gfx10-rsrc.json
65
66 $(intermediates)/common/amdgfxregs.h: $(AMDGFXREGS) $(AMDGFXREGS_INPUTS)
67 @mkdir -p $(dir $@)
68 @echo "Gen Header: $(PRIVATE_MODULE) <= $(notdir $(@))"
69 $(hide) $(MESA_PYTHON2) $(AMDGFXREGS) $(AMDGFXREGS_INPUTS) --sort address --guard AMDGFXREGS_H > $@ || ($(RM) $@; false)
70
71 LOCAL_C_INCLUDES := \
72 $(MESA_TOP)/include \
73 $(MESA_TOP)/src \
74 $(MESA_TOP)/src/amd/common \
75 $(MESA_TOP)/src/compiler \
76 $(call generated-sources-dir-for,STATIC_LIBRARIES,libmesa_nir,,)/nir \
77 $(MESA_TOP)/src/gallium/include \
78 $(MESA_TOP)/src/gallium/auxiliary \
79 $(MESA_TOP)/src/mesa \
80 $(intermediates)/common
81
82 LOCAL_EXPORT_C_INCLUDE_DIRS := \
83 $(LOCAL_PATH)/common \
84 $(intermediates)/common
85
86 LOCAL_SHARED_LIBRARIES := \
87 libdrm_amdgpu
88
89 LOCAL_STATIC_LIBRARIES := \
90 libmesa_nir
91
92 LOCAL_WHOLE_STATIC_LIBRARIES := \
93 libelf
94
95 $(call mesa-build-with-llvm)
96
97 include $(MESA_COMMON_MK)
98 include $(BUILD_STATIC_LIBRARY)