emcfanctl.h revision 1.1 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