Source-Changes-HG archive

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

[src/jdolecek-ncq]: src/sys/dev/ata only limit the openings for I/O xfer if t...



details:   https://anonhg.NetBSD.org/src/rev/f7c55c6c08ec
branches:  jdolecek-ncq
changeset: 352692:f7c55c6c08ec
user:      jdolecek <jdolecek%NetBSD.org@localhost>
date:      Sat Jun 24 00:00:10 2017 +0000

description:
only limit the openings for I/O xfer if the drive actually supports NCQ; if
it's non-NCQ drive, the tag is not going to be used, so we can use any xfer

diffstat:

 sys/dev/ata/TODO.ncq |  3 ---
 sys/dev/ata/wd.c     |  9 +++++----
 2 files changed, 5 insertions(+), 7 deletions(-)

diffs (44 lines):

diff -r 07eea52338be -r f7c55c6c08ec sys/dev/ata/TODO.ncq
--- a/sys/dev/ata/TODO.ncq      Fri Jun 23 23:49:20 2017 +0000
+++ b/sys/dev/ata/TODO.ncq      Sat Jun 24 00:00:10 2017 +0000
@@ -16,9 +16,6 @@
 maybe do device error handling in not-interrupt-context (maybe this should be
 done on a mpata branch?)
 
-do not limit openings for xfers for non-NCQ drives in wdstart(), the tag
-will not be used so can use any xfer
-
 in atastart(), restrict NCQ commands to commands for the same drive? it's
 fine for fis-based switching to have outstanding for several drives, but
 not non-FIS
diff -r 07eea52338be -r f7c55c6c08ec sys/dev/ata/wd.c
--- a/sys/dev/ata/wd.c  Fri Jun 23 23:49:20 2017 +0000
+++ b/sys/dev/ata/wd.c  Sat Jun 24 00:00:10 2017 +0000
@@ -1,4 +1,4 @@
-/*     $NetBSD: wd.c,v 1.428.2.22 2017/06/23 23:45:09 jdolecek Exp $ */
+/*     $NetBSD: wd.c,v 1.428.2.23 2017/06/24 00:00:10 jdolecek 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.22 2017/06/23 23:45:09 jdolecek Exp $");
+__KERNEL_RCSID(0, "$NetBSD: wd.c,v 1.428.2.23 2017/06/24 00:00:10 jdolecek Exp $");
 
 #include "opt_ata.h"
 
@@ -659,9 +659,10 @@
                goto out;
 
        while (bufq_peek(wd->sc_q) != NULL) {
-               /* First try to get command */
+               /* First try to get xfer. Limit to drive openings iff NCQ. */
                xfer = ata_get_xfer_ext(wd->drvp->chnl_softc, false,
-                   wd->drvp->drv_openings);
+                   ISSET(wd->drvp->drive_flags, ATA_DRIVE_NCQ)
+                       ? wd->drvp->drv_openings : 0);
                if (xfer == NULL)
                        break;
 



Home | Main Index | Thread Index | Old Index