aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorMike Kelly <mike@weatherwax.co.uk>2026-02-09 20:42:00 +0000
committerSamuel Thibault <samuel.thibault@ens-lyon.org>2026-02-11 01:03:05 +0100
commit807b3d5e48ffa63561de6cf5b4b8f6b877cd9880 (patch)
tree8ddfd2b7733a7684a09c87c7336b7c3d4579b8f2
parent98dee6c96f5abc507966e0b8be2a37969b2bccfb (diff)
downloadglibc-master.zip
glibc-master.tar.gz
glibc-master.tar.bz2
hurd: _hurd_intr_rpc_mach_msg() might not preserve the correct reply portHEADmaster
Calls to mach_msg_trap() that return MACH_SEND_INTERRUPTED modify the message header. A subsequent attempt at sending the message can return EINTR for handling by the caller. Mig generated code (expecting the message header to be unaltered) now fails assertion in __mig_dealloc_reply_port(). Fixed by restoring the altered message header content before reattempting RPC message delivery. Message-ID: <20260209204213.91782-2-mike@weatherwax.co.uk>
-rw-r--r--hurd/intr-msg.c7
1 files changed, 7 insertions, 0 deletions
diff --git a/hurd/intr-msg.c b/hurd/intr-msg.c
index 02e5144..83db941 100644
--- a/hurd/intr-msg.c
+++ b/hurd/intr-msg.c
@@ -136,6 +136,13 @@ _hurd_intr_rpc_mach_msg (mach_msg_header_t *msg,
}
if (!(option & MACH_SEND_INTERRUPT))
{
+ m->header.msgh_local_port = rcv_name;
+ m->header.msgh_remote_port = remote_port;
+ m->header.msgh_id = msgid;
+ m->header.msgh_bits = msgh_bits;
+ /* Restore the two words clobbered by the reply data. */
+ m->request.data = save_data;
+
option = user_option;
timeout = user_timeout;
goto message;