android: aco: add support for libmesa_aco
authorMauro Rossi <issor.oruam@gmail.com>
Sat, 21 Sep 2019 15:58:52 +0000 (17:58 +0200)
committerMauro Rossi <issor.oruam@gmail.com>
Sat, 28 Sep 2019 13:56:34 +0000 (15:56 +0200)
Android building rules are added in src/amd/Android.compiler.mk
libmesa_aco static library is built conditionally to radeonsi
as done for vulkan.radv module

This will prevent Android build errors for non x86 systems

filter-out compiler/aco_instruction_selection_setup.cpp source,
as already included by compiler/aco_instruction_selection.cpp
and would cause several multiple definition linker errors

NOTE: libLLVM requires AMDGPU Disassembler to build radv with aco

Fixes: 93c8ebf ("aco: Initial commit of independent AMD compiler")
Fixes: a70a998 ("radv/aco: Setup alternate path in RADV to support the experimental ACO compiler")
Signed-off-by: Mauro Rossi <issor.oruam@gmail.com>
src/amd/Android.compiler.mk [new file with mode: 0644]
src/amd/Android.mk
src/amd/Makefile.sources
src/amd/vulkan/Android.mk

diff --git a/src/amd/Android.compiler.mk b/src/amd/Android.compiler.mk
new file mode 100644 (file)
index 0000000..a62c93d
--- /dev/null
@@ -0,0 +1,93 @@
+# Copyright © 2018 Valve Corporation
+# Copyright © 2019 Mauro Rossi issor.oruam@gmail.com
+
+# Permission is hereby granted, free of charge, to any person obtaining a
+# copy of this software and associated documentation files (the "Software"),
+# to deal in the Software without restriction, including without limitation
+# the rights to use, copy, modify, merge, publish, distribute, sublicense,
+# and/or sell copies of the Software, and to permit persons to whom the
+# Software is furnished to do so, subject to the following conditions:
+#
+# The above copyright notice and this permission notice (including the next
+# paragraph) shall be included in all copies or substantial portions of the
+# Software.
+#
+# THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
+# IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
+# FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT.  IN NO EVENT SHALL
+# THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
+# LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING
+# FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS
+# IN THE SOFTWARE.
+
+LOCAL_PATH := $(call my-dir)
+
+include $(LOCAL_PATH)/Makefile.sources
+
+# ---------------------------------------
+# Build libmesa_aco
+# ---------------------------------------
+
+include $(CLEAR_VARS)
+
+LOCAL_MODULE := libmesa_aco
+
+# filter-out compiler/aco_instruction_selection_setup.cpp because
+# it's already included by compiler/aco_instruction_selection.cpp
+LOCAL_SRC_FILES := \
+       $(filter-out compiler/aco_instruction_selection_setup.cpp, $(ACO_FILES))
+
+LOCAL_CFLAGS += -DFORCE_BUILD_AMDGPU   # instructs LLVM to declare LLVMInitializeAMDGPU* functions
+
+LOCAL_CPPFLAGS += -Wall -std=c++14
+
+# generate sources
+LOCAL_MODULE_CLASS := STATIC_LIBRARIES
+intermediates := $(call local-generated-sources-dir)
+LOCAL_GENERATED_SOURCES += $(addprefix $(intermediates)/, $(ACO_GENERATED_FILES))
+
+ACO_OPCODES_H_SCRIPT := $(MESA_TOP)/src/amd/compiler/aco_opcodes_h.py
+ACO_OPCODES_CPP_SCRIPT := $(MESA_TOP)/src/amd/compiler/aco_opcodes_cpp.py
+ACO_BUILDER_H_SCRIPT := $(MESA_TOP)/src/amd/compiler/aco_builder_h.py
+
+ACO_DEPS := $(MESA_TOP)/src/amd/compiler/aco_opcodes.py
+
+$(intermediates)/compiler/aco_opcodes.h: $(ACO_OPCODES_H_SCRIPT) $(ACO_DEPS)
+       @mkdir -p $(dir $@)
+       @echo "Gen Header: $(PRIVATE_MODULE) <= $(notdir $(@))"
+       $(hide) $(MESA_PYTHON2) $(ACO_OPCODES_H_SCRIPT) > $@ || ($(RM) $@; false)
+
+$(intermediates)/compiler/aco_opcodes.cpp: $(ACO_OPCODES_CPP_SCRIPT) $(ACO_DEPS)
+       @mkdir -p $(dir $@)
+       @echo "Gen Header: $(PRIVATE_MODULE) <= $(notdir $(@))"
+       $(hide) $(MESA_PYTHON2) $(ACO_OPCODES_CPP_SCRIPT) > $@ || ($(RM) $@; false)
+
+$(intermediates)/compiler/aco_builder.h: $(ACO_BUILDER_H_SCRIPT) $(ACO_DEPS)
+       @mkdir -p $(dir $@)
+       @echo "Gen Header: $(PRIVATE_MODULE) <= $(notdir $(@))"
+       $(hide) $(MESA_PYTHON2) $(ACO_BUILDER_H_SCRIPT) > $@ || ($(RM) $@; false)
+
+LOCAL_C_INCLUDES := \
+       $(MESA_TOP)/src/amd \
+       $(MESA_TOP)/src/amd/common \
+       $(MESA_TOP)/src/amd/compiler \
+       $(MESA_TOP)/src/compiler/nir \
+       $(MESA_TOP)/src/mapi \
+       $(MESA_TOP)/src/mesa \
+       $(intermediates)/compiler
+
+LOCAL_EXPORT_C_INCLUDE_DIRS := \
+       $(MESA_TOP)/src/amd/compiler \
+       $(intermediates)/compiler
+
+LOCAL_SHARED_LIBRARIES := \
+       libdrm_amdgpu
+
+LOCAL_STATIC_LIBRARIES := \
+       libmesa_amd_common \
+       libmesa_nir
+
+$(call mesa-build-with-llvm)
+
+include $(MESA_COMMON_MK)
+include $(BUILD_STATIC_LIBRARY)
index e40e7da01bdef078b97a66e41da0950f22c8d877..c9dbeafde10fce532b039931113053efc1950085 100644 (file)
@@ -28,5 +28,6 @@ include $(LOCAL_PATH)/Makefile.sources
 include $(LOCAL_PATH)/Android.addrlib.mk
 include $(LOCAL_PATH)/Android.common.mk
 ifneq ($(filter radeonsi,$(BOARD_GPU_DRIVERS)),)
