summaryrefslogtreecommitdiff
path: root/usr/src/uts/common/sys/sensors.h
blob: b9ca9f1f3f3684bfbf3aeedf7b8c8e7dceffd473 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
/*
 * This file and its contents are supplied under the terms of the
 * Common Development and Distribution License ("CDDL"), version 1.0.
 * You may only use this file in accordance with the terms of version
 * 1.0 of the CDDL.
 *
 * A full copy of the text of the CDDL should have accompanied this
 * source.  A copy of the CDDL is also available via the Internet at
 * http://www.illumos.org/license/CDDL.
 */

/*
 * Copyright 2019, Joyent, Inc.
 */

#ifndef _SYS_SENSORS_H
#define	_SYS_SENSORS_H

/*
 * Consolidated sensor ioctls for various parts of the operating system. These
 * interfaces should not be relied on at all. They are evolving and will change
 * as we add more to the system for this. This may eventually become a larger
 * framework, though it's more likely we'll consolidate that in userland.
 */

#ifdef __cplusplus
extern "C" {
#endif

/*
 * List of different possible kinds of sensors.
 */
#define	SENSOR_KIND_UNKNOWN		0x00
#define	SENSOR_KIND_TEMPERATURE		0x01

/*
 * Lists of units that senors may have.
 */
#define	SENSOR_UNIT_UNKNOWN		0x00
#define	SENSOR_UNIT_CELSIUS		0x01
#define	SENSOR_UNIT_FAHRENHEIT		0x02
#define	SENSOR_UNIT_KELVIN		0x03

#define	SENSOR_IOCTL	(('s' << 24) | ('e' << 16) | ('n' << 8))

/*
 * Ask the sensor what kind of sensor it is.
 */
#define	SENSOR_IOCTL_TYPE	(SENSOR_IOCTL | 0x01)

typedef struct sensor_ioctl_kind {
	uint64_t	sik_kind;
} sensor_ioctl_kind_t;

/*
 * Ask the sensor for a temperature measurement. The sensor is responsible for
 * returning the units it's in.  A temperature measurement is broken down into a
 * signed value and a notion of its granularity. The sit_gran member indicates
 * the granularity: the number of increments per degree in the temperature
 * measurement (the sit_temp member). sit_gran is signed and the sign indicates
 * whether one needs to multiply or divide the granularity. For example, a
 * value that set sit_gran to 10 would mean that the value in sit_temp was in
 * 10ths of a degree and that to get the actual value in degrees, one would
 * divide by 10. On the other hand, a negative value means that we effectively
 * have to multiply to get there. For example, a value of -2 would indicate that
 * each value in sit_temp indicated two degrees and to get the temperature in
 * degrees you would multiply sit_temp by two.
 */
#define	SENSOR_IOCTL_TEMPERATURE	(SENSOR_IOCTL | 0x02)

typedef struct sensor_ioctl_temperature {
	uint32_t	sit_unit;
	int32_t		sit_gran;
	int64_t		sit_temp;
} sensor_ioctl_temperature_t;

#ifdef __cplusplus
}
#endif

#endif /* _SYS_SENSORS_H */