t2ex/bsd_source/lib/libc/src_bsd/include/sys/sensors.h | bare source | permlink (0.03 seconds) |
1: /* $OpenBSD: sensors.h,v 1.31 2011/09/16 15:44:31 yuo Exp $ */ 2: 3: /* 4: * Copyright (c) 2003, 2004 Alexander Yurchenko <grange@openbsd.org> 5: * Copyright (c) 2006 Constantine A. Murenin <cnst+openbsd@bugmail.mojo.ru> 6: * All rights reserved. 7: * 8: * Redistribution and use in source and binary forms, with or without 9: * modification, are permitted provided that the following conditions 10: * are met: 11: * 1. Redistributions of source code must retain the above copyright 12: * notice, this list of conditions and the following disclaimer. 13: * 2. Redistributions in binary form must reproduce the above copyright 14: * notice, this list of conditions and the following disclaimer in the 15: * documentation and/or other materials provided with the distribution. 16: * 17: * THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR 18: * IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES 19: * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. 20: * IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT, 21: * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT 22: * NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, 23: * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY 24: * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT 25: * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF 26: * THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. 27: */ 28: 29: #ifndef _SYS_SENSORS_H_ 30: #define _SYS_SENSORS_H_ 31: 32: /* Sensor types */ 33: enum sensor_type { 34: SENSOR_TEMP, /* temperature (muK) */ 35: SENSOR_FANRPM, /* fan revolution speed */ 36: SENSOR_VOLTS_DC, /* voltage (muV DC) */ 37: SENSOR_VOLTS_AC, /* voltage (muV AC) */ 38: SENSOR_OHMS, /* resistance */ 39: SENSOR_WATTS, /* power (muW) */ 40: SENSOR_AMPS, /* current (muA) */ 41: SENSOR_WATTHOUR, /* power capacity */ 42: SENSOR_AMPHOUR, /* power capacity */ 43: SENSOR_INDICATOR, /* boolean indicator */ 44: SENSOR_INTEGER, /* generic integer value */ 45: SENSOR_PERCENT, /* percent */ 46: SENSOR_LUX, /* illuminance (mulx) */ 47: SENSOR_DRIVE, /* disk */ 48: SENSOR_TIMEDELTA, /* system time error (nSec) */ 49: SENSOR_HUMIDITY, /* humidity (m%RH) */ 50: SENSOR_FREQ, /* frequency (muHz) */ 51: SENSOR_ANGLE, /* angle (mudegrees) */ 52: SENSOR_MAX_TYPES 53: }; 54: 55: #ifndef _KERNEL 56: static const char * const sensor_type_s[SENSOR_MAX_TYPES + 1] = { 57: "temp", 58: "fan", 59: "volt", 60: "acvolt", 61: "resistance", 62: "power", 63: "current", 64: "watthour", 65: "amphour", 66: "indicator", 67: "raw", 68: "percent", 69: "illuminance", 70: "drive", 71: "timedelta", 72: "humidity", 73: "frequency", 74: "angle", 75: "undefined" 76: }; 77: #endif /* !_KERNEL */ 78: 79: #define SENSOR_DRIVE_EMPTY 1 80: #define SENSOR_DRIVE_READY 2 81: #define SENSOR_DRIVE_POWERUP 3 82: #define SENSOR_DRIVE_ONLINE 4 83: #define SENSOR_DRIVE_IDLE 5 84: #define SENSOR_DRIVE_ACTIVE 6 85: #define SENSOR_DRIVE_REBUILD 7 86: #define SENSOR_DRIVE_POWERDOWN 8 87: #define SENSOR_DRIVE_FAIL 9 88: #define SENSOR_DRIVE_PFAIL 10 89: 90: /* Sensor states */ 91: enum sensor_status { 92: SENSOR_S_UNSPEC, /* status is unspecified */ 93: SENSOR_S_OK, /* status is ok */ 94: SENSOR_S_WARN, /* status is warning */ 95: SENSOR_S_CRIT, /* status is critical */ 96: SENSOR_S_UNKNOWN /* status is unknown */ 97: }; 98: 99: /* Sensor data: 100: * New fields should be added at the end to encourage backwards compat 101: */ 102: struct sensor { 103: char desc[32]; /* sensor description, may be empty */ 104: struct timeval tv; /* sensor value last change time */ 105: int64_t value; /* current value */ 106: enum sensor_type type; /* sensor type */ 107: enum sensor_status status; /* sensor status */ 108: int numt; /* sensor number of .type type */ 109: int flags; /* sensor flags */ 110: #define SENSOR_FINVALID 0x0001 /* sensor is invalid */ 111: #define SENSOR_FUNKNOWN 0x0002 /* sensor value is unknown */ 112: }; 113: 114: /* Sensor device data: 115: * New fields should be added at the end to encourage backwards compat 116: */ 117: struct sensordev { 118: int num; /* sensordev number */ 119: char xname[16]; /* unix device name */ 120: int maxnumt[SENSOR_MAX_TYPES]; 121: int sensors_count; 122: }; 123: 124: #ifdef _KERNEL 125: 126: /* Sensor data */ 127: struct ksensor { 128: SLIST_ENTRY(ksensor) list; /* device-scope list */ 129: char desc[32]; /* sensor description, may be empty */ 130: struct timeval tv; /* sensor value last change time */ 131: int64_t value; /* current value */ 132: enum sensor_type type; /* sensor type */ 133: enum sensor_status status; /* sensor status */ 134: int numt; /* sensor number of .type type */ 135: int flags; /* sensor flags, ie. SENSOR_FINVALID */ 136: }; 137: SLIST_HEAD(ksensors_head, ksensor); 138: 139: /* Sensor device data */ 140: struct ksensordev { 141: SLIST_ENTRY(ksensordev) list; 142: int num; /* sensordev number */ 143: char xname[16]; /* unix device name */ 144: int maxnumt[SENSOR_MAX_TYPES]; 145: int sensors_count; 146: struct ksensors_head sensors_list; 147: }; 148: 149: /* struct ksensordev */ 150: void sensordev_install(struct ksensordev *); 151: void sensordev_deinstall(struct ksensordev *); 152: int sensordev_get(int, struct ksensordev **); 153: 154: /* struct ksensor */ 155: void sensor_attach(struct ksensordev *, struct ksensor *); 156: void sensor_detach(struct ksensordev *, struct ksensor *); 157: int sensor_find(int, enum sensor_type, int, struct ksensor **); 158: 159: /* task scheduling */ 160: struct sensor_task; 161: struct sensor_task *sensor_task_register(void *, void (*)(void *), int); 162: void sensor_task_unregister(struct sensor_task *); 163: 164: #endif /* _KERNEL */ 165: 166: #endif /* !_SYS_SENSORS_H_ */