]> xenbits.xensource.com Git - people/julieng/freebsd.git/commitdiff
The error classification from lower layers is a poor indicator of
authorimp <imp@FreeBSD.org>
Sat, 31 Oct 2015 04:53:07 +0000 (04:53 +0000)
committerimp <imp@FreeBSD.org>
Sat, 31 Oct 2015 04:53:07 +0000 (04:53 +0000)
whether an error is recoverable. Always re-dirty the buffer on errors
from write requests. The invalidation we used to do for errors not EIO
doesn't need to be done for a device that's really gone, since that's
done in a different path.

Reviewed by: mckusick@, kib@

sys/kern/vfs_bio.c

index 0f1f882eeabfbfaddb006727b0a8a05e95529243..1e51db3954339ba3c966be7ee5e8bbb379f25da9 100644 (file)
@@ -2266,19 +2266,17 @@ brelse(struct buf *bp)
                bdirty(bp);
        }
        if (bp->b_iocmd == BIO_WRITE && (bp->b_ioflags & BIO_ERROR) &&
-           bp->b_error == EIO && !(bp->b_flags & B_INVAL)) {
+           !(bp->b_flags & B_INVAL)) {
                /*
                 * Failed write, redirty.  Must clear BIO_ERROR to prevent
-                * pages from being scrapped.  If the error is anything
-                * other than an I/O error (EIO), assume that retrying
-                * is futile.
+                * pages from being scrapped.
                 */
                bp->b_ioflags &= ~BIO_ERROR;
                bdirty(bp);
        } else if ((bp->b_flags & (B_NOCACHE | B_INVAL)) ||
            (bp->b_ioflags & BIO_ERROR) || (bp->b_bufsize <= 0)) {
                /*
-                * Either a failed I/O or we were asked to free or not
+                * Either a failed read I/O or we were asked to free or not
                 * cache the buffer.
                 */
                bp->b_flags |= B_INVAL;