diff options
Diffstat (limited to 'drivers/watchdog/hpwdt.c')
| -rw-r--r-- | drivers/watchdog/hpwdt.c | 12 | 
1 files changed, 11 insertions, 1 deletions
| diff --git a/drivers/watchdog/hpwdt.c b/drivers/watchdog/hpwdt.c index 286369d4f0f5..be99112fad00 100644 --- a/drivers/watchdog/hpwdt.c +++ b/drivers/watchdog/hpwdt.c @@ -51,6 +51,7 @@ static char expect_release;  static unsigned long hpwdt_is_open;  static void __iomem *pci_mem_addr;		/* the PCI-memory address */ +static unsigned long __iomem *hpwdt_nmistat;  static unsigned long __iomem *hpwdt_timer_reg;  static unsigned long __iomem *hpwdt_timer_con; @@ -474,6 +475,11 @@ static int hpwdt_time_left(void)  }  #ifdef CONFIG_HPWDT_NMI_DECODING +static int hpwdt_my_nmi(void) +{ +	return ioread8(hpwdt_nmistat) & 0x6; +} +  /*   *	NMI Handler   */ @@ -485,6 +491,9 @@ static int hpwdt_pretimeout(unsigned int ulReason, struct pt_regs *regs)  	if (!hpwdt_nmi_decoding)  		goto out; +	if ((ulReason == NMI_UNKNOWN) && !hpwdt_my_nmi()) +		return NMI_DONE; +  	spin_lock_irqsave(&rom_lock, rom_pl);  	if (!die_nmi_called && !is_icru && !is_uefi)  		asminline_call(&cmn_regs, cru_rom_addr); @@ -700,7 +709,7 @@ static void dmi_find_icru(const struct dmi_header *dm, void *dummy)  		smbios_proliant_ptr = (struct smbios_proliant_info *) dm;  		if (smbios_proliant_ptr->misc_features & 0x01)  			is_icru = 1; -		if (smbios_proliant_ptr->misc_features & 0x408) +		if (smbios_proliant_ptr->misc_features & 0x1400)  			is_uefi = 1;  	}  } @@ -840,6 +849,7 @@ static int hpwdt_init_one(struct pci_dev *dev,  		retval = -ENOMEM;  		goto error_pci_iomap;  	} +	hpwdt_nmistat	= pci_mem_addr + 0x6e;  	hpwdt_timer_reg = pci_mem_addr + 0x70;  	hpwdt_timer_con = pci_mem_addr + 0x72; | 
