[compiler-rt] e5d9310 - Revert "[compiler-rt][sanitizer_common] copy_file_range syscall interception. (#125816)" and fix

Daniel Thornburgh via llvm-commits llvm-commits at lists.llvm.org
Thu Feb 27 12:13:34 PST 2025


Author: Daniel Thornburgh
Date: 2025-02-27T12:12:51-08:00
New Revision: e5d93100b656df86854b58433816b0b03ef9f231

URL: https://github.com/llvm/llvm-project/commit/e5d93100b656df86854b58433816b0b03ef9f231
DIFF: https://github.com/llvm/llvm-project/commit/e5d93100b656df86854b58433816b0b03ef9f231.diff

LOG: Revert "[compiler-rt][sanitizer_common] copy_file_range syscall interception. (#125816)" and fix

This reverts commit 7521207e415b19b2924930ac95c2fcf07d56f2f2.
This reverts commit 5f6a3e63a31aaebc620a18c47bc5590f6f705c98.

Added: 
    

Modified: 
    compiler-rt/lib/sanitizer_common/sanitizer_common_syscalls.inc

Removed: 
    compiler-rt/test/sanitizer_common/TestCases/Linux/copy_file_range.c


################################################################################
diff  --git a/compiler-rt/lib/sanitizer_common/sanitizer_common_syscalls.inc b/compiler-rt/lib/sanitizer_common/sanitizer_common_syscalls.inc
index 521fc116f2888..29fe4721ba40d 100644
--- a/compiler-rt/lib/sanitizer_common/sanitizer_common_syscalls.inc
+++ b/compiler-rt/lib/sanitizer_common/sanitizer_common_syscalls.inc
@@ -3205,28 +3205,6 @@ POST_SYSCALL(futex)
   COMMON_SYSCALL_BLOCKING_END();
 }
 
-PRE_SYSCALL(copy_file_range)
-(int fdin, __sanitizer___kernel_off_t *offin, int fdout,
- __sanitizer___kernel_off_t *offout, SIZE_T size, unsigned int flags) {
-  if (offin != nullptr) {
-    PRE_READ(offin, sizeof(*offin));
-  }
-  if (offout != nullptr) {
-    PRE_READ(offout, sizeof(*offout));
-  }
-}
-
-POST_SYSCALL(copy_file_range)
-(SSIZE_T, int fdin, __sanitizer___kernel_off_t *offin, int fdout,
- __sanitizer___kernel_off_t *offout, SIZE_T size, unsigned int flags) {
-  if (offin != nullptr) {
-    POST_WRITE(offin, sizeof(*offin));
-  }
-  if (offout != nullptr) {
-    POST_WRITE(offout, sizeof(*offout));
-  }
-}
-
 }  // extern "C"
 
 #  undef PRE_SYSCALL

diff  --git a/compiler-rt/test/sanitizer_common/TestCases/Linux/copy_file_range.c b/compiler-rt/test/sanitizer_common/TestCases/Linux/copy_file_range.c
deleted file mode 100644
index 2cfdfdcb59ba4..0000000000000
--- a/compiler-rt/test/sanitizer_common/TestCases/Linux/copy_file_range.c
+++ /dev/null
@@ -1,42 +0,0 @@
-// RUN: %clangxx -O0 %s -D_FILE_OFFSET_BITS=64 -o %t
-
-// REQUIRES: glibc
-
-#ifndef _GNU_SOURCE
-#  define _GNU_SOURCE
-#endif
-#include <assert.h>
-#include <fcntl.h>
-#include <stdlib.h>
-#include <sys/syscall.h>
-#include <unistd.h>
-
-#if !defined(__GLIBC_PREREQ)
-#  define __GLIBC_PREREQ(a, b) 0
-#endif
-
-#if !__GLIBC_PREREQ(2, 27)
-#  define copy_file_range(a, b, c, d, e)                                       \
-    (ssize_t) syscall(__NR_copy_file_range, a, b, c, d, e)
-#endif
-
-int main(void) {
-  int fdin = open("/proc/self/maps", O_RDONLY);
-  assert(fdin > 0);
-  char tmp[] = "/tmp/map.XXXXXX";
-  int fdout = mkstemp(tmp);
-  assert(fdout > 0);
-  off_t offin = -1, offout = 0;
-  ssize_t cpy = copy_file_range(fdin, &offin, fdout, &offout, 8, 0);
-  assert(cpy < 0);
-  offin = 0;
-  offout = 16;
-  cpy = copy_file_range(fdin, &offin, fdout, &offout, 8, 0);
-  assert(cpy < 0);
-  offout = 0;
-  cpy = copy_file_range(fdin, &offin, fdout, &offout, 8, 0);
-  assert(cpy == 8);
-  close(fdout);
-  close(fdin);
-  return 0;
-}


        


More information about the llvm-commits mailing list