NetBSD/sys/dev/i2c/dbcool_reg.h
pgoyette aef4db128d Various clean-ups:
1. Trange sysctl's belong to the temp sensors, not to the fan controllers
  2. Trange really describes a slope on many chips, so modify the description
  3. Most of the sysctl's are read/write even if the chip's config is
     locked;  reflect that in the CTLFLAGs
  4. Apply correct 'nominal' values for voltage sensors/limits, specify
     them in microVolts, and calculate once rather than each time needed
  5. Be more consistent in register names - for example, use VCC instead of
     SUPPLY_VOLTAGE, to match VCC_LOWLIM & VCC_HIGHLIM
  6. Type of dbcool_islocked() should be bool, not int
  7. Reduce some unnecessary code indentation
  8. Define Vtt and Imon, and add ADT7490 support (excluding PECI sensors)
  9. Split the huge (250+ lines) dbcool_setup() function into a few smaller
     routines for better readability
 10. Update sensor tables for ADT7476 and ADT7468 - these chips have five
     voltage sensors, not two
 11. Adjust flags for ADT7463 and ADM1027 - these chips can monitor CPU
     VID data bits
 12. Update man page
2008-10-06 01:35:35 +00:00

396 lines
13 KiB
C

/* $NetBSD: dbcool_reg.h,v 1.2 2008/10/06 01:35:35 pgoyette Exp $ */
/*-
* Copyright (c) 2008 The NetBSD Foundation, Inc.
* All rights reserved.
*
* This code is derived from software contributed to The NetBSD Foundation
* by Paul Goyette
*
* Redistribution and use in source and binary forms, with or without
* modification, are permitted provided that the following conditions
* are met:
* 1. Redistributions of source code must retain the above copyright
* notice, this list of conditions and the following disclaimer.
* 2. Redistributions in binary form must reproduce the above copyright
* notice, this list of conditions and the following disclaimer in the
* documentation and/or other materials provided with the distribution.
*
* THIS SOFTWARE IS PROVIDED BY THE NETBSD FOUNDATION, INC. AND CONTRIBUTORS
* ``AS IS'' AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED
* TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
* PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE FOUNDATION OR CONTRIBUTORS
* BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
* CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
* SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
* INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
* CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
* ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
* POSSIBILITY OF SUCH DAMAGE.
*/
/*
* a driver for the dbCool(tm) family of environmental controllers
*/
#ifndef DBCOOLREG_H
#define DBCOOLREG_H
#include <sys/cdefs.h>
__KERNEL_RCSID(0, "$NetBSD: dbcool_reg.h,v 1.2 2008/10/06 01:35:35 pgoyette Exp $");
#define DBCOOL_ADDRMASK 0x7f
#define DBCOOL_ADDR 0x2e /* Some chips have multiple addrs */
/* The dBCool chip family register set */
/* Not all registers are available on all chips! */
#define DBCOOL_CONFIG5A_REG 0x04
#define DBCOOL_CONFIG6_REG 0x10
#define DBCOOL_CONFIG7_REG 0x11
#define DBCOOL_INTERNAL_TRIP 0x13
#define DBCOOL_EXTERNAL_TRIP 0x14
#define DBCOOL_TEST 0x15
#define DBCOOL_CHANNEL_MODE 0x16
#define DBCOOL_INT_TRIP_FIXED 0x17
#define DBCOOL_EXT_TRIP_FIXED 0x18
#define DBCOOL_ANALOG_OUT 0x19
#define DBCOOL_PECI1_TEMP 0x1A
#define DBCOOL_PECI2_TEMP 0x1B
#define DBCOOL_PECI3_TEMP 0x1C
#define DBCOOL_IMON 0x1D
#define DBCOOL_VTT 0x1E
#define DBCOOL_EXTRES_VTT_IMON 0x1F
#define DBCOOL_OFFSET 0x1F
#define DBCOOL_25VIN 0x20
#define DBCOOL_VCCP 0x21
#define DBCOOL_VCC 0x22
#define DBCOOL_5VIN 0x23
#define DBCOOL_12VIN 0x24
#define DBCOOL_CPU_VOLTAGE2 0x25
#define DBCOOL_REMOTE1_TEMP 0x25
#define DBCOOL_LOCAL_TEMP 0x26
#define DBCOOL_REMOTE2_TEMP 0x27
#define DBCOOL_FAN1_TACH_LSB 0x28
#define DBCOOL_FAN1_TACH_MSB 0x29
#define DBCOOL_FAN2_TACH_LSB 0x2A
#define DBCOOL_FAN2_TACH_MSB 0x2B
#define DBCOOL_FAN3_TACH_LSB 0x2C
#define DBCOOL_FAN3_TACH_MSB 0x2D
#define DBCOOL_FAN4_TACH_LSB 0x2E
#define DBCOOL_FAN4_TACH_MSB 0x2F
#define DBCOOL_PWM1_CURDUTY 0x30
#define DBCOOL_DAC0_START 0x30
#define DBCOOL_PWM2_CURDUTY 0x31
#define DBCOOL_DAC1_START 0x31
#define DBCOOL_PWM3_CURDUTY 0x32
#define DBCOOL_DAC0_MIN 0x32
#define DBCOOL_PECI0 0x33
#define DBCOOL_DAC1_MIN 0x33
#define DBCOOL_PECI_LOWLIM 0x34
#define DBCOOL_DAC0_MAX 0x34
#define DBCOOL_PECI_HIGHLIM 0x35
#define DBCOOL_DAC1_MAX 0x35
#define DBCOOL_PECI_CFG1 0x36
#define DBCOOL_DYNTMIN_CNTRL1 0x36
#define DBCOOL_DYNTMIN_CNTRL2 0x37
#define DBCOOL_PWM1_MAXDUTY 0x38
#define DBCOOL_PWM2_MAXDUTY 0x39
#define DBCOOL_PWM3_MAXDUTY 0x3A
/*
* Note: ADT7490 reused the Device_ID register for PECI Tcontrol value
* (equivalent to Ttherm for the regular temp sensors)
*/
#define DBCOOL_DEVICEID_REG 0x3D
#define DBCOOL_PECI_TCONTROL 0x3D
#define DBCOOL_COMPANYID_REG 0x3E
#define DBCOOL_REVISION_REG 0x3F
#define DBCOOL_CONFIG1_REG 0x40
#define DBCOOL_DAC0_OUT 0x40
#define DBCOOL_ISR1_REG 0x41
#define DBCOOL_DAC1_OUT 0x41
#define DBCOOL_ISR2_REG 0x42
#define DBCOOL_ISR3_REG 0x43
#define DBCOOL_VID_REG 0x43
#define DBCOOL_25VIN_LOWLIM 0x44
#define DBCOOL_25VIN_HIGHLIM 0x45
#define DBCOOL_VCCP_LOWLIM 0x46
#define DBCOOL_VCCP_HIGHLIM 0x47
#define DBCOOL_VIDB 0x47
#define DBCOOL_VCC_LOWLIM 0x48
#define DBCOOL_VCC_HIGHLIM 0x49
#define DBCOOL_VID4 0x49
#define DBCOOL_5VIN_LOWLIM 0x4A
#define DBCOOL_5VIN_HIGHLIM 0x4B
#define DBCOOL_12VIN_LOWLIM 0x4C
#define DBCOOL_12VIN_HIGHLIM 0x4D
#define DBCOOL_REMOTE1_LOWLIM 0x4E
#define DBCOOL_REMOTE1_HIGHLIM 0x4F
#define DBCOOL_LOCAL_LOWLIM 0x50
#define DBCOOL_LOCAL_HIGHLIM 0x51
#define DBCOOL_REMOTE2_LOWLIM 0x52
#define DBCOOL_REMOTE2_HIGHLIM 0x53
#define DBCOOL_TACH1_MIN_LSB 0x54
#define DBCOOL_TACH1_MIN_MSB 0x55
#define DBCOOL_TACH2_MIN_LSB 0x56
#define DBCOOL_TACH2_MIN_MSB 0x57
#define DBCOOL_TACH3_MIN_LSB 0x58
#define DBCOOL_TACH3_MIN_MSB 0x59
#define DBCOOL_TACH4_MIN_LSB 0x5A
#define DBCOOL_TACH4_MIN_MSB 0x5B
#define DBCOOL_PWM1_CTL 0x5C
#define DBCOOL_PWM2_CTL 0x5D
#define DBCOOL_PWM3_CTL 0x5E
#define DBCOOL_REMOTE1_TRANGE 0x5F /* Bits [7:4] */
#define DBCOOL_LOCAL_TRANGE 0x60 /* Bits [7:4] */
#define DBCOOL_REMOTE2_TRANGE 0x61 /* Bits [7:4] */
#define DBCOOL_ENH_ACOUST_1 0x62
#define DBCOOL_ENH_ACOUST_2 0x63
#define DBCOOL_PWM1_MINDUTY 0x64
#define DBCOOL_PWM2_MINDUTY 0x65
#define DBCOOL_PWM3_MINDUTY 0x66
#define DBCOOL_REMOTE1_TMIN 0x67
#define DBCOOL_LOCAL_TMIN 0x68
#define DBCOOL_REMOTE2_TMIN 0x69
#define DBCOOL_REMOTE1_TTHRESH 0x6A
#define DBCOOL_LOCAL_TTHRESH 0x6B
#define DBCOOL_REMOTE2_TTHRESH 0x6C
#define DBCOOL_R1_LCL_TMIN_HYST 0x6D
#define DBCOOL_R2_TMIN_HYST 0x6E
#define DBCOOL_XNOR_ENABLE 0x6F
#define DBCOOL_REMOTE1_TEMPOFF 0x70
#define DBCOOL_LOCAL_TEMPOFF 0x71
#define DBCOOL_REMOTE2_TEMPOFF 0x72
#define DBCOOL_CONFIG2_REG 0x73
#define DBCOOL_IMASK1_REG 0x74
#define DBCOOL_IMASK2_REG 0x75
#define DBCOOL_EXTRES1_REG 0x76
#define DBCOOL_EXTRES2_REG 0x77
#define DBCOOL_CONFIG3_REG 0x78
#define DBCOOL_THERM_TIMERSTATUS_REG 0x79
#define DBCOOL_THERM_TIMERLIMIT_REG 0x7A
#define DBCOOL_TACHPULSE_REG 0x7B
#define DBCOOL_CONFIG5_REG 0x7C
#define DBCOOL_CONFIG4_REG 0x7D
#define DBCOOL_TEST1_REG 0x7E
#define DBCOOL_TEST2_REG 0x7F
#define DBCOOL_GPIO_CONFIG 0x80
#define DBCOOL_ISR4_REG 0x81
#define DBCOOL_IMASK3_REG 0x82
#define DBCOOL_IMASK4_REG 0x83
#define DBCOOL_VTT_LOWLIM 0x84
#define DBCOOL_IMON_LOWLIM 0x85
#define DBCOOL_VTT_HIGHLIM 0x86
#define DBCOOL_IMON_HIGHLIM 0x87
#define DBCOOL_PECI_CFG2 0x88
#define DBCOOL_TEST3_REG 0x89
#define DBCOOL_PECI_OP_PT 0x8A
#define DBCOOL_REMOTE1_OP_PT 0x8B
#define DBCOOL_LOCAL_OP_PT 0x8C
#define DBCOOL_REMOTE2_OP_PT 0x8D
#define DBCOOL_DYNTMIN_CTL1 0x8E
#define DBCOOL_DYNTMIN_CTL2 0x8F
#define DBCOOL_DYNTMIN_CTL3 0x90
#define DBCOOL_PECI0_TEMPOFF 0x94
#define DBCOOL_PECI1_TEMPOFF 0x95
#define DBCOOL_PECI2_TEMPOFF 0x96
#define DBCOOL_PECI3_TEMPOFF 0x97
#define DBCOOL_NO_REG 0xff
/* Config register bit definitions */
#define DBCOOL_CFG1_START 0x01
#define DBCOOL_CFG1_LOCK 0x02
#define DBCOOL_CFG1_RDY 0x04
#define DBCOOL_CFG1_FSPD 0x08
#define DBCOOL_CFG1_VxI 0x10
#define DBCOOL_CFG1_RESET 0x10
#define DBCOOL_CFG1_FSPDIS 0x20
#define DBCOOL_CFG1_12VVID4_SEL 0x20
#define DBCOOL_CFG1_TODIS 0x40
#define DBCOOL_CFG1_Vcc 0x80
#define DBCOOL_CFG1_RESET_LATCH 0x80
#define DBCOOL_CFG2_AIN1 0x01
#define DBCOOL_CFG2_AIN2 0x02
#define DBCOOL_CFG2_AIN3 0x04
#define DBCOOL_CFG2_AIN4 0x08
#define DBCOOL_CFG2_AVG 0x10
#define DBCOOL_CFG2_ATTN 0x20
#define DBCOOL_CFG2_CONV 0x40
#define DBCOOL_CFG2_SHDN 0x80
#define DBCOOL_CFG3_ALERT 0x01
#define DBCOOL_CFG3_THERM 0x02
#define DBCOOL_CFG3_BOOST 0x04
#define DBCOOL_CFG3_FAST 0x08
#define DBCOOL_CFG3_DC1 0x10
#define DBCOOL_CFG3_DC2 0x20
#define DBCOOL_CFG3_DC3 0x40
#define DBCOOL_CFG3_DC4 0x80
#define DBCOOL_CFG4_PIN9FUNC 0x03
#define DBCOOL_CFG4_AINL 0x0C
#define DBCOOL_CFG4_BYPASS_ATTN 0x20
#define DBCOOL_CFG5_TWOSCOMP 0x01
#define DBCOOL_CFG5_FREQ 0x02
#define DBCOOL_CFG5_GPIOD 0x04
#define DBCOOL_CFG5_GPIOP 0x08
#define DBCOOL_CFG6_SLOW_REM1 0x01
#define DBCOOL_CFG6_SLOW_LOCAL 0x02
#define DBCOOL_CFG6_SLOW_REM2 0x04
#define DBCOOL_CFG6_THERM_MAN 0x08
#define DBCOOL_CFG6_VCCP_LOW 0x40
#define DBCOOL_CFG6_EXTRASLOW 0x80
#define DBCOOL_CFG7_DIS_THERM_HYST 0x10
/*
* The ADT7466 is an orphan stepchild in the dbCool family
*/
#define DBCOOL_ADT7466_CONFIG1 0x00
#define DBCOOL_ADT7466_CONFIG2 0x01
#define DBCOOL_ADT7466_CONFIG3 0x02
#define DBCOOL_ADT7466_CONFIG4 0x03
#define DBCOOL_ADT7466_CONFIG5 0x04
#define DBCOOL_ADT7466_AFC1 0x05
#define DBCOOL_ADT7466_AFC2 0x06
#define DBCOOL_ADT7466_REM_TEMP_LSB 0x08
#define DBCOOL_ADT7466_LCL_TEMP_LSB 0x09
#define DBCOOL_ADT7466_AIN1 0x0A
#define DBCOOL_ADT7466_AIN2 0x0B
#define DBCOOL_ADT7466_VCC 0x0C
#define DBCOOL_ADT7466_REM_TEMP_MSB 0x0D
#define DBCOOL_ADT7466_LCL_TEMP_MSB 0x0E
#define DBCOOL_ADT7466_PROCHOT 0x0F
#define DBCOOL_ADT7466_INTRPT1 0x10
#define DBCOOL_ADT7466_INTRPT2 0x11
#define DBCOOL_ADT7466_INTMSK1 0x12
#define DBCOOL_ADT7466_INTMSK2 0x13
#define DBCOOL_ADT7466_AIN1_LOLIM 0x14
#define DBCOOL_ADT7466_AIN1_HILIM 0x15
#define DBCOOL_ADT7466_AIN2_LOLIM 0x16
#define DBCOOL_ADT7466_AIN2_HILIM 0x17
#define DBCOOL_ADT7466_VCC_LOLIM 0x18
#define DBCOOL_ADT7466_VCC_HILIM 0x19
#define DBCOOL_ADT7466_REM_TEMP_LOLIM 0x1A
#define DBCOOL_ADT7466_REM_TEMP_HILIM 0x1B
#define DBCOOL_ADT7466_LCL_TEMP_LOLIM 0x1C
#define DBCOOL_ADT7466_LCL_TEMP_HILIM 0x1D
#define DBCOOL_ADT7466_PROCHOT_LIM 0x1E
#define DBCOOL_ADT7466_AIN1_THERM 0x1F
#define DBCOOL_ADT7466_AIN2_THREM 0x20
#define DBCOOL_ADT7466_REM_THERM 0x21
#define DBCOOL_ADT7466_LCL_THERM 0x22
#define DBCOOL_ADT7466_AIN1_OFFSET 0x24
#define DBCOOL_ADT7466_AIN2_OFFSET 0x25
#define DBCOOL_ADT7466_REM_OFFSET 0x26
#define DBCOOL_ADT7466_LCL_OFFSET 0x27
#define DBCOOL_ADT7466_AIN1_TMIN 0x28
#define DBCOOL_ADT7466_AIN2_TMIN 0x29
#define DBCOOL_ADT7466_REM_TMIN 0x2A
#define DBCOOL_ADT7466_LCL_TMIN 0x2B
#define DBCOOL_ADT7466_AIN_RANGES 0x2C
#define DBCOOL_ADT7466_LCL_REM_RANGES 0x2D
#define DBCOOL_ADT7466_AIN_HYSTS 0x2E
#define DBCOOL_ADT7466_LCL_REM_HYSTS 0x2F
#define DBCOOL_ADT7466_FANA_STARTV 0x30
#define DBCOOL_ADT7466_FANB_STARTV 0x31
#define DBCOOL_ADT7466_FANA_MINV 0x32
#define DBCOOL_ADT7466_FANB_MINV 0x33
#define DBCOOL_ADT7466_FANA_MAXRPM_MSB 0x34
#define DBCOOL_ADT7466_FANB_MAXRPM_MSB 0x35
#define DBCOOL_ADT7466_ENH_ACOUSTICS 0x36
#define DBCOOL_ADT7466_FAULT_INCR 0x37
#define DBCOOL_ADT7466_TIMEOUT 0x38
#define DBCOOL_ADT7466_PULSES 0x39
#define DBCOOL_ADT7466_DRIVE1 0x40
#define DBCOOL_ADT7466_DRIVE2 0x41
#define DBCOOL_ADT7466_XOR_TEST 0x42
#define DBCOOL_ADT7466_FANA_LSB 0x48
#define DBCOOL_ADT7466_FANA_MSB 0x49
#define DBCOOL_ADT7466_FANB_LSB 0x4A
#define DBCOOL_ADT7466_FANB_MSB 0x4B
#define DBCOOL_ADT7466_FANA_LOLIM_LSB 0x4C
#define DBCOOL_ADT7466_FANA_LOLIM_MSB 0x4D
#define DBCOOL_ADT7466_FANB_LOLIM_LSB 0x4E
#define DBCOOL_ADT7466_FANB_LOLIM_MSB 0x4F
#define DBCOOL_ADT7466_CFG1_Vcc 0x40
#define DBCOOL_ADT7466_CFG2_SHDN 0x40
/*
* Even though it's not really a member of the dbCool family, we also
* support the ADM1030 chip. It has a different register set.
*/
#define DBCOOL_ADM1030_CFG1 0x00
#define DBCOOL_ADM1030_CFG2 0x01
#define DBCOOL_ADM1030_STATUS1 0x02
#define DBCOOL_ADM1030_STATUS2 0x03
#define DBCOOL_ADM1030_TEMP_EXTRES 0x06
#define DBCOOL_ADM1030_TEST_REG 0x07
#define DBCOOL_ADM1030_FAN_TACH 0x08
#define DBCOOL_ADM1030_L_TEMP 0x0A
#define DBCOOL_ADM1030_R_TEMP 0x0B
#define DBCOOL_ADM1030_L_OFFSET 0x0D
#define DBCOOL_ADM1030_R_OFFSET 0x0E
#define DBCOOL_ADM1030_FAN_LO_LIM 0x10
#define DBCOOL_ADM1030_L_HI_LIM 0x14
#define DBCOOL_ADM1030_L_LO_LIM 0x15
#define DBCOOL_ADM1030_L_TTHRESH 0x16
#define DBCOOL_ADM1030_R_HI_LIM 0x18
#define DBCOOL_ADM1030_R_LO_LIM 0x19
#define DBCOOL_ADM1030_R_TTHRESH 0x1A
#define DBCOOL_ADM1030_FAN_CHAR 0x20
#define DBCOOL_ADM1030_FAN_SPEED_CFG 0x22
#define DBCOOL_ADM1030_FAN_FILTER 0x23
#define DBCOOL_ADM1030_L_TMIN 0x24
#define DBCOOL_ADM1030_R_TMIN 0x25
#define DBCOOL_ADM1030_DEVICEID DBCOOL_DEVICEID_REG
#define DBCOOL_ADM1030_COMPANYID DBCOOL_COMPANYID_REG
#define DBCOOL_ADM1030_REVISION DBCOOL_REVISION_REG
/*
* Macros to locate limit registers for the various sensor types
*/
#define DBCOOL_VOLT_LOLIM(reg) ((reg - DBCOOL_25VIN) * 2 + DBCOOL_25VIN_LOWLIM)
#define DBCOOL_VOLT_HILIM(reg) (DBCOOL_VOLT_LOLIM(reg) + 1)
#define DBCOOL_TEMP_LOLIM(reg) \
((reg - DBCOOL_LOCAL_TEMP) * 2 + DBCOOL_LOCAL_LOWLIM)
#define DBCOOL_TEMP_HILIM(reg) (DBCOOL_TEMP_LOLIM(reg) + 1)
#define DBCOOL_TACH_LOLIM(reg) \
(reg - DBCOOL_FAN1_TACH_LSB + DBCOOL_TACH1_MIN_LSB)
#define ADM1030_TEMP_HILIM(reg) \
((reg - DBCOOL_ADM1030_L_TEMP) * 3 + DBCOOL_ADM1030_L_HI_LIM)
#define ADM1030_TEMP_LOLIM(reg) \
((reg - DBCOOL_ADM1030_L_TEMP) * 3 + DBCOOL_ADM1030_L_LO_LIM)
#define ADT7466_LIM_OFFSET(reg) \
((reg - DBCOOL_AIN1) * 2 + DBCOOL_AIN1_LOWLIM)
#define ADT7466_FAN_LIM_OFFSET(reg) \
(reg - DBCOOL_FANA_LSB + DBCOOL_FANA_LOWLIM_LSB)
/* Company and Device ID values */
#define DBCOOL_COMPANYID 0x41
#define ADM1027_DEVICEID 0x27
#define ADM1030_DEVICEID 0x30
#define ADT7463_DEVICEID 0x27
#define ADT7466_DEVICEID 0x66
#define ADT7467_DEVICEID 0x68 /* The ADT7467/7468 cannot be */
#define ADT7468_DEVICEID 0x68 /* distinguished by DEVICEID */
#define ADT7473_DEVICEID 0x73
#define ADT7475_DEVICEID 0x75
#define ADT7476_DEVICEID 0x76
#define ADT7490_DEVICEID 0xFF /* Device ID not used on 7490 */
#define ADM1027_REV_ID 0x60
#define ADT7463_REV_ID1 0x62
#define ADT7463_REV_ID2 0x6A
#define ADT7467_REV_ID1 0x71
#define ADT7467_REV_ID2 0x72
#define ADT7473_REV_ID1 0x68
#define ADT7473_REV_ID2 0x69
#define ADT7490_REV_ID 0x6E
#endif /* def DBCOOLREG_H */