Source-Changes-HG archive
[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index][Old Index]
[src/trunk]: src/sys/miscfs/specfs When reading from a block device, queue pa...
details: https://anonhg.NetBSD.org/src/rev/4c444e7e706a
branches: trunk
changeset: 979346:4c444e7e706a
user: mlelstv <mlelstv%NetBSD.org@localhost>
date: Fri Dec 25 09:28:56 2020 +0000
description:
When reading from a block device, queue parallel block requests to
fill a buffer with breadn.
diffstat:
sys/miscfs/specfs/spec_vnops.c | 41 ++++++++++++++++++++++++++++++++++++-----
1 files changed, 36 insertions(+), 5 deletions(-)
diffs (78 lines):
diff -r a61e38f48c0d -r 4c444e7e706a sys/miscfs/specfs/spec_vnops.c
--- a/sys/miscfs/specfs/spec_vnops.c Fri Dec 25 09:02:41 2020 +0000
+++ b/sys/miscfs/specfs/spec_vnops.c Fri Dec 25 09:28:56 2020 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: spec_vnops.c,v 1.180 2020/06/27 17:29:19 christos Exp $ */
+/* $NetBSD: spec_vnops.c,v 1.181 2020/12/25 09:28:56 mlelstv Exp $ */
/*-
* Copyright (c) 2008 The NetBSD Foundation, Inc.
@@ -58,7 +58,7 @@
*/
#include <sys/cdefs.h>
-__KERNEL_RCSID(0, "$NetBSD: spec_vnops.c,v 1.180 2020/06/27 17:29:19 christos Exp $");
+__KERNEL_RCSID(0, "$NetBSD: spec_vnops.c,v 1.181 2020/12/25 09:28:56 mlelstv Exp $");
#include <sys/param.h>
#include <sys/proc.h>
@@ -695,6 +695,10 @@
struct partinfo pi;
int n, on;
int error = 0;
+ int i, nra;
+ daddr_t lastbn, *rablks;
+ int *rasizes;
+ int nrablks, ratogo;
KASSERT(uio->uio_rw == UIO_READ);
KASSERTMSG(VMSPACE_IS_KERNEL_P(uio->uio_vmspace) ||
@@ -723,18 +727,45 @@
bsize = BLKDEV_IOSIZE;
bscale = bsize >> DEV_BSHIFT;
+
+ nra = uimax(16 * MAXPHYS / bsize - 1, 511);
+ rablks = kmem_alloc(nra * sizeof(*rablks), KM_SLEEP);
+ rasizes = kmem_alloc(nra * sizeof(*rasizes), KM_SLEEP);
+ lastbn = ((uio->uio_offset + uio->uio_resid - 1) >> DEV_BSHIFT)
+ &~ (bscale - 1);
+ nrablks = ratogo = 0;
do {
bn = (uio->uio_offset >> DEV_BSHIFT) &~ (bscale - 1);
on = uio->uio_offset % bsize;
n = uimin((unsigned)(bsize - on), uio->uio_resid);
- error = bread(vp, bn, bsize, 0, &bp);
- if (error) {
- return (error);
+
+ if (ratogo == 0) {
+ nrablks = uimin((lastbn - bn) / bscale, nra);
+ ratogo = nrablks;
+
+ for (i = 0; i < nrablks; ++i) {
+ rablks[i] = bn + (i+1) * bscale;
+ rasizes[i] = bsize;
+ }
+
+ error = breadn(vp, bn, bsize,
+ rablks, rasizes, nrablks,
+ 0, &bp);
+ } else {
+ if (ratogo > 0)
+ --ratogo;
+ error = bread(vp, bn, bsize, 0, &bp);
}
+ if (error)
+ break;
n = uimin(n, bsize - bp->b_resid);
error = uiomove((char *)bp->b_data + on, n, uio);
brelse(bp, 0);
} while (error == 0 && uio->uio_resid > 0 && n != 0);
+
+ kmem_free(rablks, nra * sizeof(*rablks));
+ kmem_free(rasizes, nra * sizeof(*rasizes));
+
return (error);
default:
Home |
Main Index |
Thread Index |
Old Index