Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(3660)

Unified Diff: build/config/gcc/BUILD.gn

Issue 1525733002: Revert of Only set -rpath=$ORIGIN in component builds by default. (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: Created 5 years ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View side-by-side diff with in-line comments
Download patch
« no previous file with comments | « base/BUILD.gn ('k') | chrome/test/BUILD.gn » ('j') | no next file with comments »
Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
Index: build/config/gcc/BUILD.gn
diff --git a/build/config/gcc/BUILD.gn b/build/config/gcc/BUILD.gn
index b0fc9812cf5153eb7dc7dd636a47b8815db7a47d..815cfb996d327543ddfd9b953cc372ae96d85965 100644
--- a/build/config/gcc/BUILD.gn
+++ b/build/config/gcc/BUILD.gn
@@ -20,45 +20,6 @@
cflags = [ "-fvisibility=hidden" ]
}
-# The rpath is the dynamic library search path. Setting this config on a link
-# step will put the directory where the build generates shared libraries into
-# the rpath.
-#
-# It's important that this *not* be used for release builds we push out.
-# Chrome uses some setuid binaries, and hard links preserve setuid bits. An
-# unprivileged user could gain root privileges by hardlinking a setuid
-# executable and then adding in whatever binaries they want to run into the lib
-# directory.
-#
-# Example bug: https://bugs.debian.org/cgi-bin/bugreport.cgi?bug=520126
-#
-# This is required for component builds since the build generates many shared
-# libraries in the build directory that we expect to be automatically loaded.
-# It will be automatically applied in this case by :executable_ldconfig.
-#
-# In non-component builds, certain test binaries may expect to load dynamic
-# libraries from the current directory. As long as these aren't distributed,
-# this is OK. For these cases use something like this:
-#
-# if (is_linux && !is_component_build) {
-# configs += [ "//build/config/gcc:rpath_for_built_shared_libraries" ]
-# }
-config("rpath_for_built_shared_libraries") {
- if (!is_android) {
- # Note: Android doesn't support rpath.
- if (shlib_subdir != ".") {
- rpath_link = "${shlib_subdir}/"
- } else {
- rpath_link = "."
- }
- ldflags = [
- # Want to pass "\$". GN will re-escape as required for ninja.
- "-Wl,-rpath=\$ORIGIN/${rpath_link}",
- "-Wl,-rpath-link=${rpath_link}",
- ]
- }
-}
-
# Settings for executables and shared libraries.
config("executable_ldconfig") {
if (is_android) {
@@ -67,13 +28,16 @@
"-Wl,-z,nocopyreloc",
]
} else {
- if (is_component_build) {
- configs = [ ":rpath_for_built_shared_libraries" ]
+ # Note: Android doesn't support rpath.
+ rpath_link = "."
+ if (shlib_subdir != ".") {
+ rpath_link = "${shlib_subdir}/"
}
+ ldflags = [
+ # Want to pass "\$". GN will re-escape as required for ninja.
+ "-Wl,-rpath=\$ORIGIN/${rpath_link}",
+ "-Wl,-rpath-link=${rpath_link}",
- ldflags = [
- # TODO(GYP): Do we need a check on the binutils version here?
- #
# Newer binutils don't set DT_RPATH unless you disable "new" dtags
# and the new DT_RUNPATH doesn't work without --no-as-needed flag.
"-Wl,--disable-new-dtags",
« no previous file with comments | « base/BUILD.gn ('k') | chrome/test/BUILD.gn » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698