cciss: do not use bit 2 doorbell reset
authorStephen M. Cameron <scameron@beardog.cce.hp.com>
Tue, 3 May 2011 19:54:07 +0000 (14:54 -0500)
committerJens Axboe <jaxboe@fusionio.com>
Fri, 6 May 2011 14:23:58 +0000 (08:23 -0600)
It causes NMIs which are undesirable at best, unsurvivable at worst.
Prefer the soft reset instead.

Signed-off-by: Stephen M. Cameron <scameron@beardog.cce.hp.com>
Signed-off-by: Jens Axboe <jaxboe@fusionio.com>
drivers/block/cciss.c

index 865484e..9528e94 100644 (file)
@@ -4673,8 +4673,14 @@ static __devinit int cciss_kdump_hard_reset_controller(struct pci_dev *pdev)
                use_doorbell = DOORBELL_CTLR_RESET2;
        } else {
                use_doorbell = misc_fw_support & MISC_FW_DOORBELL_RESET;
-               if (use_doorbell)
-                       use_doorbell = DOORBELL_CTLR_RESET;
+               if (use_doorbell) {
+                       dev_warn(&pdev->dev, "Controller claims that "
+                               "'Bit 2 doorbell reset' is "
+                               "supported, but not 'bit 5 doorbell reset'.  "
+                               "Firmware update is recommended.\n");
+                       rc = -ENOTSUPP; /* use the soft reset */
+                       goto unmap_cfgtable;
+               }
        }
 
        rc = cciss_controller_hard_reset(pdev, vaddr, use_doorbell);