diff options
author | dan <dan@FreeBSD.org> | 2000-12-20 03:34:54 +0000 |
---|---|---|
committer | dan <dan@FreeBSD.org> | 2000-12-20 03:34:54 +0000 |
commit | c9771e4d86f2755b9d4e99ca5a3e09d7ad8b2e00 (patch) | |
tree | efd606e2e7dd4b65482c5e6b68a91eb01ecf7b1d /libexec | |
parent | 699a6f511441af9930e8ecd9be5d89b157392371 (diff) | |
download | FreeBSD-src-c9771e4d86f2755b9d4e99ca5a3e09d7ad8b2e00.zip FreeBSD-src-c9771e4d86f2755b9d4e99ca5a3e09d7ad8b2e00.tar.gz |
In send_data(), use sendfile() instead of the mmap() algorithm.
Diffstat (limited to 'libexec')
-rw-r--r-- | libexec/ftpd/ftpd.c | 42 |
1 files changed, 22 insertions, 20 deletions
diff --git a/libexec/ftpd/ftpd.c b/libexec/ftpd/ftpd.c index 2c8591b..0a49405 100644 --- a/libexec/ftpd/ftpd.c +++ b/libexec/ftpd/ftpd.c @@ -1698,9 +1698,10 @@ send_data(instr, outstr, blksize, filesize, isreg) off_t filesize; int isreg; { - int c, cnt, filefd, netfd; - char *buf, *bp; + int c, filefd, netfd; + char *buf; size_t len; + off_t cnt; transflag++; if (setjmp(urgcatch)) { @@ -1737,27 +1738,28 @@ send_data(instr, outstr, blksize, filesize, isreg) netfd = fileno(outstr); filefd = fileno(instr); - if (isreg && filesize < (off_t)16 * 1024 * 1024) { - buf = mmap(0, filesize, PROT_READ, MAP_SHARED, filefd, - (off_t)0); - if (buf == MAP_FAILED) { - syslog(LOG_WARNING, "mmap(%lu): %m", - (unsigned long)filesize); - goto oldway; - } - bp = buf; + if (isreg) { + + off_t offset; + int err; + len = filesize; - do { - cnt = write(netfd, bp, len); + err = cnt = offset = 0; + + while (err != -1 && cnt < filesize) { + err = sendfile(filefd, netfd, offset, len, + (struct sf_hdtr *) NULL, &cnt, 0); + offset += cnt; len -= cnt; - bp += cnt; - if (cnt > 0) byte_count += cnt; - } while(cnt > 0 && len > 0); - transflag = 0; - munmap(buf, (size_t)filesize); - if (cnt < 0) - goto data_err; + if (err == -1) { + if (!cnt) + goto oldway; + + goto data_err; + } + } + reply(226, "Transfer complete."); return; } |