<div dir="ltr"><div dir="ltr">Hi,<div>for this 3rd patch I'm in contact with John Stultz</div><div><br></div><div>Could you please give me both some advice on how to perform Merge Request (newbie)</div><div><br></div><div>I have pushed an android_aco branch in my gitlab repo with account issor.oruam (same used in mesa)</div><div>but I'm not able to perform Merge Request/Compare branches between source issor.oruam/mesa branch android_aco</div><div>and the mesa/mesa branch master</div><div><br></div><div>Is it mandatory that I push to a mesa/mesa branch android_aco to be able to perform MR/Compare to master?<br></div><div>Thanks for the info/help</div><div><br></div><div>Mauro</div></div><br><div class="gmail_quote"><div dir="ltr" class="gmail_attr">On Sun, Sep 22, 2019 at 12:00 PM Mauro Rossi <<a href="mailto:issor.oruam@gmail.com">issor.oruam@gmail.com</a>> wrote:<br></div><blockquote class="gmail_quote" style="margin:0px 0px 0px 0.8ex;border-left:1px solid rgb(204,204,204);padding-left:1ex">Android building rules are added in src/amd/<a href="http://Android.compiler.mk" rel="noreferrer" target="_blank">Android.compiler.mk</a><br>
libmesa_aco static library is built conditionally to radeonsi<br>
as done for vulkan.radv module<br>
<br>
This will prevent Android build errors for non x86 systems<br>
<br>
filter-out compiler/aco_instruction_selection_setup.cpp source,<br>
as already included by compiler/aco_instruction_selection.cpp<br>
and would cause several multiple definition linker errors<br>
<br>
NOTE: libLLVM requires AMDGPU Disassembler to build radv with aco<br>
<br>
Fixes: 93c8ebf ("aco: Initial commit of independent AMD compiler")<br>
Fixes: a70a998 ("radv/aco: Setup alternate path in RADV to support the experimental ACO compiler")<br>
Signed-off-by: Mauro Rossi <<a href="mailto:issor.oruam@gmail.com" target="_blank">issor.oruam@gmail.com</a>><br>
---<br>
 src/amd/<a href="http://Android.compiler.mk" rel="noreferrer" target="_blank">Android.compiler.mk</a> | 93 +++++++++++++++++++++++++++++++++++++<br>
 src/amd/Android.mk          |  1 +<br>
 src/amd/Makefile.sources    | 32 +++++++++++++<br>
 src/amd/vulkan/Android.mk   |  4 +-<br>
 4 files changed, 129 insertions(+), 1 deletion(-)<br>
 create mode 100644 src/amd/<a href="http://Android.compiler.mk" rel="noreferrer" target="_blank">Android.compiler.mk</a><br>
