Merge git://git.kernel.org/pub/scm/linux/kernel/git/wim/linux-2.6-watchdog
* git://git.kernel.org/pub/scm/linux/kernel/git/wim/linux-2.6-watchdog: [WATCHDOG] iTCO_wdt: fix SMI_EN regression 2
This commit is contained in:
commit
68cc8301b4
|
@ -406,7 +406,7 @@ config ITCO_WDT
|
||||||
---help---
|
---help---
|
||||||
Hardware driver for the intel TCO timer based watchdog devices.
|
Hardware driver for the intel TCO timer based watchdog devices.
|
||||||
These drivers are included in the Intel 82801 I/O Controller
|
These drivers are included in the Intel 82801 I/O Controller
|
||||||
Hub family (from ICH0 up to ICH8) and in the Intel 6300ESB
|
Hub family (from ICH0 up to ICH10) and in the Intel 63xxESB
|
||||||
controller hub.
|
controller hub.
|
||||||
|
|
||||||
The TCO (Total Cost of Ownership) timer is a watchdog timer
|
The TCO (Total Cost of Ownership) timer is a watchdog timer
|
||||||
|
|
|
@ -1,7 +1,7 @@
|
||||||
/*
|
/*
|
||||||
* intel TCO vendor specific watchdog driver support
|
* intel TCO vendor specific watchdog driver support
|
||||||
*
|
*
|
||||||
* (c) Copyright 2006-2008 Wim Van Sebroeck <wim@iguana.be>.
|
* (c) Copyright 2006-2009 Wim Van Sebroeck <wim@iguana.be>.
|
||||||
*
|
*
|
||||||
* This program is free software; you can redistribute it and/or
|
* This program is free software; you can redistribute it and/or
|
||||||
* modify it under the terms of the GNU General Public License
|
* modify it under the terms of the GNU General Public License
|
||||||
|
@ -19,7 +19,7 @@
|
||||||
|
|
||||||
/* Module and version information */
|
/* Module and version information */
|
||||||
#define DRV_NAME "iTCO_vendor_support"
|
#define DRV_NAME "iTCO_vendor_support"
|
||||||
#define DRV_VERSION "1.02"
|
#define DRV_VERSION "1.03"
|
||||||
#define PFX DRV_NAME ": "
|
#define PFX DRV_NAME ": "
|
||||||
|
|
||||||
/* Includes */
|
/* Includes */
|
||||||
|
@ -77,6 +77,26 @@ MODULE_PARM_DESC(vendorsupport, "iTCO vendor specific support mode, default=0 (n
|
||||||
* 20.6 seconds.
|
* 20.6 seconds.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
static void supermicro_old_pre_start(unsigned long acpibase)
|
||||||
|
{
|
||||||
|
unsigned long val32;
|
||||||
|
|
||||||
|
/* Bit 13: TCO_EN -> 0 = Disables TCO logic generating an SMI# */
|
||||||
|
val32 = inl(SMI_EN);
|
||||||
|
val32 &= 0xffffdfff; /* Turn off SMI clearing watchdog */
|
||||||
|
outl(val32, SMI_EN); /* Needed to activate watchdog */
|
||||||
|
}
|
||||||
|
|
||||||
|
static void supermicro_old_pre_stop(unsigned long acpibase)
|
||||||
|
{
|
||||||
|
unsigned long val32;
|
||||||
|
|
||||||
|
/* Bit 13: TCO_EN -> 1 = Enables the TCO logic to generate SMI# */
|
||||||
|
val32 = inl(SMI_EN);
|
||||||
|
val32 |= 0x00002000; /* Turn on SMI clearing watchdog */
|
||||||
|
outl(val32, SMI_EN); /* Needed to deactivate watchdog */
|
||||||
|
}
|
||||||
|
|
||||||
static void supermicro_old_pre_keepalive(unsigned long acpibase)
|
static void supermicro_old_pre_keepalive(unsigned long acpibase)
|
||||||
{
|
{
|
||||||
/* Reload TCO Timer (done in iTCO_wdt_keepalive) + */
|
/* Reload TCO Timer (done in iTCO_wdt_keepalive) + */
|
||||||
|
@ -228,14 +248,18 @@ static void supermicro_new_pre_set_heartbeat(unsigned int heartbeat)
|
||||||
void iTCO_vendor_pre_start(unsigned long acpibase,
|
void iTCO_vendor_pre_start(unsigned long acpibase,
|
||||||
unsigned int heartbeat)
|
unsigned int heartbeat)
|
||||||
{
|
{
|
||||||
if (vendorsupport == SUPERMICRO_NEW_BOARD)
|
if (vendorsupport == SUPERMICRO_OLD_BOARD)
|
||||||
|
supermicro_old_pre_start(acpibase);
|
||||||
|
else if (vendorsupport == SUPERMICRO_NEW_BOARD)
|
||||||
supermicro_new_pre_start(heartbeat);
|
supermicro_new_pre_start(heartbeat);
|
||||||
}
|
}
|
||||||
EXPORT_SYMBOL(iTCO_vendor_pre_start);
|
EXPORT_SYMBOL(iTCO_vendor_pre_start);
|
||||||
|
|
||||||
void iTCO_vendor_pre_stop(unsigned long acpibase)
|
void iTCO_vendor_pre_stop(unsigned long acpibase)
|
||||||
{
|
{
|
||||||
if (vendorsupport == SUPERMICRO_NEW_BOARD)
|
if (vendorsupport == SUPERMICRO_OLD_BOARD)
|
||||||
|
supermicro_old_pre_stop(acpibase);
|
||||||
|
else if (vendorsupport == SUPERMICRO_NEW_BOARD)
|
||||||
supermicro_new_pre_stop();
|
supermicro_new_pre_stop();
|
||||||
}
|
}
|
||||||
EXPORT_SYMBOL(iTCO_vendor_pre_stop);
|
EXPORT_SYMBOL(iTCO_vendor_pre_stop);
|
||||||
|
|
|
@ -1,7 +1,7 @@
|
||||||
/*
|
/*
|
||||||
* intel TCO Watchdog Driver (Used in i82801 and i6300ESB chipsets)
|
* intel TCO Watchdog Driver (Used in i82801 and i63xxESB chipsets)
|
||||||
*
|
*
|
||||||
* (c) Copyright 2006-2008 Wim Van Sebroeck <wim@iguana.be>.
|
* (c) Copyright 2006-2009 Wim Van Sebroeck <wim@iguana.be>.
|
||||||
*
|
*
|
||||||
* This program is free software; you can redistribute it and/or
|
* This program is free software; you can redistribute it and/or
|
||||||
* modify it under the terms of the GNU General Public License
|
* modify it under the terms of the GNU General Public License
|
||||||
|
@ -63,7 +63,7 @@
|
||||||
|
|
||||||
/* Module and version information */
|
/* Module and version information */
|
||||||
#define DRV_NAME "iTCO_wdt"
|
#define DRV_NAME "iTCO_wdt"
|
||||||
#define DRV_VERSION "1.04"
|
#define DRV_VERSION "1.05"
|
||||||
#define PFX DRV_NAME ": "
|
#define PFX DRV_NAME ": "
|
||||||
|
|
||||||
/* Includes */
|
/* Includes */
|
||||||
|
@ -236,16 +236,16 @@ MODULE_DEVICE_TABLE(pci, iTCO_wdt_pci_tbl);
|
||||||
|
|
||||||
/* Address definitions for the TCO */
|
/* Address definitions for the TCO */
|
||||||
/* TCO base address */
|
/* TCO base address */
|
||||||
#define TCOBASE iTCO_wdt_private.ACPIBASE + 0x60
|
#define TCOBASE iTCO_wdt_private.ACPIBASE + 0x60
|
||||||
/* SMI Control and Enable Register */
|
/* SMI Control and Enable Register */
|
||||||
#define SMI_EN iTCO_wdt_private.ACPIBASE + 0x30
|
#define SMI_EN iTCO_wdt_private.ACPIBASE + 0x30
|
||||||
|
|
||||||
#define TCO_RLD TCOBASE + 0x00 /* TCO Timer Reload and Curr. Value */
|
#define TCO_RLD TCOBASE + 0x00 /* TCO Timer Reload and Curr. Value */
|
||||||
#define TCOv1_TMR TCOBASE + 0x01 /* TCOv1 Timer Initial Value */
|
#define TCOv1_TMR TCOBASE + 0x01 /* TCOv1 Timer Initial Value */
|
||||||
#define TCO_DAT_IN TCOBASE + 0x02 /* TCO Data In Register */
|
#define TCO_DAT_IN TCOBASE + 0x02 /* TCO Data In Register */
|
||||||
#define TCO_DAT_OUT TCOBASE + 0x03 /* TCO Data Out Register */
|
#define TCO_DAT_OUT TCOBASE + 0x03 /* TCO Data Out Register */
|
||||||
#define TCO1_STS TCOBASE + 0x04 /* TCO1 Status Register */
|
#define TCO1_STS TCOBASE + 0x04 /* TCO1 Status Register */
|
||||||
#define TCO2_STS TCOBASE + 0x06 /* TCO2 Status Register */
|
#define TCO2_STS TCOBASE + 0x06 /* TCO2 Status Register */
|
||||||
#define TCO1_CNT TCOBASE + 0x08 /* TCO1 Control Register */
|
#define TCO1_CNT TCOBASE + 0x08 /* TCO1 Control Register */
|
||||||
#define TCO2_CNT TCOBASE + 0x0a /* TCO2 Control Register */
|
#define TCO2_CNT TCOBASE + 0x0a /* TCO2 Control Register */
|
||||||
#define TCOv2_TMR TCOBASE + 0x12 /* TCOv2 Timer Initial Value */
|
#define TCOv2_TMR TCOBASE + 0x12 /* TCOv2 Timer Initial Value */
|
||||||
|
@ -338,7 +338,6 @@ static int iTCO_wdt_unset_NO_REBOOT_bit(void)
|
||||||
static int iTCO_wdt_start(void)
|
static int iTCO_wdt_start(void)
|
||||||
{
|
{
|
||||||
unsigned int val;
|
unsigned int val;
|
||||||
unsigned long val32;
|
|
||||||
|
|
||||||
spin_lock(&iTCO_wdt_private.io_lock);
|
spin_lock(&iTCO_wdt_private.io_lock);
|
||||||
|
|
||||||
|
@ -351,11 +350,6 @@ static int iTCO_wdt_start(void)
|
||||||
return -EIO;
|
return -EIO;
|
||||||
}
|
}
|
||||||
|
|
||||||
/* Bit 13: TCO_EN -> 0 = Disables TCO logic generating an SMI# */
|
|
||||||
val32 = inl(SMI_EN);
|
|
||||||
val32 &= 0xffffdfff; /* Turn off SMI clearing watchdog */
|
|
||||||
outl(val32, SMI_EN);
|
|
||||||
|
|
||||||
/* Force the timer to its reload value by writing to the TCO_RLD
|
/* Force the timer to its reload value by writing to the TCO_RLD
|
||||||
register */
|
register */
|
||||||
if (iTCO_wdt_private.iTCO_version == 2)
|
if (iTCO_wdt_private.iTCO_version == 2)
|
||||||
|
@ -378,7 +372,6 @@ static int iTCO_wdt_start(void)
|
||||||
static int iTCO_wdt_stop(void)
|
static int iTCO_wdt_stop(void)
|
||||||
{
|
{
|
||||||
unsigned int val;
|
unsigned int val;
|
||||||
unsigned long val32;
|
|
||||||
|
|
||||||
spin_lock(&iTCO_wdt_private.io_lock);
|
spin_lock(&iTCO_wdt_private.io_lock);
|
||||||
|
|
||||||
|
@ -390,11 +383,6 @@ static int iTCO_wdt_stop(void)
|
||||||
outw(val, TCO1_CNT);
|
outw(val, TCO1_CNT);
|
||||||
val = inw(TCO1_CNT);
|
val = inw(TCO1_CNT);
|
||||||
|
|
||||||
/* Bit 13: TCO_EN -> 1 = Enables the TCO logic to generate SMI# */
|
|
||||||
val32 = inl(SMI_EN);
|
|
||||||
val32 |= 0x00002000;
|
|
||||||
outl(val32, SMI_EN);
|
|
||||||
|
|
||||||
/* Set the NO_REBOOT bit to prevent later reboots, just for sure */
|
/* Set the NO_REBOOT bit to prevent later reboots, just for sure */
|
||||||
iTCO_wdt_set_NO_REBOOT_bit();
|
iTCO_wdt_set_NO_REBOOT_bit();
|
||||||
|
|
||||||
|
@ -649,6 +637,7 @@ static int __devinit iTCO_wdt_init(struct pci_dev *pdev,
|
||||||
int ret;
|
int ret;
|
||||||
u32 base_address;
|
u32 base_address;
|
||||||
unsigned long RCBA;
|
unsigned long RCBA;
|
||||||
|
unsigned long val32;
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Find the ACPI/PM base I/O address which is the base
|
* Find the ACPI/PM base I/O address which is the base
|
||||||
|
@ -695,6 +684,10 @@ static int __devinit iTCO_wdt_init(struct pci_dev *pdev,
|
||||||
ret = -EIO;
|
ret = -EIO;
|
||||||
goto out;
|
goto out;
|
||||||
}
|
}
|
||||||
|
/* Bit 13: TCO_EN -> 0 = Disables TCO logic generating an SMI# */
|
||||||
|
val32 = inl(SMI_EN);
|
||||||
|
val32 &= 0xffffdfff; /* Turn off SMI clearing watchdog */
|
||||||
|
outl(val32, SMI_EN);
|
||||||
|
|
||||||
/* The TCO I/O registers reside in a 32-byte range pointed to
|
/* The TCO I/O registers reside in a 32-byte range pointed to
|
||||||
by the TCOBASE value */
|
by the TCOBASE value */
|
||||||
|
|
Loading…
Reference in New Issue