Source-Changes-HG archive
[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index][Old Index]
[src/trunk]: src/sys/dev/ata de-quadruplicate, remove unused argument
details: https://anonhg.NetBSD.org/src/rev/9487d0d8e0ef
branches: trunk
changeset: 976590:9487d0d8e0ef
user: christos <christos%NetBSD.org@localhost>
date: Sun Sep 27 16:58:11 2020 +0000
description:
de-quadruplicate, remove unused argument
diffstat:
sys/dev/ata/wd.c | 109 +++++++++++++++++-------------------------------------
1 files changed, 34 insertions(+), 75 deletions(-)
diffs (199 lines):
diff -r 3584cc1a60bc -r 9487d0d8e0ef sys/dev/ata/wd.c
--- a/sys/dev/ata/wd.c Sun Sep 27 16:52:22 2020 +0000
+++ b/sys/dev/ata/wd.c Sun Sep 27 16:58:11 2020 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: wd.c,v 1.463 2020/05/24 22:12:29 jdolecek Exp $ */
+/* $NetBSD: wd.c,v 1.464 2020/09/27 16:58:11 christos 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.463 2020/05/24 22:12:29 jdolecek Exp $");
+__KERNEL_RCSID(0, "$NetBSD: wd.c,v 1.464 2020/09/27 16:58:11 christos Exp $");
#include "opt_ata.h"
#include "opt_wd.h"
@@ -203,7 +203,7 @@
static void wddone(device_t, struct ata_xfer *);
static int wd_get_params(struct wd_softc *, struct ataparams *);
static void wd_set_geometry(struct wd_softc *);
-static int wd_flushcache(struct wd_softc *, int, bool);
+static int wd_flushcache(struct wd_softc *, int);
static int wd_trim(struct wd_softc *, daddr_t, long);
static bool wd_shutdown(device_t, int);
@@ -512,7 +512,7 @@
if (sc->atabus->ata_addref(sc->drvp))
return true; /* no need to complain */
- wd_flushcache(sc, AT_WAIT, false);
+ wd_flushcache(sc, AT_WAIT);
wd_standby(sc, AT_WAIT);
sc->atabus->ata_delref(sc->drvp);
@@ -1194,7 +1194,7 @@
KASSERTMSG(bufq_peek(wd->sc_dksc.sc_bufq) == NULL, "bufq not empty");
if (wd->sc_flags & WDF_DIRTY)
- wd_flushcache(wd, AT_WAIT, false);
+ wd_flushcache(wd, AT_WAIT);
wd->atabus->ata_delref(wd->drvp);
wd->sc_flags &= ~WDF_OPEN;
@@ -1373,7 +1373,7 @@
return wd_setcache(wd, *(int *)addr);
case DIOCCACHESYNC:
- return wd_flushcache(wd, AT_WAIT, true);
+ return wd_flushcache(wd, AT_WAIT);
case ATAIOCCOMMAND:
/*
@@ -1765,7 +1765,28 @@
return 0;
}
-const char at_errbits[] = "\20\10ERROR\11TIMEOU\12DF";
+
+static int
+wd_check_error(const struct dk_softc *dksc, const struct ata_xfer *xfer,
+ const char *func)
+{
+ static const char at_errbits[] = "\20\10ERROR\11TIMEOU\12DF";
+
+ int flags = xfer->c_ata_c.flags;
+
+ if ((flags & AT_ERROR) != 0 && xfer->c_ata_c.r_error == WDCE_ABRT) {
+ /* command not supported */
+ aprint_debug_dev(dksc->sc_dev, "%s: not supported\n", func);
+ return ENODEV;
+ }
+ if (flags & (AT_ERROR | AT_TIMEOU | AT_DF)) {
+ char sbuf[sizeof(at_errbits) + 64];
+ snprintb(sbuf, sizeof(sbuf), at_errbits, flags);
+ aprint_error_dev(dksc->sc_dev, "%s: status=%s\n", func, sbuf);
+ return EIO;
+ }
+ return 0;
+}
int
wd_setcache(struct wd_softc *wd, int bits)
@@ -1802,17 +1823,7 @@
wd->atabus->ata_exec_command(wd->drvp, xfer);
ata_wait_cmd(wd->drvp->chnl_softc, xfer);
- if (xfer->c_ata_c.flags & (AT_ERROR | AT_TIMEOU | AT_DF)) {
- char sbuf[sizeof(at_errbits) + 64];
- snprintb(sbuf, sizeof(sbuf), at_errbits, xfer->c_ata_c.flags);
- aprint_error_dev(dksc->sc_dev, "wd_setcache: status=%s\n", sbuf);
- error = EIO;
- goto out;
- }
-
- error = 0;
-
-out:
+ error = wd_check_error(dksc, xfer, __func__);
ata_free_xfer(wd->drvp->chnl_softc, xfer);
return error;
}
@@ -1836,31 +1847,13 @@
wd->atabus->ata_exec_command(wd->drvp, xfer);
ata_wait_cmd(wd->drvp->chnl_softc, xfer);
- if (xfer->c_ata_c.flags & AT_ERROR) {
- if (xfer->c_ata_c.r_error == WDCE_ABRT) {
- /* command not supported */
- aprint_debug_dev(dksc->sc_dev,
- "standby immediate not supported\n");
- error = ENODEV;
- goto out;
- }
- }
- if (xfer->c_ata_c.flags & (AT_ERROR | AT_TIMEOU | AT_DF)) {
- char sbuf[sizeof(at_errbits) + 64];
- snprintb(sbuf, sizeof(sbuf), at_errbits, xfer->c_ata_c.flags);
- aprint_error_dev(dksc->sc_dev, "wd_standby: status=%s\n", sbuf);
- error = EIO;
- goto out;
- }
- error = 0;
-
-out:
+ error = wd_check_error(dksc, xfer, __func__);
ata_free_xfer(wd->drvp->chnl_softc, xfer);
return error;
}
int
-wd_flushcache(struct wd_softc *wd, int flags, bool start_self)
+wd_flushcache(struct wd_softc *wd, int flags)
{
struct dk_softc *dksc = &wd->sc_dksc;
struct ata_xfer *xfer;
@@ -1891,25 +1884,8 @@
wd->atabus->ata_exec_command(wd->drvp, xfer);
ata_wait_cmd(wd->drvp->chnl_softc, xfer);
- if (xfer->c_ata_c.flags & AT_ERROR) {
- if (xfer->c_ata_c.r_error == WDCE_ABRT) {
- /* command not supported */
- error = ENODEV;
- goto out_xfer;
- }
- }
- if (xfer->c_ata_c.flags & (AT_ERROR | AT_TIMEOU | AT_DF)) {
- char sbuf[sizeof(at_errbits) + 64];
- snprintb(sbuf, sizeof(sbuf), at_errbits, xfer->c_ata_c.flags);
- aprint_error_dev(dksc->sc_dev, "wd_flushcache: status=%s\n",
- sbuf);
- error = EIO;
- goto out_xfer;
- }
+ error = wd_check_error(dksc, xfer, __func__);
wd->sc_flags &= ~WDF_DIRTY;
- error = 0;
-
-out_xfer:
ata_free_xfer(wd->drvp->chnl_softc, xfer);
return error;
}
@@ -1959,24 +1935,7 @@
ata_wait_cmd(wd->drvp->chnl_softc, xfer);
kmem_free(req, 512);
- if (xfer->c_ata_c.flags & AT_ERROR) {
- if (xfer->c_ata_c.r_error == WDCE_ABRT) {
- /* command not supported */
- error = ENODEV;
- goto out;
- }
- }
- if (xfer->c_ata_c.flags & (AT_ERROR | AT_TIMEOU | AT_DF)) {
- char sbuf[sizeof(at_errbits) + 64];
- snprintb(sbuf, sizeof(sbuf), at_errbits, xfer->c_ata_c.flags);
- aprint_error_dev(dksc->sc_dev, "wd_trim: status=%s\n",
- sbuf);
- error = EIO;
- goto out;
- }
- error = 0;
-
-out:
+ error = wd_check_error(dksc, xfer, __func__);
ata_free_xfer(wd->drvp->chnl_softc, xfer);
return error;
}
@@ -1990,7 +1949,7 @@
if (wd->atabus->ata_addref(wd->drvp))
return true; /* no need to complain */
- wd_flushcache(wd, AT_POLL, false);
+ wd_flushcache(wd, AT_POLL);
if ((how & RB_POWERDOWN) == RB_POWERDOWN)
wd_standby(wd, AT_POLL);
return true;
Home |
Main Index |
Thread Index |
Old Index