diff options
Diffstat (limited to 'drivers/net/sk98lin/h/lm80.h')
| -rw-r--r-- | drivers/net/sk98lin/h/lm80.h | 197 | 
1 files changed, 197 insertions, 0 deletions
| diff --git a/drivers/net/sk98lin/h/lm80.h b/drivers/net/sk98lin/h/lm80.h new file mode 100644 index 000000000..981a4cab0 --- /dev/null +++ b/drivers/net/sk98lin/h/lm80.h @@ -0,0 +1,197 @@ +/****************************************************************************** + * + * Name:	lm80.h + * Project:	GEnesis, PCI Gigabit Ethernet Adapter + * Version:	$Revision: 1.4 $ + * Date:	$Date: 2002/04/25 11:04:10 $ + * Purpose:	Contains all defines for the LM80 Chip + *		(National Semiconductor). + * + ******************************************************************************/ + +/****************************************************************************** + * + *	(C)Copyright 1998-2002 SysKonnect GmbH. + * + *	This program is free software; you can redistribute it and/or modify + *	it under the terms of the GNU General Public License as published by + *	the Free Software Foundation; either version 2 of the License, or + *	(at your option) any later version. + * + *	The information in this file is provided "AS IS" without warranty. + * + ******************************************************************************/ + +/****************************************************************************** + * + * History: + *	$Log: lm80.h,v $ + *	Revision 1.4  2002/04/25 11:04:10  rschmidt + *	Editorial changes + * + *	Revision 1.3  1999/11/22 13:41:19  cgoos + *	Changed license header to GPL. + * + *	Revision 1.2  1999/03/12 13:26:51  malthoff + *	remove __STDC__. + * + *	Revision 1.1  1998/06/19 09:28:31  malthoff + *	created. + * + * + ******************************************************************************/ + +#ifndef __INC_LM80_H +#define __INC_LM80_H + +#ifdef __cplusplus +extern "C" { +#endif	/* __cplusplus */ + +/* defines ********************************************************************/ + +/* + * LM80 register definition + * + * All registers are 8 bit wide + */ +#define	LM80_CFG			0x00	/* Configuration Register */ +#define	LM80_ISRC_1			0x01	/* Interrupt Status Register 1 */ +#define LM80_ISRC_2			0x02	/* Interrupt Status Register 2 */ +#define LM80_IMSK_1			0x03	/* Interrupt Mask Register 1 */ +#define LM80_IMSK_2			0x04	/* Interrupt Mask Register 2 */ +#define LM80_FAN_CTRL		0x05	/* Fan Devisor/RST#/OS# Register */ +#define LM80_TEMP_CTRL		0x06	/* OS# Config, Temp Res. Reg */ +	/* 0x07 - 0x1f reserved	*/ +	/* current values */ +#define LM80_VT0_IN			0x20	/* current Voltage 0 value */ +#define LM80_VT1_IN			0x21	/* current Voltage 1 value */ +#define LM80_VT2_IN			0x22	/* current Voltage 2 value */ +#define LM80_VT3_IN			0x23	/* current Voltage 3 value */ +#define LM80_VT4_IN			0x24	/* current Voltage 4 value */ +#define LM80_VT5_IN			0x25	/* current Voltage 5 value */ +#define LM80_VT6_IN			0x26	/* current Voltage 6 value */ +#define LM80_TEMP_IN		0x27	/* current Temperature value */ +#define LM80_FAN1_IN		0x28	/* current Fan 1 count */ +#define LM80_FAN2_IN		0x29	/* current Fan 2 count */ +	/* limit values */ +#define LM80_VT0_HIGH_LIM	0x2a	/* high limit val for Voltage 0 */ +#define LM80_VT0_LOW_LIM	0x2b	/* low limit val for Voltage 0 */ +#define LM80_VT1_HIGH_LIM	0x2c	/* high limit val for Voltage 1 */ +#define LM80_VT1_LOW_LIM	0x2d	/* low limit val for Voltage 1 */ +#define LM80_VT2_HIGH_LIM	0x2e	/* high limit val for Voltage 2 */ +#define LM80_VT2_LOW_LIM	0x2f	/* low limit val for Voltage 2 */ +#define LM80_VT3_HIGH_LIM	0x30	/* high limit val for Voltage 3 */ +#define LM80_VT3_LOW_LIM	0x31	/* low limit val for Voltage 3 */ +#define LM80_VT4_HIGH_LIM	0x32	/* high limit val for Voltage 4 */ +#define LM80_VT4_LOW_LIM	0x33	/* low limit val for Voltage 4 */ +#define LM80_VT5_HIGH_LIM	0x34	/* high limit val for Voltage 5 */ +#define LM80_VT5_LOW_LIM	0x35	/* low limit val for Voltage 5 */ +#define LM80_VT6_HIGH_LIM	0x36	/* high limit val for Voltage 6 */ +#define LM80_VT6_LOW_LIM	0x37	/* low limit val for Voltage 6 */ +#define LM80_THOT_LIM_UP	0x38	/* hot temperature limit (high) */ +#define LM80_THOT_LIM_LO	0x39	/* hot temperature limit (low) */ +#define LM80_TOS_LIM_UP		0x3a	/* OS temperature limit (high) */ +#define LM80_TOS_LIM_LO		0x3b	/* OS temperature limit (low) */ +#define	LM80_FAN1_COUNT_LIM	0x3c	/* Fan 1 count limit (high) */ +#define	LM80_FAN2_COUNT_LIM	0x3d	/* Fan 2 count limit (low) */ +	/* 0x3e - 0x3f reserved	*/ + +/* + * LM80 bit definitions + */ + +/*	LM80_CFG		Configuration Register */ +#define LM80_CFG_START		(1<<0)	/* start monitoring operation */ +#define LM80_CFG_INT_ENA	(1<<1)	/* enables the INT# Interrupt output */ +#define LM80_CFG_INT_POL	(1<<2)	/* INT# pol: 0 act low, 1 act high */ +#define LM80_CFG_INT_CLR	(1<<3)	/* disables INT#/RST_OUT#/OS# outputs */ +#define LM80_CFG_RESET		(1<<4)	/* signals a reset */ +#define LM80_CFG_CHASS_CLR	(1<<5)	/* clears Chassis Intrusion (CI) pin */ +#define LM80_CFG_GPO		(1<<6)	/* drives the GPO# pin */ +#define LM80_CFG_INIT		(1<<7)	/* restore power on defaults */ + +/*	LM80_ISRC_1		Interrupt Status Register 1 */ +/*	LM80_IMSK_1		Interrupt Mask Register 1 */ +#define LM80_IS_VT0			(1<<0)	/* limit exceeded for Voltage 0 */ +#define LM80_IS_VT1			(1<<1)	/* limit exceeded for Voltage 1 */ +#define LM80_IS_VT2			(1<<2)	/* limit exceeded for Voltage 2 */ +#define LM80_IS_VT3			(1<<3)	/* limit exceeded for Voltage 3 */ +#define LM80_IS_VT4			(1<<4)	/* limit exceeded for Voltage 4 */ +#define LM80_IS_VT5			(1<<5)	/* limit exceeded for Voltage 5 */ +#define LM80_IS_VT6			(1<<6)	/* limit exceeded for Voltage 6 */ +#define LM80_IS_INT_IN		(1<<7)	/* state of INT_IN# */ + +/*	LM80_ISRC_2		Interrupt Status Register 2 */ +/*	LM80_IMSK_2		Interrupt Mask Register 2 */ +#define	LM80_IS_TEMP		(1<<0)	/* HOT temperature limit exceeded */ +#define LM80_IS_BTI			(1<<1)	/* state of BTI# pin */ +#define LM80_IS_FAN1		(1<<2)	/* count limit exceeded for Fan 1 */ +#define LM80_IS_FAN2		(1<<3)	/* count limit exceeded for Fan 2 */ +#define LM80_IS_CI			(1<<4)	/* Chassis Intrusion occured */ +#define LM80_IS_OS			(1<<5)	/* OS temperature limit exceeded */ +	/* bit 6 and 7 are reserved in LM80_ISRC_2 */ +#define LM80_IS_HT_IRQ_MD	(1<<6)	/* Hot temperature interrupt mode */ +#define LM80_IS_OT_IRQ_MD	(1<<7)	/* OS temperature interrupt mode */ + +/*	LM80_FAN_CTRL		Fan Devisor/RST#/OS# Register */ +#define LM80_FAN1_MD_SEL	(1<<0)	/* Fan 1 mode select */ +#define LM80_FAN2_MD_SEL	(1<<1)	/* Fan 2 mode select */ +#define LM80_FAN1_PRM_CTL	(3<<2)	/* Fan 1 speed control */ +#define LM80_FAN2_PRM_CTL	(3<<4)	/* Fan 2 speed control */ +#define LM80_FAN_OS_ENA		(1<<6)	/* enable OS mode on RST_OUT#/OS# pins*/ +#define LM80_FAN_RST_ENA	(1<<7)	/* sets RST_OUT#/OS# pins in RST mode */ + +/*	LM80_TEMP_CTRL		OS# Config, Temp Res. Reg */ +#define	LM80_TEMP_OS_STAT	(1<<0)	/* mirrors the state of RST_OUT#/OS# */ +#define LM80_TEMP_OS_POL	(1<<1)	/* select OS# polarity */ +#define LM80_TEMP_OS_MODE	(1<<2)	/* selects Interrupt mode */ +#define LM80_TEMP_RES		(1<<3)	/* selects 9 or 11 bit temp resulution*/ +#define LM80_TEMP_LSB		(0xf<<4)/* 4 LSBs of 11 bit temp data */ +#define LM80_TEMP_LSB_9		(1<<7)	/* LSB of 9 bit temperature data */ + +	/* 0x07 - 0x1f reserved	*/ +/*	LM80_VT0_IN		current Voltage 0 value */ +/*	LM80_VT1_IN		current Voltage 1 value */ +/*	LM80_VT2_IN		current Voltage 2 value */ +/*	LM80_VT3_IN		current Voltage 3 value */ +/*	LM80_VT4_IN		current Voltage 4 value */ +/*	LM80_VT5_IN		current Voltage 5 value */ +/*	LM80_VT6_IN		current Voltage 6 value */ +/*	LM80_TEMP_IN		current temperature value */ +/*	LM80_FAN1_IN		current Fan 1 count */ +/*	LM80_FAN2_IN		current Fan 2 count */ +/*	LM80_VT0_HIGH_LIM	high limit val for Voltage 0 */ +/*	LM80_VT0_LOW_LIM	low limit val for Voltage 0 */ +/*	LM80_VT1_HIGH_LIM	high limit val for Voltage 1 */ +/*	LM80_VT1_LOW_LIM	low limit val for Voltage 1 */ +/*	LM80_VT2_HIGH_LIM	high limit val for Voltage 2 */ +/*	LM80_VT2_LOW_LIM	low limit val for Voltage 2 */ +/*	LM80_VT3_HIGH_LIM	high limit val for Voltage 3 */ +/*	LM80_VT3_LOW_LIM	low limit val for Voltage 3 */ +/*	LM80_VT4_HIGH_LIM	high limit val for Voltage 4 */ +/*	LM80_VT4_LOW_LIM	low limit val for Voltage 4 */ +/*	LM80_VT5_HIGH_LIM	high limit val for Voltage 5 */ +/*	LM80_VT5_LOW_LIM	low limit val for Voltage 5 */ +/*	LM80_VT6_HIGH_LIM	high limit val for Voltage 6 */ +/*	LM80_VT6_LOW_LIM	low limit val for Voltage 6 */ +/*	LM80_THOT_LIM_UP	hot temperature limit (high) */ +/*	LM80_THOT_LIM_LO	hot temperature limit (low) */ +/*	LM80_TOS_LIM_UP		OS temperature limit (high) */ +/*	LM80_TOS_LIM_LO		OS temperature limit (low) */ +/*	LM80_FAN1_COUNT_LIM	Fan 1 count limit (high) */ +/*	LM80_FAN2_COUNT_LIM	Fan 2 count limit (low) */ +	/* 0x3e - 0x3f reserved	*/ + +#define LM80_ADDR		0x28	/* LM80 default addr */ + +/* typedefs *******************************************************************/ + + +/* function prototypes ********************************************************/ + +#ifdef __cplusplus +} +#endif	/* __cplusplus */ + +#endif	/* __INC_LM80_H */ |