1*53ee8cc1Swenshuai.xi /* 2*53ee8cc1Swenshuai.xi * Generic watchdog defines. Derived from.. 3*53ee8cc1Swenshuai.xi * 4*53ee8cc1Swenshuai.xi * Berkshire PC Watchdog Defines 5*53ee8cc1Swenshuai.xi * by Ken Hollis <khollis@bitgate.com> 6*53ee8cc1Swenshuai.xi * 7*53ee8cc1Swenshuai.xi */ 8*53ee8cc1Swenshuai.xi 9*53ee8cc1Swenshuai.xi #ifndef _LINUX_WATCHDOG_H 10*53ee8cc1Swenshuai.xi #define _LINUX_WATCHDOG_H 11*53ee8cc1Swenshuai.xi 12*53ee8cc1Swenshuai.xi #include <linux/ioctl.h> 13*53ee8cc1Swenshuai.xi #include <linux/types.h> 14*53ee8cc1Swenshuai.xi 15*53ee8cc1Swenshuai.xi #define WATCHDOG_IOCTL_BASE 'W' 16*53ee8cc1Swenshuai.xi 17*53ee8cc1Swenshuai.xi struct watchdog_info { 18*53ee8cc1Swenshuai.xi __u32 options; /* Options the card/driver supports */ 19*53ee8cc1Swenshuai.xi __u32 firmware_version; /* Firmware version of the card */ 20*53ee8cc1Swenshuai.xi __u8 identity[32]; /* Identity of the board */ 21*53ee8cc1Swenshuai.xi }; 22*53ee8cc1Swenshuai.xi 23*53ee8cc1Swenshuai.xi #define WDIOC_GETSUPPORT _IOR(WATCHDOG_IOCTL_BASE, 0, struct watchdog_info) 24*53ee8cc1Swenshuai.xi #define WDIOC_GETSTATUS _IOR(WATCHDOG_IOCTL_BASE, 1, int) 25*53ee8cc1Swenshuai.xi #define WDIOC_GETBOOTSTATUS _IOR(WATCHDOG_IOCTL_BASE, 2, int) 26*53ee8cc1Swenshuai.xi #define WDIOC_GETTEMP _IOR(WATCHDOG_IOCTL_BASE, 3, int) 27*53ee8cc1Swenshuai.xi #define WDIOC_SETOPTIONS _IOR(WATCHDOG_IOCTL_BASE, 4, int) 28*53ee8cc1Swenshuai.xi #define WDIOC_KEEPALIVE _IOR(WATCHDOG_IOCTL_BASE, 5, int) 29*53ee8cc1Swenshuai.xi #define WDIOC_SETTIMEOUT _IOWR(WATCHDOG_IOCTL_BASE, 6, int) 30*53ee8cc1Swenshuai.xi #define WDIOC_GETTIMEOUT _IOR(WATCHDOG_IOCTL_BASE, 7, int) 31*53ee8cc1Swenshuai.xi #define WDIOC_SETPRETIMEOUT _IOWR(WATCHDOG_IOCTL_BASE, 8, int) 32*53ee8cc1Swenshuai.xi #define WDIOC_GETPRETIMEOUT _IOR(WATCHDOG_IOCTL_BASE, 9, int) 33*53ee8cc1Swenshuai.xi #define WDIOC_GETTIMELEFT _IOR(WATCHDOG_IOCTL_BASE, 10, int) 34*53ee8cc1Swenshuai.xi 35*53ee8cc1Swenshuai.xi #define WDIOF_UNKNOWN -1 /* Unknown flag error */ 36*53ee8cc1Swenshuai.xi #define WDIOS_UNKNOWN -1 /* Unknown status error */ 37*53ee8cc1Swenshuai.xi 38*53ee8cc1Swenshuai.xi #define WDIOF_OVERHEAT 0x0001 /* Reset due to CPU overheat */ 39*53ee8cc1Swenshuai.xi #define WDIOF_FANFAULT 0x0002 /* Fan failed */ 40*53ee8cc1Swenshuai.xi #define WDIOF_EXTERN1 0x0004 /* External relay 1 */ 41*53ee8cc1Swenshuai.xi #define WDIOF_EXTERN2 0x0008 /* External relay 2 */ 42*53ee8cc1Swenshuai.xi #define WDIOF_POWERUNDER 0x0010 /* Power bad/power fault */ 43*53ee8cc1Swenshuai.xi #define WDIOF_CARDRESET 0x0020 /* Card previously reset the CPU */ 44*53ee8cc1Swenshuai.xi #define WDIOF_POWEROVER 0x0040 /* Power over voltage */ 45*53ee8cc1Swenshuai.xi #define WDIOF_SETTIMEOUT 0x0080 /* Set timeout (in seconds) */ 46*53ee8cc1Swenshuai.xi #define WDIOF_MAGICCLOSE 0x0100 /* Supports magic close char */ 47*53ee8cc1Swenshuai.xi #define WDIOF_PRETIMEOUT 0x0200 /* Pretimeout (in seconds), get/set */ 48*53ee8cc1Swenshuai.xi #define WDIOF_KEEPALIVEPING 0x8000 /* Keep alive ping reply */ 49*53ee8cc1Swenshuai.xi 50*53ee8cc1Swenshuai.xi #define WDIOS_DISABLECARD 0x0001 /* Turn off the watchdog timer */ 51*53ee8cc1Swenshuai.xi #define WDIOS_ENABLECARD 0x0002 /* Turn on the watchdog timer */ 52*53ee8cc1Swenshuai.xi #define WDIOS_TEMPPANIC 0x0004 /* Kernel panic on temperature trip */ 53*53ee8cc1Swenshuai.xi 54*53ee8cc1Swenshuai.xi 55*53ee8cc1Swenshuai.xi #endif /* ifndef _LINUX_WATCHDOG_H */ 56