aboutsummaryrefslogtreecommitdiff
path: root/sys/kern/link_elf.c
diff options
context:
space:
mode:
authorPeter Wemm <peter@FreeBSD.org>2003-04-06 05:20:00 +0000
committerPeter Wemm <peter@FreeBSD.org>2003-04-06 05:20:00 +0000
commit67db8b23c39868ba4da8b345f306242e239c6868 (patch)
tree5b658f1dcc9264a61cce8f8d8782caff11379b22 /sys/kern/link_elf.c
parentf7e19a98fdf21f5d7bddacbea2f6a7e030cd32f5 (diff)
downloadsrc-67db8b23c39868ba4da8b345f306242e239c6868.tar.gz
src-67db8b23c39868ba4da8b345f306242e239c6868.zip
Search for "elf32 kernel" (and elf64) and "elf32 module" (and elf64)
as well as "elf kernel" and "elf module". This is a precursor to x86-64 support in the i386 loader so it can load an elf64 x86-64 kernel.
Notes
Notes: svn path=/head/; revision=113158
Diffstat (limited to 'sys/kern/link_elf.c')
-rw-r--r--sys/kern/link_elf.c8
1 files changed, 6 insertions, 2 deletions
diff --git a/sys/kern/link_elf.c b/sys/kern/link_elf.c
index f15803fa8435..1d27f735294d 100644
--- a/sys/kern/link_elf.c
+++ b/sys/kern/link_elf.c
@@ -258,7 +258,9 @@ link_elf_init(void* arg)
dp = (Elf_Dyn*) &_DYNAMIC;
modname = NULL;
- modptr = preload_search_by_type("elf kernel");
+ modptr = preload_search_by_type("elf" __XSTRING(__ELF_WORD_SIZE) " kernel");
+ if (modptr == NULL)
+ modptr = preload_search_by_type("elf kernel");
if (modptr)
modname = (char *)preload_search_info(modptr, MODINFO_NAME);
if (modname == NULL)
@@ -462,7 +464,9 @@ link_elf_link_preload(linker_class_t cls,
baseptr = preload_search_info(modptr, MODINFO_ADDR);
sizeptr = preload_search_info(modptr, MODINFO_SIZE);
dynptr = preload_search_info(modptr, MODINFO_METADATA|MODINFOMD_DYNAMIC);
- if (type == NULL || strcmp(type, "elf module") != 0)
+ if (type == NULL ||
+ (strcmp(type, "elf" __XSTRING(__ELF_WORD_SIZE) " module") != 0 &&
+ strcmp(type, "elf module") != 0))
return (EFTYPE);
if (baseptr == NULL || sizeptr == NULL || dynptr == NULL)
return (EINVAL);