Module Name: src
Committed By: jakllsch
Date: Sat Apr 22 20:07:54 UTC 2017
Modified Files:
src/sys/dev/ata [jdolecek-ncq]: wd.c
Log Message:
Avoid destroying uninitialized xfer on error in wdioctlstrategy().
To generate a diff of this commit:
cvs rdiff -u -r1.428.2.9 -r1.428.2.10 src/sys/dev/ata/wd.c
Please note that diffs are not public domain; they are subject to the
copyright notices on the relevant files.
Modified files:
Index: src/sys/dev/ata/wd.c
diff -u src/sys/dev/ata/wd.c:1.428.2.9 src/sys/dev/ata/wd.c:1.428.2.10
--- src/sys/dev/ata/wd.c:1.428.2.9 Wed Apr 19 21:42:39 2017
+++ src/sys/dev/ata/wd.c Sat Apr 22 20:07:54 2017
@@ -1,4 +1,4 @@
-/* $NetBSD: wd.c,v 1.428.2.9 2017/04/19 21:42:39 jdolecek Exp $ */
+/* $NetBSD: wd.c,v 1.428.2.10 2017/04/22 20:07:54 jakllsch Exp $ */
/*
* Copyright (c) 1998, 2001 Manuel Bouyer. All rights reserved.
@@ -54,7 +54,7 @@
*/
#include <sys/cdefs.h>
-__KERNEL_RCSID(0, "$NetBSD: wd.c,v 1.428.2.9 2017/04/19 21:42:39 jdolecek Exp $");
+__KERNEL_RCSID(0, "$NetBSD: wd.c,v 1.428.2.10 2017/04/22 20:07:54 jakllsch Exp $");
#include "opt_ata.h"
@@ -2249,7 +2249,7 @@ wdioctlstrategy(struct buf *bp)
printf("wdioctlstrategy: "
"No matching ioctl request found in queue\n");
error = EINVAL;
- goto out;
+ goto out2;
}
ata_xfer_init(&xfer, true);
@@ -2342,6 +2342,7 @@ wdioctlstrategy(struct buf *bp)
out:
ata_xfer_destroy(&xfer);
+out2:
bp->b_error = error;
if (error)
bp->b_resid = bp->b_bcount;