llvmbot wrote:

<!--LLVM PR SUMMARY COMMENT-->

@llvm/pr-subscribers-clang-driver

Author: Pekka Jääskeläinen (pjaaskel)

<details>
<summary>Changes</summary>

OpenASIP (ex. TCE*) is a special target which has only a stub target definition 
in the LLVM side that has resided in LLVM for over 15 years. I'm the original 
contributors of this stub.

Due to needing various other patches to LLVM that were not nicely upstreamable, 
the upstream TCE target defs have long been unupdated. However, with the recent 
changes to the vectorization types etc. I managed to minimize the required LLVM 
TCE patch to this one and with this patch OpenASIP can be (finally!) used 
without a patched LLVM for VLIW/TTA customization. RISC-V operation set 
customization still requires a patch to polish and upstream (TBD).

This patch:

* Introduces a 64b variant of an OpenASIP target.
* Unifies the datalayouts of the different target variants to make it 
compatible with OpenASIP v2.2 and above.
* Updates the OpenCL address space IDs to be compatible with the latest PoCL 
backends.
* Implements Triple::computeDataLayout() for completeness.

The patch is very unintrusive and I'd love to backport it in the LLVM 22 
release as well.

[*] More info:
https://blog.llvm.org/2010/06/tce-project-co-design-of-application.html 
https://openasip.org

The actual backends for the customized processors are generated on the fly with 
a backend generator of the OpenASIP project based on a target definition file 
and loaded as plugins to the LLVM framework. This mechanism enables fast 
"design space exploration" of application-specific processors designed with the 
toolset as only a small part of the compiler has to be regenerated for new 
design candidates.

---
Full diff: https://github.com/llvm/llvm-project/pull/176698.diff


11 Files Affected:

- (modified) clang/lib/Basic/Targets.cpp (+3) 
- (modified) clang/lib/Basic/Targets/TCE.cpp (+12) 
- (modified) clang/lib/Basic/Targets/TCE.h (+50-9) 
- (modified) clang/lib/CodeGen/CodeGenModule.cpp (+1) 
- (modified) clang/lib/Driver/Driver.cpp (+4) 
- (modified) clang/lib/Driver/ToolChains/TCE.cpp (+6) 
- (modified) clang/lib/Driver/ToolChains/TCE.h (+7) 
- (modified) clang/test/CodeGen/target-data.c (+6-2) 
- (modified) llvm/include/llvm/TargetParser/Triple.h (+3-2) 
- (modified) llvm/lib/TargetParser/TargetDataLayout.cpp (+13) 
- (modified) llvm/lib/TargetParser/Triple.cpp (+10-1) 


