summaryrefslogtreecommitdiffstats
path: root/arch/csky/include/uapi/asm
diff options
context:
space:
mode:
authorArnd Bergmann <arnd@arndb.de>2024-06-14 09:54:20 +0200
committerArnd Bergmann <arnd@arndb.de>2024-06-25 15:57:37 +0200
commit3339b99ef6fe38dac43b534cba3a8a0e29fb2eff (patch)
treef2634c5d4358c71557c5b86396c1d9406c1f6868 /arch/csky/include/uapi/asm
parent30766f1105d6d2459c3b9fe34a3e52b637a72950 (diff)
downloadlinux-stable-3339b99ef6fe38dac43b534cba3a8a0e29fb2eff.tar.gz
linux-stable-3339b99ef6fe38dac43b534cba3a8a0e29fb2eff.tar.bz2
linux-stable-3339b99ef6fe38dac43b534cba3a8a0e29fb2eff.zip
csky, hexagon: fix broken sys_sync_file_range
Both of these architectures require u64 function arguments to be passed in even/odd pairs of registers or stack slots, which in case of sync_file_range would result in a seven-argument system call that is not currently possible. The system call is therefore incompatible with all existing binaries. While it would be possible to implement support for seven arguments like on mips, it seems better to use a six-argument version, either with the normal argument order but misaligned as on most architectures or with the reordered sync_file_range2() calling conventions as on arm and powerpc. Cc: stable@vger.kernel.org Acked-by: Guo Ren <guoren@kernel.org> Signed-off-by: Arnd Bergmann <arnd@arndb.de>
Diffstat (limited to 'arch/csky/include/uapi/asm')
-rw-r--r--arch/csky/include/uapi/asm/unistd.h1
1 files changed, 1 insertions, 0 deletions
diff --git a/arch/csky/include/uapi/asm/unistd.h b/arch/csky/include/uapi/asm/unistd.h
index 7ff6a2466af1..e0594b6370a6 100644
--- a/arch/csky/include/uapi/asm/unistd.h
+++ b/arch/csky/include/uapi/asm/unistd.h
@@ -6,6 +6,7 @@
#define __ARCH_WANT_SYS_CLONE3
#define __ARCH_WANT_SET_GET_RLIMIT
#define __ARCH_WANT_TIME32_SYSCALLS
+#define __ARCH_WANT_SYNC_FILE_RANGE2
#include <asm-generic/unistd.h>
#define __NR_set_thread_area (__NR_arch_specific_syscall + 0)