From: Chris Metcalf Date: Mon, 26 Mar 2012 20:26:12 +0000 (-0400) Subject: compat: use sys_sendfile64() implementation for sendfile syscall X-Git-Tag: firefly_0821_release~7541^2~1446 X-Git-Url: http://demsky.eecs.uci.edu/git/?a=commitdiff_plain;h=12810ac9f485e5ea6106181b3dcb690e986cc06a;p=firefly-linux-kernel-4.4.55.git compat: use sys_sendfile64() implementation for sendfile syscall commit 1631fcea8399da5e80a80084b3b8c5bfd99d21e7 upstream. was set up to use sys_sendfile() for the 32-bit compat API instead of sys_sendfile64(), but in fact the right thing to do is to use sys_sendfile64() in all cases. The 32-bit sendfile64() API in glibc uses the sendfile64 syscall, so it has to be capable of doing full 64-bit operations. But the sys_sendfile() kernel implementation has a MAX_NON_LFS test in it which explicitly limits the offset to 2^32. So, we need to use the sys_sendfile64() implementation in the kernel for this case. Acked-by: Arnd Bergmann Signed-off-by: Chris Metcalf Signed-off-by: Greg Kroah-Hartman --- diff --git a/include/asm-generic/unistd.h b/include/asm-generic/unistd.h index 4f76959397fa..5518963e38b0 100644 --- a/include/asm-generic/unistd.h +++ b/include/asm-generic/unistd.h @@ -218,7 +218,7 @@ __SC_COMP(__NR_pwritev, sys_pwritev, compat_sys_pwritev) /* fs/sendfile.c */ #define __NR3264_sendfile 71 -__SC_3264(__NR3264_sendfile, sys_sendfile64, sys_sendfile) +__SYSCALL(__NR3264_sendfile, sys_sendfile64) /* fs/select.c */ #define __NR_pselect6 72