/* $NetBSD: emcfanreg.h,v 1.1 2025/03/11 13:56:46 brad Exp $ */
/*
* Copyright (c) 2025 Brad Spencer <
[email protected]>
*
* Permission to use, copy, modify, and distribute this software for any
* purpose with or without fee is hereby granted, provided that the above
* copyright notice and this permission notice appear in all copies.
*
* THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES
* WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF
* MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR
* ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES
* WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN
* ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF
* OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
*/
#ifndef _DEV_I2C_EMCFANREG_H_
#define _DEV_I2C_EMCFANREG_H_
#include <dev/i2c/i2c_io.h>
static const i2c_addr_t emcfan_typical_addrs[] = { 0x2c, 0x2d, 0x2e, 0x2f, 0x4c, 0x4d };
#define EMCFAN_VOID_READ 0x55
#define EMCFAN_INTERNAL_TEMP_HIGH 0x00
#define EMCFAN_INTERNAL_TEMP_LOW 0x01
#define EMCFAN_2101_EXTERNAL_TEMP_HIGH 0x01
#define EMCFAN_2101_CHIP_CONFIG 0x03
#define EMCFAN_EXTERNAL_1_TEMP_HIGH 0x02
#define EMCFAN_2101_EXTERNAL_TEMP_LOW 0x10
#define EMCFAN_EXTERNAL_1_TEMP_LOW 0x03
#define EMCFAN_EXTERNAL_2_TEMP_HIGH 0x04
#define EMCFAN_EXTERNAL_2_TEMP_LOW 0x05
#define EMCFAN_EXTERNAL_3_TEMP_HIGH 0x06
#define EMCFAN_EXTERNAL_3_TEMP_LOW 0x07
#define EMCFAN_EXTERNAL_4_TEMP_HIGH 0x08
#define EMCFAN_EXTERNAL_4_TEMP_LOW 0x09
#define EMCFAN_VIN4_VOLTAGE 0x10
#define EMCFAN_CHIP_CONFIG 0x20
#define EMCFAN_CHIP_CONFIG_2 0x21
#define EMCFAN_TEMP_CONFIG_3 0x22
#define EMCFAN_210_346_FAN_STATUS 0x27
#define EMCFAN_POLARITY_CONFIG 0x2a
#define EMCFAN_210_346_PWM_BASEFREQ 0x2b
#define EMCFAN_2106_FAN_3_DIVIDE 0x2c
#define EMCFAN_2106_FAN_3_DRIVE 0x2d
#define EMCFAN_2106_FAN_4_DRIVE 0x2e
#define EMCFAN_2106_FAN_4_DIVIDE 0x2f
#define EMCFAN_2101_TACH_LOW 0x46
#define EMCFAN_2101_TACH_HIGH 0x47
#define EMCFAN_2101_FAN_CONFIG 0x4a
#define EMCFAN_2101_FAN_DRIVE 0x4c
#define EMCFAN_2101_FAN_DIVIDE 0x4e
#define EMCFAN_210_346_FAN_1_DRIVE 0x40
#define EMCFAN_210_346_FAN_1_DIVIDE 0x41
#define EMCFAN_210_346_CONFIG_1 0x42
#define EMCFAN_210_346_TACH_1_HIGH 0x4e
#define EMCFAN_210_346_TACH_1_LOW 0x4f
#define EMCFAN_210_346_CONFIG_2 0x82
#define EMCFAN_210_346_FAN_2_DRIVE 0x80
#define EMCFAN_210_346_FAN_2_DIVIDE 0x81
#define EMCFAN_210_346_TACH_2_HIGH 0x8e
#define EMCFAN_210_346_TACH_2_LOW 0x8f
#define EMCFAN_230X_FAN_STATUS 0x24
#define EMCFAN_230X_FAN_STALL_STATUS 0x25
#define EMCFAN_230X_FAN_SPIN_STATUS 0x26
#define EMCFAN_230X_FAN_DRIVE_STATUS 0x27
#define EMCFAN_230X_OUTPUT_CONFIG 0x2b
#define EMCFAN_230X_BASE_FREQ_45 0x2c
#define EMCFAN_230X_BASE_FREQ_123 0x2d
#define EMCFAN_230X_FAN_1_DRIVE 0x30
#define EMCFAN_230X_FAN_1_DIVIDE 0x31
#define EMCFAN_230X_CONFIG_1 0x32
#define EMCFAN_230X_TACH_1_HIGH 0x3e
#define EMCFAN_230X_TACH_1_LOW 0x3f
#define EMCFAN_230X_FAN_2_DRIVE 0x40
#define EMCFAN_230X_FAN_2_DIVIDE 0x41
#define EMCFAN_230X_CONFIG_2 0x42
#define EMCFAN_230X_TACH_2_HIGH 0x4e
#define EMCFAN_230X_TACH_2_LOW 0x4f
#define EMCFAN_230X_FAN_3_DRIVE 0x50
#define EMCFAN_230X_FAN_3_DIVIDE 0x51
#define EMCFAN_230X_CONFIG_3 0x52
#define EMCFAN_230X_TACH_3_HIGH 0x5e
#define EMCFAN_230X_TACH_3_LOW 0x5f
#define EMCFAN_230X_FAN_4_DRIVE 0x60
#define EMCFAN_230X_FAN_4_DIVIDE 0x61
#define EMCFAN_230X_CONFIG_4 0x62
#define EMCFAN_230X_TACH_4_HIGH 0x6e
#define EMCFAN_230X_TACH_4_LOW 0x6f
#define EMCFAN_230X_FAN_5_DRIVE 0x70
#define EMCFAN_230X_FAN_5_DIVIDE 0x71
#define EMCFAN_230X_CONFIG_5 0x72
#define EMCFAN_230X_TACH_5_HIGH 0x7e
#define EMCFAN_230X_TACH_5_LOW 0x7f
#define EMCFAN_PRODUCT_ID 0xfd
#define EMCFAN_PRODUCT_2101 0x16
#define EMCFAN_PRODUCT_2101R 0x28
#define EMCFAN_PRODUCT_2103_1 0x24
#define EMCFAN_PRODUCT_2103_24 0x26 /* EMC2103-2 and EMC2103-4 */
#define EMCFAN_PRODUCT_2104 0x1d
#define EMCFAN_PRODUCT_2106 0x1e
#define EMCFAN_PRODUCT_2305 0x34
#define EMCFAN_PRODUCT_2303 0x35
#define EMCFAN_PRODUCT_2302 0x36
#define EMCFAN_PRODUCT_2301 0x37
#define EMCFAN_MUX_PINS 0xe0
#define EMCFAN_DIR_PINS 0xe1
#define EMCFAN_OUTPUT_PIN_CONFIG 0xe2
#define EMCFAN_PINS_INPUT 0xe3
#define EMCFAN_PINS_OUTPUT 0xe4
#define EMCFAN_MANUFACTURER_ID 0xfe
#define EMCFAN_VALID_MANUFACTURER_ID 0x5d
#define EMCFAN_REVISION 0xff
#define EMCFAN_FAMILY_210X 1
#define EMCFAN_FAMILY_230X 2
#endif