954b63d4c8
-z nodynamic-undefined-weak is only implemented for x86. (The sparc backend has some support code but doesn't enable the option by including ld/emulparams/dynamic_undefined_weak.sh, and since the support looks like it may be broken I haven't enabled it.) This patch adds the complementary -z dynamic-undefined-weak, extends both options to affect building of shared libraries as well as executables, and adds support for the option on powerpc. include/ * bfdlink.h (struct bfd_link_info <dynamic_undefined_weak>): Revise comment. bfd/ * elflink.c (_bfd_elf_adjust_dynamic_symbol): Hide undefweak or make dynamic for info->dynamic_undefined_weak 0 and 1. * elf32-ppc.c:Formatting. (ensure_undefweak_dynamic): Don't make dynamic when info->dynamic_undefined_weak is zero. (allocate_dynrelocs): Discard undefweak dyn_relocs for info->dynamic_undefined_weak. Discard undef dyn_relocs when not default visibility. Discard undef and undefweak dyn_relocs earlier. (ppc_elf_relocate_section): Adjust to suit. * elf64-ppc.c: Formatting. (ensure_undefweak_dynamic): Don't make dynamic when info->dynamic_undefined_weak is zero. (allocate_dynrelocs): Discard undefweak dyn_relocs for info->dynamic_undefined_weak. Discard them earlier. ld/ * ld.texinfo (dynamic-undefined-weak): Document. (nodynamic-undefined-weak): Document that this option now can be used with shared libs. * emulparams/dynamic_undefined_weak.sh: Support -z dynamic-undefined-weak. * emulparams/elf32ppccommon.sh: Include dynamic_undefined_weak.sh. * testsuite/ld-undefined/weak-undef.exp (undef_weak_so), (undef_weak_exe): New. Use them. Add -z dynamic-undefined-weak and -z nodynamic-undefined-weak tests. * Makefile.am: Update powerpc dependencies. * Makefile.in: Regenerate.
59 lines
1.9 KiB
Bash
59 lines
1.9 KiB
Bash
# The PLT-agnostic parts of a generic 32-bit ELF PowerPC target. Included by:
|
|
# elf32ppc.sh elf32ppcvxworks.sh elf64ppc.sh
|
|
. ${srcdir}/emulparams/dynamic_undefined_weak.sh
|
|
|
|
TEMPLATE_NAME=elf32
|
|
GENERATE_SHLIB_SCRIPT=yes
|
|
GENERATE_PIE_SCRIPT=yes
|
|
SCRIPT_NAME=elf
|
|
OUTPUT_FORMAT="elf32-powerpc"
|
|
NO_REL_RELOCS=yes
|
|
TEXT_START_ADDR=0x01800000
|
|
MAXPAGESIZE="CONSTANT (MAXPAGESIZE)"
|
|
COMMONPAGESIZE="CONSTANT (COMMONPAGESIZE)"
|
|
ARCH=powerpc:common
|
|
MACHINE=
|
|
EXECUTABLE_SYMBOLS='PROVIDE (__stack = 0); PROVIDE (___stack = 0);'
|
|
if test -z "${CREATE_SHLIB}"; then
|
|
SBSS_START_SYMBOLS="PROVIDE (__sbss_start = .); PROVIDE (___sbss_start = .);"
|
|
SBSS_END_SYMBOLS="PROVIDE (__sbss_end = .); PROVIDE (___sbss_end = .);"
|
|
else
|
|
unset SDATA_START_SYMBOLS
|
|
unset SDATA2_START_SYMBOLS
|
|
unset SBSS_START_SYMBOLS
|
|
unset SBSS_END_SYMBOLS
|
|
fi
|
|
OTHER_END_SYMBOLS="__end = .;"
|
|
OTHER_RELRO_SECTIONS="
|
|
.fixup ${RELOCATING-0} : { *(.fixup) }
|
|
.got1 ${RELOCATING-0} : { *(.got1) }
|
|
.got2 ${RELOCATING-0} : { *(.got2) }
|
|
"
|
|
OTHER_GOT_RELOC_SECTIONS="
|
|
.rela.got1 ${RELOCATING-0} : { *(.rela.got1) }
|
|
.rela.got2 ${RELOCATING-0} : { *(.rela.got2) }
|
|
"
|
|
|
|
# Treat a host that matches the target with the possible exception of "64"
|
|
# in the name as if it were native.
|
|
if test `echo "$host" | sed -e s/64//` = `echo "$target" | sed -e s/64//`; then
|
|
case " $EMULATION_LIBPATH " in
|
|
*" ${EMULATION_NAME} "*)
|
|
NATIVE=yes
|
|
;;
|
|
esac
|
|
fi
|
|
|
|
# Look for 64 bit target libraries in /lib64, /usr/lib64 etc., first.
|
|
# Similarly, look for 32 bit libraries in /lib32, /usr/lib32 etc.
|
|
case `echo "$target" | sed -e 's/-.*//'`:"$EMULATION_NAME" in
|
|
*le:*64lppc*) LIBPATH_SUFFIX=64 ;;
|
|
*le:*32lppc*) LIBPATH_SUFFIX=32 ;;
|
|
*le:*64*) LIBPATH_SUFFIX=64be ;;
|
|
*le:*32*) LIBPATH_SUFFIX=32be ;;
|
|
*:*64lppc*) LIBPATH_SUFFIX=64le ;;
|
|
*:*32lppc*) LIBPATH_SUFFIX=32le ;;
|
|
*:*64*) LIBPATH_SUFFIX=64 ;;
|
|
*:*32*) LIBPATH_SUFFIX=32 ;;
|
|
esac
|