aboutsummaryrefslogtreecommitdiffstats
path: root/main/busybox/0001-cp-optional-reflink-support.patch
diff options
context:
space:
mode:
Diffstat (limited to 'main/busybox/0001-cp-optional-reflink-support.patch')
-rw-r--r--main/busybox/0001-cp-optional-reflink-support.patch120
1 files changed, 0 insertions, 120 deletions
diff --git a/main/busybox/0001-cp-optional-reflink-support.patch b/main/busybox/0001-cp-optional-reflink-support.patch
deleted file mode 100644
index 777d9b8bd3..0000000000
--- a/main/busybox/0001-cp-optional-reflink-support.patch
+++ /dev/null
@@ -1,120 +0,0 @@
-From 79fb6ac7a5acc4178b66314c573aeada1d387ed9 Mon Sep 17 00:00:00 2001
-From: Denys Vlasenko <vda.linux@googlemail.com>
-Date: Fri, 13 Jul 2018 20:30:02 +0200
-Subject: [PATCH] cp: optional --reflink support
-
-function old new delta
-cp_main 428 512 +84
-copy_file 1676 1742 +66
-
-Signed-off-by: Denys Vlasenko <vda.linux@googlemail.com>
----
- coreutils/cp.c | 24 ++++++++++++++++++++++++
- include/libbb.h | 3 +++
- libbb/copy_file.c | 19 +++++++++++++++++++
- 3 files changed, 46 insertions(+)
-
-diff --git a/coreutils/cp.c b/coreutils/cp.c
-index 455bffbba..b623aaf33 100644
---- a/coreutils/cp.c
-+++ b/coreutils/cp.c
-@@ -24,6 +24,11 @@
- //config: help
- //config: Enable long options.
- //config: Also add support for --parents option.
-+//config:
-+//config:config FEATURE_CP_REFLINK
-+//config: bool "Enable --reflink[=auto]
-+//config: default y
-+//config: depends on FEATURE_CP_LONG_OPTIONS
-
- //applet:IF_CP(APPLET_NOEXEC(cp, cp, BB_DIR_BIN, BB_SUID_DROP, cp))
- /* NOEXEC despite cases when it can be a "runner" (cp -r LARGE_DIR NEW_DIR) */
-@@ -72,10 +77,14 @@ int cp_main(int argc, char **argv)
- #if ENABLE_FEATURE_CP_LONG_OPTIONS
- /*OPT_rmdest = FILEUTILS_RMDEST = 1 << FILEUTILS_CP_OPTNUM */
- OPT_parents = 1 << (FILEUTILS_CP_OPTNUM+1),
-+ OPT_reflink = 1 << (FILEUTILS_CP_OPTNUM+2),
- #endif
- };
-
- #if ENABLE_FEATURE_CP_LONG_OPTIONS
-+# if ENABLE_FEATURE_CP_REFLINK
-+ char *reflink = NULL;
-+# endif
- flags = getopt32long(argv, "^"
- FILEUTILS_CP_OPTSTR
- "\0"
-@@ -99,7 +108,22 @@ int cp_main(int argc, char **argv)
- "update\0" No_argument "u"
- "remove-destination\0" No_argument "\xff"
- "parents\0" No_argument "\xfe"
-+# if ENABLE_FEATURE_CP_REFLINK
-+ "reflink\0" Optional_argument "\xfd"
-+ , &reflink
-+# endif
- );
-+# if ENABLE_FEATURE_CP_REFLINK
-+ BUILD_BUG_ON(OPT_reflink != FILEUTILS_REFLINK);
-+ if (flags & FILEUTILS_REFLINK) {
-+ if (!reflink)
-+ flags |= FILEUTILS_REFLINK_ALWAYS;
-+ else if (strcmp(reflink, "always") == 0)
-+ flags |= FILEUTILS_REFLINK_ALWAYS;
-+ else if (strcmp(reflink, "auto") != 0)
-+ bb_show_usage();
-+ }
-+# endif
- #else
- flags = getopt32(argv, "^"
- FILEUTILS_CP_OPTSTR
-diff --git a/include/libbb.h b/include/libbb.h
-index d4ba031df..94caba2bb 100644
---- a/include/libbb.h
-+++ b/include/libbb.h
-@@ -410,6 +410,9 @@ enum { /* cp.c, mv.c, install.c depend on these values. CAREFUL when changing th
- FILEUTILS_PRESERVE_SECURITY_CONTEXT = 1 << 15, /* -c */
- #endif
- FILEUTILS_RMDEST = 1 << (16 - !ENABLE_SELINUX), /* --remove-destination */
-+ /* bit 17 skipped for "cp --parents" */
-+ FILEUTILS_REFLINK = 1 << (18 - !ENABLE_SELINUX), /* cp --reflink=auto */
-+ FILEUTILS_REFLINK_ALWAYS = 1 << (19 - !ENABLE_SELINUX), /* cp --reflink[=always] */
- /*
- * Hole. cp may have some bits set here,
- * they should not affect remove_file()/copy_file()
-diff --git a/libbb/copy_file.c b/libbb/copy_file.c
-index 1b8befd65..98bd4fe72 100644
---- a/libbb/copy_file.c
-+++ b/libbb/copy_file.c
-@@ -339,9 +339,28 @@ int FAST_FUNC copy_file(const char *source, const char *dest, int flags)
- freecon(con);
- }
- }
-+#endif
-+#if ENABLE_FEATURE_CP_REFLINK
-+# undef BTRFS_IOCTL_MAGIC
-+# define BTRFS_IOCTL_MAGIC 0x94
-+# undef BTRFS_IOC_CLONE
-+# define BTRFS_IOC_CLONE _IOW (BTRFS_IOCTL_MAGIC, 9, int)
-+ if (flags & FILEUTILS_REFLINK) {
-+ retval = ioctl(dst_fd, BTRFS_IOC_CLONE, src_fd);
-+ if (retval == 0)
-+ goto do_close;
-+ /* reflink did not work */
-+ if (flags & FILEUTILS_REFLINK_ALWAYS) {
-+ bb_perror_msg("failed to clone '%s' from '%s'", dest, source);
-+ goto do_close;
-+ }
-+ /* fall through to standard copy */
-+ retval = 0;
-+ }
- #endif
- if (bb_copyfd_eof(src_fd, dst_fd) == -1)
- retval = -1;
-+ IF_FEATURE_CP_REFLINK(do_close:)
- /* Careful with writing... */
- if (close(dst_fd) < 0) {
- bb_perror_msg("error writing to '%s'", dest);
---
-2.20.1
-