mirror of
git://sourceware.org/git/glibc.git
synced 2025-03-31 14:01:18 +08:00
hurd: Make _exit work during early boot-up
If any of the early boot-up tasks calls exit () or returns from main (), terminate it properly instead of crashing on trying to dereference _hurd_ports and getting forcibly terminated by the kernel. We sadly cannot make the __USEPORT macro do the check for _hurd_ports being unset, because it evaluates to the value of the expression provided as the second argument, and that can be of any type; so there is no single suitable fallback value for the macro to evaluate to in case _hurd_ports is unset. Instead, each use site that wants to care for this case will have to do its own checking. Checked on x86_64-gnu. Signed-off-by: Sergey Bugaev <bugaevc@gmail.com> Message-Id: <20230429131354.2507443-4-bugaevc@gmail.com>
This commit is contained in:
parent
a9fb57105e
commit
41aac87234
@ -24,8 +24,9 @@
|
||||
void
|
||||
_hurd_exit (int status)
|
||||
{
|
||||
/* Give the proc server our exit status. */
|
||||
__USEPORT (PROC, __proc_mark_exit (port, status, 0));
|
||||
if (_hurd_ports != NULL)
|
||||
/* Give the proc server our exit status. */
|
||||
__USEPORT (PROC, __proc_mark_exit (port, status, 0));
|
||||
|
||||
/* Commit suicide. */
|
||||
__task_terminate (__mach_task_self ());
|
||||
|
Loading…
x
Reference in New Issue
Block a user