diff options
author | Peter Wemm <peter@FreeBSD.org> | 2003-04-06 05:20:00 +0000 |
---|---|---|
committer | Peter Wemm <peter@FreeBSD.org> | 2003-04-06 05:20:00 +0000 |
commit | 67db8b23c39868ba4da8b345f306242e239c6868 (patch) | |
tree | 5b658f1dcc9264a61cce8f8d8782caff11379b22 /sys/kern/link_elf.c | |
parent | f7e19a98fdf21f5d7bddacbea2f6a7e030cd32f5 (diff) | |
download | src-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.c | 8 |
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); |