Merge pull request #83 from CyanoHao/aarch64-support

Handle non-x86 64-bit targets
This commit is contained in:
Roy Qu 2022-12-11 22:37:39 +08:00 committed by GitHub
commit 800d4c9e07
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
2 changed files with 51 additions and 6 deletions

View File

@ -27,6 +27,7 @@
#include <QScreen>
#include <QDesktopWidget>
#include <QHash>
#include <iterator>
#ifdef Q_OS_LINUX
#include <sys/sysinfo.h>
#endif
@ -2072,12 +2073,10 @@ void Settings::CompilerSet::setProperties(const QString &binDir, const QString&
int delimPos2 = delimPos1;
while (delimPos2<output.length() && !isNonPrintableAsciiChar(output[delimPos2]))
delimPos2++;
mTarget = output.mid(delimPos1,delimPos2-delimPos1);
QString triplet = output.mid(delimPos1,delimPos2-delimPos1);
if (mTarget.contains("x86_64"))
mTarget = "x86_64";
else
mTarget = "i686";
int tripletDelimPos1 = triplet.indexOf('-');
mTarget = triplet.mid(0, tripletDelimPos1);
//Find version number
targetStr = "clang version ";
@ -2660,7 +2659,7 @@ bool Settings::CompilerSets::addSets(const QString &folder, const QString& cc_pr
return false;
QString baseName = baseSet->name();
QString platformName;
if (baseSet->target() == "x86_64") {
if (isTarget64Bit(baseSet->target())) {
if (baseName.startsWith("TDM-GCC ")) {
PCompilerSet set= addSet(baseSet);
platformName = "32-bit";
@ -3146,6 +3145,51 @@ QString Settings::CompilerSets::getKeyFromCompilerCompatibleIndex(int idx) const
return mCompilerCompatibleIndex[idx];
}
bool Settings::CompilerSets::isTarget64Bit(const QString &target)
{
static const auto generateSortedTargets = []() -> decltype(auto) {
/* Fetched from LLVM 15.0.6's arch parser,
* `Triple::ArchType parseArch(StringRef ArchName)`
* in `llvm/lib/Support/Triple.cpp`.
* The following non-CPU targets are not included:
* nvptx64, le64, amdil64, hsail64, spir64, spirv64, renderscript64.
*/
static QString targets[] = {
// x86_64
"amd64", "x86_64", "x86_64h",
// ppc64
"powerpc64", "ppu", "ppc64",
// ppc64le
"powerpc64le", "ppc64le",
// aarch64
"aarch64", "arm64", "arm64e",
// aarch64_be
"aarch64_be",
// aarch64_32
"aarch64_32", "arm64_32",
// mips64
"mips64", "mips64eb", "mipsn32", "mipsisa64r6", "mips64r6", "mipsn32r6",
// mips64el
"mips64el", "mipsn32el", "mipsisa64r6el", "mips64r6el", "mipsn32r6el",
// riscv64
"riscv64",
// systemz
"s390x", "systemz",
// sparcv9
"sparcv9", "sparc64",
// wasm64
"wasm64",
// loongarch64
"loongarch64",
};
std::sort(std::begin(targets), std::end(targets));
return (targets); // parentheses required for type deduction
};
static const auto &common64BitTargets = generateSortedTargets();
bool is64Bit = std::binary_search(std::begin(common64BitTargets), std::end(common64BitTargets), target);
return is64Bit;
}
Settings::Environment::Environment(Settings *settings):_Base(settings, SETTING_ENVIRONMENT)
{

View File

@ -1430,6 +1430,7 @@ public:
void loadPathList(const QString& name, QStringList& list);
PCompilerSet loadSet(int index);
void prepareCompatibleIndex();
static bool isTarget64Bit(const QString &target);
private:
CompilerSetList mList;
int mDefaultIndex;