Source-Changes-HG archive

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

[src/trunk]: src/sys/dev/pci PR/52330: Jia-Ju Bai: mpii driver: a sleep-in-in...



details:   https://anonhg.NetBSD.org/src/rev/18d9cfb85ae0
branches:  trunk
changeset: 354694:18d9cfb85ae0
user:      christos <christos%NetBSD.org@localhost>
date:      Sun Jun 25 15:56:32 2017 +0000

description:
PR/52330: Jia-Ju Bai: mpii driver: a sleep-in-interrupt bug in mpii_intr
Since the enclosing routime mpii_event_raid already calls malloc with
M_NOWAIT, fix the cache routine to do the same. While there check the
result of the cache routine and change some error prints to aprint.

diffstat:

 sys/dev/pci/mpii.c |  40 +++++++++++++++++++++++++---------------
 1 files changed, 25 insertions(+), 15 deletions(-)

diffs (109 lines):

diff -r 988e5baea07e -r 18d9cfb85ae0 sys/dev/pci/mpii.c
--- a/sys/dev/pci/mpii.c        Sun Jun 25 12:44:04 2017 +0000
+++ b/sys/dev/pci/mpii.c        Sun Jun 25 15:56:32 2017 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: mpii.c,v 1.8 2016/05/02 19:18:29 christos Exp $ */
+/* $NetBSD: mpii.c,v 1.9 2017/06/25 15:56:32 christos Exp $ */
 /*     OpenBSD: mpii.c,v 1.51 2012/04/11 13:29:14 naddy Exp    */
 /*
  * Copyright (c) 2010 Mike Belopuhov <mkb%crypt.org.ru@localhost>
@@ -20,7 +20,7 @@
  */
 
 #include <sys/cdefs.h>
-__KERNEL_RCSID(0, "$NetBSD: mpii.c,v 1.8 2016/05/02 19:18:29 christos Exp $");
+__KERNEL_RCSID(0, "$NetBSD: mpii.c,v 1.9 2017/06/25 15:56:32 christos Exp $");
 
 #include "bio.h"
 
@@ -3434,26 +3434,34 @@
                        case MPII_EVT_IR_CFG_ELEMENT_RC_VOLUME_CREATED:
                                if (mpii_find_dev(sc,
                                    le16toh(ce->vol_dev_handle))) {
-                                       printf("%s: device %#x is already "
-                                           "configured\n", DEVNAME(sc),
+                                       aprint_error_dev(sc->sc_dev,
+                                           "device %#x is already "
+                                           "configured\n",
                                            le16toh(ce->vol_dev_handle));
                                        break;
                                }
                                dev = malloc(sizeof(*dev), M_DEVBUF,
                                    M_NOWAIT | M_ZERO);
                                if (!dev) {
-                                       printf("%s: failed to allocate a "
-                                           "device structure\n", DEVNAME(sc));
+                                       aprint_error_dev(sc->sc_dev,
+                                           "can't allocate device structure\n");
                                        break;
                                }
                                SET(dev->flags, MPII_DF_VOLUME);
                                dev->slot = sc->sc_vd_id_low;
                                dev->dev_handle = le16toh(ce->vol_dev_handle);
                                if (mpii_insert_dev(sc, dev)) {
+                                       aprint_error_dev(sc->sc_dev,
+                                           "can't insert device structure\n");
                                        free(dev, M_DEVBUF);
                                        break;
                                }
-                               mpii_cache_enable(sc, dev);
+                               if (mpii_cache_enable(sc, dev)) {
+                                       aprint_error_dev(sc->sc_dev,
+                                           "can't enable device cache\n");
+                                       free(dev, M_DEVBUF);
+                                       break;
+                               }
                                sc->sc_vd_count++;
                                break;
                        case MPII_EVT_IR_CFG_ELEMENT_RC_REMOVED:
@@ -3515,15 +3523,15 @@
                switch (pe->phy_status & MPII_EVENT_SAS_TOPO_PS_RC_MASK) {
                case MPII_EVENT_SAS_TOPO_PS_RC_ADDED:
                        if (mpii_find_dev(sc, le16toh(pe->dev_handle))) {
-                               printf("%s: device %#x is already "
-                                   "configured\n", DEVNAME(sc),
+                               aprint_error_dev(sc->sc_dev,
+                                   "device %#x is already configured\n",
                                    le16toh(pe->dev_handle));
                                break;
                        }
                        dev = malloc(sizeof(*dev), M_DEVBUF, M_NOWAIT | M_ZERO);
                        if (!dev) {
-                               printf("%s: failed to allocate a "
-                                   "device structure\n", DEVNAME(sc));
+                               aprint_error_dev(sc->sc_dev, "can't allocate "
+                                   "device structure\n");
                                break;
                        }
                        dev->slot = sc->sc_pd_id_start + tcl->start_phy_num + i;
@@ -3534,6 +3542,8 @@
                        dev->enclosure = le16toh(tcl->enclosure_handle);
                        dev->expander = le16toh(tcl->expander_handle);
                        if (mpii_insert_dev(sc, dev)) {
+                               aprint_error_dev(sc->sc_dev, "can't insert "
+                                   "device structure\n");
                                free(dev, M_DEVBUF);
                                break;
                        }
@@ -3550,9 +3560,9 @@
                                    DVACT_DEACTIVATE);
                                if (scsi_task(mpii_event_defer, sc,
                                    dev, 0) != 0)
-                                       printf("%s: unable to run device "
-                                           "detachment routine\n",
-                                           DEVNAME(sc));
+                                       aprint_error_dev(sc->sc_dev, 
+                                           "unable to run device "
+                                           "detachment routine\n");
                        }
 #else
                        mpii_event_defer(sc, dev);
@@ -4979,7 +4989,7 @@
                return (EINVAL);
 
        pagelen = hdr.page_length * 4;
-       vpg = malloc(pagelen, M_TEMP, M_WAITOK | M_CANFAIL | M_ZERO);
+       vpg = malloc(pagelen, M_TEMP, M_NOWAIT | M_ZERO);
        if (vpg == NULL)
                return (ENOMEM);
 



Home | Main Index | Thread Index | Old Index