llvmorg-github-actions[bot] wrote:

<!--LLVM PR SUMMARY COMMENT-->

@llvm/pr-subscribers-clang-driver

Author: aokblast

<details>
<summary>Changes</summary>

Rename the platform-specific option CLANG_DEFAULT_PIE_ON_LINUX to the more 
generic CLANG_DEFAULT_PIE to allow enabling PIE by default on other platforms.

This change only renames the option. The default values at each use site remain 
unchanged, so there is no functional behavior change.

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


13 Files Affected:

- (modified) clang/CMakeLists.txt (+1-1) 
- (modified) clang/include/clang/Config/config.h.cmake (+1-1) 
- (modified) clang/lib/Driver/ToolChains/Linux.cpp (+2-2) 
- (modified) clang/test/CMakeLists.txt (+1-1) 
- (modified) clang/test/Driver/hip-fpie-option.hip (+1-1) 
- (modified) clang/test/Driver/linux-default-pie.c (+2-2) 
- (modified) clang/test/lit.cfg.py (+2-2) 
- (modified) clang/test/lit.site.cfg.py.in (+1-1) 
- (modified) flang/test/Driver/linker-options.f90 (+8-8) 
- (modified) flang/test/Driver/pic-flags.f90 (+1-1) 
- (modified) llvm/utils/gn/secondary/clang/include/clang/Config/BUILD.gn (+1-1) 
- (modified) llvm/utils/gn/secondary/clang/test/BUILD.gn (+1-1) 
- (modified) 
utils/bazel/llvm-project-overlay/clang/include/clang/Config/config.h (+1-1) 


