|
@@ -0,0 +1,62 @@
|
|
|
+From ad8078ca2ef35c91bedad61c9e2a6c01bf13a605 Mon Sep 17 00:00:00 2001
|
|
|
+From: Palmer Dabbelt <palmer@dabbelt.com>
|
|
|
+Date: Fri, 29 Dec 2017 10:19:51 -0800
|
|
|
+Subject: [PATCH] misc: rename copy_file_range to copy_file_chunk
|
|
|
+
|
|
|
+As of 2.27, glibc will have a copy_file_range library call to wrap the
|
|
|
+new copy_file_range system call. This conflicts with the function in
|
|
|
+misc/create_inode.c, which this patch renames _copy_file_range.
|
|
|
+
|
|
|
+Signed-off-by: Palmer Dabbelt <palmer@dabbelt.com>
|
|
|
+Signed-off-by: Theodore Ts'o <tytso@mit.edu>
|
|
|
+
|
|
|
+Upstream-Status: Backport
|
|
|
+
|
|
|
+Signed-off-by: Tanu Kaskinen <tanuk@iki.fi>
|
|
|
+---
|
|
|
+ misc/create_inode.c | 8 ++++----
|
|
|
+ 1 file changed, 4 insertions(+), 4 deletions(-)
|
|
|
+
|
|
|
+diff --git a/misc/create_inode.c b/misc/create_inode.c
|
|
|
+index ae22ff6f..ea6fa7e7 100644
|
|
|
+--- a/misc/create_inode.c
|
|
|
++++ b/misc/create_inode.c
|
|
|
+@@ -392,7 +392,7 @@ static ssize_t my_pread(int fd, void *buf, size_t count, off_t offset)
|
|
|
+ }
|
|
|
+ #endif /* !defined HAVE_PREAD64 && !defined HAVE_PREAD */
|
|
|
+
|
|
|
+-static errcode_t copy_file_range(ext2_filsys fs, int fd, ext2_file_t e2_file,
|
|
|
++static errcode_t copy_file_chunk(ext2_filsys fs, int fd, ext2_file_t e2_file,
|
|
|
+ off_t start, off_t end, char *buf,
|
|
|
+ char *zerobuf)
|
|
|
+ {
|
|
|
+@@ -466,7 +466,7 @@ static errcode_t try_lseek_copy(ext2_filsys fs, int fd, struct stat *statbuf,
|
|
|
+
|
|
|
+ data_blk = data & ~(fs->blocksize - 1);
|
|
|
+ hole_blk = (hole + (fs->blocksize - 1)) & ~(fs->blocksize - 1);
|
|
|
+- err = copy_file_range(fs, fd, e2_file, data_blk, hole_blk, buf,
|
|
|
++ err = copy_file_chunk(fs, fd, e2_file, data_blk, hole_blk, buf,
|
|
|
+ zerobuf);
|
|
|
+ if (err)
|
|
|
+ return err;
|
|
|
+@@ -517,7 +517,7 @@ static errcode_t try_fiemap_copy(ext2_filsys fs, int fd, ext2_file_t e2_file,
|
|
|
+ goto out;
|
|
|
+ for (i = 0, ext = ext_buf; i < fiemap_buf->fm_mapped_extents;
|
|
|
+ i++, ext++) {
|
|
|
+- err = copy_file_range(fs, fd, e2_file, ext->fe_logical,
|
|
|
++ err = copy_file_chunk(fs, fd, e2_file, ext->fe_logical,
|
|
|
+ ext->fe_logical + ext->fe_length,
|
|
|
+ buf, zerobuf);
|
|
|
+ if (err)
|
|
|
+@@ -570,7 +570,7 @@ static errcode_t copy_file(ext2_filsys fs, int fd, struct stat *statbuf,
|
|
|
+ goto out;
|
|
|
+ #endif
|
|
|
+
|
|
|
+- err = copy_file_range(fs, fd, e2_file, 0, statbuf->st_size, buf,
|
|
|
++ err = copy_file_chunk(fs, fd, e2_file, 0, statbuf->st_size, buf,
|
|
|
+ zerobuf);
|
|
|
+ out:
|
|
|
+ ext2fs_free_mem(&zerobuf);
|
|
|
+--
|
|
|
+2.16.2
|
|
|
+
|