From: George Hu <integral@archlinux.org>
To: git@vger.kernel.org
Cc: George Hu <integral@archlinux.org>,
Junio C Hamano <gitster@pobox.com>,
Johannes Schindelin <Johannes.Schindelin@gmx.de>
Subject: [PATCH] copy.c: use `sendfile()` for in-kernel file copying on Linux
Date: Fri, 13 Feb 2026 20:46:56 +0800 [thread overview]
Message-ID: <20260213124656.218396-1-integral@archlinux.org> (raw)
The `sendfile()` system call copies data between one file descriptor
and another within the kernel, which is more efficient than the
combination of `read()` and `write()`.
Signed-off-by: George Hu <integral@archlinux.org>
---
copy.c | 17 +++++++++++++++++
1 file changed, 17 insertions(+)
diff --git a/copy.c b/copy.c
index b668209b6c..d4b7cde764 100644
--- a/copy.c
+++ b/copy.c
@@ -7,8 +7,23 @@
#include "strbuf.h"
#include "abspath.h"
+#ifdef __linux__
+# include <sys/sendfile.h>
+#endif
+
int copy_fd(int ifd, int ofd)
{
+#ifdef __linux__
+ struct stat ifd_st;
+ size_t ifd_len;
+ ssize_t ret = 0;
+
+ fstat(ifd, &ifd_st);
+ ifd_len = ifd_st.st_size;
+
+ while (ifd_len && (ret = sendfile(ofd, ifd, NULL, ifd_len)) > 0)
+ ifd_len -= (size_t)ret;
+#else
while (1) {
char buffer[8192];
ssize_t len = xread(ifd, buffer, sizeof(buffer));
@@ -19,6 +34,8 @@ int copy_fd(int ifd, int ofd)
if (write_in_full(ofd, buffer, len) < 0)
return COPY_WRITE_ERROR;
}
+#endif
+
return 0;
}
--
2.53.0
next reply other threads:[~2026-02-13 12:47 UTC|newest]
Thread overview: 9+ messages / expand[flat|nested] mbox.gz Atom feed top
2026-02-13 12:46 George Hu [this message]
2026-02-13 15:36 ` [PATCH] copy.c: use `sendfile()` for in-kernel file copying on Linux Chris Torek
2026-02-14 9:21 ` George Hu
2026-02-14 16:50 ` Chris Torek
2026-02-20 16:35 ` Ed Maste
2026-02-20 16:48 ` Collin Funk
2026-02-14 16:43 ` Phillip Wood
2026-02-15 6:23 ` George Hu
2026-02-15 7:43 ` Jeff King
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=20260213124656.218396-1-integral@archlinux.org \
--to=integral@archlinux.org \
--cc=Johannes.Schindelin@gmx.de \
--cc=git@vger.kernel.org \
--cc=gitster@pobox.com \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.