mirror of
https://sourceware.org/git/glibc.git
synced 2025-01-18 06:30:05 +00:00
1999-07-20 Mark Kettenis <kettenis@gnu.org>
* sysdeps/mach/_strerror.c: Include <libintl.h>. 1999-07-19 Roland McGrath <roland@baalperazim.frob.com> * hurd/hurdsig.c (_hurd_internal_post_signal): If a hurd_signal_preemptor matches but its `preemptor' field is null, use its `handler' field directly. This is to comply with behavior documented in <hurd/sigpreempt.h>.
This commit is contained in:
parent
6818bcaef7
commit
e26996aa99
11
ChangeLog
11
ChangeLog
@ -1,3 +1,14 @@
|
|||||||
|
1999-07-20 Mark Kettenis <kettenis@gnu.org>
|
||||||
|
|
||||||
|
* sysdeps/mach/_strerror.c: Include <libintl.h>.
|
||||||
|
|
||||||
|
1999-07-19 Roland McGrath <roland@baalperazim.frob.com>
|
||||||
|
|
||||||
|
* hurd/hurdsig.c (_hurd_internal_post_signal): If a
|
||||||
|
hurd_signal_preemptor matches but its `preemptor' field is null, use
|
||||||
|
its `handler' field directly. This is to comply with behavior
|
||||||
|
documented in <hurd/sigpreempt.h>.
|
||||||
|
|
||||||
1999-07-21 Andreas Schwab <schwab@suse.de>
|
1999-07-21 Andreas Schwab <schwab@suse.de>
|
||||||
|
|
||||||
* libio/fileops.c (_IO_new_file_underflow): Set error indicator
|
* libio/fileops.c (_IO_new_file_underflow): Set error indicator
|
||||||
|
@ -1,4 +1,4 @@
|
|||||||
/* Copyright (C) 1991, 92, 93, 94, 95, 96, 97, 98 Free Software Foundation, Inc.
|
/* Copyright (C) 1991,92,93,94,95,96,97,98,99 Free Software Foundation, Inc.
|
||||||
This file is part of the GNU C Library.
|
This file is part of the GNU C Library.
|
||||||
|
|
||||||
The GNU C Library is free software; you can redistribute it and/or
|
The GNU C Library is free software; you can redistribute it and/or
|
||||||
@ -448,7 +448,6 @@ _hurd_internal_post_signal (struct hurd_sigstate *ss,
|
|||||||
error_t err;
|
error_t err;
|
||||||
struct machine_thread_all_state thread_state;
|
struct machine_thread_all_state thread_state;
|
||||||
enum { stop, ignore, core, term, handle } act;
|
enum { stop, ignore, core, term, handle } act;
|
||||||
struct hurd_signal_preemptor *pe;
|
|
||||||
sighandler_t handler;
|
sighandler_t handler;
|
||||||
sigset_t pending;
|
sigset_t pending;
|
||||||
int ss_suspended;
|
int ss_suspended;
|
||||||
@ -549,20 +548,38 @@ _hurd_internal_post_signal (struct hurd_sigstate *ss,
|
|||||||
|
|
||||||
/* Check for a preempted signal. Preempted signals can arrive during
|
/* Check for a preempted signal. Preempted signals can arrive during
|
||||||
critical sections. */
|
critical sections. */
|
||||||
|
{
|
||||||
|
inline sighandler_t try_preemptor (struct hurd_signal_preemptor *pe)
|
||||||
|
{ /* PE cannot be null. */
|
||||||
|
do
|
||||||
|
{
|
||||||
|
if (HURD_PREEMPT_SIGNAL_P (pe, signo, detail->code))
|
||||||
|
{
|
||||||
|
if (pe->preemptor)
|
||||||
|
{
|
||||||
|
sighandler_t handler = (*pe->preemptor) (pe, ss,
|
||||||
|
&signo, detail);
|
||||||
|
if (handler != SIG_ERR)
|
||||||
|
return handler;
|
||||||
|
}
|
||||||
|
else
|
||||||
|
return pe->handler;
|
||||||
|
}
|
||||||
|
pe = pe->next;
|
||||||
|
} while (pe != 0);
|
||||||
|
return SIG_ERR;
|
||||||
|
}
|
||||||
|
|
||||||
handler = SIG_ERR;
|
handler = ss->preemptors ? try_preemptor (ss->preemptors) : SIG_ERR;
|
||||||
for (pe = ss->preemptors; pe && handler == SIG_ERR; pe = pe->next)
|
|
||||||
if (HURD_PREEMPT_SIGNAL_P (pe, signo, detail->code))
|
|
||||||
handler = (*pe->preemptor) (pe, ss, &signo, detail);
|
|
||||||
|
|
||||||
if (handler == SIG_ERR && (__sigmask (signo) & _hurdsig_preempted_set))
|
/* If no thread-specific preemptor, check for a global one. */
|
||||||
{
|
if (handler == SIG_ERR && (__sigmask (signo) & _hurdsig_preempted_set))
|
||||||
__mutex_lock (&_hurd_siglock);
|
{
|
||||||
for (pe = _hurdsig_preemptors; pe && handler == SIG_ERR; pe = pe->next)
|
__mutex_lock (&_hurd_siglock);
|
||||||
if (HURD_PREEMPT_SIGNAL_P (pe, signo, detail->code))
|
handler = try_preemptor (_hurdsig_preemptors);
|
||||||
handler = (*pe->preemptor) (pe, ss, &signo, detail);
|
__mutex_unlock (&_hurd_siglock);
|
||||||
__mutex_unlock (&_hurd_siglock);
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
ss_suspended = 0;
|
ss_suspended = 0;
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user