svn commit: r327187 - stable/11/usr.sbin/diskinfo
Alan Somers
asomers at FreeBSD.org
Tue Dec 26 04:00:32 UTC 2017
Author: asomers
Date: Tue Dec 26 04:00:30 2017
New Revision: 327187
URL: https://svnweb.freebsd.org/changeset/base/327187
Log:
MFC r326290:
diskinfo(8): Delete dead code in slog test
Reported by: Coverity
CID: 1377556
Reviewed by: mav
Sponsored by: Spectra Logic Corp
Differential Revision: https://reviews.freebsd.org/D13275
Modified:
stable/11/usr.sbin/diskinfo/diskinfo.c
Directory Properties:
stable/11/ (props changed)
Modified: stable/11/usr.sbin/diskinfo/diskinfo.c
==============================================================================
--- stable/11/usr.sbin/diskinfo/diskinfo.c Tue Dec 26 03:59:49 2017 (r327186)
+++ stable/11/usr.sbin/diskinfo/diskinfo.c Tue Dec 26 04:00:30 2017 (r327187)
@@ -644,22 +644,22 @@ parwrite(int fd, size_t size, off_t off)
{
struct aiocb aios[MAXIOS];
off_t o;
- size_t s;
int n, error;
struct aiocb *aiop;
- for (n = 0, o = 0; size > MAXIO; n++, size -= s, o += s) {
- s = (size >= MAXIO) ? MAXIO : size;
+ // if size > MAXIO, use AIO to write n - 1 pieces in parallel
+ for (n = 0, o = 0; size > MAXIO; n++, size -= MAXIO, o += MAXIO) {
aiop = &aios[n];
bzero(aiop, sizeof(*aiop));
aiop->aio_buf = &buf[o];
aiop->aio_fildes = fd;
aiop->aio_offset = off + o;
- aiop->aio_nbytes = s;
+ aiop->aio_nbytes = MAXIO;
error = aio_write(aiop);
if (error != 0)
err(EX_IOERR, "AIO write submit error");
}
+ // Use synchronous writes for the runt of size <= MAXIO
error = pwrite(fd, &buf[o], size, off + o);
if (error < 0)
err(EX_IOERR, "Sync write error");
More information about the svn-src-stable
mailing list