1 1.1 brad /* $NetBSD: emcfanctl.h,v 1.1 2025/03/11 13:56:48 brad Exp $ */ 2 1.1 brad 3 1.1 brad /* 4 1.1 brad * Copyright (c) 2025 Brad Spencer <brad (at) anduin.eldar.org> 5 1.1 brad * 6 1.1 brad * Permission to use, copy, modify, and distribute this software for any 7 1.1 brad * purpose with or without fee is hereby granted, provided that the above 8 1.1 brad * copyright notice and this permission notice appear in all copies. 9 1.1 brad * 10 1.1 brad * THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES 11 1.1 brad * WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF 12 1.1 brad * MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR 13 1.1 brad * ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES 14 1.1 brad * WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN 15 1.1 brad * ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF 16 1.1 brad * OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE. 17 1.1 brad */ 18 1.1 brad 19 1.1 brad #ifndef _EMCFANCTL_H_ 20 1.1 brad #define _EMCFANCTL_H_ 21 1.1 brad 22 1.1 brad /* Top level commands */ 23 1.1 brad #define EMCFANCTL_INFO 1 24 1.1 brad #define EMCFANCTL_REGISTER 2 25 1.1 brad #define EMCFANCTL_FAN 3 26 1.1 brad #define EMCFANCTL_APD 4 27 1.1 brad #define EMCFANCTL_SMBUSTO 5 28 1.1 brad 29 1.1 brad /* REGISTER sub commands */ 30 1.1 brad #define EMCFANCTL_REGISTER_LIST 1 31 1.1 brad #define EMCFANCTL_REGISTER_READ 2 32 1.1 brad #define EMCFANCTL_REGISTER_WRITE 3 33 1.1 brad 34 1.1 brad /* FAN sub commands */ 35 1.1 brad #define EMCFANCTL_FAN_STATUS 1 36 1.1 brad #define EMCFANCTL_FAN_DRIVE 2 37 1.1 brad #define EMCFANCTL_FAN_DIVIDER 3 38 1.1 brad #define EMCFANCTL_FAN_MINEXPECTED_RPM 4 39 1.1 brad #define EMCFANCTL_FAN_EDGES 5 40 1.1 brad #define EMCFANCTL_FAN_POLARITY 6 41 1.1 brad #define EMCFANCTL_FAN_PWM_BASEFREQ 7 42 1.1 brad #define EMCFANCTL_FAN_PWM_OUTPUTTYPE 8 43 1.1 brad 44 1.1 brad /* APD and SMSBUS timeout sub command */ 45 1.1 brad 46 1.1 brad #define EMCFANCTL_APD_READ 1 47 1.1 brad #define EMCFANCTL_APD_ON 2 48 1.1 brad #define EMCFANCTL_APD_OFF 3 49 1.1 brad 50 1.1 brad /* FAN driver, divider, edges, min_expected_rpm 51 1.1 brad * and base_freqsub commands 52 1.1 brad */ 53 1.1 brad #define EMCFANCTL_FAN_DD_READ 1 54 1.1 brad #define EMCFANCTL_FAN_DD_WRITE 2 55 1.1 brad 56 1.1 brad /* FAN polarity sub commands */ 57 1.1 brad #define EMCFANCTL_FAN_P_READ 1 58 1.1 brad #define EMCFANCTL_FAN_P_INVERTED 2 59 1.1 brad #define EMCFANCTL_FAN_P_NONINVERTED 3 60 1.1 brad 61 1.1 brad /* FAN pwm_output_type sub commands */ 62 1.1 brad #define EMCFANCTL_FAN_OT_READ 1 63 1.1 brad #define EMCFANCTL_FAN_OT_PUSHPULL 2 64 1.1 brad #define EMCFANCTL_FAN_OT_OPENDRAIN 3 65 1.1 brad 66 1.1 brad struct emcfanctlcmd { 67 1.1 brad const char *cmd; 68 1.1 brad const int id; 69 1.1 brad const char *helpargs; 70 1.1 brad }; 71 1.1 brad 72 1.1 brad struct emcfan_registers { 73 1.1 brad const char *name; 74 1.1 brad const uint8_t reg; 75 1.1 brad }; 76 1.1 brad 77 1.1 brad #define EMCFAN_TRANSLATE_INT 1 78 1.1 brad #define EMCFAN_TRANSLATE_STR 2 79 1.1 brad #define EMCFAN_NO_INSTANCE -10191 80 1.1 brad 81 1.1 brad struct emcfan_bits_translate { 82 1.1 brad const int type; 83 1.1 brad const uint8_t clear_mask; 84 1.1 brad const uint8_t bit_mask; 85 1.1 brad const int human_int; 86 1.1 brad const char *human_str; 87 1.1 brad const int instance; 88 1.1 brad }; 89 1.1 brad 90 1.1 brad #define EMCFAN_FAMILY_UNKNOWN 0 91 1.1 brad 92 1.1 brad #endif 93