f32da6f20f
* new .base64 pseudo-op, allowing base64 encoded data as strings * Intel APX: add support for CFCMOV, CCMP, CTEST, zero-upper, NF (APX_F now fully supported) * x86 Intel syntax now warns about more mnemonic suffixes * macros and .irp/.irpc/.rept bodies can use \+ to get at number of times the macro/body was executed * aarch64: support 'armv9.5-a' for -march, add support for LUT and LUT2 * s390: base register operand in D(X,B) and D(L,B) can now be omitted (ala 'D(X,)'); warn when register type doesn't match operand type (use option 'warn-regtype-mismatch=[strict|relaxed|no]' to adjust) * riscv: support various extensions: Zacas, Zcmp, Zfbfmin, Zvfbfmin, Zvfbfwma, Smcsrind/Sscsrind, XCvMem, XCvBi, XCvElw, XSfCease, all at version 1.0; remove support for assembly of privileged spec 1.9.1 (linking support remains) * arm: remove support for some old co-processors: Maverick and FPA * mips: '--trap' now causes either trap or breakpoint instructions to be emitted as per current ISA, instead of always using trap insn and failing when current ISA was incompatible with that * LoongArch: accept .option pseudo-op for fine-grained control of assembly code options; add support for DT_RELR * readelf: now displays RELR relocations in full detail; add -j/--display-section to show just those section(s) content according to their type * objdump/readelf now dump also .eh_frame_hdr (when present) when dumping .eh_frame * gprofng: add event types for AMD Zen3/Zen4 and Intel Ice Lake processors; add minimal support for riscv * linker: OBS-URL: https://build.opensuse.org/package/show/devel:gcc/binutils?expand=0&rev=471
128 lines
3.4 KiB
Diff
128 lines
3.4 KiB
Diff
diff --git a/ld/emultempl/elf.em b/ld/emultempl/elf.em
|
|
index 42c552b36e..dd0a6b1e60 100644
|
|
--- a/ld/emultempl/elf.em
|
|
+++ b/ld/emultempl/elf.em
|
|
@@ -135,6 +135,8 @@ if test x"$LDEMUL_BEFORE_ALLOCATION" != xgld"$EMULATION_NAME"_before_allocation;
|
|
if test x"${ELF_INTERPRETER_NAME}" = x; then
|
|
ELF_INTERPRETER_NAME=NULL
|
|
fi
|
|
+
|
|
+ libpath_nl=`echo ${NATIVE_LIB_DIRS// /\\\n}`
|
|
fragment <<EOF
|
|
|
|
/* This is called after the sections have been attached to output
|
|
diff --git a/ld/ldelf.c b/ld/ldelf.c
|
|
index 2e27cf48a8..7162d0cf91 100644
|
|
--- a/ld/ldelf.c
|
|
+++ b/ld/ldelf.c
|
|
@@ -1506,6 +1506,31 @@ ldelf_append_to_separated_string (char **to, char *op_arg)
|
|
}
|
|
}
|
|
|
|
+static int
|
|
+ldelf_is_contained (const char *path, const char *dc)
|
|
+{
|
|
+ while (*dc)
|
|
+ {
|
|
+ const char *pc = path;
|
|
+
|
|
+ while (*dc && *pc && *dc == *pc && *dc != '\n'
|
|
+ && *pc != ':' && *dc != '=')
|
|
+ {
|
|
+ dc++;
|
|
+ pc++;
|
|
+ }
|
|
+ if ((*pc == 0 || *pc == ':') && (*dc == '\n' || *dc == '=' || *dc == 0))
|
|
+ return 1;
|
|
+
|
|
+ while (*dc && *dc != '\n')
|
|
+ dc++;
|
|
+ if (*dc == '\n')
|
|
+ dc++;
|
|
+ }
|
|
+
|
|
+ return 0;
|
|
+}
|
|
+
|
|
/* This is called after the sections have been attached to output
|
|
sections, but before any sizes or addresses have been set. */
|
|
|
|
@@ -1513,7 +1538,7 @@ void
|
|
ldelf_before_allocation (char *audit, char *depaudit,
|
|
const char *default_interpreter_name)
|
|
{
|
|
- const char *rpath;
|
|
+ char *rpath;
|
|
asection *sinterp;
|
|
bfd *abfd;
|
|
struct bfd_link_hash_entry *ehdr_start = NULL;
|
|
@@ -1608,7 +1633,67 @@ ldelf_before_allocation (char *audit, char *depaudit,
|
|
by dynamic linking. */
|
|
rpath = command_line.rpath;
|
|
if (rpath == NULL)
|
|
- rpath = (const char *) getenv ("LD_RUN_PATH");
|
|
+ rpath = getenv ("LD_RUN_PATH");
|
|
+
|
|
+ if (rpath != NULL && getenv ("SUSE_IGNORED_RPATHS"))
|
|
+ {
|
|
+ char *dirs = 0;
|
|
+ FILE *ldso = fopen (getenv ("SUSE_IGNORED_RPATHS"), "r");
|
|
+ if (ldso)
|
|
+ {
|
|
+ off_t endcur = 0;
|
|
+ fseek (ldso, 0, SEEK_END);
|
|
+ endcur = ftell (ldso);
|
|
+ fseek (ldso, 0, SEEK_SET);
|
|
+ dirs = xmalloc (endcur + 1);
|
|
+ if (fread (dirs, 1, endcur, ldso) != (size_t) endcur)
|
|
+ {
|
|
+ free (dirs);
|
|
+ dirs = NULL;
|
|
+ }
|
|
+ else
|
|
+ dirs[endcur] = '\0';
|
|
+ }
|
|
+ if (dirs)
|
|
+ {
|
|
+ char *cr;
|
|
+ rpath = xstrdup (rpath);
|
|
+ cr = rpath; /* cursor read */
|
|
+
|
|
+ while (*cr)
|
|
+ {
|
|
+ if (ldelf_is_contained (cr, dirs)
|
|
+ || ldelf_is_contained (cr, "$libpath_nl"))
|
|
+ {
|
|
+ char *cc = cr, *cw = cr;
|
|
+ while (*cc && *cc != ':')
|
|
+ cc++;
|
|
+ if (*cc == ':')
|
|
+ {
|
|
+ cc++;
|
|
+ for (; *cc; cc++, cw++)
|
|
+ *cw = *cc;
|
|
+ }
|
|
+ else if (cw > rpath)
|
|
+ cw[-1] = 0;
|
|
+
|
|
+ *cw = 0;
|
|
+ }
|
|
+ else
|
|
+ {
|
|
+ while (*cr && *cr != ':')
|
|
+ cr++;
|
|
+ if (*cr == ':')
|
|
+ cr++;
|
|
+ }
|
|
+ }
|
|
+ if (*rpath == '\0')
|
|
+ {
|
|
+ free (rpath);
|
|
+ rpath = NULL;
|
|
+ }
|
|
+ }
|
|
+ }
|
|
|
|
for (abfd = link_info.input_bfds; abfd; abfd = abfd->link.next)
|
|
if (bfd_get_flavour (abfd) == bfd_target_elf_flavour)
|