sysmon_envsysvar.h revision 1.23.2.1 1 1.23.2.1 mjf /* $NetBSD: sysmon_envsysvar.h,v 1.23.2.1 2007/11/19 00:48:24 mjf Exp $ */
2 1.1 xtraeme
3 1.1 xtraeme /*-
4 1.20 xtraeme * Copyright (c) 2007 Juan Romero Pardines.
5 1.1 xtraeme * All rights reserved.
6 1.1 xtraeme *
7 1.1 xtraeme * Redistribution and use in source and binary forms, with or without
8 1.1 xtraeme * modification, are permitted provided that the following conditions
9 1.1 xtraeme * are met:
10 1.1 xtraeme * 1. Redistributions of source code must retain the above copyright
11 1.1 xtraeme * notice, this list of conditions and the following disclaimer.
12 1.1 xtraeme * 2. Redistributions in binary form must reproduce the above copyright
13 1.1 xtraeme * notice, this list of conditions and the following disclaimer in the
14 1.1 xtraeme * documentation and/or other materials provided with the distribution.
15 1.1 xtraeme *
16 1.20 xtraeme * THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR
17 1.20 xtraeme * IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
18 1.20 xtraeme * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED.
19 1.20 xtraeme * IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT,
20 1.20 xtraeme * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT
21 1.20 xtraeme * NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
22 1.20 xtraeme * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
23 1.20 xtraeme * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
24 1.20 xtraeme * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF
25 1.20 xtraeme * THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
26 1.1 xtraeme */
27 1.1 xtraeme
28 1.1 xtraeme #ifndef _DEV_SYSMON_ENVSYSVAR_H_
29 1.1 xtraeme #define _DEV_SYSMON_ENVSYSVAR_H_
30 1.1 xtraeme
31 1.1 xtraeme #include <sys/param.h>
32 1.1 xtraeme #include <sys/types.h>
33 1.1 xtraeme #include <sys/conf.h>
34 1.1 xtraeme #include <sys/kernel.h>
35 1.1 xtraeme #include <sys/systm.h>
36 1.1 xtraeme #include <sys/mutex.h>
37 1.1 xtraeme #include <sys/workqueue.h>
38 1.8 xtraeme #include <sys/condvar.h>
39 1.1 xtraeme
40 1.1 xtraeme #include <dev/sysmon/sysmonvar.h>
41 1.1 xtraeme #include <prop/proplib.h>
42 1.1 xtraeme
43 1.17 xtraeme enum sme_description_types {
44 1.17 xtraeme SME_DESC_UNITS = 1,
45 1.17 xtraeme SME_DESC_STATES,
46 1.17 xtraeme SME_DESC_DRIVE_STATES,
47 1.23 xtraeme SME_DESC_BATTERY_CAPACITY
48 1.17 xtraeme };
49 1.17 xtraeme
50 1.1 xtraeme #ifdef ENVSYS_DEBUG
51 1.1 xtraeme #define DPRINTF(x) printf x
52 1.1 xtraeme #else
53 1.1 xtraeme #define DPRINTF(x)
54 1.1 xtraeme #endif
55 1.1 xtraeme
56 1.1 xtraeme #ifdef ENVSYS_OBJECTS_DEBUG
57 1.1 xtraeme #define DPRINTFOBJ(x) printf x
58 1.1 xtraeme #else
59 1.1 xtraeme #define DPRINTFOBJ(x)
60 1.1 xtraeme #endif
61 1.1 xtraeme
62 1.23.2.1 mjf /*
63 1.23.2.1 mjf * Default timeout value for the callouts if no specified.
64 1.23.2.1 mjf */
65 1.23.2.1 mjf #define SME_EVENTS_DEFTIMEOUT 30
66 1.23.2.1 mjf
67 1.23.2.1 mjf /*
68 1.23.2.1 mjf * struct used by a sensor description in a sysmon envsys device.
69 1.23.2.1 mjf */
70 1.23.2.1 mjf struct sme_sensor_names {
71 1.23.2.1 mjf SLIST_ENTRY(sme_sensor_names) sme_names;
72 1.23.2.1 mjf int assigned;
73 1.23.2.1 mjf char desc[ENVSYS_DESCLEN];
74 1.23.2.1 mjf };
75 1.1 xtraeme
76 1.23.2.1 mjf /*
77 1.23.2.1 mjf * struct used by a sysmon envsys event.
78 1.23.2.1 mjf */
79 1.1 xtraeme typedef struct sme_event {
80 1.6 xtraeme struct work see_wk;
81 1.6 xtraeme LIST_ENTRY(sme_event) see_list;
82 1.23.2.1 mjf struct sysmon_envsys *see_sme; /* device associated */
83 1.23.2.1 mjf struct penvsys_state see_pes; /* our power envsys */
84 1.23.2.1 mjf envsys_data_t *see_edata; /* our sensor data */
85 1.23.2.1 mjf int32_t see_critval; /* critical value set */
86 1.23.2.1 mjf int see_type; /* type of the event */
87 1.23.2.1 mjf int see_evsent; /* event already sent */
88 1.5 xtraeme int see_flags; /* see above */
89 1.6 xtraeme #define SME_EVENT_WORKING 0x0001 /* This event is busy */
90 1.22 xtraeme #define SME_EVENT_REFRESHED 0x0002 /* sensor already refreshed */
91 1.1 xtraeme } sme_event_t;
92 1.1 xtraeme
93 1.23.2.1 mjf /*
94 1.23.2.1 mjf * struct by a sysmon envsys event set by a driver.
95 1.23.2.1 mjf */
96 1.1 xtraeme typedef struct sme_event_drv {
97 1.23.2.1 mjf struct sysmon_envsys *sed_sme;
98 1.23.2.1 mjf prop_dictionary_t sed_sdict;
99 1.23.2.1 mjf envsys_data_t *sed_edata;
100 1.23.2.1 mjf int sed_powertype;
101 1.1 xtraeme } sme_event_drv_t;
102 1.1 xtraeme
103 1.17 xtraeme struct sme_description_table {
104 1.17 xtraeme int type;
105 1.17 xtraeme int crittype;
106 1.17 xtraeme const char *desc;
107 1.17 xtraeme };
108 1.17 xtraeme
109 1.23.2.1 mjf /*
110 1.23.2.1 mjf * common stuff.
111 1.23.2.1 mjf */
112 1.19 xtraeme extern kmutex_t sme_mtx; /* mutex for devices/events */
113 1.23.2.1 mjf extern kmutex_t sme_events_mtx; /* to init/destroy the events layer */
114 1.23.2.1 mjf extern kmutex_t sme_callout_mtx; /* for the callouts */
115 1.19 xtraeme extern kcondvar_t sme_cv; /* to wait for devices/events working */
116 1.23.2.1 mjf extern kcondvar_t sme_callout_cv; /* to wait for the callout handler */
117 1.1 xtraeme
118 1.23.2.1 mjf /*
119 1.23.2.1 mjf * linked list for the sysmon envsys devices.
120 1.23.2.1 mjf */
121 1.1 xtraeme LIST_HEAD(, sysmon_envsys) sysmon_envsys_list;
122 1.1 xtraeme
123 1.23.2.1 mjf /*
124 1.23.2.1 mjf * functions to handle sysmon envsys devices.
125 1.23.2.1 mjf */
126 1.18 xtraeme sme_event_drv_t *sme_add_sensor_dictionary(struct sysmon_envsys *,
127 1.18 xtraeme prop_array_t,
128 1.18 xtraeme prop_dictionary_t,
129 1.18 xtraeme envsys_data_t *);
130 1.1 xtraeme int sme_update_dictionary(struct sysmon_envsys *);
131 1.1 xtraeme int sme_userset_dictionary(struct sysmon_envsys *,
132 1.1 xtraeme prop_dictionary_t, prop_array_t);
133 1.20 xtraeme prop_dictionary_t sme_sensor_dictionary_get(prop_array_t, const char *);
134 1.23 xtraeme struct sysmon_envsys *sysmon_envsys_find(const char *);
135 1.23.2.1 mjf void sysmon_envsys_acquire(struct sysmon_envsys *);
136 1.23.2.1 mjf void sysmon_envsys_release(struct sysmon_envsys *);
137 1.1 xtraeme
138 1.23.2.1 mjf /*
139 1.23.2.1 mjf * functions to handle sysmon envsys events.
140 1.23.2.1 mjf */
141 1.23.2.1 mjf int sme_event_register(prop_dictionary_t, envsys_data_t *,
142 1.23.2.1 mjf struct sysmon_envsys *, const char *,
143 1.23.2.1 mjf int32_t, int, int);
144 1.23.2.1 mjf int sme_event_unregister(struct sysmon_envsys *, const char *, int);
145 1.23.2.1 mjf void sme_event_unregister_all(struct sysmon_envsys *);
146 1.1 xtraeme void sme_event_drvadd(void *);
147 1.23.2.1 mjf int sme_events_init(struct sysmon_envsys *);
148 1.23.2.1 mjf void sme_events_destroy(struct sysmon_envsys *);
149 1.1 xtraeme void sme_events_check(void *);
150 1.1 xtraeme void sme_events_worker(struct work *, void *);
151 1.1 xtraeme
152 1.23.2.1 mjf /*
153 1.23.2.1 mjf * common functions to create/update objects in a dictionary.
154 1.23.2.1 mjf */
155 1.9 xtraeme int sme_sensor_upbool(prop_dictionary_t, const char *, bool);
156 1.9 xtraeme int sme_sensor_upint32(prop_dictionary_t, const char *, int32_t);
157 1.9 xtraeme int sme_sensor_upuint32(prop_dictionary_t, const char *, uint32_t);
158 1.9 xtraeme int sme_sensor_upstring(prop_dictionary_t, const char *, const char *);
159 1.8 xtraeme
160 1.17 xtraeme const struct sme_description_table *sme_get_description_table(int);
161 1.17 xtraeme
162 1.1 xtraeme #endif /* _DEV_SYSMON_ENVSYSVAR_H_ */
163