<br>
diff --git a/src/amd/<a href="http://Android.compiler.mk" rel="noreferrer" target="_blank">Android.compiler.mk</a> b/src/amd/<a href="http://Android.compiler.mk" rel="noreferrer" target="_blank">Android.compiler.mk</a><br>
new file mode 100644<br>
index 0000000000..a62c93d9d3<br>
--- /dev/null<br>
+++ b/src/amd/<a href="http://Android.compiler.mk" rel="noreferrer" target="_blank">Android.compiler.mk</a><br>
@@ -0,0 +1,93 @@<br>
+# Copyright © 2018 Valve Corporation<br>
+# Copyright © 2019 Mauro Rossi <a href="mailto:issor.oruam@gmail.com" target="_blank">issor.oruam@gmail.com</a><br>
+<br>
+# Permission is hereby granted, free of charge, to any person obtaining a<br>
+# copy of this software and associated documentation files (the "Software"),<br>
+# to deal in the Software without restriction, including without limitation<br>
+# the rights to use, copy, modify, merge, publish, distribute, sublicense,<br>
+# and/or sell copies of the Software, and to permit persons to whom the<br>
+# Software is furnished to do so, subject to the following conditions:<br>
+#<br>
+# The above copyright notice and this permission notice (including the next<br>
+# paragraph) shall be included in all copies or substantial portions of the<br>
+# Software.<br>
+#<br>
+# THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR<br>
+# IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,<br>
+# FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT.  IN NO EVENT SHALL<br>
+# THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER<br>
+# LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING<br>
+# FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS<br>
+# IN THE SOFTWARE.<br>
+<br>
+LOCAL_PATH := $(call my-dir)<br>
+<br>
+include $(LOCAL_PATH)/Makefile.sources<br>
+<br>
+# ---------------------------------------<br>
+# Build libmesa_aco<br>
+# ---------------------------------------<br>
+<br>
+include $(CLEAR_VARS)<br>
+<br>
+LOCAL_MODULE := libmesa_aco<br>
+<br>
+# filter-out compiler/aco_instruction_selection_setup.cpp because<br>
+# it's already included by compiler/aco_instruction_selection.cpp<br>
+LOCAL_SRC_FILES := \<br>
+       $(filter-out compiler/aco_instruction_selection_setup.cpp, $(ACO_FILES))<br>
+<br>
+LOCAL_CFLAGS += -DFORCE_BUILD_AMDGPU   # instructs LLVM to declare LLVMInitializeAMDGPU* functions<br>
+<br>
+LOCAL_CPPFLAGS += -Wall -std=c++14<br>
+<br>
+# generate sources<br>
+LOCAL_MODULE_CLASS := STATIC_LIBRARIES<br>
+intermediates := $(call local-generated-sources-dir)<br>
+LOCAL_GENERATED_SOURCES += $(addprefix $(intermediates)/, $(ACO_GENERATED_FILES))<br>
+<br>
+ACO_OPCODES_H_SCRIPT := $(MESA_TOP)/src/amd/compiler/aco_opcodes_h.py<br>
+ACO_OPCODES_CPP_SCRIPT := $(MESA_TOP)/src/amd/compiler/aco_opcodes_cpp.py<br>
+ACO_BUILDER_H_SCRIPT := $(MESA_TOP)/src/amd/compiler/aco_builder_h.py<br>
+<br>
+ACO_DEPS := $(MESA_TOP)/src/amd/compiler/aco_opcodes.py<br>
+<br>
+$(intermediates)/compiler/aco_opcodes.h: $(ACO_OPCODES_H_SCRIPT) $(ACO_DEPS)<br>
+       @mkdir -p $(dir $@)<br>
+       @echo "Gen Header: $(PRIVATE_MODULE) <= $(notdir $(@))"<br>
+       $(hide) $(MESA_PYTHON2) $(ACO_OPCODES_H_SCRIPT) > $@ || ($(RM) $@; false)<br>
+<br>
+$(intermediates)/compiler/aco_opcodes.cpp: $(ACO_OPCODES_CPP_SCRIPT) $(ACO_DEPS)<br>
+       @mkdir -p $(dir $@)<br>
+       @echo "Gen Header: $(PRIVATE_MODULE) <= $(notdir $(@))"<br>
+       $(hide) $(MESA_PYTHON2) $(ACO_OPCODES_CPP_SCRIPT) > $@ || ($(RM) $@; false)<br>
+<br>
+$(intermediates)/compiler/aco_builder.h: $(ACO_BUILDER_H_SCRIPT) $(ACO_DEPS)<br>
+       @mkdir -p $(dir $@)<br>
+       @echo "Gen Header: $(PRIVATE_MODULE) <= $(notdir $(@))"<br>
+       $(hide) $(MESA_PYTHON2) $(ACO_BUILDER_H_SCRIPT) > $@ || ($(RM) $@; false)<br>
+<br>
+LOCAL_C_INCLUDES := \<br>
+       $(MESA_TOP)/src/amd \<br>
+       $(MESA_TOP)/src/amd/common \<br>
+       $(MESA_TOP)/src/amd/compiler \<br>
+       $(MESA_TOP)/src/compiler/nir \<br>
+       $(MESA_TOP)/src/mapi \<br>
+       $(MESA_TOP)/src/mesa \<br>
+       $(intermediates)/compiler<br>
+<br>
+LOCAL_EXPORT_C_INCLUDE_DIRS := \<br>
+       $(MESA_TOP)/src/amd/compiler \<br>
+       $(intermediates)/compiler<br>
+<br>
+LOCAL_SHARED_LIBRARIES := \<br>
+       libdrm_amdgpu<br>
+<br>
+LOCAL_STATIC_LIBRARIES := \<br>
+       libmesa_amd_common \<br>
+       libmesa_nir<br>
+<br>
+$(call mesa-build-with-llvm)<br>
+<br>
+include $(MESA_COMMON_MK)<br>
+include $(BUILD_STATIC_LIBRARY)<br>
diff --git a/src/amd/Android.mk b/src/amd/Android.mk<br>
index e40e7da01b..c9dbeafde1 100644<br>
--- a/src/amd/Android.mk<br>
+++ b/src/amd/Android.mk<br>
@@ -28,5 +28,6 @@ include $(LOCAL_PATH)/Makefile.sources<br>
 include $(LOCAL_PATH)/<a href="http://Android.addrlib.mk" rel="noreferrer" target="_blank">Android.addrlib.mk</a><br>
 include $(LOCAL_PATH)/<a href="http://Android.common.mk" rel="noreferrer" target="_blank">Android.common.mk</a><br>
 ifneq ($(filter radeonsi,$(BOARD_GPU_DRIVERS)),)<br>
