|
|
00db10 |
This patch is based on the following upstream commit:
|
|
|
00db10 |
|
|
|
00db10 |
commit 2d6ab5df3b675e96ee587ae6a8c2ce004c6b1ba9
|
|
|
00db10 |
Author: Florian Weimer <fweimer@redhat.com>
|
|
|
00db10 |
Date: Thu Mar 2 14:44:28 2017 +0100
|
|
|
00db10 |
|
|
|
00db10 |
Document and fix --enable-bind-now [BZ #21015]
|
|
|
00db10 |
|
|
|
00db10 |
diff --git a/INSTALL b/INSTALL
|
|
|
00db10 |
index 82b29f5d8746f929..230be71b9d0821c2 100644
|
|
|
00db10 |
--- a/INSTALL
|
|
|
00db10 |
+++ b/INSTALL
|
|
|
00db10 |
@@ -143,6 +143,12 @@ will be used, and CFLAGS sets optimization options for the compiler.
|
|
|
00db10 |
`--enable-lock-elision=yes'
|
|
|
00db10 |
Enable lock elision for pthread mutexes by default.
|
|
|
00db10 |
|
|
|
00db10 |
+'--enable-bind-now'
|
|
|
00db10 |
+ Disable lazy binding for installed shared objects. This provides
|
|
|
00db10 |
+ additional security hardening because it enables full RELRO and a
|
|
|
00db10 |
+ read-only global offset table (GOT), at the cost of slightly
|
|
|
00db10 |
+ increased program load times.
|
|
|
00db10 |
+
|
|
|
00db10 |
`--disable-werror'
|
|
|
00db10 |
By default, the GNU C Library is built with `-Werror'. If you wish
|
|
|
00db10 |
to build without this option (for example, if building with a newer
|
|
|
00db10 |
diff --git a/Makeconfig b/Makeconfig
|
|
|
00db10 |
index f8313c9774d47522..1ad9b6f0d494c027 100644
|
|
|
00db10 |
--- a/Makeconfig
|
|
|
00db10 |
+++ b/Makeconfig
|
|
|
00db10 |
@@ -384,6 +384,13 @@ LDFLAGS.so += $(hashstyle-LDFLAGS)
|
|
|
00db10 |
LDFLAGS-rtld += $(hashstyle-LDFLAGS)
|
|
|
00db10 |
endif
|
|
|
00db10 |
|
|
|
00db10 |
+# If lazy relocations are disabled, add the -z now flag. Use
|
|
|
00db10 |
+# LDFLAGS-lib.so instead of LDFLAGS.so, to avoid adding the flag to
|
|
|
00db10 |
+# test modules.
|
|
|
00db10 |
+ifeq ($(bind-now),yes)
|
|
|
00db10 |
+LDFLAGS-lib.so += -Wl,-z,now
|
|
|
00db10 |
+endif
|
|
|
00db10 |
+
|
|
|
00db10 |
# Additional libraries to link into every test.
|
|
|
00db10 |
link-extra-libs-tests = $(libsupport)
|
|
|
00db10 |
|
|
|
00db10 |
diff --git a/Makerules b/Makerules
|
|
|
00db10 |
index 9bd7d603fc28a4de..50fe7e48187f0e68 100644
|
|
|
00db10 |
--- a/Makerules
|
|
|
00db10 |
+++ b/Makerules
|
|
|
00db10 |
@@ -477,7 +477,7 @@ $(LINK.o) -shared $(static-libgcc) -Wl,-O1 $(sysdep-LDFLAGS) \
|
|
|
00db10 |
$(extra-B-$(@F:lib%.so=%).so) -B$(csu-objpfx) \
|
|
|
00db10 |
$(extra-B-$(@F:lib%.so=%).so) $(load-map-file) \
|
|
|
00db10 |
-Wl,-soname=lib$(libprefix)$(@F:lib%.so=%).so$($(@F)-version) \
|
|
|
00db10 |
- $(LDFLAGS.so) $(LDFLAGS-$(@F:lib%.so=%).so) \
|
|
|
00db10 |
+ $(LDFLAGS.so) $(LDFLAGS-lib.so) $(LDFLAGS-$(@F:lib%.so=%).so) \
|
|
|
00db10 |
-L$(subst :, -L,$(rpath-link)) -Wl,-rpath-link=$(rpath-link)
|
|
|
00db10 |
endef
|
|
|
00db10 |
|
|
|
00db10 |
@@ -938,7 +938,8 @@ $(common-objpfx)format.lds: $(..)scripts/output-format.sed \
|
|
|
00db10 |
ifneq (unknown,$(output-format))
|
|
|
00db10 |
echo > $@.new 'OUTPUT_FORMAT($(output-format))'
|
|
|
00db10 |
else
|
|
|
00db10 |
- $(LINK.o) -shared $(sysdep-LDFLAGS) $(config-LDFLAGS) $(LDFLAGS.so) \
|
|
|
00db10 |
+ $(LINK.o) -shared $(sysdep-LDFLAGS) $(config-LDFLAGS) \
|
|
|
00db10 |
+ $(LDFLAGS.so) $(LDFLAGS-lib.so) \
|
|
|
00db10 |
-x c /dev/null -o $@.so -Wl,--verbose -v 2>&1 \
|
|
|
00db10 |
| sed -n -f $< > $@.new
|
|
|
00db10 |
test -s $@.new
|
|
|
00db10 |
diff --git a/iconvdata/Makefile b/iconvdata/Makefile
|
|
|
00db10 |
index 7930dcd49d77c818..ddb2dc6a3c6500c8 100644
|
|
|
00db10 |
--- a/iconvdata/Makefile
|
|
|
00db10 |
+++ b/iconvdata/Makefile
|
|
|
00db10 |
@@ -65,6 +65,10 @@ modules.so := $(addsuffix .so, $(modules))
|
|
|
00db10 |
|
|
|
00db10 |
include ../Makeconfig
|
|
|
00db10 |
|
|
|
00db10 |
+ifeq ($(bind-now),yes)
|
|
|
00db10 |
+LDFLAGS.so += -Wl,-z,now
|
|
|
00db10 |
+endif
|
|
|
00db10 |
+
|
|
|
00db10 |
ifeq (yes,$(build-shared))
|
|
|
00db10 |
tests = bug-iconv1 bug-iconv2 tst-loading tst-e2big tst-iconv4 bug-iconv4 \
|
|
|
00db10 |
tst-iconv6 bug-iconv5 bug-iconv6 tst-iconv7 bug-iconv8 bug-iconv9 \
|
|
|
00db10 |
diff --git a/manual/install.texi b/manual/install.texi
|
|
|
00db10 |
index 3799cee621ddc4f9..47d832cc59bc695e 100644
|
|
|
00db10 |
--- a/manual/install.texi
|
|
|
00db10 |
+++ b/manual/install.texi
|
|
|
00db10 |
@@ -160,6 +160,12 @@ so that they can be invoked directly.
|
|
|
00db10 |
@item --enable-lock-elision=yes
|
|
|
00db10 |
Enable lock elision for pthread mutexes by default.
|
|
|
00db10 |
|
|
|
00db10 |
+@item --enable-bind-now
|
|
|
00db10 |
+Disable lazy binding for installed shared objects. This provides
|
|
|
00db10 |
+additional security hardening because it enables full RELRO and a
|
|
|
00db10 |
+read-only global offset table (GOT), at the cost of slightly increased
|
|
|
00db10 |
+program load times.
|
|
|
00db10 |
+
|
|
|
00db10 |
@pindex pt_chown
|
|
|
00db10 |
@findex grantpt
|
|
|
00db10 |
@item --enable-pt_chown
|