linux: fix architecture returned for uname on aarch64
Previously it would return "arm64", which was breaking build for Linux kernel. While here, reshuffle entries in the auxv vector to match real Linux. Reviewed By: emaste Sponsored By: EPSRC Differential Revision: https://reviews.freebsd.org/D30500
This commit is contained in:
parent
f0f4712165
commit
aa462cab60
@ -40,7 +40,7 @@
|
|||||||
|
|
||||||
.globl linux_platform
|
.globl linux_platform
|
||||||
linux_platform:
|
linux_platform:
|
||||||
.asciz "arm64"
|
.asciz "aarch64"
|
||||||
|
|
||||||
.text
|
.text
|
||||||
|
|
||||||
|
@ -172,11 +172,11 @@ linux_copyout_auxargs(struct image_params *imgp, uintptr_t base)
|
|||||||
#if 0 /* LINUXTODO: implement arm64 LINUX_AT_HWCAP */
|
#if 0 /* LINUXTODO: implement arm64 LINUX_AT_HWCAP */
|
||||||
AUXARGS_ENTRY(pos, LINUX_AT_HWCAP, cpu_feature);
|
AUXARGS_ENTRY(pos, LINUX_AT_HWCAP, cpu_feature);
|
||||||
#endif
|
#endif
|
||||||
|
AUXARGS_ENTRY(pos, AT_PAGESZ, args->pagesz);
|
||||||
AUXARGS_ENTRY(pos, LINUX_AT_CLKTCK, stclohz);
|
AUXARGS_ENTRY(pos, LINUX_AT_CLKTCK, stclohz);
|
||||||
AUXARGS_ENTRY(pos, AT_PHDR, args->phdr);
|
AUXARGS_ENTRY(pos, AT_PHDR, args->phdr);
|
||||||
AUXARGS_ENTRY(pos, AT_PHENT, args->phent);
|
AUXARGS_ENTRY(pos, AT_PHENT, args->phent);
|
||||||
AUXARGS_ENTRY(pos, AT_PHNUM, args->phnum);
|
AUXARGS_ENTRY(pos, AT_PHNUM, args->phnum);
|
||||||
AUXARGS_ENTRY(pos, AT_PAGESZ, args->pagesz);
|
|
||||||
AUXARGS_ENTRY(pos, AT_BASE, args->base);
|
AUXARGS_ENTRY(pos, AT_BASE, args->base);
|
||||||
AUXARGS_ENTRY(pos, AT_FLAGS, args->flags);
|
AUXARGS_ENTRY(pos, AT_FLAGS, args->flags);
|
||||||
AUXARGS_ENTRY(pos, AT_ENTRY, args->entry);
|
AUXARGS_ENTRY(pos, AT_ENTRY, args->entry);
|
||||||
@ -185,15 +185,14 @@ linux_copyout_auxargs(struct image_params *imgp, uintptr_t base)
|
|||||||
AUXARGS_ENTRY(pos, AT_GID, imgp->proc->p_ucred->cr_rgid);
|
AUXARGS_ENTRY(pos, AT_GID, imgp->proc->p_ucred->cr_rgid);
|
||||||
AUXARGS_ENTRY(pos, AT_EGID, imgp->proc->p_ucred->cr_svgid);
|
AUXARGS_ENTRY(pos, AT_EGID, imgp->proc->p_ucred->cr_svgid);
|
||||||
AUXARGS_ENTRY(pos, LINUX_AT_SECURE, issetugid);
|
AUXARGS_ENTRY(pos, LINUX_AT_SECURE, issetugid);
|
||||||
#if 0 /* LINUXTODO: implement arm64 LINUX_AT_PLATFORM */
|
|
||||||
AUXARGS_ENTRY(pos, LINUX_AT_PLATFORM, PTROUT(linux_platform));
|
|
||||||
#endif
|
|
||||||
AUXARGS_ENTRY_PTR(pos, LINUX_AT_RANDOM, imgp->canary);
|
AUXARGS_ENTRY_PTR(pos, LINUX_AT_RANDOM, imgp->canary);
|
||||||
if (imgp->execpathp != 0)
|
if (imgp->execpathp != 0)
|
||||||
AUXARGS_ENTRY_PTR(pos, LINUX_AT_EXECFN, imgp->execpathp);
|
AUXARGS_ENTRY_PTR(pos, LINUX_AT_EXECFN, imgp->execpathp);
|
||||||
if (args->execfd != -1)
|
if (args->execfd != -1)
|
||||||
AUXARGS_ENTRY(pos, AT_EXECFD, args->execfd);
|
AUXARGS_ENTRY(pos, AT_EXECFD, args->execfd);
|
||||||
|
AUXARGS_ENTRY(pos, LINUX_AT_PLATFORM, PTROUT(linux_platform));
|
||||||
AUXARGS_ENTRY(pos, AT_NULL, 0);
|
AUXARGS_ENTRY(pos, AT_NULL, 0);
|
||||||
|
|
||||||
free(imgp->auxargs, M_TEMP);
|
free(imgp->auxargs, M_TEMP);
|
||||||
imgp->auxargs = NULL;
|
imgp->auxargs = NULL;
|
||||||
KASSERT(pos - argarray <= LINUX_AT_COUNT, ("Too many auxargs"));
|
KASSERT(pos - argarray <= LINUX_AT_COUNT, ("Too many auxargs"));
|
||||||
@ -464,13 +463,8 @@ linux_vdso_install(const void *param)
|
|||||||
linux_szsigcode);
|
linux_szsigcode);
|
||||||
elf_linux_sysvec.sv_shared_page_obj = linux_shared_page_obj;
|
elf_linux_sysvec.sv_shared_page_obj = linux_shared_page_obj;
|
||||||
|
|
||||||
printf("LINUXTODO: %s: fix linux_kplatform\n", __func__);
|
|
||||||
#if 0
|
|
||||||
linux_kplatform = linux_shared_page_mapping +
|
linux_kplatform = linux_shared_page_mapping +
|
||||||
(linux_platform - (caddr_t)elf_linux_sysvec.sv_shared_page_base);
|
(linux_platform - (caddr_t)elf_linux_sysvec.sv_shared_page_base);
|
||||||
#else
|
|
||||||
linux_kplatform = "arm64";
|
|
||||||
#endif
|
|
||||||
}
|
}
|
||||||
SYSINIT(elf_linux_vdso_init, SI_SUB_EXEC, SI_ORDER_ANY,
|
SYSINIT(elf_linux_vdso_init, SI_SUB_EXEC, SI_ORDER_ANY,
|
||||||
linux_vdso_install, NULL);
|
linux_vdso_install, NULL);
|
||||||
|
Loading…
x
Reference in New Issue
Block a user