sysmon_envsysvar.h revision 1.12.6.2 1 1.12.6.2 matt /* $NetBSD: sysmon_envsysvar.h,v 1.12.6.2 2008/01/09 01:54:34 matt Exp $ */
2 1.1 xtraeme
3 1.1 xtraeme /*-
4 1.12.6.1 matt * 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.12.6.1 matt * THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR
17 1.12.6.1 matt * IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
18 1.12.6.1 matt * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED.
19 1.12.6.1 matt * IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT,
20 1.12.6.1 matt * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT
21 1.12.6.1 matt * NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
22 1.12.6.1 matt * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
23 1.12.6.1 matt * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
24 1.12.6.1 matt * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF
25 1.12.6.1 matt * 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.12.6.1 matt enum sme_description_types {
44 1.12.6.1 matt SME_DESC_UNITS = 1,
45 1.12.6.1 matt SME_DESC_STATES,
46 1.12.6.1 matt SME_DESC_DRIVE_STATES,
47 1.12.6.1 matt SME_DESC_BATTERY_CAPACITY
48 1.12.6.1 matt };
49 1.12.6.1 matt
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.12.6.2 matt /*
63 1.12.6.2 matt * Default timeout value for the callouts if no specified.
64 1.12.6.2 matt */
65 1.12.6.2 matt #define SME_EVENTS_DEFTIMEOUT 30
66 1.12.6.2 matt
67 1.12.6.2 matt /*
68 1.12.6.2 matt * struct used by a sensor description in a sysmon envsys device.
69 1.12.6.2 matt */
70 1.12.6.2 matt struct sme_sensor_names {
71 1.12.6.2 matt SLIST_ENTRY(sme_sensor_names) sme_names;
72 1.12.6.2 matt int assigned;
73 1.12.6.2 matt char desc[ENVSYS_DESCLEN];
74 1.12.6.2 matt };
75 1.1 xtraeme
76 1.12.6.2 matt /*
77 1.12.6.2 matt * struct used by a sysmon envsys event.
78 1.12.6.2 matt */
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.12.6.2 matt struct sysmon_envsys *see_sme; /* device associated */
83 1.12.6.2 matt struct penvsys_state see_pes; /* our power envsys */
84 1.12.6.2 matt envsys_data_t *see_edata; /* our sensor data */
85 1.12.6.2 matt int32_t see_critval; /* critical value set */
86 1.12.6.2 matt int see_type; /* type of the event */
87 1.12.6.2 matt 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.12.6.1 matt #define SME_EVENT_REFRESHED 0x0002 /* sensor already refreshed */
91 1.1 xtraeme } sme_event_t;
92 1.1 xtraeme
93 1.12.6.2 matt /*
94 1.12.6.2 matt * struct by a sysmon envsys event set by a driver.
95 1.12.6.2 matt */
96 1.1 xtraeme typedef struct sme_event_drv {
97 1.12.6.2 matt struct sysmon_envsys *sed_sme;
98 1.12.6.2 matt prop_dictionary_t sed_sdict;
99 1.12.6.2 matt envsys_data_t *sed_edata;
100 1.12.6.2 matt int sed_powertype;
101 1.1 xtraeme } sme_event_drv_t;
102 1.1 xtraeme
103 1.12.6.1 matt struct sme_description_table {
104 1.12.6.1 matt int type;
105 1.12.6.1 matt int crittype;
106 1.12.6.1 matt const char *desc;
107 1.12.6.1 matt };
108 1.12 xtraeme
109 1.12.6.2 matt /*
110 1.12.6.2 matt * common stuff.
111 1.12.6.2 matt */
112 1.12.6.1 matt extern kmutex_t sme_mtx; /* mutex for devices/events */
113 1.12.6.2 matt extern kmutex_t sme_events_mtx; /* to init/destroy the events layer */
114 1.12.6.2 matt extern kmutex_t sme_callout_mtx; /* for the callouts */
115 1.12.6.1 matt extern kcondvar_t sme_cv; /* to wait for devices/events working */
116 1.1 xtraeme
117 1.12.6.2 matt /*
118 1.12.6.2 matt * linked list for the sysmon envsys devices.
119 1.12.6.2 matt */
120 1.1 xtraeme LIST_HEAD(, sysmon_envsys) sysmon_envsys_list;
121 1.1 xtraeme
122 1.12.6.2 matt /*
123 1.12.6.2 matt * functions to handle sysmon envsys devices.
124 1.12.6.2 matt */
125 1.12.6.1 matt sme_event_drv_t *sme_add_sensor_dictionary(struct sysmon_envsys *,
126 1.12.6.1 matt prop_array_t,
127 1.12.6.1 matt prop_dictionary_t,
128 1.12.6.1 matt envsys_data_t *);
129 1.1 xtraeme int sme_update_dictionary(struct sysmon_envsys *);
130 1.1 xtraeme int sme_userset_dictionary(struct sysmon_envsys *,
131 1.1 xtraeme prop_dictionary_t, prop_array_t);
132 1.12.6.1 matt prop_dictionary_t sme_sensor_dictionary_get(prop_array_t, const char *);
133 1.12.6.1 matt struct sysmon_envsys *sysmon_envsys_find(const char *);
134 1.12.6.2 matt void sysmon_envsys_acquire(struct sysmon_envsys *);
135 1.12.6.2 matt void sysmon_envsys_release(struct sysmon_envsys *);
136 1.1 xtraeme
137 1.12.6.2 matt /*
138 1.12.6.2 matt * functions to handle sysmon envsys events.
139 1.12.6.2 matt */
140 1.12.6.2 matt int sme_event_register(prop_dictionary_t, envsys_data_t *,
141 1.12.6.2 matt struct sysmon_envsys *, const char *,
142 1.12.6.2 matt int32_t, int, int);
143 1.12.6.2 matt int sme_event_unregister(struct sysmon_envsys *, const char *, int);
144 1.12.6.2 matt void sme_event_unregister_all(struct sysmon_envsys *);
145 1.1 xtraeme void sme_event_drvadd(void *);
146 1.12.6.2 matt int sme_events_init(struct sysmon_envsys *);
147 1.12.6.2 matt void sme_events_destroy(struct sysmon_envsys *);
148 1.1 xtraeme void sme_events_check(void *);
149 1.1 xtraeme void sme_events_worker(struct work *, void *);
150 1.1 xtraeme
151 1.12.6.2 matt /*
152 1.12.6.2 matt * common functions to create/update objects in a dictionary.
153 1.12.6.2 matt */
154 1.9 xtraeme int sme_sensor_upbool(prop_dictionary_t, const char *, bool);
155 1.9 xtraeme int sme_sensor_upint32(prop_dictionary_t, const char *, int32_t);
156 1.9 xtraeme int sme_sensor_upuint32(prop_dictionary_t, const char *, uint32_t);
157 1.9 xtraeme int sme_sensor_upstring(prop_dictionary_t, const char *, const char *);
158 1.8 xtraeme
159 1.12.6.1 matt const struct sme_description_table *sme_get_description_table(int);
160 1.12.6.1 matt
161 1.1 xtraeme #endif /* _DEV_SYSMON_ENVSYSVAR_H_ */
162