lists.openwall.net   lists  /  announce  owl-users  owl-dev  john-users  john-dev  passwdqc-users  yescrypt  popa3d-users  /  oss-security  kernel-hardening  musl  sabotage  tlsify  passwords  /  crypt-dev  xvendor  /  Bugtraq  Full-Disclosure  linux-kernel  linux-netdev  linux-ext4  linux-hardening  linux-cve-announce  PHC 
Open Source and information security mailing list archives
 
Hash Suite: Windows password security audit tool. GUI, reports in PDF.
[<prev] [next>] [<thread-prev] [day] [month] [year] [list]
Date:	Sat, 21 Feb 2009 18:08:03 -0500
From:	Stephen Clark <sclark46@...thlink.net>
To:	Wim Van Sebroeck <wim@...ana.be>
CC:	Linus Torvalds <torvalds@...ux-foundation.org>,
	Andrew Morton <akpm@...ux-foundation.org>,
	LKML <linux-kernel@...r.kernel.org>
Subject: Re: [WATCHDOG] v2.6.29-rc5 iTCO_wdt regression.

Wim Van Sebroeck wrote:
> Hi Linus,
> 
> This should have gone out more then 2 weeks ago, but a disk crash changed my planning :-(
> 
> Please pull from 'master' branch of
> 	git://git.kernel.org/pub/scm/linux/kernel/git/wim/linux-2.6-watchdog.git
> or if master.kernel.org hasn't synced up yet:
> 	master.kernel.org:/pub/scm/linux/kernel/git/wim/linux-2.6-watchdog.git
> 
> This will update the following files:
> 
>  drivers/watchdog/Kconfig               |    2 -
>  drivers/watchdog/iTCO_vendor_support.c |   32 ++++++++++++++++++++++++++----
>  drivers/watchdog/iTCO_wdt.c            |   35 +++++++++++++--------------------
>  3 files changed, 43 insertions(+), 26 deletions(-)
> 
> with these Changes:
> 
> Author: Wim Van Sebroeck <wim@...ana.be>
> Date:   Wed Jan 28 20:51:04 2009 +0000
> 
>     [WATCHDOG] iTCO_wdt: fix SMI_EN regression 2
>     
>     bugzilla: #12363
>     commit 7cd5b08be3c489df11b559fef210b81133764ad4 added a second regression:
>     some Dell's and Compaq's lockup on boot. So we revert most of the code.
>     The ICH9 reboot issue remains in place and will need some more fixing... :-(

Any idea when you could have a fix for the ICH9?

>     
>     Signed-off-by: Wim Van Sebroeck <wim@...ana.be>
> 
> The Changes can also be looked at on:
> 	http://www.kernel.org/git/?p=linux/kernel/git/wim/linux-2.6-watchdog.git;a=summary
> 
> For completeness, I added the overal diff below.
> 
> Greetings,
> Wim.
> 
> ================================================================================
> diff --git a/drivers/watchdog/Kconfig b/drivers/watchdog/Kconfig
> index 09a3d55..325c10f 100644
> --- a/drivers/watchdog/Kconfig
> +++ b/drivers/watchdog/Kconfig
> @@ -406,7 +406,7 @@ config ITCO_WDT
>  	---help---
>  	  Hardware driver for the intel TCO timer based watchdog devices.
>  	  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.
>  
>  	  The TCO (Total Cost of Ownership) timer is a watchdog timer
> diff --git a/drivers/watchdog/iTCO_vendor_support.c b/drivers/watchdog/iTCO_vendor_support.c
> index 2474ebc..d8264ad 100644
> --- a/drivers/watchdog/iTCO_vendor_support.c
> +++ b/drivers/watchdog/iTCO_vendor_support.c
> @@ -1,7 +1,7 @@
>  /*
>   *	intel TCO vendor specific watchdog driver support
>   *
> - *	(c) Copyright 2006-2008 Wim Van Sebroeck <wim@...ana.be>.
> + *	(c) Copyright 2006-2009 Wim Van Sebroeck <wim@...ana.be>.
>   *
>   *	This program is free software; you can redistribute it and/or
>   *	modify it under the terms of the GNU General Public License
> @@ -19,7 +19,7 @@
>  
>  /* Module and version information */
>  #define DRV_NAME	"iTCO_vendor_support"
> -#define DRV_VERSION	"1.02"
> +#define DRV_VERSION	"1.03"
>  #define PFX		DRV_NAME ": "
>  
>  /* Includes */
> @@ -77,6 +77,26 @@ MODULE_PARM_DESC(vendorsupport, "iTCO vendor specific support mode, default=0 (n
>   *	    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)
>  {
>  	/* 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,
>  			   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);
>  }
>  EXPORT_SYMBOL(iTCO_vendor_pre_start);
>  
>  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();
>  }
>  EXPORT_SYMBOL(iTCO_vendor_pre_stop);
> diff --git a/drivers/watchdog/iTCO_wdt.c b/drivers/watchdog/iTCO_wdt.c
> index 5b395a4..3523349 100644
> --- a/drivers/watchdog/iTCO_wdt.c
> +++ b/drivers/watchdog/iTCO_wdt.c
> @@ -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@...ana.be>.
> + *	(c) Copyright 2006-2009 Wim Van Sebroeck <wim@...ana.be>.
>   *
>   *	This program is free software; you can redistribute it and/or
>   *	modify it under the terms of the GNU General Public License
> @@ -63,7 +63,7 @@
>  
>  /* Module and version information */
>  #define DRV_NAME	"iTCO_wdt"
> -#define DRV_VERSION	"1.04"
> +#define DRV_VERSION	"1.05"
>  #define PFX		DRV_NAME ": "
>  
>  /* Includes */
> @@ -236,16 +236,16 @@ MODULE_DEVICE_TABLE(pci, iTCO_wdt_pci_tbl);
>  
>  /* Address definitions for the TCO */
>  /* TCO base address */
> -#define	TCOBASE		iTCO_wdt_private.ACPIBASE + 0x60
> +#define TCOBASE		iTCO_wdt_private.ACPIBASE + 0x60
>  /* 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 TCOv1_TMR	TCOBASE + 0x01	/* TCOv1 Timer Initial Value	*/
> -#define	TCO_DAT_IN	TCOBASE + 0x02	/* TCO Data In Register		*/
> -#define	TCO_DAT_OUT	TCOBASE + 0x03	/* TCO Data Out Register	*/
> -#define	TCO1_STS	TCOBASE + 0x04	/* TCO1 Status Register		*/
> -#define	TCO2_STS	TCOBASE + 0x06	/* TCO2 Status Register		*/
> +#define TCO_DAT_IN	TCOBASE + 0x02	/* TCO Data In Register		*/
> +#define TCO_DAT_OUT	TCOBASE + 0x03	/* TCO Data Out Register	*/
> +#define TCO1_STS	TCOBASE + 0x04	/* TCO1 Status Register		*/
> +#define TCO2_STS	TCOBASE + 0x06	/* TCO2 Status Register		*/
>  #define TCO1_CNT	TCOBASE + 0x08	/* TCO1 Control Register	*/
>  #define TCO2_CNT	TCOBASE + 0x0a	/* TCO2 Control Register	*/
>  #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)
>  {
>  	unsigned int val;
> -	unsigned long val32;
>  
>  	spin_lock(&iTCO_wdt_private.io_lock);
>  
> @@ -351,11 +350,6 @@ static int iTCO_wdt_start(void)
>  		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
>  	   register */
>  	if (iTCO_wdt_private.iTCO_version == 2)
> @@ -378,7 +372,6 @@ static int iTCO_wdt_start(void)
>  static int iTCO_wdt_stop(void)
>  {
>  	unsigned int val;
> -	unsigned long val32;
>  
>  	spin_lock(&iTCO_wdt_private.io_lock);
>  
> @@ -390,11 +383,6 @@ static int iTCO_wdt_stop(void)
>  	outw(val, 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 */
>  	iTCO_wdt_set_NO_REBOOT_bit();
>  
> @@ -649,6 +637,7 @@ static int __devinit iTCO_wdt_init(struct pci_dev *pdev,
>  	int ret;
>  	u32 base_address;
>  	unsigned long RCBA;
> +	unsigned long val32;
>  
>  	/*
>  	 *      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;
>  		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
>  	   by the TCOBASE value */
> --
> To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
> the body of a message to majordomo@...r.kernel.org
> More majordomo info at  http://vger.kernel.org/majordomo-info.html
> Please read the FAQ at  http://www.tux.org/lkml/
> 


-- 

"They that give up essential liberty to obtain temporary safety,
deserve neither liberty nor safety."  (Ben Franklin)

"The course of history shows that as a government grows, liberty
decreases."  (Thomas Jefferson)


--
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to majordomo@...r.kernel.org
More majordomo info at  http://vger.kernel.org/majordomo-info.html
Please read the FAQ at  http://www.tux.org/lkml/

Powered by blists - more mailing lists

Powered by Openwall GNU/*/Linux Powered by OpenVZ