rework zm_sendfile to try again if not all bytes were sent. According to the docs, this is entirely possible.

This commit is contained in:
Isaac Connor 2022-02-16 09:59:23 -05:00
parent 055414c778
commit 2d3f99eabb
1 changed files with 13 additions and 10 deletions

View File

@ -3,22 +3,25 @@
#ifdef HAVE_SENDFILE4_SUPPORT
#include <sys/sendfile.h>
int zm_sendfile(int out_fd, int in_fd, off_t *offset, size_t size) {
int err;
err = sendfile(out_fd, in_fd, offset, size);
if ( err < 0 )
ssize_t zm_sendfile(int out_fd, int in_fd, off_t *offset, size_t size) {
size_t remaining = size;
while (remaining) {
ssize_t err = sendfile(out_fd, in_fd, offset, remaining);
if (err < 0) {
return -errno;
}
remaining -= err;
offset += err;
}
return err;
return size-remaining;
}
#elif HAVE_SENDFILE7_SUPPORT
#include <sys/types.h>
#include <sys/socket.h>
#include <sys/uio.h>
int zm_sendfile(int out_fd, int in_fd, off_t *offset, off_t size) {
int err;
err = sendfile(in_fd, out_fd, *offset, size, nullptr, &size, 0);
ssize_t zm_sendfile(int out_fd, int in_fd, off_t *offset, off_t size) {
ssize_t err = sendfile(in_fd, out_fd, *offset, size, nullptr, &size, 0);
if (err && errno != EAGAIN)
return -errno;