``````````diff
diff --git a/clang/lib/Basic/Targets.cpp b/clang/lib/Basic/Targets.cpp
index 263253918d965..8b916e736c101 100644
--- a/clang/lib/Basic/Targets.cpp
+++ b/clang/lib/Basic/Targets.cpp
@@ -541,6 +541,9 @@ std::unique_ptr<TargetInfo> AllocateTarget(const 
llvm::Triple &Triple,
   case llvm::Triple::tcele:
     return std::make_unique<TCELETargetInfo>(Triple, Opts);
 
+  case llvm::Triple::tcele64:
+    return std::make_unique<TCELE64TargetInfo>(Triple, Opts);
+
   case llvm::Triple::x86:
     if (Triple.isOSDarwin())
       return std::make_unique<DarwinI386TargetInfo>(Triple, Opts);
diff --git a/clang/lib/Basic/Targets/TCE.cpp b/clang/lib/Basic/Targets/TCE.cpp
index 91194b568a09f..3a0bdffe2d166 100644
--- a/clang/lib/Basic/Targets/TCE.cpp
+++ b/clang/lib/Basic/Targets/TCE.cpp
@@ -24,6 +24,18 @@ void TCETargetInfo::getTargetDefines(const LangOptions &Opts,
   Builder.defineMacro("__TCE_V1__");
 }
 
+void TCELE64TargetInfo::getTargetDefines(const LangOptions &Opts,
+                                         MacroBuilder &Builder) const {
+  DefineStd(Builder, "tcele64", Opts);
+  Builder.defineMacro("__TCE__");
+  Builder.defineMacro("__TCE_V1__");
+  Builder.defineMacro("__TCELE__");
+  Builder.defineMacro("__TCELE_V1__");
+  Builder.defineMacro("__TCELE64__");
+  Builder.defineMacro("__TCELE64_V1__");
+  Builder.defineMacro("__TCE64__");
+}
+
 void TCELETargetInfo::getTargetDefines(const LangOptions &Opts,
                                        MacroBuilder &Builder) const {
   DefineStd(Builder, "tcele", Opts);
diff --git a/clang/lib/Basic/Targets/TCE.h b/clang/lib/Basic/Targets/TCE.h
index 161025378c471..8132aac67755c 100644
--- a/clang/lib/Basic/Targets/TCE.h
+++ b/clang/lib/Basic/Targets/TCE.h
@@ -31,9 +31,9 @@ namespace targets {
 
 static const unsigned TCEOpenCLAddrSpaceMap[] = {
     0, // Default
-    3, // opencl_global
-    4, // opencl_local
-    5, // opencl_constant
+    1, // opencl_global
+    3, // opencl_local
+    2, // opencl_constant
     0, // opencl_private
     1, // opencl_global_device
     1, // opencl_global_host
@@ -88,9 +88,11 @@ class LLVM_LIBRARY_VISIBILITY TCETargetInfo : public 
TargetInfo {
     LongDoubleFormat = &llvm::APFloat::IEEEsingle();
     resetDataLayout("E-p:32:32:32-i1:8:8-i8:8:32-"
                     "i16:16:32-i32:32:32-i64:32:32-"
-                    "f32:32:32-f64:32:32-v64:32:32-"
-                    "v128:32:32-v256:32:32-v512:32:32-"
-                    "v1024:32:32-a0:0:32-n32");
+                    "f16:16:16-f32:32:32-f64:32:32-v64:64:64-"
+                    "i128:128-"
+                    "v128:128:128-v256:256:256-v512:512:512-"
+                    "v1024:1024:1024-v2048:2048:2048-"
+                    "v4096:4096:4096-a0:0:32-n32");
     AddrSpaceMap = &TCEOpenCLAddrSpaceMap;
     UseAddrSpaceMapMangling = true;
   }
@@ -120,6 +122,9 @@ class LLVM_LIBRARY_VISIBILITY TCETargetInfo : public 
TargetInfo {
   ArrayRef<TargetInfo::GCCRegAlias> getGCCRegAliases() const override {
     return {};
   }
+
+  // TCE does not have fixed, but user specified register names.
+  bool isValidGCCRegisterName(StringRef Name) const override { return true; }
 };
 
 class LLVM_LIBRARY_VISIBILITY TCELETargetInfo : public TCETargetInfo {
@@ -130,14 +135,50 @@ class LLVM_LIBRARY_VISIBILITY TCELETargetInfo : public 
TCETargetInfo {
 
     resetDataLayout("e-p:32:32:32-i1:8:8-i8:8:32-"
                     "i16:16:32-i32:32:32-i64:32:32-"
-                    "f32:32:32-f64:32:32-v64:32:32-"
-                    "v128:32:32-v256:32:32-v512:32:32-"
-                    "v1024:32:32-a0:0:32-n32");
+                    "f16:16:16-f32:32:32-f64:32:32-v64:64:64-"
+                    "i128:128-"
+                    "v128:128:128-v256:256:256-v512:512:512-"
+                    "v1024:1024:1024-v2048:2048:2048-"
+                    "v4096:4096:4096-a0:0:32-n32");
+  }
+
+  void getTargetDefines(const LangOptions &Opts,
+                        MacroBuilder &Builder) const override;
+};
+
+class LLVM_LIBRARY_VISIBILITY TCELE64TargetInfo : public TCETargetInfo {
+public:
+  TCELE64TargetInfo(const llvm::Triple &Triple, const TargetOptions &Opts)
+      : TCETargetInfo(Triple, Opts) {
+    BigEndian = false;
+
+    resetDataLayout("e-p:64:64:64-i1:8:64-i8:8:64-"
+                    "i16:16:64-i32:32:64-i64:64:64-"
+                    "f16:16:64-f32:32:64-f64:64:64-v64:64:64-"
+                    "i128:128-"
+                    "v128:128:128-v256:256:256-v512:512:512-"
+                    "v1024:1024:1024-v2048:2048:2048-"
+                    "v4096:4096:4096-a0:0:64-n64");
+
+    LongWidth = LongLongWidth = 64;
+    PointerWidth = 64;
+    PointerAlign = 64;
+    LongAlign = LongLongAlign = 64;
+    IntPtrType = SignedLong;
+    SizeType = UnsignedLong;
+    PtrDiffType = SignedLong;
+    DoubleWidth = 64;
+    DoubleAlign = 64;
+    LongDoubleWidth = 64;
+    LongDoubleAlign = 64;
+    DoubleFormat = &llvm::APFloat::IEEEdouble();
+    LongDoubleFormat = &llvm::APFloat::IEEEdouble();
   }
 
   void getTargetDefines(const LangOptions &Opts,
                         MacroBuilder &Builder) const override;
 };
+
 } // namespace targets
 } // namespace clang
 #endif // LLVM_CLANG_LIB_BASIC_TARGETS_TCE_H
