Source-Changes-HG archive

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index][Old Index]

[src/trunk]: src/sys/dev/ic Avoid rounding errors for timeout values.



details:   https://anonhg.NetBSD.org/src/rev/643dfaecd41b
branches:  trunk
changeset: 360979:643dfaecd41b
user:      mlelstv <mlelstv%NetBSD.org@localhost>
date:      Sun Apr 08 11:57:43 2018 +0000

description:
Avoid rounding errors for timeout values.

diffstat:

 sys/dev/ic/mvsata.c |  32 ++++++++++++++++++++------------
 1 files changed, 20 insertions(+), 12 deletions(-)

diffs (69 lines):

diff -r 4fed81d3ee74 -r 643dfaecd41b sys/dev/ic/mvsata.c
--- a/sys/dev/ic/mvsata.c       Sun Apr 08 11:50:46 2018 +0000
+++ b/sys/dev/ic/mvsata.c       Sun Apr 08 11:57:43 2018 +0000
@@ -1,4 +1,4 @@
-/*     $NetBSD: mvsata.c,v 1.39 2017/10/17 16:24:14 jdolecek Exp $     */
+/*     $NetBSD: mvsata.c,v 1.40 2018/04/08 11:57:43 mlelstv Exp $      */
 /*
  * Copyright (c) 2008 KIYOHARA Takashi
  * All rights reserved.
@@ -26,7 +26,7 @@
  */
 
 #include <sys/cdefs.h>
-__KERNEL_RCSID(0, "$NetBSD: mvsata.c,v 1.39 2017/10/17 16:24:14 jdolecek Exp $");
+__KERNEL_RCSID(0, "$NetBSD: mvsata.c,v 1.40 2018/04/08 11:57:43 mlelstv Exp $");
 
 #include "opt_mvsata.h"
 
@@ -3574,32 +3574,40 @@
 {
        struct ata_channel *chp = &mvport->port_ata_channel;
        uint32_t status, command;
-       int ms;
+       uint32_t idlestatus = EDMA_S_EDMAIDLE | EDMA_S_ECACHEEMPTY;
+       int t;
 
        if (MVSATA_EDMA_READ_4(mvport, EDMA_CMD) & EDMA_CMD_EENEDMA) {
-               for (ms = 0; ms < timeout; ms++) {
+
+               timeout = mstohz(timeout + hztoms(1) - 1);
+
+               for (t = 0; ; ++t) {
                        status = MVSATA_EDMA_READ_4(mvport, EDMA_S);
-                       if (status & EDMA_S_EDMAIDLE)
+                       if ((status & idlestatus) == idlestatus)
                                break;
-                       ata_delay(chp, 1, "mvsata_edma1", wflags);
+                       if (t >= timeout)
+                               break;
+                       ata_delay(chp, hztoms(1), "mvsata_edma1", wflags);
                }
-               if (ms == timeout) {
-                       aprint_error("%s:%d:%d: unable to disable EDMA\n",
+               if (t >= timeout) {
+                       aprint_error("%s:%d:%d: unable to stop EDMA\n",
                            device_xname(MVSATA_DEV2(mvport)),
                            mvport->port_hc->hc, mvport->port);
                        return EBUSY;
                }
 
-               /* The diable bit (eDsEDMA) is self negated. */
+               /* The disable bit (eDsEDMA) is self negated. */
                MVSATA_EDMA_WRITE_4(mvport, EDMA_CMD, EDMA_CMD_EDSEDMA);
 
-               for ( ; ms < timeout; ms++) {
+               for (t = 0; ; ++t) {
                        command = MVSATA_EDMA_READ_4(mvport, EDMA_CMD);
                        if (!(command & EDMA_CMD_EENEDMA))
                                break;
-                       ata_delay(chp, 1, "mvsata_edma2", wflags);
+                       if (t >= timeout)
+                               break;
+                       ata_delay(chp, hztoms(1), "mvsata_edma2", wflags);
                }
-               if (ms == timeout) {
+               if (t >= timeout) {
                        aprint_error("%s:%d:%d: unable to re-enable EDMA\n",
                            device_xname(MVSATA_DEV2(mvport)),
                            mvport->port_hc->hc, mvport->port);



Home | Main Index | Thread Index | Old Index