[PATCH] PR ld/20283: gold: Add a linker configure option --enable-relro
H.J. Lu
hjl.tools@gmail.com
Wed Jun 22 14:45:00 GMT 2016
On Wed, Jun 22, 2016 at 7:09 AM, Mike Frysinger <vapier@gentoo.org> wrote:
> On 22 Jun 2016 06:33, H.J. Lu wrote:
>> On Wed, Jun 22, 2016 at 6:16 AM, Mike Frysinger <vapier@gentoo.org> wrote:
>> > On 22 Jun 2016 05:41, H.J. Lu wrote:
>> >> On Wed, Jun 22, 2016 at 3:43 AM, Mike Frysinger <vapier@gentoo.org> wrote:
>> >> > On 21 Jun 2016 19:45, H.J. Lu wrote:
>> >> >> On Tue, Jun 21, 2016 at 6:06 PM, Mike Frysinger wrote:
>> >> >> > On 21 Jun 2016 15:11, H.J. Lu wrote:
>> >> >> >> +# Decide if -z relro should be enabled in ELF linker by default.
>> >> >> >> +ac_default_ld_z_relro=unset
>> >> >> >> +# Provide a configure time option to override our default.
>> >> >> >> +AC_ARG_ENABLE(relro,
>> >> >> >> + AS_HELP_STRING([--enable-relro],
>> >> >> >> + [enable -z relro in ELF linker by default]),
>> >> >> >> +[case "${enableval}" in
>> >> >> >> + no) ac_default_ld_z_relro=0 ;;
>> >> >> >> +esac])dnl
>> >> >> >> +if test ${ac_default_ld_z_relro} = unset; then
>> >> >> >> + ac_default_ld_z_relro=1
>> >> >> >> +fi
>> >> >> >
>> >> >> > any reason to not just write it like:
>> >> >> > AC_ARG_ENABLE(relro,
>> >> >> > AS_HELP_STRING([--enable-relro],
>> >> >> > [enable -z relro in ELF linker by default]))
>> >> >> > if test "${enable_relro}" = "yes"; then
>> >> >> > ac_default_ld_z_relro=1
>> >> >> > else
>> >> >> > ac_default_ld_z_relro=0
>> >> >> > fi
>> >> >> >
>> >> >> > it's a bit simpler that way.
>> >> >>
>> >> >> I copied it from ld where ac_default_ld_z_relro is set to 1 unless
>> >> >> --disable-relro is used or not a Linux target. For gold, it becomes
>> >> >> unless --disable-relro is used. It is easier for me to keep both ld
>> >> >> and gold similar.
>> >> >
>> >> > except that patch isn't merged yet, so you have time to change it too
>> >>
>> >> This is what I checked in.
>> >
>> > there was still no reason to not write it the way i suggested.
>> > it's shorter and simpler.
>>
>> It is better to make ld and gold consistent just in case
>> we may need to change.
>
> that is entirely irrelevant. neither ld nor gold had this change
> merged which meant you could fix both at the same time. in fact,
The ld case is done such a way on purpose since default depends
on configure.tgt:
# Decide if -z relro should be enabled in ELF linker by default.
ac_default_ld_z_relro=unset
# Provide a configure time option to override our default.
AC_ARG_ENABLE(relro,
AS_HELP_STRING([--enable-relro],
[enable -z relro in ELF linker by default]),
[case "${enableval}" in
yes) ac_default_ld_z_relro=1 ;;
no) ac_default_ld_z_relro=0 ;;
esac])dnl
...
---configure.tgt---
*-*-linux*)
if test ${ac_default_ld_z_relro} = unset; then
ac_default_ld_z_relro=1
fi
..
if test "${ac_default_ld_z_relro}" = unset; then
ac_default_ld_z_relro=0
fi
Your suggestion doesn't work for ld even if the typo is fixed:
AC_ARG_ENABLE(relro,
AS_HELP_STRING([--enable-relro],
[enable -z relro in ELF linker by default]))
if test "${enable_relro}" = "yes"; then <<<< Default is no.
ac_default_ld_z_relro=1
else
ac_default_ld_z_relro=0
fi
It is better to make ld and gold consistent if gold decides to
change the default depending on target like ld.
> Nick asked you to fix bugs in the ld version which my suggestion
> above already had fixed.
> -mike
--
H.J.
More information about the Binutils
mailing list