diff --git a/clang/lib/CodeGen/CodeGenModule.cpp 
b/clang/lib/CodeGen/CodeGenModule.cpp
index dc8a31b7f7f0d..69b9ee7d6c722 100644
--- a/clang/lib/CodeGen/CodeGenModule.cpp
+++ b/clang/lib/CodeGen/CodeGenModule.cpp
@@ -244,6 +244,7 @@ createTargetCodeGenInfo(CodeGenModule &CGM) {
 
   case llvm::Triple::tce:
   case llvm::Triple::tcele:
+  case llvm::Triple::tcele64:
     return createTCETargetCodeGenInfo(CGM);
 
   case llvm::Triple::x86: {
diff --git a/clang/lib/Driver/Driver.cpp b/clang/lib/Driver/Driver.cpp
index eb3f9cbea2845..ed7b201b5cbe8 100644
--- a/clang/lib/Driver/Driver.cpp
+++ b/clang/lib/Driver/Driver.cpp
@@ -6971,6 +6971,10 @@ const ToolChain &Driver::getToolChain(const ArgList 
&Args,
       case llvm::Triple::tcele:
         TC = std::make_unique<toolchains::TCELEToolChain>(*this, Target, Args);
         break;
+      case llvm::Triple::tcele64:
+        TC =
+            std::make_unique<toolchains::TCELE64ToolChain>(*this, Target, 
Args);
+        break;
       case llvm::Triple::hexagon:
         TC = std::make_unique<toolchains::HexagonToolChain>(*this, Target,
                                                              Args);
diff --git a/clang/lib/Driver/ToolChains/TCE.cpp 
b/clang/lib/Driver/ToolChains/TCE.cpp
index 14db69a8ff2c0..ea619f63eb870 100644
--- a/clang/lib/Driver/ToolChains/TCE.cpp
+++ b/clang/lib/Driver/ToolChains/TCE.cpp
@@ -44,4 +44,10 @@ TCELEToolChain::TCELEToolChain(const Driver &D, const 
llvm::Triple& Triple,
   : TCEToolChain(D, Triple, Args) {
 }
 
+TCELE64ToolChain::TCELE64ToolChain(const Driver &D, const llvm::Triple &Triple,
+                                   const ArgList &Args)
+    : TCEToolChain(D, Triple, Args) {}
+
+TCELE64ToolChain::~TCELE64ToolChain() {}
+
 TCELEToolChain::~TCELEToolChain() {}
diff --git a/clang/lib/Driver/ToolChains/TCE.h 
b/clang/lib/Driver/ToolChains/TCE.h
index 31a64cfe878a7..5a255ec68cba6 100644
--- a/clang/lib/Driver/ToolChains/TCE.h
+++ b/clang/lib/Driver/ToolChains/TCE.h
@@ -39,6 +39,13 @@ class LLVM_LIBRARY_VISIBILITY TCELEToolChain : public 
TCEToolChain {
   ~TCELEToolChain() override;
 };
 
+class LLVM_LIBRARY_VISIBILITY TCELE64ToolChain : public TCEToolChain {
+public:
+  TCELE64ToolChain(const Driver &D, const llvm::Triple &Triple,
+                   const llvm::opt::ArgList &Args);
+  ~TCELE64ToolChain() override;
+};
+
 } // end namespace toolchains
 } // end namespace driver
 } // end namespace clang
diff --git a/clang/test/CodeGen/target-data.c b/clang/test/CodeGen/target-data.c
index e95079490bd3c..a8bbcec2ee0c1 100644
--- a/clang/test/CodeGen/target-data.c
+++ b/clang/test/CodeGen/target-data.c
@@ -227,11 +227,15 @@
 
 // RUN: %clang_cc1 -triple tce-unknown -o - -emit-llvm %s | \
 // RUN: FileCheck %s -check-prefix=TCE
-// TCE: target datalayout = 
"E-p:32:32:32-i1:8:8-i8:8:32-i16:16:32-i32:32:32-i64:32:32-f32:32:32-f64:32:32-v64:32:32-v128:32:32-v256:32:32-v512:32:32-v1024:32:32-a0:0:32-n32"
+// TCE: target datalayout = 
"E-p:32:32:32-i1:8:8-i8:8:32-i16:16:32-i32:32:32-i64:32:32-f16:16:16-f32:32:32-f64:32:32-v64:64:64-i128:128-v128:128:128-v256:256:256-v512:512:512-v1024:1024:1024-v2048:2048:2048-v4096:4096:4096-a0:0:32-n32"
 
 // RUN: %clang_cc1 -triple tcele-unknown -o - -emit-llvm %s | \
 // RUN: FileCheck %s -check-prefix=TCELE
-// TCELE: target datalayout = 
"e-p:32:32:32-i1:8:8-i8:8:32-i16:16:32-i32:32:32-i64:32:32-f32:32:32-f64:32:32-v64:32:32-v128:32:32-v256:32:32-v512:32:32-v1024:32:32-a0:0:32-n32"
+// TCELE: target datalayout = 
"e-p:32:32:32-i1:8:8-i8:8:32-i16:16:32-i32:32:32-i64:32:32-f16:16:16-f32:32:32-f64:32:32-v64:64:64-i128:128-v128:128:128-v256:256:256-v512:512:512-v1024:1024:1024-v2048:2048:2048-v4096:4096:4096-a0:0:32-n32"
+
+// RUN: %clang_cc1 -triple tcele64-unknown -o - -emit-llvm %s | \
+// RUN: FileCheck %s -check-prefix=TCELE64
+// TCELE64: target datalayout = 
"e-p:64:64:64-i1:8:64-i8:8:64-i16:16:64-i32:32:64-i64:64:64-f16:16:64-f32:32:64-f64:64:64-v64:64:64-i128:128-v128:128:128-v256:256:256-v512:512:512-v1024:1024:1024-v2048:2048:2048-v4096:4096:4096-a0:0:64-n64"
 
 // RUN: %clang_cc1 -triple spir-unknown -o - -emit-llvm %s | \
 // RUN: FileCheck %s -check-prefix=SPIR
diff --git a/llvm/include/llvm/TargetParser/Triple.h 
b/llvm/include/llvm/TargetParser/Triple.h
index 8559d7b088ee1..5bfd27dc5e339 100644
--- a/llvm/include/llvm/TargetParser/Triple.h
+++ b/llvm/include/llvm/TargetParser/Triple.h
@@ -83,8 +83,9 @@ class Triple {
     sparcv9,     // Sparcv9: Sparcv9
     sparcel,     // Sparc: (endianness = little). NB: 'Sparcle' is a CPU 
variant
     systemz,     // SystemZ: s390x
-    tce,         // TCE (http://tce.cs.tut.fi/): tce
-    tcele,       // TCE little endian (http://tce.cs.tut.fi/): tcele
+    tce,         // OpenASIP (http://openasip.org) / big endian 32b targets: 
tce
+    tcele,       // OpenASIP (http://openasip.org) / little endian 32b 
targets: tcele
+    tcele64,     // OpenASIP (http://openasip.org) / little endian 64b 
targets: tcele
     thumb,       // Thumb (little endian): thumb, thumbv.*
     thumbeb,     // Thumb (big endian): thumbeb
     x86,         // X86: i[3-9]86
diff --git a/llvm/lib/TargetParser/TargetDataLayout.cpp 
b/llvm/lib/TargetParser/TargetDataLayout.cpp
index b8c3b4325558c..d7eba1a8d3002 100644
--- a/llvm/lib/TargetParser/TargetDataLayout.cpp
+++ b/llvm/lib/TargetParser/TargetDataLayout.cpp
@@ -601,7 +601,20 @@ std::string Triple::computeDataLayout(StringRef ABIName) 
const {
   case Triple::systemz:
     return computeSystemZDataLayout(*this);
   case Triple::tce:
+    return "E-p:32:32:32-i1:8:8-i8:8:32-i16:16:32-i32:32:32-i64:32:32-"
+           "f16:16:16-f32:32:32-f64:32:32-v64:64:64-i128:128-v128:128:128-"
+           "v256:256:256-v512:512:512-v1024:1024:1024-v2048:2048:2048-"
+           "v4096:4096:4096-a0:0:32-n32";
   case Triple::tcele:
+    return "e-p:32:32:32-i1:8:8-i8:8:32-i16:16:32-i32:32:32-i64:32:32-"
+           "f16:16:16-f32:32:32-f64:32:32-v64:64:64-i128:128-v128:128:128-"
+           "v256:256:256-v512:512:512-v1024:1024:1024-v2048:2048:2048-"
+           "v4096:4096:4096-a0:0:32-n32";
+  case Triple::tcele64:
+    return "e-p:64:64:64-i1:8:64-i8:8:64-i16:16:64-i32:32:64-i64:64:64-"
+           "f16:16:64-f32:32:64-f64:64:64-v64:64:64-i128:128-v128:128:128-"
+           "v256:256:256-v512:512:512-v1024:1024:1024-v2048:2048:2048-"
+           "v4096:4096:4096-a0:0:64-n64";
   case Triple::x86:
   case Triple::x86_64:
     return computeX86DataLayout(*this);
diff --git a/llvm/lib/TargetParser/Triple.cpp b/llvm/lib/TargetParser/Triple.cpp
index e6a9eedab5954..33929762d1543 100644
--- a/llvm/lib/TargetParser/Triple.cpp
+++ b/llvm/lib/TargetParser/Triple.cpp
@@ -79,6 +79,7 @@ StringRef Triple::getArchTypeName(ArchType Kind) {
   case systemz:        return "s390x";
   case tce:            return "tce";
   case tcele:          return "tcele";
+  case tcele64:        return "tcele64";
   case thumb:          return "thumb";
   case thumbeb:        return "thumbeb";
   case ve:             return "ve";
@@ -490,6 +491,7 @@ Triple::ArchType Triple::getArchTypeForLLVMName(StringRef 
Name) {
       .Case("systemz", systemz)
       .Case("tce", tce)
       .Case("tcele", tcele)
+      .Case("tcele64", tcele64)
       .Case("thumb", thumb)
       .Case("thumbeb", thumbeb)
       .Case("x86", x86)
@@ -640,6 +642,7 @@ static Triple::ArchType parseArch(StringRef ArchName) {
           .Cases({"sparcv9", "sparc64"}, Triple::sparcv9)
           .Case("tce", Triple::tce)
           .Case("tcele", Triple::tcele)
+          .Case("tcele64", Triple::tcele64)
           .Case("xcore", Triple::xcore)
           .Case("nvptx", Triple::nvptx)
           .Case("nvptx64", Triple::nvptx64)
@@ -1027,6 +1030,7 @@ static Triple::ObjectFormatType getDefaultFormat(const 
Triple &T) {
   case Triple::spir:
   case Triple::tce:
   case Triple::tcele:
+  case Triple::tcele64:
   case Triple::thumbeb:
   case Triple::ve:
   case Triple::xcore:
@@ -1779,6 +1783,7 @@ unsigned 
Triple::getArchPointerBitWidth(llvm::Triple::ArchType Arch) {
   case llvm::Triple::spirv:
   case llvm::Triple::spir64:
   case llvm::Triple::spirv64:
+  case llvm::Triple::tcele64:
   case llvm::Triple::systemz:
   case llvm::Triple::ve:
   case llvm::Triple::wasm64:
@@ -1895,6 +1900,7 @@ Triple Triple::get32BitArchVariant() const {
   case Triple::spirv64:
     T.setArch(Triple::spirv32, getSubArch());
     break;
+  case Triple::tcele64:        T.setArch(Triple::tcele);   break;
   case Triple::wasm64:         T.setArch(Triple::wasm32);  break;
   case Triple::x86_64:         T.setArch(Triple::x86);     break;
   }
@@ -1918,7 +1924,6 @@ Triple Triple::get64BitArchVariant() const {
   case Triple::shave:
   case Triple::sparcel:
   case Triple::tce:
-  case Triple::tcele:
   case Triple::xcore:
   case Triple::xtensa:
     T.setArch(UnknownArch);
@@ -1944,6 +1949,7 @@ Triple Triple::get64BitArchVariant() const {
   case Triple::spir64:
   case Triple::spirv64:
   case Triple::systemz:
+  case Triple::tcele64:
   case Triple::ve:
   case Triple::wasm64:
   case Triple::x86_64:
@@ -1976,6 +1982,7 @@ Triple Triple::get64BitArchVariant() const {
   case Triple::spirv32:
     T.setArch(Triple::spirv64, getSubArch());
     break;
+  case Triple::tcele:           T.setArch(Triple::tcele64);    break;
   case Triple::thumb:           T.setArch(Triple::aarch64);    break;
   case Triple::thumbeb:         T.setArch(Triple::aarch64_be); break;
   case Triple::wasm32:          T.setArch(Triple::wasm64);     break;
@@ -2014,6 +2021,7 @@ Triple Triple::getBigEndianArchVariant() const {
   case Triple::spirv:
   case Triple::spirv32:
   case Triple::spirv64:
+  case Triple::tcele64:
   case Triple::wasm32:
   case Triple::wasm64:
   case Triple::x86:
@@ -2135,6 +2143,7 @@ bool Triple::isLittleEndian() const {
   case Triple::spirv32:
   case Triple::spirv64:
   case Triple::tcele:
+  case Triple::tcele64:
   case Triple::thumb:
   case Triple::ve:
   case Triple::wasm32:

``````````

</details>


https://github.com/llvm/llvm-project/pull/176698
_______________________________________________
cfe-commits mailing list
[email protected]
https://lists.llvm.org/cgi-bin/mailman/listinfo/cfe-commits

Reply via email to