summary refs log tree commit diff stats
path: root/linux-user/m68k/target_syscall.h
diff options
context:
space:
mode:
authorLaurent Vivier <laurent@vivier.eu>2016-07-08 01:17:27 +0200
committerRiku Voipio <riku.voipio@linaro.org>2016-09-22 07:24:21 +0300
commit5457dc9e37fe0a29989bd64306c63941074864ce (patch)
tree500f40acbc2b3e2e4401a037447d93904856c522 /linux-user/m68k/target_syscall.h
parent45eafb4d32ced9ff1dcb3800c89f8beaf47b61cc (diff)
downloadfocaccia-qemu-5457dc9e37fe0a29989bd64306c63941074864ce.tar.gz
focaccia-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.h2
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 */