root/lm-sensors/tags/V3-0-1/lib/sensors.h

Revision 4978, 8.7 kB (checked in by jwrdegoede, 1 year ago)

make SENSORS_API_VERSION hexadecimal

  • Property svn:eol-style set to native
  • Property svn:keywords set to Author Date Id Revision
Line 
1 /*
2     sensors.h - Part of libsensors, a Linux library for reading sensor data.
3     Copyright (c) 1998, 1999  Frodo Looijaard <frodol@dds.nl>
4     Copyright (C) 2007        Jean Delvare <khali@linux-fr.org>
5
6     This program is free software; you can redistribute it and/or modify
7     it under the terms of the GNU General Public License as published by
8     the Free Software Foundation; either version 2 of the License, or
9     (at your option) any later version.
10
11     This program is distributed in the hope that it will be useful,
12     but WITHOUT ANY WARRANTY; without even the implied warranty of
13     MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
14     GNU General Public License for more details.
15
16     You should have received a copy of the GNU General Public License
17     along with this program; if not, write to the Free Software
18     Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
19 */
20
21 #ifndef LIB_SENSORS_SENSORS_H
22 #define LIB_SENSORS_SENSORS_H
23
24 #include <stdio.h>
25 #include <limits.h>
26
27 /* Publicly accessible library functions */
28
29 /* libsensors API version define, first digit is the major version (changed
30    when the API + ABI breaks), the third digit is incremented to track small
31    API additions like new flags / enum values. The second digit is for tracking
32    larger additions like new methods. */
33 #define SENSORS_API_VERSION 0x400
34
35 #define SENSORS_CHIP_NAME_PREFIX_ANY NULL
36 #define SENSORS_CHIP_NAME_ADDR_ANY -1
37
38 #define SENSORS_BUS_TYPE_ANY    (-1)
39 #define SENSORS_BUS_TYPE_I2C    0
40 #define SENSORS_BUS_TYPE_ISA    1
41 #define SENSORS_BUS_TYPE_PCI    2
42 #define SENSORS_BUS_TYPE_SPI    3
43 #define SENSORS_BUS_NR_ANY      (-1)
44 #define SENSORS_BUS_NR_IGNORE   (-2)
45
46 #ifdef __cplusplus
47 extern "C" {
48 #endif /* __cplusplus */
49
50 extern const char *libsensors_version;
51
52 typedef struct sensors_bus_id {
53         short type;
54         short nr;
55 } sensors_bus_id;
56
57 /* A chip name is encoded in this structure */
58 typedef struct sensors_chip_name {
59         char *prefix;
60         sensors_bus_id bus;
61         int addr;
62         char *path;
63 } sensors_chip_name;
64
65 /* Load the configuration file and the detected chips list. If this
66    returns a value unequal to zero, you are in trouble; you can not
67    assume anything will be initialized properly. If you want to
68    reload the configuration file, call sensors_cleanup() below before
69    calling sensors_init() again. */
70 int sensors_init(FILE *input);
71
72 /* Clean-up function: You can't access anything after
73    this, until the next sensors_init() call! */
74 void sensors_cleanup(void);
75
76 /* Parse a chip name to the internal representation. Return 0 on success, <0
77    on error. */
78 int sensors_parse_chip_name(const char *orig_name, sensors_chip_name *res);
79
80 /* Print a chip name from its internal representation. Note that chip should
81    not contain wildcard values! Return the number of characters printed on
82    success (same as snprintf), <0 on error. */
83 int sensors_snprintf_chip_name(char *str, size_t size,
84                                const sensors_chip_name *chip);
85
86 /* This function returns the adapter name of a bus,
87    as used within the sensors_chip_name structure. If it could not be found,
88    it returns NULL */
89 const char *sensors_get_adapter_name(const sensors_bus_id *bus);
90
91 typedef struct sensors_feature sensors_feature;
92
93 /* Look up the label for a given feature. Note that chip should not
94    contain wildcard values! The returned string is newly allocated (free it
95    yourself). On failure, NULL is returned.
96    If no label exists for this feature, its name is returned itself. */
97 char *sensors_get_label(const sensors_chip_name *name,
98                         const sensors_feature *feature);
99
100 /* Read the value of a subfeature of a certain chip. Note that chip should not
101    contain wildcard values! This function will return 0 on success, and <0
102    on failure.  */
103 int sensors_get_value(const sensors_chip_name *name, int subfeat_nr,
104                       double *value);
105
106 /* Set the value of a subfeature of a certain chip. Note that chip should not
107    contain wildcard values! This function will return 0 on success, and <0
108    on failure. */
109 int sensors_set_value(const sensors_chip_name *name, int subfeat_nr,
110                       double value);
111
112 /* Execute all set statements for this particular chip. The chip may contain
113    wildcards!  This function will return 0 on success, and <0 on failure. */
114 int sensors_do_chip_sets(const sensors_chip_name *name);
115
116 /* This function returns all detected chips that match a given chip name,
117    one by one. If no chip name is provided, all detected chips are returned.
118    To start at the beginning of the list, use 0 for nr; NULL is returned if
119    we are at the end of the list. Do not try to change these chip names, as
120    they point to internal structures! */
121 const sensors_chip_name *sensors_get_detected_chips(const sensors_chip_name
122                                                     *match, int *nr);
123
124 /* These defines are used in the flags field of sensors_subfeature */
125 #define SENSORS_MODE_R                  1
126 #define SENSORS_MODE_W                  2
127 #define SENSORS_COMPUTE_MAPPING         4
128
129 typedef enum sensors_feature_type {
130         SENSORS_FEATURE_IN              = 0x00,
131         SENSORS_FEATURE_FAN             = 0x01,
132         SENSORS_FEATURE_TEMP            = 0x02,
133         SENSORS_FEATURE_VID             = 0x10,
134         SENSORS_FEATURE_BEEP_ENABLE     = 0x18,
135         SENSORS_FEATURE_UNKNOWN         = INT_MAX,
136 } sensors_feature_type;
137
138 /* All the sensor types (in, fan, temp, vid) are a multiple of 0x100 apart,
139    and sensor subfeatures which have no compute mapping have bit 7 set. */
140 typedef enum sensors_subfeature_type {
141         SENSORS_SUBFEATURE_IN_INPUT = SENSORS_FEATURE_IN << 8,
142         SENSORS_SUBFEATURE_IN_MIN,
143         SENSORS_SUBFEATURE_IN_MAX,
144         SENSORS_SUBFEATURE_IN_ALARM = (SENSORS_FEATURE_IN << 8) | 0x80,
145         SENSORS_SUBFEATURE_IN_MIN_ALARM,
146         SENSORS_SUBFEATURE_IN_MAX_ALARM,
147         SENSORS_SUBFEATURE_IN_BEEP,
148
149         SENSORS_SUBFEATURE_FAN_INPUT = SENSORS_FEATURE_FAN << 8,
150         SENSORS_SUBFEATURE_FAN_MIN,
151         SENSORS_SUBFEATURE_FAN_ALARM = (SENSORS_FEATURE_FAN << 8) | 0x80,
152         SENSORS_SUBFEATURE_FAN_FAULT,
153         SENSORS_SUBFEATURE_FAN_DIV,
154         SENSORS_SUBFEATURE_FAN_BEEP,
155
156         SENSORS_SUBFEATURE_TEMP_INPUT = SENSORS_FEATURE_TEMP << 8,
157         SENSORS_SUBFEATURE_TEMP_MAX,
158         SENSORS_SUBFEATURE_TEMP_MAX_HYST,
159         SENSORS_SUBFEATURE_TEMP_MIN,
160         SENSORS_SUBFEATURE_TEMP_CRIT,
161         SENSORS_SUBFEATURE_TEMP_CRIT_HYST,
162         SENSORS_SUBFEATURE_TEMP_ALARM = (SENSORS_FEATURE_TEMP << 8) | 0x80,
163         SENSORS_SUBFEATURE_TEMP_MAX_ALARM,
164         SENSORS_SUBFEATURE_TEMP_MIN_ALARM,
165         SENSORS_SUBFEATURE_TEMP_CRIT_ALARM,
166         SENSORS_SUBFEATURE_TEMP_FAULT,
167         SENSORS_SUBFEATURE_TEMP_TYPE,
168         SENSORS_SUBFEATURE_TEMP_OFFSET,
169         SENSORS_SUBFEATURE_TEMP_BEEP,
170
171         SENSORS_SUBFEATURE_VID = SENSORS_FEATURE_VID << 8,
172
173         SENSORS_SUBFEATURE_BEEP_ENABLE = SENSORS_FEATURE_BEEP_ENABLE << 8,
174
175         SENSORS_SUBFEATURE_UNKNOWN = INT_MAX,
176 } sensors_subfeature_type;
177
178 /* Data about a single chip feature (or category leader) */
179 struct sensors_feature {
180         char *name;
181         int number;
182         sensors_feature_type type;
183         /* Members below are for libsensors internal use only */
184         int first_subfeature;
185         int padding1;
186 };
187
188 /* Data about a single chip subfeature:
189    name is the string name used to refer to this subfeature (in config files)
190    number is the internal subfeature number, used in many functions to refer
191      to this subfeature
192    type is the subfeature type
193    mapping is the number of a main feature this subfeature belongs to
194      (for example subfeatures fan1_input, fan1_min, fan1_div and fan1_alarm
195       are mapped to main feature fan1)
196    flags is a bitfield, its value is a combination of SENSORS_MODE_R (readable),
197      SENSORS_MODE_W (writable) and SENSORS_COMPUTE_MAPPING (affected by the
198      computation rules of the main feature) */
199 typedef struct sensors_subfeature {
200         char *name;
201         int number;
202         sensors_subfeature_type type;
203         int mapping;
204         unsigned int flags;
205 } sensors_subfeature;
206
207 /* This returns all main features of a specific chip. nr is an internally
208    used variable. Set it to zero to start at the begin of the list. If no
209    more features are found NULL is returned.
210    Do not try to change the returned structure; you will corrupt internal
211    data structures. */
212 const sensors_feature *
213 sensors_get_features(const sensors_chip_name *name, int *nr);
214
215 /* This returns all subfeatures of a given main feature. nr is an internally
216    used variable. Set it to zero to start at the begin of the list. If no
217    more features are found NULL is returned.
218    Do not try to change the returned structure; you will corrupt internal
219    data structures. */
220 const sensors_subfeature *
221 sensors_get_all_subfeatures(const sensors_chip_name *name,
222                             const sensors_feature *feature, int *nr);
223
224 /* This returns the subfeature of the given type for a given main feature,
225    if it exists, NULL otherwise.
226    Do not try to change the returned structure; you will corrupt internal
227    data structures. */
228 const sensors_subfeature *
229 sensors_get_subfeature(const sensors_chip_name *name,
230                        const sensors_feature *feature,
231                        sensors_subfeature_type type);
232
233 #ifdef __cplusplus
234 }
235 #endif /* __cplusplus */
236
237 #endif /* def LIB_SENSORS_ERROR_H */
Note: See TracBrowser for help on using the browser.