diff options
author | Christophe Fergeau <cfergeau@redhat.com> | 2013-10-10 11:17:52 +0200 |
---|---|---|
committer | Christophe Fergeau <cfergeau@redhat.com> | 2013-10-10 11:17:52 +0200 |
commit | ceb672bf85f99af9290e0576224072ff6c7533c9 (patch) | |
tree | c904626065927eacb4120ea7d6616ca435a5802e /m4/virt-linker-relro.m4 | |
parent | f78f1ae61b6af9262b1a8d1ffbf162b323549b83 (diff) | |
download | spice-ceb672bf85f99af9290e0576224072ff6c7533c9.tar.gz spice-ceb672bf85f99af9290e0576224072ff6c7533c9.tar.xz spice-ceb672bf85f99af9290e0576224072ff6c7533c9.zip |
Use hardened linker flags if available
This commit reuse several macros from libvirt to test for
support for "-Wl,-z -Wl,relro", "-Wl,-z -Wl,now" and
"-Wl,--no-copy-dt-needed-entries", and use them if available.
Diffstat (limited to 'm4/virt-linker-relro.m4')
-rw-r--r-- | m4/virt-linker-relro.m4 | 35 |
1 files changed, 35 insertions, 0 deletions
diff --git a/m4/virt-linker-relro.m4 b/m4/virt-linker-relro.m4 new file mode 100644 index 00000000..079a095f --- /dev/null +++ b/m4/virt-linker-relro.m4 @@ -0,0 +1,35 @@ +dnl +dnl Check for -z now and -z relro linker flags +dnl +dnl Copyright (C) 2013 Red Hat, Inc. +dnl +dnl This library is free software; you can redistribute it and/or +dnl modify it under the terms of the GNU Lesser General Public +dnl License as published by the Free Software Foundation; either +dnl version 2.1 of the License, or (at your option) any later version. +dnl +dnl This library is distributed in the hope that it will be useful, +dnl but WITHOUT ANY WARRANTY; without even the implied warranty of +dnl MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU +dnl Lesser General Public License for more details. +dnl +dnl You should have received a copy of the GNU Lesser General Public +dnl License along with this library. If not, see +dnl <http://www.gnu.org/licenses/>. +dnl + +AC_DEFUN([LIBVIRT_LINKER_RELRO],[ + AC_MSG_CHECKING([for how to force completely read-only GOT table]) + + RELRO_LDFLAGS= + ld_help=`$LD --help 2>&1` + case $ld_help in + *"-z relro"*) RELRO_LDFLAGS="-Wl,-z -Wl,relro" ;; + esac + case $ld_help in + *"-z now"*) RELRO_LDFLAGS="$RELRO_LDFLAGS -Wl,-z -Wl,now" ;; + esac + AC_SUBST([RELRO_LDFLAGS]) + + AC_MSG_RESULT([$RELRO_LDFLAGS]) +]) |