diff options
author | Laurent Vivier <laurent@vivier.eu> | 2016-07-08 01:17:27 +0200 |
---|---|---|
committer | Riku Voipio <riku.voipio@linaro.org> | 2016-09-22 07:24:21 +0300 |
commit | 5457dc9e37fe0a29989bd64306c63941074864ce (patch) | |
tree | 500f40acbc2b3e2e4401a037447d93904856c522 /linux-user/m68k/target_syscall.h | |
parent | 45eafb4d32ced9ff1dcb3800c89f8beaf47b61cc (diff) | |
download | qemu-5457dc9e37fe0a29989bd64306c63941074864ce.zip |
linux-user: fix TARGET_NR_select
TARGET_NR_select can have three different implementations:
1- to always return -ENOSYS
microblaze, ppc, ppc64
-> TARGET_WANT_NI_OLD_SELECT
2- to take parameters from a structure pointed by arg1
(kernel sys_old_select)
i386, arm, m68k
-> TARGET_WANT_OLD_SYS_SELECT
3- to take parameters from arg[1-5]
(kernel sys_select)
x86_64, alpha, s390x,
cris, sparc, sparc64
Some (new) architectures don't define NR_select,
4- but only NR__newselect with sys_select:
mips, mips64, sh
5- don't define NR__newselect, and use pselect6 syscall:
aarch64, openrisc, tilegx, unicore32
Reported-by: Timothy Pearson <tpearson@raptorengineering.com>
Reported-by: Allan Wirth <awirth@akamai.com>
Suggested-by: Peter Maydell <peter.maydell@linaro.org>
Reviewed-by: Peter Maydell <peter.maydell@linaro.org>
Signed-off-by: Laurent Vivier <laurent@vivier.eu>
Signed-off-by: Riku Voipio <riku.voipio@linaro.org>
Diffstat (limited to 'linux-user/m68k/target_syscall.h')
-rw-r--r-- | linux-user/m68k/target_syscall.h | 2 |
1 files changed, 2 insertions, 0 deletions
diff --git a/linux-user/m68k/target_syscall.h b/linux-user/m68k/target_syscall.h index db2be4f101..632ee4fcf8 100644 --- a/linux-user/m68k/target_syscall.h +++ b/linux-user/m68k/target_syscall.h @@ -24,6 +24,8 @@ struct target_pt_regs { #define TARGET_MLOCKALL_MCL_CURRENT 1 #define TARGET_MLOCKALL_MCL_FUTURE 2 +#define TARGET_WANT_OLD_SYS_SELECT + void do_m68k_simcall(CPUM68KState *, int); #endif /* M68K_TARGET_SYSCALL_H */ |