diff options
| author | Alan Cox <alc@FreeBSD.org> | 2003-04-05 21:19:58 +0000 |
|---|---|---|
| committer | Alan Cox <alc@FreeBSD.org> | 2003-04-05 21:19:58 +0000 |
| commit | cdb06eda663a7fa638035a196634a688384fe79c (patch) | |
| tree | daac55d85c2186dd488dd773c43109493dbf1120 | |
| parent | 2206cb596fe9b602d7b059189b4e500b36aba1cf (diff) | |
Notes
| -rw-r--r-- | sys/kern/kern_physio.c | 16 |
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(); |
