summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorAlan Cox <alc@FreeBSD.org>2003-04-05 21:19:58 +0000
committerAlan Cox <alc@FreeBSD.org>2003-04-05 21:19:58 +0000
commitcdb06eda663a7fa638035a196634a688384fe79c (patch)
treedaac55d85c2186dd488dd773c43109493dbf1120
parent2206cb596fe9b602d7b059189b4e500b36aba1cf (diff)
Notes
-rw-r--r--sys/kern/kern_physio.c16
1 files changed, 1 insertions, 15 deletions
diff --git a/sys/kern/kern_physio.c b/sys/kern/kern_physio.c
index aebbbdb6f29a..9a289362b3ee 100644
--- a/sys/kern/kern_physio.c
+++ b/sys/kern/kern_physio.c
@@ -88,25 +88,11 @@ physio(dev_t dev, struct uio *uio, int ioflag)
bp->b_blkno = btodb(bp->b_offset);
- if (uio->uio_segflg == UIO_USERSPACE) {
- /*
- * Note that useracc() alone is not a
- * sufficient test. vmapbuf() can still fail
- * due to a smaller file mapped into a larger
- * area of VM, or if userland races against
- * vmapbuf() after the useracc() check.
- */
- if (!useracc(bp->b_data, bp->b_bufsize,
- bp->b_iocmd == BIO_READ ?
- VM_PROT_WRITE : VM_PROT_READ)) {
- error = EFAULT;
- goto doerror;
- }
+ if (uio->uio_segflg == UIO_USERSPACE)
if (vmapbuf(bp) < 0) {
error = EFAULT;
goto doerror;
}
- }
DEV_STRATEGY(bp);
spl = splbio();