-
Notifications
You must be signed in to change notification settings - Fork 126
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Arm port #1009
Draft
XapaJIaMnu
wants to merge
5
commits into
master
Choose a base branch
from
armport
base: master
Could not load branches
Branch not found: {{ refName }}
Loading
Could not load tags
Nothing to show
Loading
Are you sure you want to change the base?
Some commits from the old base branch may be removed from the timeline,
and old review comments may become outdated.
Draft
Arm port #1009
Changes from all commits
Commits
Show all changes
5 commits
Select commit
Hold shift + click to select a range
File filter
Filter by extension
Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,142 @@ | ||
# Modified from https://github.com/axr/solar-cmake/blob/73cfea0db0284c5e2010aca23989046e5bda95c9/Solar.cmake | ||
# Based on the Qt 5 processor detection code, so should be very accurate | ||
# https://qt.gitorious.org/qt/qtbase/blobs/master/src/corelib/global/qprocessordetection.h | ||
# Currently handles arm (v5, v6, v7), x86 (32/64), ia64, and ppc (32/64) | ||
|
||
# Regarding POWER/PowerPC, just as is noted in the Qt source, | ||
# "There are many more known variants/revisions that we do not handle/detect." | ||
|
||
set(archdetect_c_code " | ||
#if defined(__arm__) || defined(__TARGET_ARCH_ARM) || defined(_M_ARM) || defined(_M_ARM64) || defined(__aarch64__) || defined(__ARM64__) | ||
#if defined(__ARM_ARCH_8__) || defined(__ARM_ARCH_8) \\ | ||
|| defined(__ARM_ARCH_8A__) || defined(__ARM_ARCH_8A) \\ | ||
|| defined(__ARM_ARCH_8R__) || defined(__ARM_ARCH_8R) \\ | ||
|| defined(__ARM_ARCH_8M__) || defined(__ARM_ARCH_8M) \\ | ||
|| (defined(__TARGET_ARCH_ARM) && __TARGET_ARCH_ARM-0 >= 8) | ||
#error cmake_ARCH armv8 | ||
#elif defined(__ARM_ARCH_7__) \\ | ||
|| defined(__ARM_ARCH_7A__) \\ | ||
|| defined(__ARM_ARCH_7R__) \\ | ||
|| defined(__ARM_ARCH_7M__) \\ | ||
|| (defined(__TARGET_ARCH_ARM) && __TARGET_ARCH_ARM-0 >= 7) | ||
#error cmake_ARCH armv7 | ||
#elif defined(__ARM_ARCH_6__) \\ | ||
|| defined(__ARM_ARCH_6J__) \\ | ||
|| defined(__ARM_ARCH_6T2__) \\ | ||
|| defined(__ARM_ARCH_6Z__) \\ | ||
|| defined(__ARM_ARCH_6K__) \\ | ||
|| defined(__ARM_ARCH_6ZK__) \\ | ||
|| defined(__ARM_ARCH_6M__) \\ | ||
|| (defined(__TARGET_ARCH_ARM) && __TARGET_ARCH_ARM-0 >= 6) | ||
#error cmake_ARCH armv6 | ||
#elif defined(__ARM_ARCH_5TEJ__) \\ | ||
|| (defined(__TARGET_ARCH_ARM) && __TARGET_ARCH_ARM-0 >= 5) | ||
#error cmake_ARCH armv5 | ||
#else | ||
#error cmake_ARCH arm | ||
#endif | ||
#elif defined(__i386) || defined(__i386__) || defined(_M_IX86) | ||
#error cmake_ARCH i386 | ||
#elif defined(__x86_64) || defined(__x86_64__) || defined(__amd64) || defined(_M_X64) | ||
#error cmake_ARCH x86_64 | ||
#elif defined(__ia64) || defined(__ia64__) || defined(_M_IA64) | ||
#error cmake_ARCH ia64 | ||
#elif defined(__ppc__) || defined(__ppc) || defined(__powerpc__) \\ | ||
|| defined(_ARCH_COM) || defined(_ARCH_PWR) || defined(_ARCH_PPC) \\ | ||
|| defined(_M_MPPC) || defined(_M_PPC) | ||
#if defined(__ppc64__) || defined(__powerpc64__) || defined(__64BIT__) | ||
#error cmake_ARCH ppc64 | ||
#else | ||
#error cmake_ARCH ppc | ||
#endif | ||
#endif | ||
|
||
#error cmake_ARCH unknown | ||
") | ||
|
||
|
||
# Set ppc_support to TRUE before including this file or ppc and ppc64 | ||
# will be treated as invalid architectures since they are no longer supported by Apple | ||
|
||
function(target_architecture output_var) | ||
if(APPLE AND CMAKE_OSX_ARCHITECTURES) | ||
# On OS X we use CMAKE_OSX_ARCHITECTURES *if* it was set | ||
# First let's normalize the order of the values | ||
|
||
# Note that it's not possible to compile PowerPC applications if you are using | ||
# the OS X SDK version 10.6 or later - you'll need 10.4/10.5 for that, so we | ||
# disable it by default | ||
# See this page for more information: | ||
# http://stackoverflow.com/questions/5333490/how-can-we-restore-ppc-ppc64-as-well-as-full-10-4-10-5-sdk-support-to-xcode-4 | ||
|
||
# Architecture defaults to i386 or ppc on OS X 10.5 and earlier, depending on the CPU type detected at runtime. | ||
# On OS X 10.6+ the default is x86_64 if the CPU supports it, i386 otherwise. | ||
|
||
foreach(osx_arch ${CMAKE_OSX_ARCHITECTURES}) | ||
if("${osx_arch}" STREQUAL "ppc" AND ppc_support) | ||
set(osx_arch_ppc TRUE) | ||
elseif("${osx_arch}" STREQUAL "i386") | ||
set(osx_arch_i386 TRUE) | ||
elseif("${osx_arch}" STREQUAL "x86_64") | ||
set(osx_arch_x86_64 TRUE) | ||
elseif("${osx_arch}" STREQUAL "ppc64" AND ppc_support) | ||
set(osx_arch_ppc64 TRUE) | ||
else() | ||
message(FATAL_ERROR "Invalid OS X arch name: ${osx_arch}") | ||
endif() | ||
endforeach() | ||
|
||
# Now add all the architectures in our normalized order | ||
if(osx_arch_ppc) | ||
list(APPEND ARCH ppc) | ||
endif() | ||
|
||
if(osx_arch_i386) | ||
list(APPEND ARCH i386) | ||
endif() | ||
|
||
if(osx_arch_x86_64) | ||
list(APPEND ARCH x86_64) | ||
endif() | ||
|
||
if(osx_arch_ppc64) | ||
list(APPEND ARCH ppc64) | ||
endif() | ||
else() | ||
file(WRITE "${CMAKE_BINARY_DIR}/arch.c" "${archdetect_c_code}") | ||
|
||
enable_language(C) | ||
|
||
# Detect the architecture in a rather creative way... | ||
# This compiles a small C program which is a series of ifdefs that selects a | ||
# particular #error preprocessor directive whose message string contains the | ||
# target architecture. The program will always fail to compile (both because | ||
# file is not a valid C program, and obviously because of the presence of the | ||
# #error preprocessor directives... but by exploiting the preprocessor in this | ||
# way, we can detect the correct target architecture even when cross-compiling, | ||
# since the program itself never needs to be run (only the compiler/preprocessor) | ||
try_run( | ||
run_result_unused | ||
compile_result_unused | ||
"${CMAKE_BINARY_DIR}" | ||
"${CMAKE_BINARY_DIR}/arch.c" | ||
COMPILE_OUTPUT_VARIABLE ARCH | ||
CMAKE_FLAGS CMAKE_OSX_ARCHITECTURES=${CMAKE_OSX_ARCHITECTURES} | ||
) | ||
|
||
# Parse the architecture name from the compiler output | ||
string(REGEX MATCH "cmake_ARCH ([a-zA-Z0-9_]+)" ARCH "${ARCH}") | ||
|
||
# Get rid of the value marker leaving just the architecture name | ||
string(REPLACE "cmake_ARCH " "" ARCH "${ARCH}") | ||
|
||
# If we are compiling with an unknown architecture this variable should | ||
# already be set to "unknown" but in the case that it's empty (i.e. due | ||
# to a typo in the code), then set it to unknown | ||
if (NOT ARCH) | ||
set(ARCH unknown) | ||
endif() | ||
endif() | ||
|
||
set(${output_var} "${ARCH}" PARENT_SCOPE) | ||
endfunction() |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
|
@@ -19,6 +19,10 @@ | |
|
||
using namespace faiss; | ||
|
||
#ifdef ARM | ||
#include "3rd_party/simd_utils/simd_utils.h" | ||
#endif | ||
|
||
|
||
extern "C" { | ||
|
||
|
Submodule simd_utils
added at
696036
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Oops, something went wrong.
Oops, something went wrong.
Add this suggestion to a batch that can be applied as a single commit.
This suggestion is invalid because no changes were made to the code.
Suggestions cannot be applied while the pull request is closed.
Suggestions cannot be applied while viewing a subset of changes.
Only one suggestion per line can be applied in a batch.
Add this suggestion to a batch that can be applied as a single commit.
Applying suggestions on deleted lines is not supported.
You must change the existing code in this line in order to create a valid suggestion.
Outdated suggestions cannot be applied.
This suggestion has been applied or marked resolved.
Suggestions cannot be applied from pending reviews.
Suggestions cannot be applied on multi-line comments.
Suggestions cannot be applied while the pull request is queued to merge.
Suggestion cannot be applied right now. Please check back later.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
TODO. This file needs to be removed and detecting ARM needs to be done in a different way. The variables that this file sets break the double M1/x86_64 compilation that is supposed to be done on modern OSX.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
what are the offending variables in this file?