+include $(LOCAL_PATH)/<a href="http://Android.compiler.mk" rel="noreferrer" target="_blank">Android.compiler.mk</a><br>
 include $(LOCAL_PATH)/vulkan/Android.mk<br>
 endif<br>
diff --git a/src/amd/Makefile.sources b/src/amd/Makefile.sources<br>
index 8ebcd8803d..22f71bf175 100644<br>
--- a/src/amd/Makefile.sources<br>
+++ b/src/amd/Makefile.sources<br>
@@ -71,3 +71,35 @@ AMD_DEBUG_FILES = \<br>
 AMD_GENERATED_FILES = \<br>
        common/amdgfxregs.h \<br>
        common/sid_tables.h<br>
+<br>
+ACO_FILES = \<br>
+       compiler/aco_dead_code_analysis.cpp \<br>
+       compiler/aco_dominance.cpp \<br>
+       compiler/aco_instruction_selection.cpp \<br>
+       compiler/aco_instruction_selection_setup.cpp \<br>
+       compiler/aco_interface.cpp \<br>
+       compiler/aco_interface.h \<br>
+       compiler/aco_ir.h \<br>
+       compiler/aco_assembler.cpp \<br>
+       compiler/aco_insert_exec_mask.cpp \<br>
+       compiler/aco_insert_NOPs.cpp \<br>
+       compiler/aco_insert_waitcnt.cpp \<br>
+       compiler/aco_reduce_assign.cpp \<br>
+       compiler/aco_register_allocation.cpp \<br>
+       compiler/aco_live_var_analysis.cpp \<br>
+       compiler/aco_lower_bool_phis.cpp \<br>
+       compiler/aco_lower_to_hw_instr.cpp \<br>
+       compiler/aco_optimizer.cpp \<br>
+       compiler/aco_opt_value_numbering.cpp \<br>
+       compiler/aco_print_asm.cpp \<br>
+       compiler/aco_print_ir.cpp \<br>
+       compiler/aco_scheduler.cpp \<br>
+       compiler/aco_ssa_elimination.cpp \<br>
+       compiler/aco_spill.cpp \<br>
+       compiler/aco_util.h \<br>
+       compiler/aco_validate.cpp<br>
+<br>
+ACO_GENERATED_FILES = \<br>
+       compiler/aco_builder.h \<br>
+       compiler/aco_opcodes.cpp \<br>
+       compiler/aco_opcodes.h<br>
diff --git a/src/amd/vulkan/Android.mk b/src/amd/vulkan/Android.mk<br>
index d0002b8aac..f01e10f900 100644<br>
--- a/src/amd/vulkan/Android.mk<br>
+++ b/src/amd/vulkan/Android.mk<br>
@@ -67,6 +67,7 @@ $(call mesa-build-with-llvm)<br>
 LOCAL_C_INCLUDES := $(RADV_COMMON_INCLUDES)<br>
<br>
 LOCAL_STATIC_LIBRARIES := \<br>
+       libmesa_aco \<br>
        libmesa_amd_common \<br>
        libmesa_nir \<br>
        libmesa_util \<br>
@@ -167,7 +168,8 @@ LOCAL_WHOLE_STATIC_LIBRARIES := \<br>
        libmesa_amdgpu_addrlib \<br>
        libmesa_amd_common \<br>
        libmesa_radv_common \<br>
-       libmesa_vulkan_util<br>
+       libmesa_vulkan_util \<br>
+       libmesa_aco<br>
<br>
 LOCAL_SHARED_LIBRARIES += $(RADV_SHARED_LIBRARIES) libz libsync liblog<br>
<br>
-- <br>
2.20.1<br>
<br>
</blockquote></div></div>