root/lm-sensors/branches/lm-sensors-3.0.0/lib/sensors.h @ 4686

Revision 4686, 6.7 KB (checked in by khali, 6 years ago)

Support more bus types (part 1 of 2). Originally libsensors was very
i2c-centric. Make it more neutral so that we can cleanly support
additional bus types such as SPI or One-Wire.

This first part introduces sensors_bus_id, and updates
sensors_chip_name to use it.

  • 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#define SENSORS_CHIP_NAME_PREFIX_ANY NULL
30#define SENSORS_CHIP_NAME_ADDR_ANY -1
31
32#define SENSORS_BUS_TYPE_ANY    (-1)
33#define SENSORS_BUS_TYPE_I2C    0
34#define SENSORS_BUS_TYPE_ISA    1
35#define SENSORS_BUS_TYPE_PCI    2
36#define SENSORS_BUS_NR_ANY      (-1)
37
38#ifdef __cplusplus
39extern "C" {
40#endif /* __cplusplus */
41
42extern const char *libsensors_version;
43
44typedef struct sensors_bus_id {
45        short type;
46        short nr;
47} sensors_bus_id;
48
49/* A chip name is encoded in this structure */
50typedef struct sensors_chip_name {
51        char *prefix;
52        sensors_bus_id bus;
53        int addr;
54        char *path;
55} sensors_chip_name;
56
57/* (Re)load the configuration file and the detected chips list. If this
58    returns a value unequal to zero, you are in trouble; you can not
59    assume anything will be initialized properly. */
60int sensors_init(FILE *input);
61
62/* Clean-up function: You can't access anything after
63   this, until the next sensors_init() call! */
64void sensors_cleanup(void);
65
66/* Parse a chip name to the internal representation. Return 0 on success, <0
67   on error. */
68int sensors_parse_chip_name(const char *orig_name, sensors_chip_name *res);
69
70/* Print a chip name from its internal representation. Note that chip should
71   not contain wildcard values! Return the number of characters printed on
72   success (same as snprintf), <0 on error. */
73int sensors_snprintf_chip_name(char *str, size_t size,
74                               const sensors_chip_name *chip);
75
76/* Compare two chips name descriptions, to see whether they could match.
77   Return 0 if it does not match, return 1 if it does match. */
78int sensors_match_chip(const sensors_chip_name *chip1,
79                       const sensors_chip_name *chip2);
80
81/* This function returns the adapter name of a bus,
82   as used within the sensors_chip_name structure. If it could not be found,
83   it returns NULL */
84const char *sensors_get_adapter_name(const sensors_bus_id *bus);
85
86/* Look up the label which belongs to this chip. Note that chip should not
87   contain wildcard values! *result is newly allocated (free it yourself).
88   This function will return 0 on success, and <0 on failure.
89   If no label exists for this feature, its name is returned itself. */
90int sensors_get_label(const sensors_chip_name *name, int feature,
91                      char **result);
92
93/* Read the value of a feature of a certain chip. Note that chip should not
94   contain wildcard values! This function will return 0 on success, and <0
95   on failure.  */
96int sensors_get_feature(const sensors_chip_name *name, int feature,
97                        double *result);
98
99/* Set the value of a feature of a certain chip. Note that chip should not
100   contain wildcard values! This function will return 0 on success, and <0
101   on failure. */
102int sensors_set_feature(const sensors_chip_name *name, int feature,
103                        double value);
104
105/* Execute all set statements for this particular chip. The chip may contain
106   wildcards!  This function will return 0 on success, and <0 on failure. */
107int sensors_do_chip_sets(const sensors_chip_name *name);
108
109/* This function returns all detected chips, one by one. To start at the
110   beginning of the list, use 0 for nr; NULL is returned if we are
111   at the end of the list. Do not try to change these chip names, as
112   they point to internal structures! Do not use nr for anything else. */
113const sensors_chip_name *sensors_get_detected_chips(int *nr);
114
115/* These defines are used in the mode field of sensors_feature_data */
116#define SENSORS_MODE_NO_RW 0
117#define SENSORS_MODE_R 1
118#define SENSORS_MODE_W 2
119#define SENSORS_MODE_RW 3
120
121/* This define is used in the mapping field of sensors_feature_data if no
122   mapping is available */
123#define SENSORS_NO_MAPPING -1
124
125/* This enum contains some "magic" used by sensors_read_dynamic_chip() from
126   lib/sysfs.c. All the sensor types (in, fan, temp, vid) are a multiple of
127   0x100 apart, and sensor features which should not have a compute_mapping to
128   the _input feature start at 0x?10. */
129typedef enum sensors_feature_type {
130        SENSORS_FEATURE_IN = 0x000,
131        SENSORS_FEATURE_IN_MIN,
132        SENSORS_FEATURE_IN_MAX,
133        SENSORS_FEATURE_IN_ALARM = 0x010,
134        SENSORS_FEATURE_IN_MIN_ALARM,
135        SENSORS_FEATURE_IN_MAX_ALARM,
136
137        SENSORS_FEATURE_FAN = 0x100,
138        SENSORS_FEATURE_FAN_MIN,
139        SENSORS_FEATURE_FAN_ALARM = 0x110,
140        SENSORS_FEATURE_FAN_FAULT,
141        SENSORS_FEATURE_FAN_DIV,
142
143        SENSORS_FEATURE_TEMP = 0x200,
144        SENSORS_FEATURE_TEMP_MAX,
145        SENSORS_FEATURE_TEMP_MAX_HYST,
146        SENSORS_FEATURE_TEMP_MIN,
147        SENSORS_FEATURE_TEMP_CRIT,
148        SENSORS_FEATURE_TEMP_CRIT_HYST,
149        SENSORS_FEATURE_TEMP_ALARM = 0x210,
150        SENSORS_FEATURE_TEMP_MAX_ALARM,
151        SENSORS_FEATURE_TEMP_MIN_ALARM,
152        SENSORS_FEATURE_TEMP_CRIT_ALARM,
153        SENSORS_FEATURE_TEMP_FAULT,
154        SENSORS_FEATURE_TEMP_SENS,
155
156        SENSORS_FEATURE_VID = 0x300,
157
158        SENSORS_FEATURE_UNKNOWN = INT_MAX,
159
160        /* special the largest number of subfeatures used, iow the
161           highest ## from all the 0x?## above + 1*/
162        SENSORS_FEATURE_MAX_SUB_FEATURES = 22
163} sensors_feature_type;
164
165/* This structure is used when you want to get all features of a specific
166   chip. */
167typedef struct sensors_feature_data {
168        int number;
169        char *name;
170        sensors_feature_type type;
171        int mapping;
172        int compute_mapping;
173        int mode;
174} sensors_feature_data;
175
176/* This returns all features of a specific chip. They are returned in
177   bunches: everything with the same mapping is returned just after each
178   other, with the master feature in front (that feature does not map to
179   itself, but has SENSORS_NO_MAPPING as mapping field). nr is
180   an internally used variable. Set it to zero to start again at the
181   begin of the list. If no more features are found NULL is returned.
182   Do not try to change the returned structure; you will corrupt internal
183   data structures. */
184const sensors_feature_data *sensors_get_all_features
185             (const sensors_chip_name *name, int *nr);
186
187#ifdef __cplusplus
188}
189#endif /* __cplusplus */
190
191#endif /* def LIB_SENSORS_ERROR_H */
Note: See TracBrowser for help on using the browser.