Merge tag 'upstream/1.2.0'
[psensor-pkg-debian.git] / src / lib / psensor.h
1 /*
2  * Copyright (C) 2010-2016 jeanfi@gmail.com
3  *
4  * This program is free software; you can redistribute it and/or
5  * modify it under the terms of the GNU General Public License as
6  * published by the Free Software Foundation; either version 2 of the
7  * License, or (at your option) any later version.
8  *
9  * This program is distributed in the hope that it will be useful, but
10  * WITHOUT ANY WARRANTY; without even the implied warranty of
11  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
12  * General Public License for more details.
13  *
14  * You should have received a copy of the GNU General Public License
15  * along with this program; if not, write to the Free Software
16  * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA
17  * 02110-1301 USA
18  */
19 #ifndef _PSENSOR_PSENSOR_H_
20 #define _PSENSOR_PSENSOR_H_
21
22 #include <config.h>
23
24 #include <bool.h>
25 #include <measure.h>
26 #include <plog.h>
27
28 enum psensor_type {
29         /* type of sensor values */
30         SENSOR_TYPE_TEMP = 0x00001,
31         SENSOR_TYPE_RPM = 0x00002,
32         SENSOR_TYPE_PERCENT = 0x00004,
33
34         /* Whether the sensor is remote */
35         SENSOR_TYPE_REMOTE = 0x00008,
36
37         /* Libraries used for retrieving sensor information */
38         SENSOR_TYPE_LMSENSOR = 0x00100,
39         SENSOR_TYPE_NVCTRL = 0x00200,
40         SENSOR_TYPE_GTOP = 0x00400,
41         SENSOR_TYPE_ATIADL = 0x00800,
42         SENSOR_TYPE_ATASMART = 0x01000,
43         SENSOR_TYPE_HDDTEMP = 0x02000,
44         SENSOR_TYPE_UDISKS2 = 0x800000,
45
46         /* Type of HW component */
47         SENSOR_TYPE_HDD = 0x04000,
48         SENSOR_TYPE_CPU = 0x08000,
49         SENSOR_TYPE_GPU = 0x10000,
50         SENSOR_TYPE_FAN = 0x20000,
51
52         SENSOR_TYPE_GRAPHICS = 0x40000,
53         SENSOR_TYPE_VIDEO = 0x80000,
54         SENSOR_TYPE_PCIE = 0x100000,
55         SENSOR_TYPE_MEMORY = 0x200000,
56         SENSOR_TYPE_AMBIENT = 0x400000,
57
58         /* Combinations */
59         SENSOR_TYPE_HDD_TEMP = (SENSOR_TYPE_HDD | SENSOR_TYPE_TEMP),
60         SENSOR_TYPE_CPU_USAGE = (SENSOR_TYPE_CPU | SENSOR_TYPE_PERCENT)
61 };
62
63 struct psensor {
64         /* Human readable name of the sensor.  It may not be uniq. */
65         char *name;
66
67         /* Uniq id of the sensor */
68         char *id;
69
70         /* Name of the chip. */
71         char *chip;
72
73         /* Maximum length of 'values' */
74         int values_max_length;
75
76         /*
77          * Last registered measures of the sensor.  Index 0 for the
78          * oldest measure.
79          */
80         struct measure *measures;
81
82         /* see psensor_type */
83         unsigned int type;
84
85         double max;
86
87         double min;
88
89         /* The highest value detected during this session. */
90         double sess_highest;
91
92         /* The lowest value detected during this session. */
93         double sess_lowest;
94
95         double alarm_high_threshold;
96         double alarm_low_threshold;
97
98         /* Whether an alarm is raised for this sensor */
99         bool alarm_raised;
100
101         void (*cb_alarm_raised)(struct psensor *, void *);
102         void *cb_alarm_raised_data;
103
104 #ifdef HAVE_LIBATIADL
105         /* AMD id for the aticonfig */
106         int amd_id;
107 #endif
108
109         void *provider_data;
110         void (*provider_data_free_fct)(void *);
111 };
112
113 struct psensor *psensor_create(char *id,
114                                char *name,
115                                char *chip,
116                                unsigned int type,
117                                int values_max_length);
118
119 void psensor_values_resize(struct psensor *s, int new_size);
120
121 void psensor_free(struct psensor *sensor);
122
123 void psensor_list_free(struct psensor **sensors);
124 int psensor_list_size(struct psensor **sensors);
125
126 struct psensor *psensor_list_get_by_id(struct psensor **sensors,
127                                        const char *id);
128
129 int is_temp_type(unsigned int type);
130
131 double get_min_temp(struct psensor **sensors);
132 double get_max_temp(struct psensor **sensors);
133
134 double get_min_rpm(struct psensor **sensors);
135 double get_max_rpm(struct psensor **sensors);
136
137 /*
138  * Converts the value of a sensor to a string.
139  *
140  * parameter 'type' is SENSOR_TYPE_LMSENSOR_TEMP, SENSOR_TYPE_NVIDIA,
141  * or SENSOR_TYPE_LMSENSOR_FAN
142  */
143 char *psensor_value_to_str(unsigned int type,
144                            double value,
145                            int use_celsius);
146
147 char *psensor_measure_to_str(const struct measure *m,
148                              unsigned int type,
149                              unsigned int use_celsius);
150
151 struct psensor **psensor_list_add(struct psensor **sensors,
152                                   struct psensor *sensor);
153
154 void psensor_list_append(struct psensor ***sensors, struct psensor *sensor);
155
156 struct psensor **psensor_list_copy(struct psensor **);
157
158 void psensor_set_current_value(struct psensor *sensor, double value);
159 void psensor_set_current_measure(struct psensor *sensor, double value,
160                                  struct timeval tv);
161
162 double psensor_get_current_value(const struct psensor *);
163
164 struct measure *psensor_get_current_measure(struct psensor *sensor);
165
166 /* Returns a string representation of a psensor type. */
167 const char *psensor_type_to_str(unsigned int type);
168
169 const char *psensor_type_to_unit_str(unsigned int type, int use_celsius);
170
171 double get_max_value(struct psensor **sensors, int type);
172
173 char *psensor_current_value_to_str(const struct psensor *, unsigned int);
174
175 void psensor_log_measures(struct psensor **sensors);
176
177 #endif