linux-user: Simplify host <-> target errno conversion using macros
Convert the host_to_target_errno_table[] array to a switch case to allow compiler optimizations (such noticing the identity function when host and guest errnos match). Extract the errnos list as to a new includible unit, using a generic macro. Remove the code related to target_to_host_errno_table[] initialization. Suggested-by: Richard Henderson <richard.henderson@linaro.org> Signed-off-by: Philippe Mathieu-Daudé <f4bug@amsat.org> Reviewed-by: Laurent Vivier <laurent@vivier.eu> Reviewed-by: Richard Henderson <richard.henderson@linaro.org> Message-Id: <20210708170550.1846343-8-f4bug@amsat.org> Signed-off-by: Laurent Vivier <laurent@vivier.eu>
This commit is contained in:
parent
f317c0ee57
commit
3ffe3268ea
140
linux-user/errnos.c.inc
Normal file
140
linux-user/errnos.c.inc
Normal file
@ -0,0 +1,140 @@
|
|||||||
|
/*
|
||||||
|
* This list is the union of errno values overridden in asm-<arch>/errno.h
|
||||||
|
* minus the errnos that are not actually generic to all archs.
|
||||||
|
*
|
||||||
|
* Please keep this list sorted alphabetically.
|
||||||
|
*
|
||||||
|
* Copyright (c) 2003 Fabrice Bellard
|
||||||
|
*
|
||||||
|
* This program is free software; you can redistribute it and/or modify
|
||||||
|
* it under the terms of the GNU General Public License as published by
|
||||||
|
* the Free Software Foundation; either version 2 of the License, or
|
||||||
|
* (at your option) any later version.
|
||||||
|
*
|
||||||
|
* This program 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 General Public License for more details.
|
||||||
|
*
|
||||||
|
* You should have received a copy of the GNU General Public License
|
||||||
|
* along with this program; if not, see <http://www.gnu.org/licenses/>.
|
||||||
|
*
|
||||||
|
* SPDX-License-Identifier: GPL-2.0-or-later
|
||||||
|
*/
|
||||||
|
|
||||||
|
E(EADDRINUSE)
|
||||||
|
E(EADDRNOTAVAIL)
|
||||||
|
E(EADV)
|
||||||
|
E(EAFNOSUPPORT)
|
||||||
|
E(EAGAIN)
|
||||||
|
E(EALREADY)
|
||||||
|
E(EBADE)
|
||||||
|
E(EBADFD)
|
||||||
|
E(EBADMSG)
|
||||||
|
E(EBADR)
|
||||||
|
E(EBADRQC)
|
||||||
|
E(EBADSLT)
|
||||||
|
E(EBFONT)
|
||||||
|
E(ECANCELED)
|
||||||
|
E(ECHRNG)
|
||||||
|
E(ECOMM)
|
||||||
|
E(ECONNABORTED)
|
||||||
|
E(ECONNREFUSED)
|
||||||
|
E(ECONNRESET)
|
||||||
|
E(EDEADLK)
|
||||||
|
E(EDESTADDRREQ)
|
||||||
|
E(EDOTDOT)
|
||||||
|
E(EDQUOT)
|
||||||
|
E(EHOSTDOWN)
|
||||||
|
E(EHOSTUNREACH)
|
||||||
|
#ifdef EHWPOISON
|
||||||
|
E(EHWPOISON)
|
||||||
|
#endif
|
||||||
|
E(EIDRM)
|
||||||
|
E(EILSEQ)
|
||||||
|
E(EINPROGRESS)
|
||||||
|
E(EISCONN)
|
||||||
|
E(EISNAM)
|
||||||
|
#ifdef EKEYEXPIRED
|
||||||
|
E(EKEYEXPIRED)
|
||||||
|
#endif
|
||||||
|
#ifdef EKEYREJECTED
|
||||||
|
E(EKEYREJECTED)
|
||||||
|
#endif
|
||||||
|
#ifdef EKEYREVOKED
|
||||||
|
E(EKEYREVOKED)
|
||||||
|
#endif
|
||||||
|
E(EL2HLT)
|
||||||
|
E(EL2NSYNC)
|
||||||
|
E(EL3HLT)
|
||||||
|
E(EL3RST)
|
||||||
|
E(ELIBACC)
|
||||||
|
E(ELIBBAD)
|
||||||
|
E(ELIBEXEC)
|
||||||
|
E(ELIBMAX)
|
||||||
|
E(ELIBSCN)
|
||||||
|
E(ELNRNG)
|
||||||
|
E(ELOOP)
|
||||||
|
E(EMEDIUMTYPE)
|
||||||
|
E(EMSGSIZE)
|
||||||
|
E(EMULTIHOP)
|
||||||
|
E(ENAMETOOLONG)
|
||||||
|
E(ENAVAIL)
|
||||||
|
E(ENETDOWN)
|
||||||
|
E(ENETRESET)
|
||||||
|
E(ENETUNREACH)
|
||||||
|
E(ENOANO)
|
||||||
|
E(ENOBUFS)
|
||||||
|
E(ENOCSI)
|
||||||
|
E(ENODATA)
|
||||||
|
#ifdef ENOKEY
|
||||||
|
E(ENOKEY)
|
||||||
|
#endif
|
||||||
|
E(ENOLCK)
|
||||||
|
E(ENOLINK)
|
||||||
|
E(ENOMEDIUM)
|
||||||
|
#ifdef ENOMSG
|
||||||
|
E(ENOMSG)
|
||||||
|
#endif
|
||||||
|
E(ENONET)
|
||||||
|
E(ENOPKG)
|
||||||
|
E(ENOPROTOOPT)
|
||||||
|
E(ENOSR)
|
||||||
|
E(ENOSTR)
|
||||||
|
E(ENOSYS)
|
||||||
|
E(ENOTCONN)
|
||||||
|
E(ENOTEMPTY)
|
||||||
|
E(ENOTNAM)
|
||||||
|
#ifdef ENOTRECOVERABLE
|
||||||
|
E(ENOTRECOVERABLE)
|
||||||
|
#endif
|
||||||
|
E(ENOTSOCK)
|
||||||
|
E(ENOTUNIQ)
|
||||||
|
E(EOPNOTSUPP)
|
||||||
|
E(EOVERFLOW)
|
||||||
|
#ifdef EOWNERDEAD
|
||||||
|
E(EOWNERDEAD)
|
||||||
|
#endif
|
||||||
|
E(EPFNOSUPPORT)
|
||||||
|
E(EPROTO)
|
||||||
|
E(EPROTONOSUPPORT)
|
||||||
|
E(EPROTOTYPE)
|
||||||
|
E(EREMCHG)
|
||||||
|
E(EREMOTE)
|
||||||
|
E(EREMOTEIO)
|
||||||
|
E(ERESTART)
|
||||||
|
#ifdef ERFKILL
|
||||||
|
E(ERFKILL)
|
||||||
|
#endif
|
||||||
|
E(ESHUTDOWN)
|
||||||
|
E(ESOCKTNOSUPPORT)
|
||||||
|
E(ESRMNT)
|
||||||
|
E(ESTALE)
|
||||||
|
E(ESTRPIPE)
|
||||||
|
E(ETIME)
|
||||||
|
E(ETIMEDOUT)
|
||||||
|
E(ETOOMANYREFS)
|
||||||
|
E(EUCLEAN)
|
||||||
|
E(EUNATCH)
|
||||||
|
E(EUSERS)
|
||||||
|
E(EXFULL)
|
@ -509,150 +509,26 @@ static inline int next_free_host_timer(void)
|
|||||||
|
|
||||||
#define ERRNO_TABLE_SIZE 1200
|
#define ERRNO_TABLE_SIZE 1200
|
||||||
|
|
||||||
/* target_to_host_errno_table[] is initialized from
|
static inline int host_to_target_errno(int host_errno)
|
||||||
* host_to_target_errno_table[] in syscall_init(). */
|
|
||||||
static uint16_t target_to_host_errno_table[ERRNO_TABLE_SIZE] = {
|
|
||||||
};
|
|
||||||
|
|
||||||
/*
|
|
||||||
* This list is the union of errno values overridden in asm-<arch>/errno.h
|
|
||||||
* minus the errnos that are not actually generic to all archs.
|
|
||||||
*/
|
|
||||||
static uint16_t host_to_target_errno_table[ERRNO_TABLE_SIZE] = {
|
|
||||||
[EAGAIN] = TARGET_EAGAIN,
|
|
||||||
[EIDRM] = TARGET_EIDRM,
|
|
||||||
[ECHRNG] = TARGET_ECHRNG,
|
|
||||||
[EL2NSYNC] = TARGET_EL2NSYNC,
|
|
||||||
[EL3HLT] = TARGET_EL3HLT,
|
|
||||||
[EL3RST] = TARGET_EL3RST,
|
|
||||||
[ELNRNG] = TARGET_ELNRNG,
|
|
||||||
[EUNATCH] = TARGET_EUNATCH,
|
|
||||||
[ENOCSI] = TARGET_ENOCSI,
|
|
||||||
[EL2HLT] = TARGET_EL2HLT,
|
|
||||||
[EDEADLK] = TARGET_EDEADLK,
|
|
||||||
[ENOLCK] = TARGET_ENOLCK,
|
|
||||||
[EBADE] = TARGET_EBADE,
|
|
||||||
[EBADR] = TARGET_EBADR,
|
|
||||||
[EXFULL] = TARGET_EXFULL,
|
|
||||||
[ENOANO] = TARGET_ENOANO,
|
|
||||||
[EBADRQC] = TARGET_EBADRQC,
|
|
||||||
[EBADSLT] = TARGET_EBADSLT,
|
|
||||||
[EBFONT] = TARGET_EBFONT,
|
|
||||||
[ENOSTR] = TARGET_ENOSTR,
|
|
||||||
[ENODATA] = TARGET_ENODATA,
|
|
||||||
[ETIME] = TARGET_ETIME,
|
|
||||||
[ENOSR] = TARGET_ENOSR,
|
|
||||||
[ENONET] = TARGET_ENONET,
|
|
||||||
[ENOPKG] = TARGET_ENOPKG,
|
|
||||||
[EREMOTE] = TARGET_EREMOTE,
|
|
||||||
[ENOLINK] = TARGET_ENOLINK,
|
|
||||||
[EADV] = TARGET_EADV,
|
|
||||||
[ESRMNT] = TARGET_ESRMNT,
|
|
||||||
[ECOMM] = TARGET_ECOMM,
|
|
||||||
[EPROTO] = TARGET_EPROTO,
|
|
||||||
[EDOTDOT] = TARGET_EDOTDOT,
|
|
||||||
[EMULTIHOP] = TARGET_EMULTIHOP,
|
|
||||||
[EBADMSG] = TARGET_EBADMSG,
|
|
||||||
[ENAMETOOLONG] = TARGET_ENAMETOOLONG,
|
|
||||||
[EOVERFLOW] = TARGET_EOVERFLOW,
|
|
||||||
[ENOTUNIQ] = TARGET_ENOTUNIQ,
|
|
||||||
[EBADFD] = TARGET_EBADFD,
|
|
||||||
[EREMCHG] = TARGET_EREMCHG,
|
|
||||||
[ELIBACC] = TARGET_ELIBACC,
|
|
||||||
[ELIBBAD] = TARGET_ELIBBAD,
|
|
||||||
[ELIBSCN] = TARGET_ELIBSCN,
|
|
||||||
[ELIBMAX] = TARGET_ELIBMAX,
|
|
||||||
[ELIBEXEC] = TARGET_ELIBEXEC,
|
|
||||||
[EILSEQ] = TARGET_EILSEQ,
|
|
||||||
[ENOSYS] = TARGET_ENOSYS,
|
|
||||||
[ELOOP] = TARGET_ELOOP,
|
|
||||||
[ERESTART] = TARGET_ERESTART,
|
|
||||||
[ESTRPIPE] = TARGET_ESTRPIPE,
|
|
||||||
[ENOTEMPTY] = TARGET_ENOTEMPTY,
|
|
||||||
[EUSERS] = TARGET_EUSERS,
|
|
||||||
[ENOTSOCK] = TARGET_ENOTSOCK,
|
|
||||||
[EDESTADDRREQ] = TARGET_EDESTADDRREQ,
|
|
||||||
[EMSGSIZE] = TARGET_EMSGSIZE,
|
|
||||||
[EPROTOTYPE] = TARGET_EPROTOTYPE,
|
|
||||||
[ENOPROTOOPT] = TARGET_ENOPROTOOPT,
|
|
||||||
[EPROTONOSUPPORT] = TARGET_EPROTONOSUPPORT,
|
|
||||||
[ESOCKTNOSUPPORT] = TARGET_ESOCKTNOSUPPORT,
|
|
||||||
[EOPNOTSUPP] = TARGET_EOPNOTSUPP,
|
|
||||||
[EPFNOSUPPORT] = TARGET_EPFNOSUPPORT,
|
|
||||||
[EAFNOSUPPORT] = TARGET_EAFNOSUPPORT,
|
|
||||||
[EADDRINUSE] = TARGET_EADDRINUSE,
|
|
||||||
[EADDRNOTAVAIL] = TARGET_EADDRNOTAVAIL,
|
|
||||||
[ENETDOWN] = TARGET_ENETDOWN,
|
|
||||||
[ENETUNREACH] = TARGET_ENETUNREACH,
|
|
||||||
[ENETRESET] = TARGET_ENETRESET,
|
|
||||||
[ECONNABORTED] = TARGET_ECONNABORTED,
|
|
||||||
[ECONNRESET] = TARGET_ECONNRESET,
|
|
||||||
[ENOBUFS] = TARGET_ENOBUFS,
|
|
||||||
[EISCONN] = TARGET_EISCONN,
|
|
||||||
[ENOTCONN] = TARGET_ENOTCONN,
|
|
||||||
[EUCLEAN] = TARGET_EUCLEAN,
|
|
||||||
[ENOTNAM] = TARGET_ENOTNAM,
|
|
||||||
[ENAVAIL] = TARGET_ENAVAIL,
|
|
||||||
[EISNAM] = TARGET_EISNAM,
|
|
||||||
[EREMOTEIO] = TARGET_EREMOTEIO,
|
|
||||||
[EDQUOT] = TARGET_EDQUOT,
|
|
||||||
[ESHUTDOWN] = TARGET_ESHUTDOWN,
|
|
||||||
[ETOOMANYREFS] = TARGET_ETOOMANYREFS,
|
|
||||||
[ETIMEDOUT] = TARGET_ETIMEDOUT,
|
|
||||||
[ECONNREFUSED] = TARGET_ECONNREFUSED,
|
|
||||||
[EHOSTDOWN] = TARGET_EHOSTDOWN,
|
|
||||||
[EHOSTUNREACH] = TARGET_EHOSTUNREACH,
|
|
||||||
[EALREADY] = TARGET_EALREADY,
|
|
||||||
[EINPROGRESS] = TARGET_EINPROGRESS,
|
|
||||||
[ESTALE] = TARGET_ESTALE,
|
|
||||||
[ECANCELED] = TARGET_ECANCELED,
|
|
||||||
[ENOMEDIUM] = TARGET_ENOMEDIUM,
|
|
||||||
[EMEDIUMTYPE] = TARGET_EMEDIUMTYPE,
|
|
||||||
#ifdef ENOKEY
|
|
||||||
[ENOKEY] = TARGET_ENOKEY,
|
|
||||||
#endif
|
|
||||||
#ifdef EKEYEXPIRED
|
|
||||||
[EKEYEXPIRED] = TARGET_EKEYEXPIRED,
|
|
||||||
#endif
|
|
||||||
#ifdef EKEYREVOKED
|
|
||||||
[EKEYREVOKED] = TARGET_EKEYREVOKED,
|
|
||||||
#endif
|
|
||||||
#ifdef EKEYREJECTED
|
|
||||||
[EKEYREJECTED] = TARGET_EKEYREJECTED,
|
|
||||||
#endif
|
|
||||||
#ifdef EOWNERDEAD
|
|
||||||
[EOWNERDEAD] = TARGET_EOWNERDEAD,
|
|
||||||
#endif
|
|
||||||
#ifdef ENOTRECOVERABLE
|
|
||||||
[ENOTRECOVERABLE] = TARGET_ENOTRECOVERABLE,
|
|
||||||
#endif
|
|
||||||
#ifdef ENOMSG
|
|
||||||
[ENOMSG] = TARGET_ENOMSG,
|
|
||||||
#endif
|
|
||||||
#ifdef ERFKILL
|
|
||||||
[ERFKILL] = TARGET_ERFKILL,
|
|
||||||
#endif
|
|
||||||
#ifdef EHWPOISON
|
|
||||||
[EHWPOISON] = TARGET_EHWPOISON,
|
|
||||||
#endif
|
|
||||||
};
|
|
||||||
|
|
||||||
static inline int host_to_target_errno(int err)
|
|
||||||
{
|
{
|
||||||
if (err >= 0 && err < ERRNO_TABLE_SIZE &&
|
switch (host_errno) {
|
||||||
host_to_target_errno_table[err]) {
|
#define E(X) case X: return TARGET_##X;
|
||||||
return host_to_target_errno_table[err];
|
#include "errnos.c.inc"
|
||||||
|
#undef E
|
||||||
|
default:
|
||||||
|
return host_errno;
|
||||||
}
|
}
|
||||||
return err;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
static inline int target_to_host_errno(int err)
|
static inline int target_to_host_errno(int target_errno)
|
||||||
{
|
{
|
||||||
if (err >= 0 && err < ERRNO_TABLE_SIZE &&
|
switch (target_errno) {
|
||||||
target_to_host_errno_table[err]) {
|
#define E(X) case TARGET_##X: return X;
|
||||||
return target_to_host_errno_table[err];
|
#include "errnos.c.inc"
|
||||||
|
#undef E
|
||||||
|
default:
|
||||||
|
return target_errno;
|
||||||
}
|
}
|
||||||
return err;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
static inline abi_long get_errno(abi_long ret)
|
static inline abi_long get_errno(abi_long ret)
|
||||||
@ -7102,7 +6978,6 @@ void syscall_init(void)
|
|||||||
IOCTLEntry *ie;
|
IOCTLEntry *ie;
|
||||||
const argtype *arg_type;
|
const argtype *arg_type;
|
||||||
int size;
|
int size;
|
||||||
int i;
|
|
||||||
|
|
||||||
thunk_init(STRUCT_MAX);
|
thunk_init(STRUCT_MAX);
|
||||||
|
|
||||||
@ -7112,12 +6987,6 @@ void syscall_init(void)
|
|||||||
#undef STRUCT
|
#undef STRUCT
|
||||||
#undef STRUCT_SPECIAL
|
#undef STRUCT_SPECIAL
|
||||||
|
|
||||||
/* Build target_to_host_errno_table[] table from
|
|
||||||
* host_to_target_errno_table[]. */
|
|
||||||
for (i = 0; i < ERRNO_TABLE_SIZE; i++) {
|
|
||||||
target_to_host_errno_table[host_to_target_errno_table[i]] = i;
|
|
||||||
}
|
|
||||||
|
|
||||||
/* we patch the ioctl size if necessary. We rely on the fact that
|
/* we patch the ioctl size if necessary. We rely on the fact that
|
||||||
no ioctl has all the bits at '1' in the size field */
|
no ioctl has all the bits at '1' in the size field */
|
||||||
ie = ioctl_entries;
|
ie = ioctl_entries;
|
||||||
|
Loading…
Reference in New Issue
Block a user