diff options
author | Flavio Cruz <flaviocruz@gmail.com> | 2023-05-06 16:55:10 -0400 |
---|---|---|
committer | Samuel Thibault <samuel.thibault@ens-lyon.org> | 2023-05-06 23:10:55 +0200 |
commit | 84b4a81aebdb3a0dab335914ebb83faa67eb7df2 (patch) | |
tree | 77a7824f7dcf9933d78df70b470ed41e0af3f748 /sysdeps/mach | |
parent | e64b7c26d45bc54130d9381711c592d85ff5db6a (diff) | |
download | glibc-84b4a81aebdb3a0dab335914ebb83faa67eb7df2.tar glibc-84b4a81aebdb3a0dab335914ebb83faa67eb7df2.tar.gz glibc-84b4a81aebdb3a0dab335914ebb83faa67eb7df2.tar.bz2 glibc-84b4a81aebdb3a0dab335914ebb83faa67eb7df2.zip |
Update hurd/hurdselect.c to be more portable.
Summary of changes:
- Use BAD_TYPECHECK to perform type checking in a cleaner way.
BAD_TYPECHECK is moved into sysdeps/mach/rpc.h to avoid duplication.
- Remove assertions for mach_msg_type_t since those won't work for
x86_64.
- Update message structs to use mach_msg_type_t directly.
- Use designated initializers.
Message-Id: <ZFa+roan3ioo0ONM@jupiter.tail36e24.ts.net>
Diffstat (limited to 'sysdeps/mach')
-rw-r--r-- | sysdeps/mach/hurd/ioctl.c | 6 | ||||
-rw-r--r-- | sysdeps/mach/mach_rpc.h | 30 |
2 files changed, 31 insertions, 5 deletions
diff --git a/sysdeps/mach/hurd/ioctl.c b/sysdeps/mach/hurd/ioctl.c index 66daaa751e..752cfa60f4 100644 --- a/sysdeps/mach/hurd/ioctl.c +++ b/sysdeps/mach/hurd/ioctl.c @@ -28,6 +28,7 @@ #include <stdint.h> #include <hurd/ioctl.h> #include <mach/mig_support.h> +#include <mach_rpc.h> #include <sysdep-cancel.h> #include <hurd/ioctls.defs> @@ -35,11 +36,6 @@ #define msg_align(x) ALIGN_UP (x, __alignof__ (uintptr_t)) #define typesize(type) (1 << (type)) -/* Macro used by MIG to cleanly check the type. */ -#define BAD_TYPECHECK(type, check) __glibc_unlikely (({ \ - union { mach_msg_type_t t; uint32_t w; } _t, _c; \ - _t.t = *(type); _c.t = *(check);_t.w != _c.w; })) - /* Perform the I/O control operation specified by REQUEST on FD. The actual type and use of ARG and the return value depend on REQUEST. */ int diff --git a/sysdeps/mach/mach_rpc.h b/sysdeps/mach/mach_rpc.h new file mode 100644 index 0000000000..152f057ca7 --- /dev/null +++ b/sysdeps/mach/mach_rpc.h @@ -0,0 +1,30 @@ +/* Macros for handling Mach RPC messages. + Copyright (C) 2023 Free Software Foundation, Inc. + This file is part of the GNU C Library. + + The GNU C Library is free software; you can redistribute it and/or + 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. + + 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 + Lesser General Public License for more details. + + You should have received a copy of the GNU Lesser General Public + License along with the GNU C Library; if not, see + <https://www.gnu.org/licenses/>. */ + +#include <mach/message.h> + +/* Macro used by MIG to cleanly check the type. */ +#define BAD_TYPECHECK(type, check) __glibc_unlikely (({ \ + union { mach_msg_type_t t; uint32_t w; } _t, _c; \ + _t.t = *(type); _c.t = *(check);_t.w != _c.w; })) + +/* TODO: add this assertion for x86_64. */ +#ifndef __x86_64__ +_Static_assert (sizeof (uint32_t) == sizeof (mach_msg_type_t), + "mach_msg_type_t needs to be the same size as uint32_t"); +#endif |