svn commit: r364675 - head/sys/powerpc/powerpc
Leandro Lupori
luporl at FreeBSD.org
Mon Aug 24 13:40:36 UTC 2020
Author: luporl
Date: Mon Aug 24 13:40:35 2020
New Revision: 364675
URL: https://svnweb.freebsd.org/changeset/base/364675
Log:
[PowerPC] Make new auxv format default
Assume ELF images without OSREL use the new auxv format.
This is specially important for rtld, that is not tagged. Using
direct exec mode with new (ELFv2) binaries that expect the new auxv
format would result in crashes otherwise.
Unfortunately, this may break direct exec'ing old binaries,
but it seems better to correctly support new binaries by default,
considering the transition to ELFv2 happened quite some time
ago. If needed, a sysctl may be added to allow old auxv format to
be used when OSREL is not found.
Reviewed by: bdragon
Sponsored by: Eldorado Research Institute (eldorado.org.br)
Differential Revision: https://reviews.freebsd.org/D25651
Modified:
head/sys/powerpc/powerpc/elf_common.c
Modified: head/sys/powerpc/powerpc/elf_common.c
==============================================================================
--- head/sys/powerpc/powerpc/elf_common.c Mon Aug 24 13:19:16 2020 (r364674)
+++ head/sys/powerpc/powerpc/elf_common.c Mon Aug 24 13:40:35 2020 (r364675)
@@ -36,7 +36,22 @@ __elfN(powerpc_copyout_auxargs)(struct image_params *i
Elf_Auxinfo *argarray, *pos;
int error;
- if (imgp->proc->p_osrel >= P_OSREL_POWERPC_NEW_AUX_ARGS)
+ /*
+ * XXX If we can't find image's OSREL, assume it uses the new auxv
+ * format.
+ *
+ * This is specially important for rtld, that is not tagged. Using
+ * direct exec mode with new (ELFv2) binaries that expect the new auxv
+ * format would result in crashes otherwise.
+ *
+ * Unfortunately, this may break direct exec'ing old binaries,
+ * but it seems better to correctly support new binaries by default,
+ * considering the transition to ELFv2 happened quite some time
+ * ago. If needed, a sysctl may be added to allow old auxv format to
+ * be used when OSREL is not found.
+ */
+ if (imgp->proc->p_osrel >= P_OSREL_POWERPC_NEW_AUX_ARGS ||
+ imgp->proc->p_osrel == 0)
return (__elfN(freebsd_copyout_auxargs)(imgp, base));
args = (Elf_Auxargs *)imgp->auxargs;
More information about the svn-src-head
mailing list