Commit fc113d54 authored by Brian Boylston's avatar Brian Boylston Committed by Wim Van Sebroeck

watchdog: hpwdt: add support for iLO5

iLO5 will offer the same watchdog timer as previous generations, but the
PCI subsystem vendor ID will be PCI_VENDOR_ID_HP_3PAR (0x1590) instead of
PCI_VENDOR_ID_HP (0x103c).  Add 0x1590 to the whitelist and be more
specific when ignoring the 103c,1979 device.
Signed-off-by: default avatarBrian Boylston <brian.boylston@hpe.com>
Reviewed-by: default avatarGuenter Roeck <linux@roeck-us.net>
Signed-off-by: default avatarGuenter Roeck <linux@roeck-us.net>
Signed-off-by: default avatarWim Van Sebroeck <wim@iguana.be>
parent 97beb3ae
...@@ -39,7 +39,7 @@ ...@@ -39,7 +39,7 @@
#include <asm/nmi.h> #include <asm/nmi.h>
#include <asm/frame.h> #include <asm/frame.h>
#define HPWDT_VERSION "1.3.3" #define HPWDT_VERSION "1.4.0"
#define SECS_TO_TICKS(secs) ((secs) * 1000 / 128) #define SECS_TO_TICKS(secs) ((secs) * 1000 / 128)
#define TICKS_TO_SECS(ticks) ((ticks) * 128 / 1000) #define TICKS_TO_SECS(ticks) ((ticks) * 128 / 1000)
#define HPWDT_MAX_TIMER TICKS_TO_SECS(65535) #define HPWDT_MAX_TIMER TICKS_TO_SECS(65535)
...@@ -814,7 +814,8 @@ static int hpwdt_init_one(struct pci_dev *dev, ...@@ -814,7 +814,8 @@ static int hpwdt_init_one(struct pci_dev *dev,
* not run on a legacy ASM box. * not run on a legacy ASM box.
* So we only support the G5 ProLiant servers and higher. * So we only support the G5 ProLiant servers and higher.
*/ */
if (dev->subsystem_vendor != PCI_VENDOR_ID_HP) { if (dev->subsystem_vendor != PCI_VENDOR_ID_HP &&
dev->subsystem_vendor != PCI_VENDOR_ID_HP_3PAR) {
dev_warn(&dev->dev, dev_warn(&dev->dev,
"This server does not have an iLO2+ ASIC.\n"); "This server does not have an iLO2+ ASIC.\n");
return -ENODEV; return -ENODEV;
...@@ -823,7 +824,8 @@ static int hpwdt_init_one(struct pci_dev *dev, ...@@ -823,7 +824,8 @@ static int hpwdt_init_one(struct pci_dev *dev,
/* /*
* Ignore all auxilary iLO devices with the following PCI ID * Ignore all auxilary iLO devices with the following PCI ID
*/ */
if (dev->subsystem_device == 0x1979) if (dev->subsystem_vendor == PCI_VENDOR_ID_HP &&
dev->subsystem_device == 0x1979)
return -ENODEV; return -ENODEV;
if (pci_enable_device(dev)) { if (pci_enable_device(dev)) {
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment