1995-08-22 22:47:57 +00:00
|
|
|
|
/* Machine-dependent details of interruptible RPC messaging. i386 version.
|
2024-01-01 18:12:26 +00:00
|
|
|
|
Copyright (C) 1995-2024 Free Software Foundation, Inc.
|
1997-06-23 21:55:26 +00:00
|
|
|
|
This file is part of the GNU C Library.
|
1995-08-22 22:47:57 +00:00
|
|
|
|
|
1997-06-23 21:55:26 +00:00
|
|
|
|
The GNU C Library is free software; you can redistribute it and/or
|
2001-07-06 04:58:11 +00:00
|
|
|
|
modify it under the terms of the GNU Lesser General Public
|
|
|
|
|
License as published by the Free Software Foundation; either
|
|
|
|
|
version 2.1 of the License, or (at your option) any later version.
|
1995-08-22 22:47:57 +00:00
|
|
|
|
|
1997-06-23 21:55:26 +00:00
|
|
|
|
The GNU C Library is distributed in the hope that it will be useful,
|
|
|
|
|
but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
|
|
|
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
|
2001-07-06 04:58:11 +00:00
|
|
|
|
Lesser General Public License for more details.
|
1995-08-22 22:47:57 +00:00
|
|
|
|
|
2001-07-06 04:58:11 +00:00
|
|
|
|
You should have received a copy of the GNU Lesser General Public
|
2012-02-09 23:18:22 +00:00
|
|
|
|
License along with the GNU C Library; if not, see
|
Prefer https to http for gnu.org and fsf.org URLs
Also, change sources.redhat.com to sourceware.org.
This patch was automatically generated by running the following shell
script, which uses GNU sed, and which avoids modifying files imported
from upstream:
sed -ri '
s,(http|ftp)(://(.*\.)?(gnu|fsf|sourceware)\.org($|[^.]|\.[^a-z])),https\2,g
s,(http|ftp)(://(.*\.)?)sources\.redhat\.com($|[^.]|\.[^a-z]),https\2sourceware.org\4,g
' \
$(find $(git ls-files) -prune -type f \
! -name '*.po' \
! -name 'ChangeLog*' \
! -path COPYING ! -path COPYING.LIB \
! -path manual/fdl-1.3.texi ! -path manual/lgpl-2.1.texi \
! -path manual/texinfo.tex ! -path scripts/config.guess \
! -path scripts/config.sub ! -path scripts/install-sh \
! -path scripts/mkinstalldirs ! -path scripts/move-if-change \
! -path INSTALL ! -path locale/programs/charmap-kw.h \
! -path po/libc.pot ! -path sysdeps/gnu/errlist.c \
! '(' -name configure \
-execdir test -f configure.ac -o -f configure.in ';' ')' \
! '(' -name preconfigure \
-execdir test -f preconfigure.ac ';' ')' \
-print)
and then by running 'make dist-prepare' to regenerate files built
from the altered files, and then executing the following to cleanup:
chmod a+x sysdeps/unix/sysv/linux/riscv/configure
# Omit irrelevant whitespace and comment-only changes,
# perhaps from a slightly-different Autoconf version.
git checkout -f \
sysdeps/csky/configure \
sysdeps/hppa/configure \
sysdeps/riscv/configure \
sysdeps/unix/sysv/linux/csky/configure
# Omit changes that caused a pre-commit check to fail like this:
# remote: *** error: sysdeps/powerpc/powerpc64/ppc-mcount.S: trailing lines
git checkout -f \
sysdeps/powerpc/powerpc64/ppc-mcount.S \
sysdeps/unix/sysv/linux/s390/s390-64/syscall.S
# Omit change that caused a pre-commit check to fail like this:
# remote: *** error: sysdeps/sparc/sparc64/multiarch/memcpy-ultra3.S: last line does not end in newline
git checkout -f sysdeps/sparc/sparc64/multiarch/memcpy-ultra3.S
2019-09-07 05:40:42 +00:00
|
|
|
|
<https://www.gnu.org/licenses/>. */
|
1995-08-22 22:47:57 +00:00
|
|
|
|
|
|
|
|
|
|
1999-08-22 22:23:58 +00:00
|
|
|
|
/* Note that we must mark OPTION and TIMEOUT as outputs of this operation,
|
|
|
|
|
to indicate that the signal thread might mutate them as part
|
|
|
|
|
of sending us to a signal handler. */
|
2018-10-09 21:40:09 +00:00
|
|
|
|
|
|
|
|
|
#define INTR_MSG_TRAP(msg, option, send_size, rcv_size, rcv_name, timeout, notify, cancel_p, intr_port_p) \
|
1995-08-22 22:47:57 +00:00
|
|
|
|
({ \
|
|
|
|
|
error_t err; \
|
2018-10-09 21:40:09 +00:00
|
|
|
|
asm (".globl _hurd_intr_rpc_msg_about_to\n" \
|
hurd: Remove the ecx kludge
"We don't need it any more"
The INTR_MSG_TRAP macro in intr-msg.h used to play little trick with
the stack pointer: it would temporarily save the "real" stack pointer
into ecx, while setting esp to point to just before the message buffer,
and then invoke the mach_msg trap. This way, INTR_MSG_TRAP reused the
on-stack arguments laid out for the containing call of
_hurd_intr_rpc_mach_msg (), passing them to the mach_msg trap directly.
This, however, required special support in hurdsig.c and trampoline.c,
since they now had to recognize when a thread is inside the piece of
code where esp doesn't point to the real tip of the stack, and handle
this situation specially.
Commit 1d20f33ff4fb634310f27493b7b87d0b20f4a0b0 has removed the actual
temporary change of esp by actually re-pushing mach_msg arguments onto
the stack, and popping them back at end. It did not, however, deal with
the rest of "the ecx kludge" code in other files, resulting in potential
crashes if a signal arrives in the middle of pushing arguments onto the
stack.
Fix that by removing "the ecx kludge". Instead, when we want a thread
to skip the RPC, but cannot make just make it jump to after the trap
since it's not done adjusting the stack yet, set the SYSRETURN register
to MACH_SEND_INTERRUPTED (as we do anyway), and rely on the thread
itself for detecting this case and skipping the RPC.
This simplifies things somewhat and paves the way for a future x86_64
port of this code.
Signed-off-by: Sergey Bugaev <bugaevc@gmail.com>
Message-Id: <20230301162355.426887-1-bugaevc@gmail.com>
2023-03-01 16:23:54 +00:00
|
|
|
|
".globl _hurd_intr_rpc_msg_setup_done\n" \
|
2018-10-09 21:40:09 +00:00
|
|
|
|
".globl _hurd_intr_rpc_msg_in_trap\n" \
|
hurd: Remove the ecx kludge
"We don't need it any more"
The INTR_MSG_TRAP macro in intr-msg.h used to play little trick with
the stack pointer: it would temporarily save the "real" stack pointer
into ecx, while setting esp to point to just before the message buffer,
and then invoke the mach_msg trap. This way, INTR_MSG_TRAP reused the
on-stack arguments laid out for the containing call of
_hurd_intr_rpc_mach_msg (), passing them to the mach_msg trap directly.
This, however, required special support in hurdsig.c and trampoline.c,
since they now had to recognize when a thread is inside the piece of
code where esp doesn't point to the real tip of the stack, and handle
this situation specially.
Commit 1d20f33ff4fb634310f27493b7b87d0b20f4a0b0 has removed the actual
temporary change of esp by actually re-pushing mach_msg arguments onto
the stack, and popping them back at end. It did not, however, deal with
the rest of "the ecx kludge" code in other files, resulting in potential
crashes if a signal arrives in the middle of pushing arguments onto the
stack.
Fix that by removing "the ecx kludge". Instead, when we want a thread
to skip the RPC, but cannot make just make it jump to after the trap
since it's not done adjusting the stack yet, set the SYSRETURN register
to MACH_SEND_INTERRUPTED (as we do anyway), and rely on the thread
itself for detecting this case and skipping the RPC.
This simplifies things somewhat and paves the way for a future x86_64
port of this code.
Signed-off-by: Sergey Bugaev <bugaevc@gmail.com>
Message-Id: <20230301162355.426887-1-bugaevc@gmail.com>
2023-03-01 16:23:54 +00:00
|
|
|
|
/* Clear eax before we do the check for cancel below. This is to
|
|
|
|
|
detect eax being set to non-zero (actually MACH_SEND_INTERRUPTED)
|
|
|
|
|
from the outside (namely, _hurdsig_abort_rpcs), which signals us
|
|
|
|
|
to skip the trap we were about to enter. */ \
|
|
|
|
|
" xorl %0, %0\n" \
|
2021-10-17 22:43:23 +00:00
|
|
|
|
"_hurd_intr_rpc_msg_about_to:" \
|
|
|
|
|
/* We need to make a last check of cancel, in case we got interrupted
|
|
|
|
|
right before _hurd_intr_rpc_msg_about_to. */ \
|
|
|
|
|
" cmpl $0, %5\n" \
|
2018-10-09 21:40:09 +00:00
|
|
|
|
" jz _hurd_intr_rpc_msg_do\n" \
|
2021-10-17 22:43:23 +00:00
|
|
|
|
/* We got interrupted, note so and return EINTR. */ \
|
2018-10-09 21:40:09 +00:00
|
|
|
|
" movl $0, %3\n" \
|
hurd: Remove the ecx kludge
"We don't need it any more"
The INTR_MSG_TRAP macro in intr-msg.h used to play little trick with
the stack pointer: it would temporarily save the "real" stack pointer
into ecx, while setting esp to point to just before the message buffer,
and then invoke the mach_msg trap. This way, INTR_MSG_TRAP reused the
on-stack arguments laid out for the containing call of
_hurd_intr_rpc_mach_msg (), passing them to the mach_msg trap directly.
This, however, required special support in hurdsig.c and trampoline.c,
since they now had to recognize when a thread is inside the piece of
code where esp doesn't point to the real tip of the stack, and handle
this situation specially.
Commit 1d20f33ff4fb634310f27493b7b87d0b20f4a0b0 has removed the actual
temporary change of esp by actually re-pushing mach_msg arguments onto
the stack, and popping them back at end. It did not, however, deal with
the rest of "the ecx kludge" code in other files, resulting in potential
crashes if a signal arrives in the middle of pushing arguments onto the
stack.
Fix that by removing "the ecx kludge". Instead, when we want a thread
to skip the RPC, but cannot make just make it jump to after the trap
since it's not done adjusting the stack yet, set the SYSRETURN register
to MACH_SEND_INTERRUPTED (as we do anyway), and rely on the thread
itself for detecting this case and skipping the RPC.
This simplifies things somewhat and paves the way for a future x86_64
port of this code.
Signed-off-by: Sergey Bugaev <bugaevc@gmail.com>
Message-Id: <20230301162355.426887-1-bugaevc@gmail.com>
2023-03-01 16:23:54 +00:00
|
|
|
|
" movl %6, %0\n" \
|
2018-10-09 21:40:09 +00:00
|
|
|
|
" jmp _hurd_intr_rpc_msg_sp_restored\n" \
|
2021-10-17 22:43:23 +00:00
|
|
|
|
"_hurd_intr_rpc_msg_do:" \
|
hurd: Remove the ecx kludge
"We don't need it any more"
The INTR_MSG_TRAP macro in intr-msg.h used to play little trick with
the stack pointer: it would temporarily save the "real" stack pointer
into ecx, while setting esp to point to just before the message buffer,
and then invoke the mach_msg trap. This way, INTR_MSG_TRAP reused the
on-stack arguments laid out for the containing call of
_hurd_intr_rpc_mach_msg (), passing them to the mach_msg trap directly.
This, however, required special support in hurdsig.c and trampoline.c,
since they now had to recognize when a thread is inside the piece of
code where esp doesn't point to the real tip of the stack, and handle
this situation specially.
Commit 1d20f33ff4fb634310f27493b7b87d0b20f4a0b0 has removed the actual
temporary change of esp by actually re-pushing mach_msg arguments onto
the stack, and popping them back at end. It did not, however, deal with
the rest of "the ecx kludge" code in other files, resulting in potential
crashes if a signal arrives in the middle of pushing arguments onto the
stack.
Fix that by removing "the ecx kludge". Instead, when we want a thread
to skip the RPC, but cannot make just make it jump to after the trap
since it's not done adjusting the stack yet, set the SYSRETURN register
to MACH_SEND_INTERRUPTED (as we do anyway), and rely on the thread
itself for detecting this case and skipping the RPC.
This simplifies things somewhat and paves the way for a future x86_64
port of this code.
Signed-off-by: Sergey Bugaev <bugaevc@gmail.com>
Message-Id: <20230301162355.426887-1-bugaevc@gmail.com>
2023-03-01 16:23:54 +00:00
|
|
|
|
/* Ok, push the mach_msg_trap arguments and a fake return address. */ \
|
2021-10-17 22:43:23 +00:00
|
|
|
|
" pushl 24(%4)\n" \
|
|
|
|
|
" pushl %2\n" \
|
|
|
|
|
" pushl 16(%4)\n" \
|
|
|
|
|
" pushl 12(%4)\n" \
|
|
|
|
|
" pushl 8(%4)\n" \
|
|
|
|
|
" pushl %1\n" \
|
|
|
|
|
" pushl (%4)\n" \
|
|
|
|
|
" pushl $0\n" \
|
hurd: Remove the ecx kludge
"We don't need it any more"
The INTR_MSG_TRAP macro in intr-msg.h used to play little trick with
the stack pointer: it would temporarily save the "real" stack pointer
into ecx, while setting esp to point to just before the message buffer,
and then invoke the mach_msg trap. This way, INTR_MSG_TRAP reused the
on-stack arguments laid out for the containing call of
_hurd_intr_rpc_mach_msg (), passing them to the mach_msg trap directly.
This, however, required special support in hurdsig.c and trampoline.c,
since they now had to recognize when a thread is inside the piece of
code where esp doesn't point to the real tip of the stack, and handle
this situation specially.
Commit 1d20f33ff4fb634310f27493b7b87d0b20f4a0b0 has removed the actual
temporary change of esp by actually re-pushing mach_msg arguments onto
the stack, and popping them back at end. It did not, however, deal with
the rest of "the ecx kludge" code in other files, resulting in potential
crashes if a signal arrives in the middle of pushing arguments onto the
stack.
Fix that by removing "the ecx kludge". Instead, when we want a thread
to skip the RPC, but cannot make just make it jump to after the trap
since it's not done adjusting the stack yet, set the SYSRETURN register
to MACH_SEND_INTERRUPTED (as we do anyway), and rely on the thread
itself for detecting this case and skipping the RPC.
This simplifies things somewhat and paves the way for a future x86_64
port of this code.
Signed-off-by: Sergey Bugaev <bugaevc@gmail.com>
Message-Id: <20230301162355.426887-1-bugaevc@gmail.com>
2023-03-01 16:23:54 +00:00
|
|
|
|
"_hurd_intr_rpc_msg_setup_done:" \
|
|
|
|
|
/* From here on, it is safe to make us jump over the syscall. Now
|
|
|
|
|
check if we have been told to skip the syscall while running
|
|
|
|
|
the above. */ \
|
|
|
|
|
" test %0, %0\n" \
|
|
|
|
|
" jnz _hurd_intr_rpc_msg_in_trap\n" \
|
|
|
|
|
/* Do the actual syscall. */ \
|
|
|
|
|
" movl $-25, %%eax\n" \
|
1995-08-22 22:47:57 +00:00
|
|
|
|
"_hurd_intr_rpc_msg_do_trap: lcall $7, $0 # status in %0\n" \
|
2021-10-17 22:43:23 +00:00
|
|
|
|
"_hurd_intr_rpc_msg_in_trap:" \
|
|
|
|
|
/* Ok, clean the arguments and update OPTION and TIMEOUT. */ \
|
|
|
|
|
" addl $8, %%esp\n" \
|
|
|
|
|
" popl %1\n" \
|
|
|
|
|
" addl $12, %%esp\n" \
|
|
|
|
|
" popl %2\n" \
|
|
|
|
|
" addl $4, %%esp\n" \
|
1995-08-22 22:47:57 +00:00
|
|
|
|
"_hurd_intr_rpc_msg_sp_restored:" \
|
hurd: Remove the ecx kludge
"We don't need it any more"
The INTR_MSG_TRAP macro in intr-msg.h used to play little trick with
the stack pointer: it would temporarily save the "real" stack pointer
into ecx, while setting esp to point to just before the message buffer,
and then invoke the mach_msg trap. This way, INTR_MSG_TRAP reused the
on-stack arguments laid out for the containing call of
_hurd_intr_rpc_mach_msg (), passing them to the mach_msg trap directly.
This, however, required special support in hurdsig.c and trampoline.c,
since they now had to recognize when a thread is inside the piece of
code where esp doesn't point to the real tip of the stack, and handle
this situation specially.
Commit 1d20f33ff4fb634310f27493b7b87d0b20f4a0b0 has removed the actual
temporary change of esp by actually re-pushing mach_msg arguments onto
the stack, and popping them back at end. It did not, however, deal with
the rest of "the ecx kludge" code in other files, resulting in potential
crashes if a signal arrives in the middle of pushing arguments onto the
stack.
Fix that by removing "the ecx kludge". Instead, when we want a thread
to skip the RPC, but cannot make just make it jump to after the trap
since it's not done adjusting the stack yet, set the SYSRETURN register
to MACH_SEND_INTERRUPTED (as we do anyway), and rely on the thread
itself for detecting this case and skipping the RPC.
This simplifies things somewhat and paves the way for a future x86_64
port of this code.
Signed-off-by: Sergey Bugaev <bugaevc@gmail.com>
Message-Id: <20230301162355.426887-1-bugaevc@gmail.com>
2023-03-01 16:23:54 +00:00
|
|
|
|
: "=&a" (err), "+r" (option), "+r" (timeout), "=m" (*intr_port_p) \
|
|
|
|
|
: "r" (&msg), "m" (*cancel_p), "i" (EINTR)); \
|
1995-08-22 22:47:57 +00:00
|
|
|
|
err; \
|
|
|
|
|
})
|
1996-02-08 02:10:15 +00:00
|
|
|
|
|
|
|
|
|
#include "hurdfault.h"
|
|
|
|
|
|
* sysdeps/mach/hurd/Makefile ($(link-rpcuserlibs)): Don't append
options after $(build-module), which is no longer a single command.
(LDFLAGS-link-rpcuserlibs): New variable to hold those options.
(LDFLAGS-libmachuser-link.so, LDFLAGS-libhurduser-link.so): New
variables using it. Reported by Mark Kettenis <kettenis@gnu.org>.
2001-03-11 Roland McGrath <roland@frob.com>
* elf/rtld.c (dl_main): Add cast to quiet warning.
* elf/dl-load.c (_dl_map_object_from_fd): Likewise.
* iconv/gconv_conf.c (__gconv_get_path): Likewise.
(__gconv_read_conf): Likewise.
* iconv/gconv_db.c (gen_steps): Likewise.
(__gconv_find_transform): Likewise.
* locale/programs/charmap-dir.c (fopen_uncompressed): Likewise.
(fopen_uncompressed): Use const in second argument's type.
2001-03-11 Roland McGrath <roland@frob.com>
* sysdeps/mach/hurd/dl-sysdep.c (__writev): New function.
* mach/mach_error.h: Fix ancient #endif syntax.
* hurd/hurdmalloc.c: Likewise.
* sysdeps/generic/atomicity.h (exchange_and_add, atomic_add,
compare_and_swap): Add volatile qualifier to first arg, to bring
these prototypes in line with all the other implementations.
Add a #warning to remind the builder that these are not atomic.
2001-03-04 Roland McGrath <roland@frob.com>
* hurd/vpprintf.c (vpprintf) [USE_IN_LIBIO]: Use innermore first
member of TEMP_F so its type is _IO_FILE * as expected.
* hurd/fopenport.c (seekio): Conditionalize type of POS argument
on [USE_IN_LIBIO]. Check the value for overflow, since for libio
it might exceed off_t's range.
2001-02-25 Roland McGrath <roland@frob.com>
* sysdeps/mach/hurd/sysd-stdio.c (__stdio_reopen): Use prototype.
* sysdeps/unix/bsd/getpt.c (__posix_openpt): Likewise.
* sysdeps/mach/hurd/i386/intr-msg.h (SYSCALL_EXAMINE): Make this a
macro instead of an inline function,
(MSG_EXAMINE): Likewise.
* hurd/hurd/ioctl.h (_HURD_HANDLE_IOCTLS_1): Remove extraneous ##.
* hurd/get-host.c: Include <string.h> for decls of built-ins.
* hurd/hurdchdir.c: Likewise.
* sysdeps/mach/hurd/i386/sigreturn.c: Likweise.
* sysdeps/mach/hurd/opendir.c: Likewise.
* mach/mach_init.c: Include <unistd.h> for _exit decl.
* mach/errsystems.awk: Give output file a trailing newline.
* mach/Machrules (MIG): Prepend CC='${CC}' to the mig command, so that
the script will use our compiler for the cpp stage.
With --enable-all-warnings we get a whole bunch of warnings,
and these are just a few fixes; there are more needed to silence it.
* mach/mach/mig_support.h (__mig_strncpy, mig_strncpy): Add extern
decls before extern inline defns to quiet gcc warning.
* hurd/hurd/threadvar.h (__hurd_threadvar_location_from_sp): Likewise.
* sysdeps/mach/i386/machine-sp.h (__thread_stack_pointer): Likewise.
2001-04-01 05:04:31 +00:00
|
|
|
|
/* This cannot be an inline function because it calls setjmp. */
|
|
|
|
|
#define SYSCALL_EXAMINE(state, callno) \
|
|
|
|
|
({ \
|
|
|
|
|
struct { unsigned int c[2]; } *p = (void *) ((state)->eip - 7); \
|
|
|
|
|
int result; \
|
|
|
|
|
if (_hurdsig_catch_memory_fault (p)) \
|
|
|
|
|
return 0; \
|
|
|
|
|
if (result = p->c[0] == 0x0000009a && (p->c[1] & 0x00ffffff) == 0x00000700) \
|
|
|
|
|
/* The PC is just after an `lcall $7,$0' instruction. \
|
|
|
|
|
This is a system call in progress; %eax holds the call number. */ \
|
|
|
|
|
*(callno) = (state)->eax; \
|
|
|
|
|
_hurdsig_end_catch_fault (); \
|
|
|
|
|
result; \
|
|
|
|
|
})
|
1996-02-08 02:10:15 +00:00
|
|
|
|
|
|
|
|
|
|
|
|
|
|
struct mach_msg_trap_args
|
|
|
|
|
{
|
|
|
|
|
void *retaddr; /* Address mach_msg_trap will return to. */
|
|
|
|
|
/* This is the order of arguments to mach_msg_trap. */
|
|
|
|
|
mach_msg_header_t *msg;
|
|
|
|
|
mach_msg_option_t option;
|
|
|
|
|
mach_msg_size_t send_size;
|
|
|
|
|
mach_msg_size_t rcv_size;
|
|
|
|
|
mach_port_t rcv_name;
|
|
|
|
|
mach_msg_timeout_t timeout;
|
|
|
|
|
mach_port_t notify;
|
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
|
* sysdeps/mach/hurd/Makefile ($(link-rpcuserlibs)): Don't append
options after $(build-module), which is no longer a single command.
(LDFLAGS-link-rpcuserlibs): New variable to hold those options.
(LDFLAGS-libmachuser-link.so, LDFLAGS-libhurduser-link.so): New
variables using it. Reported by Mark Kettenis <kettenis@gnu.org>.
2001-03-11 Roland McGrath <roland@frob.com>
* elf/rtld.c (dl_main): Add cast to quiet warning.
* elf/dl-load.c (_dl_map_object_from_fd): Likewise.
* iconv/gconv_conf.c (__gconv_get_path): Likewise.
(__gconv_read_conf): Likewise.
* iconv/gconv_db.c (gen_steps): Likewise.
(__gconv_find_transform): Likewise.
* locale/programs/charmap-dir.c (fopen_uncompressed): Likewise.
(fopen_uncompressed): Use const in second argument's type.
2001-03-11 Roland McGrath <roland@frob.com>
* sysdeps/mach/hurd/dl-sysdep.c (__writev): New function.
* mach/mach_error.h: Fix ancient #endif syntax.
* hurd/hurdmalloc.c: Likewise.
* sysdeps/generic/atomicity.h (exchange_and_add, atomic_add,
compare_and_swap): Add volatile qualifier to first arg, to bring
these prototypes in line with all the other implementations.
Add a #warning to remind the builder that these are not atomic.
2001-03-04 Roland McGrath <roland@frob.com>
* hurd/vpprintf.c (vpprintf) [USE_IN_LIBIO]: Use innermore first
member of TEMP_F so its type is _IO_FILE * as expected.
* hurd/fopenport.c (seekio): Conditionalize type of POS argument
on [USE_IN_LIBIO]. Check the value for overflow, since for libio
it might exceed off_t's range.
2001-02-25 Roland McGrath <roland@frob.com>
* sysdeps/mach/hurd/sysd-stdio.c (__stdio_reopen): Use prototype.
* sysdeps/unix/bsd/getpt.c (__posix_openpt): Likewise.
* sysdeps/mach/hurd/i386/intr-msg.h (SYSCALL_EXAMINE): Make this a
macro instead of an inline function,
(MSG_EXAMINE): Likewise.
* hurd/hurd/ioctl.h (_HURD_HANDLE_IOCTLS_1): Remove extraneous ##.
* hurd/get-host.c: Include <string.h> for decls of built-ins.
* hurd/hurdchdir.c: Likewise.
* sysdeps/mach/hurd/i386/sigreturn.c: Likweise.
* sysdeps/mach/hurd/opendir.c: Likewise.
* mach/mach_init.c: Include <unistd.h> for _exit decl.
* mach/errsystems.awk: Give output file a trailing newline.
* mach/Machrules (MIG): Prepend CC='${CC}' to the mig command, so that
the script will use our compiler for the cpp stage.
With --enable-all-warnings we get a whole bunch of warnings,
and these are just a few fixes; there are more needed to silence it.
* mach/mach/mig_support.h (__mig_strncpy, mig_strncpy): Add extern
decls before extern inline defns to quiet gcc warning.
* hurd/hurd/threadvar.h (__hurd_threadvar_location_from_sp): Likewise.
* sysdeps/mach/i386/machine-sp.h (__thread_stack_pointer): Likewise.
2001-04-01 05:04:31 +00:00
|
|
|
|
/* This cannot be an inline function because it calls setjmp. */
|
|
|
|
|
#define MSG_EXAMINE(state, msgid, rcvname, send_name, opt, tmout) \
|
|
|
|
|
({ \
|
|
|
|
|
const struct mach_msg_trap_args *args = (const void *) (state)->uesp; \
|
|
|
|
|
mach_msg_header_t *msg; \
|
|
|
|
|
_hurdsig_catch_memory_fault (args) ? -1 : \
|
|
|
|
|
({ \
|
|
|
|
|
msg = args->msg; \
|
|
|
|
|
*(opt) = args->option; \
|
|
|
|
|
*(tmout) = args->timeout; \
|
|
|
|
|
*(rcvname) = args->rcv_name; \
|
|
|
|
|
_hurdsig_end_catch_fault (); \
|
|
|
|
|
if (msg == 0) \
|
|
|
|
|
{ \
|
|
|
|
|
*(send_name) = MACH_PORT_NULL; \
|
|
|
|
|
*(msgid) = 0; \
|
|
|
|
|
} \
|
|
|
|
|
else \
|
|
|
|
|
{ \
|
|
|
|
|
if (_hurdsig_catch_memory_fault (msg)) \
|
|
|
|
|
return -1; \
|
|
|
|
|
*(send_name) = msg->msgh_remote_port; \
|
|
|
|
|
*(msgid) = msg->msgh_id; \
|
|
|
|
|
_hurdsig_end_catch_fault (); \
|
|
|
|
|
} \
|
|
|
|
|
0; \
|
|
|
|
|
}); \
|
|
|
|
|
})
|