Module Name:    src
Committed By:   nonaka
Date:           Wed Oct  5 03:46:38 UTC 2016

Modified Files:
        src/sys/dev/ic: nvme.c

Log Message:
The maximum number of IO queue entries is hardware supported value.


To generate a diff of this commit:
cvs rdiff -u -r1.14 -r1.15 src/sys/dev/ic/nvme.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/ic/nvme.c
diff -u src/sys/dev/ic/nvme.c:1.14 src/sys/dev/ic/nvme.c:1.15
--- src/sys/dev/ic/nvme.c:1.14	Tue Sep 27 03:33:32 2016
+++ src/sys/dev/ic/nvme.c	Wed Oct  5 03:46:38 2016
@@ -1,4 +1,4 @@
-/*	$NetBSD: nvme.c,v 1.14 2016/09/27 03:33:32 pgoyette Exp $	*/
+/*	$NetBSD: nvme.c,v 1.15 2016/10/05 03:46:38 nonaka Exp $	*/
 /*	$OpenBSD: nvme.c,v 1.49 2016/04/18 05:59:50 dlg Exp $ */
 
 /*
@@ -18,7 +18,7 @@
  */
 
 #include <sys/cdefs.h>
-__KERNEL_RCSID(0, "$NetBSD: nvme.c,v 1.14 2016/09/27 03:33:32 pgoyette Exp $");
+__KERNEL_RCSID(0, "$NetBSD: nvme.c,v 1.15 2016/10/05 03:46:38 nonaka Exp $");
 
 #include <sys/param.h>
 #include <sys/systm.h>
@@ -357,6 +357,8 @@ nvme_attach(struct nvme_softc *sc)
 	}
 	if (NVME_CAP_MPSMAX(cap) < mps)
 		mps = NVME_CAP_MPSMAX(cap);
+	if (ioq_entries > NVME_CAP_MQES(cap))
+		ioq_entries = NVME_CAP_MQES(cap);
 
 	/* set initial values to be used for admin queue during probe */
 	sc->sc_rdy_to = NVME_CAP_TO(cap);
@@ -445,16 +447,22 @@ free_admin_q:
 int
 nvme_rescan(device_t self, const char *attr, const int *flags)
 {
-	int i;
 	struct nvme_softc *sc = device_private(self);
 	struct nvme_attach_args naa;
+	uint64_t cap;
+	int ioq_entries = nvme_ioq_size;
+	int i;
+
+	cap = nvme_read8(sc, NVME_CAP);
+	if (ioq_entries > NVME_CAP_MQES(cap))
+		ioq_entries = NVME_CAP_MQES(cap);
 
 	for (i = 0; i < sc->sc_nn; i++) {
 		if (sc->sc_namespaces[i].dev)
 			continue;
 		memset(&naa, 0, sizeof(naa));
 		naa.naa_nsid = i + 1;
-		naa.naa_qentries = nvme_ioq_size;
+		naa.naa_qentries = ioq_entries;
 		sc->sc_namespaces[i].dev = config_found(sc->sc_dev, &naa,
 		    nvme_print);
 	}

Reply via email to