``````````diff
diff --git a/clang/CMakeLists.txt b/clang/CMakeLists.txt
index cd7ba53b03061..f8b7f35612cf3 100644
--- a/clang/CMakeLists.txt
+++ b/clang/CMakeLists.txt
@@ -278,7 +278,7 @@ set(PPC_LINUX_DEFAULT_IEEELONGDOUBLE OFF CACHE BOOL
 set(CLANG_SPAWN_CC1 OFF CACHE BOOL
     "Whether clang should use a new process for the CC1 invocation")
 
-option(CLANG_DEFAULT_PIE_ON_LINUX "Default to -fPIE and -pie on linux-gnu" ON)
+option(CLANG_DEFAULT_PIE "Default to -fPIE and -pie on linux-gnu" ON)
 
 set(CLANG_DEFAULT_LINKER "" CACHE STRING
   "Default linker to use (linker name or absolute path, empty for platform 
default)")
diff --git a/clang/include/clang/Config/config.h.cmake 
b/clang/include/clang/Config/config.h.cmake
index 11b4096726f67..ea0cd01c6c596 100644
--- a/clang/include/clang/Config/config.h.cmake
+++ b/clang/include/clang/Config/config.h.cmake
@@ -9,7 +9,7 @@
 #define BUG_REPORT_URL "${BUG_REPORT_URL}"
 
 /* Default to -fPIE and -pie on Linux. */
-#cmakedefine01 CLANG_DEFAULT_PIE_ON_LINUX
+#cmakedefine01 CLANG_DEFAULT_PIE
 
 /* Default linker to use. */
 #define CLANG_DEFAULT_LINKER "${CLANG_DEFAULT_LINKER}"
diff --git a/clang/lib/Driver/ToolChains/Linux.cpp 
b/clang/lib/Driver/ToolChains/Linux.cpp
index 512788d235fec..6c6b3647e2f81 100644
--- a/clang/lib/Driver/ToolChains/Linux.cpp
+++ b/clang/lib/Driver/ToolChains/Linux.cpp
@@ -934,8 +934,8 @@ void Linux::addSYCLIncludeArgs(const ArgList &DriverArgs,
 }
 
 bool Linux::isPIEDefault(const llvm::opt::ArgList &Args) const {
-  return CLANG_DEFAULT_PIE_ON_LINUX || getTriple().isAndroid() ||
-         getTriple().isMusl() || getSanitizerArgs(Args).requiresPIE();
+  return CLANG_DEFAULT_PIE || getTriple().isAndroid() || getTriple().isMusl() 
||
+         getSanitizerArgs(Args).requiresPIE();
 }
 
 bool Linux::IsAArch64OutlineAtomicsDefault(const ArgList &Args) const {
diff --git a/clang/test/CMakeLists.txt b/clang/test/CMakeLists.txt
index 8dd0084c53224..7807a3e4d00d5 100644
--- a/clang/test/CMakeLists.txt
+++ b/clang/test/CMakeLists.txt
@@ -5,7 +5,7 @@ llvm_canonicalize_cmake_booleans(
   BUILD_SHARED_LIBS
   CLANG_BUILD_EXAMPLES
   CLANG_BUILT_STANDALONE
-  CLANG_DEFAULT_PIE_ON_LINUX
+  CLANG_DEFAULT_PIE
   CLANG_ENABLE_STATIC_ANALYZER
   CLANG_PLUGIN_SUPPORT
   CLANG_SPAWN_CC1
diff --git a/clang/test/Driver/hip-fpie-option.hip 
b/clang/test/Driver/hip-fpie-option.hip
index 426564b67066e..de2cd7fc343ed 100644
--- a/clang/test/Driver/hip-fpie-option.hip
+++ b/clang/test/Driver/hip-fpie-option.hip
@@ -1,4 +1,4 @@
-// REQUIRES: default-pie-on-linux
+// REQUIRES: default-pie
 
 // -fPIC and -fPIE only affects host relocation model.
 // device compilation always uses PIC. 
diff --git a/clang/test/Driver/linux-default-pie.c 
b/clang/test/Driver/linux-default-pie.c
index 6772a6cd3fd0c..0b1aa0b2d5ab3 100644
--- a/clang/test/Driver/linux-default-pie.c
+++ b/clang/test/Driver/linux-default-pie.c
@@ -1,5 +1,5 @@
-// REQUIRES: default-pie-on-linux
-/// Test -DCLANG_DEFAULT_PIE_ON_LINUX=on.
+// REQUIRES: default-pie
+/// Test -DCLANG_DEFAULT_PIE=on.
 
 // RUN: %clang -### --target=aarch64-linux-gnu %s 2>&1 | FileCheck %s 
--check-prefix=PIE2
 
diff --git a/clang/test/lit.cfg.py b/clang/test/lit.cfg.py
index f7b3a77266cb8..749878690b245 100644
--- a/clang/test/lit.cfg.py
+++ b/clang/test/lit.cfg.py
@@ -326,8 +326,8 @@ def have_host_clang_repl_cuda():
 if config.has_plugins and config.llvm_plugin_ext:
     config.available_features.add("plugins")
 
-if config.clang_default_pie_on_linux:
-    config.available_features.add("default-pie-on-linux")
+if config.clang_default_pie:
+    config.available_features.add("default-pie")
 
 # Set available features we allow tests to conditionalize on.
 #
diff --git a/clang/test/lit.site.cfg.py.in b/clang/test/lit.site.cfg.py.in
index cb35118167d99..0def99827c111 100644
--- a/clang/test/lit.site.cfg.py.in
+++ b/clang/test/lit.site.cfg.py.in
@@ -21,7 +21,7 @@ config.llvm_use_sanitizer = "@LLVM_USE_SANITIZER@"
 config.have_zlib = @LLVM_ENABLE_ZLIB@
 config.have_zstd = @LLVM_ENABLE_ZSTD@
 config.clang_objc_rewriter = @CLANG_ENABLE_OBJC_REWRITER@
-config.clang_default_pie_on_linux = @CLANG_DEFAULT_PIE_ON_LINUX@
+config.clang_default_pie = @CLANG_DEFAULT_PIE@
 config.clang_default_cxx_stdlib = "@CLANG_DEFAULT_CXX_STDLIB@"
 config.clang_staticanalyzer = @CLANG_ENABLE_STATIC_ANALYZER@
 config.clang_staticanalyzer_z3 = @LLVM_WITH_Z3@
diff --git a/flang/test/Driver/linker-options.f90 
b/flang/test/Driver/linker-options.f90
index 07f967b4bac5d..5de7d8c23aacb 100644
--- a/flang/test/Driver/linker-options.f90
+++ b/flang/test/Driver/linker-options.f90
@@ -58,20 +58,20 @@
 ! RUN: %flang -target i386-pc-openbsd -pie -### %s 2>&1 \
 ! RUN:   | FileCheck %s --check-prefix=PIE
 !
-! On FreeBSD, -pie is not passed to the linker, but can be forced.
-! RUN: %flang -target amd64-pc-freebsd -### %s 2>&1 \
+! On FreeBSD, pie is passed to the linker, but can be forced cancelled.
+! RUN: %flang -no-pie -target amd64-pc-freebsd -### %s 2>&1 \
 ! RUN:   | FileCheck %s --check-prefix=NO-PIE
-! RUN: %flang -target i386-pc-freebsd -### %s 2>&1 \
+! RUN: %flang -no-pie -target i386-pc-freebsd -### %s 2>&1 \
 ! RUN:   | FileCheck %s --check-prefix=NO-PIE
-! RUN: %flang -target aarch64-unknown-freebsd -### %s 2>&1 \
+! RUN: %flang -no-pie -target aarch64-unknown-freebsd -### %s 2>&1 \
 ! RUN:   | FileCheck %s --check-prefix=NO-PIE
-! RUN: %flang -target arm-unknown-freebsd -### %s 2>&1 \
+! RUN: %flang -no-pie -target arm-unknown-freebsd -### %s 2>&1 \
 ! RUN:   | FileCheck %s --check-prefix=NO-PIE
-! RUN: %flang -target powerpc-unknown-freebsd -### %s 2>&1 \
+! RUN: %flang -no-pie -target powerpc-unknown-freebsd -### %s 2>&1 \
 ! RUN:   | FileCheck %s --check-prefix=NO-PIE
-! RUN: %flang -target sparc64-unknown-freebsd -### %s 2>&1 \
+! RUN: %flang -no-pie -target sparc64-unknown-freebsd -### %s 2>&1 \
 ! RUN:   | FileCheck %s --check-prefix=NO-PIE
-! RUN: %flang -target i386-pc-freebsd -pie -### %s 2>&1 \
+! RUN: %flang -no-pie -target i386-pc-freebsd -pie -### %s 2>&1 \
 ! RUN:   | FileCheck %s --check-prefix=PIE
 !
 ! On AIX, -pie is never passed to the linker.
diff --git a/flang/test/Driver/pic-flags.f90 b/flang/test/Driver/pic-flags.f90
index 5a06163c485cd..23315bde96c28 100644
--- a/flang/test/Driver/pic-flags.f90
+++ b/flang/test/Driver/pic-flags.f90
@@ -1,6 +1,6 @@
 ! RUN: %if aarch64-registered-target %{ %flang -v -S -emit-llvm -o - %s 
--target=aarch64-linux-gnu -fno-pie 2>&1 | FileCheck %s 
--check-prefixes=CHECK,CHECK-STATIC,CHECK-STATIC-IR %}
 
-! RUN: %if aarch64-registered-target && clang_default_pie_on_linux %{ %flang 
-v -S -emit-llvm -o - %s --target=aarch64-linux-gnu 2>&1 | FileCheck %s 
--check-prefixes=CHECK,CHECK-PIE-LEVEL2,CHECK-PIE-LEVEL2-IR %}
+! RUN: %if aarch64-registered-target && clang_default_pie %{ %flang -v -S 
-emit-llvm -o - %s --target=aarch64-linux-gnu 2>&1 | FileCheck %s 
--check-prefixes=CHECK,CHECK-PIE-LEVEL2,CHECK-PIE-LEVEL2-IR %}
 ! RUN: %if aarch64-registered-target %{ %flang -v -S -emit-llvm -o - %s 
--target=aarch64-linux-gnu -fpie 2>&1 | FileCheck %s 
--check-prefixes=CHECK,CHECK-PIE-LEVEL1,CHECK-PIE-LEVEL1-IR %}
 ! RUN: %if aarch64-registered-target %{ %flang -v -S -emit-llvm -o - %s 
--target=aarch64-linux-gnu -fPIE 2>&1 | FileCheck %s 
--check-prefixes=CHECK,CHECK-PIE-LEVEL2,CHECK-PIE-LEVEL2-IR %}
 
diff --git a/llvm/utils/gn/secondary/clang/include/clang/Config/BUILD.gn 
b/llvm/utils/gn/secondary/clang/include/clang/Config/BUILD.gn
index f8196d1b248e5..c569c80cc74ad 100644
--- a/llvm/utils/gn/secondary/clang/include/clang/Config/BUILD.gn
+++ b/llvm/utils/gn/secondary/clang/include/clang/Config/BUILD.gn
@@ -8,7 +8,7 @@ write_cmake_config("Config") {
   output = "$target_gen_dir/config.h"
   values = [
     "BUG_REPORT_URL=https://github.com/llvm/llvm-project/issues/";,
-    "CLANG_DEFAULT_PIE_ON_LINUX=1",
+    "CLANG_DEFAULT_PIE=1",
     "CLANG_DEFAULT_LINKER=",
     "CLANG_DEFAULT_CXX_STDLIB=",
     "CLANG_DEFAULT_RTLIB=",
diff --git a/llvm/utils/gn/secondary/clang/test/BUILD.gn 
b/llvm/utils/gn/secondary/clang/test/BUILD.gn
index 73f3bd020a1e0..16622fa62f4d7 100644
--- a/llvm/utils/gn/secondary/clang/test/BUILD.gn
+++ b/llvm/utils/gn/secondary/clang/test/BUILD.gn
@@ -52,7 +52,7 @@ write_lit_config("lit_site_cfg") {
     "CLANG_BUILD_EXAMPLES=0",
     "CLANG_BUILT_STANDALONE=0",
     "CLANG_DEFAULT_CXX_STDLIB=",  # Empty string means "default value" here.
-    "CLANG_DEFAULT_PIE_ON_LINUX=0",
+    "CLANG_DEFAULT_PIE=0",
     "CLANG_ENABLE_CIR=0",
     "CLANG_ENABLE_OBJC_REWRITER=0",
     "CLANG_PLUGIN_SUPPORT=0",  # FIXME: Analysis/plugins need global -fPIC
diff --git 
a/utils/bazel/llvm-project-overlay/clang/include/clang/Config/config.h 
b/utils/bazel/llvm-project-overlay/clang/include/clang/Config/config.h
index 7f7308f338966..0fbe93028a076 100644
--- a/utils/bazel/llvm-project-overlay/clang/include/clang/Config/config.h
+++ b/utils/bazel/llvm-project-overlay/clang/include/clang/Config/config.h
@@ -23,7 +23,7 @@
 #define BUG_REPORT_URL "https://github.com/llvm/llvm-project/issues/";
 
 /* Default to -fPIE and -pie on Linux. */
-#define CLANG_DEFAULT_PIE_ON_LINUX 1
+#define CLANG_DEFAULT_PIE 1
 
 /* Default linker to use. */
 #define CLANG_DEFAULT_LINKER ""

``````````

</details>


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

Reply via email to