+include $(LOCAL_PATH)/Android.compiler.mk
 include $(LOCAL_PATH)/vulkan/Android.mk
 endif
index 8ebcd8803d693038ba9e3e505b742b8cdd4fa184..22f71bf17581c1cbcce722d9b18f806ae6220d68 100644 (file)
@@ -71,3 +71,35 @@ AMD_DEBUG_FILES = \
 AMD_GENERATED_FILES = \
        common/amdgfxregs.h \
        common/sid_tables.h
+
+ACO_FILES = \
+       compiler/aco_dead_code_analysis.cpp \
+       compiler/aco_dominance.cpp \
+       compiler/aco_instruction_selection.cpp \
+       compiler/aco_instruction_selection_setup.cpp \
+       compiler/aco_interface.cpp \
+       compiler/aco_interface.h \
+       compiler/aco_ir.h \
+       compiler/aco_assembler.cpp \
+       compiler/aco_insert_exec_mask.cpp \
+       compiler/aco_insert_NOPs.cpp \
+       compiler/aco_insert_waitcnt.cpp \
+       compiler/aco_reduce_assign.cpp \
+       compiler/aco_register_allocation.cpp \
+       compiler/aco_live_var_analysis.cpp \
+       compiler/aco_lower_bool_phis.cpp \
+       compiler/aco_lower_to_hw_instr.cpp \
+       compiler/aco_optimizer.cpp \
+       compiler/aco_opt_value_numbering.cpp \
+       compiler/aco_print_asm.cpp \
+       compiler/aco_print_ir.cpp \
+       compiler/aco_scheduler.cpp \
+       compiler/aco_ssa_elimination.cpp \
+       compiler/aco_spill.cpp \
+       compiler/aco_util.h \
+       compiler/aco_validate.cpp
+
+ACO_GENERATED_FILES = \
+       compiler/aco_builder.h \
+       compiler/aco_opcodes.cpp \
+       compiler/aco_opcodes.h
index d0002b8aac51ed5290903c7208a6346ca127ddcd..f01e10f90035bc9007263984640c80fcadafd382 100644 (file)
@@ -67,6 +67,7 @@ $(call mesa-build-with-llvm)
 LOCAL_C_INCLUDES := $(RADV_COMMON_INCLUDES)
 
 LOCAL_STATIC_LIBRARIES := \
+       libmesa_aco \
        libmesa_amd_common \
        libmesa_nir \
        libmesa_util \
@@ -167,7 +168,8 @@ LOCAL_WHOLE_STATIC_LIBRARIES := \
        libmesa_amdgpu_addrlib \
        libmesa_amd_common \
        libmesa_radv_common \
-       libmesa_vulkan_util
+       libmesa_vulkan_util \
+       libmesa_aco
 
 LOCAL_SHARED_LIBRARIES += $(RADV_SHARED_LIBRARIES) libz libsync liblog