root / lab4 / .minix-src / include / sys / device.h @ 14
History | View | Annotate | Download (20 KB)
1 |
/* $NetBSD: device.h,v 1.147 2015/03/06 09:28:15 mrg Exp $ */
|
---|---|
2 |
|
3 |
/*
|
4 |
* Copyright (c) 1996, 2000 Christopher G. Demetriou
|
5 |
* All rights reserved.
|
6 |
*
|
7 |
* Redistribution and use in source and binary forms, with or without
|
8 |
* modification, are permitted provided that the following conditions
|
9 |
* are met:
|
10 |
* 1. Redistributions of source code must retain the above copyright
|
11 |
* notice, this list of conditions and the following disclaimer.
|
12 |
* 2. Redistributions in binary form must reproduce the above copyright
|
13 |
* notice, this list of conditions and the following disclaimer in the
|
14 |
* documentation and/or other materials provided with the distribution.
|
15 |
* 3. All advertising materials mentioning features or use of this software
|
16 |
* must display the following acknowledgement:
|
17 |
* This product includes software developed for the
|
18 |
* NetBSD Project. See http://www.NetBSD.org/ for
|
19 |
* information about NetBSD.
|
20 |
* 4. The name of the author may not be used to endorse or promote products
|
21 |
* derived from this software without specific prior written permission.
|
22 |
*
|
23 |
* THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR
|
24 |
* IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
|
25 |
* OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED.
|
26 |
* IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT,
|
27 |
* INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT
|
28 |
* NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
|
29 |
* DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
|
30 |
* THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
|
31 |
* (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF
|
32 |
* THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
33 |
*
|
34 |
* --(license Id: LICENSE.proto,v 1.1 2000/06/13 21:40:26 cgd Exp )--
|
35 |
*/
|
36 |
|
37 |
/*
|
38 |
* Copyright (c) 1992, 1993
|
39 |
* The Regents of the University of California. All rights reserved.
|
40 |
*
|
41 |
* This software was developed by the Computer Systems Engineering group
|
42 |
* at Lawrence Berkeley Laboratory under DARPA contract BG 91-66 and
|
43 |
* contributed to Berkeley.
|
44 |
*
|
45 |
* All advertising materials mentioning features or use of this software
|
46 |
* must display the following acknowledgement:
|
47 |
* This product includes software developed by the University of
|
48 |
* California, Lawrence Berkeley Laboratories.
|
49 |
*
|
50 |
* Redistribution and use in source and binary forms, with or without
|
51 |
* modification, are permitted provided that the following conditions
|
52 |
* are met:
|
53 |
* 1. Redistributions of source code must retain the above copyright
|
54 |
* notice, this list of conditions and the following disclaimer.
|
55 |
* 2. Redistributions in binary form must reproduce the above copyright
|
56 |
* notice, this list of conditions and the following disclaimer in the
|
57 |
* documentation and/or other materials provided with the distribution.
|
58 |
* 3. Neither the name of the University nor the names of its contributors
|
59 |
* may be used to endorse or promote products derived from this software
|
60 |
* without specific prior written permission.
|
61 |
*
|
62 |
* THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``AS IS'' AND
|
63 |
* ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
|
64 |
* IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
|
65 |
* ARE DISCLAIMED. IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE
|
66 |
* FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
|
67 |
* DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
|
68 |
* OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
|
69 |
* HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
|
70 |
* LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
|
71 |
* OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
|
72 |
* SUCH DAMAGE.
|
73 |
*
|
74 |
* @(#)device.h 8.2 (Berkeley) 2/17/94
|
75 |
*/
|
76 |
|
77 |
#ifndef _SYS_DEVICE_H_
|
78 |
#define _SYS_DEVICE_H_
|
79 |
|
80 |
#include <sys/device_if.h> |
81 |
#include <sys/evcnt.h> |
82 |
#include <sys/queue.h> |
83 |
|
84 |
#ifdef _KERNEL
|
85 |
#include <sys/mutex.h> |
86 |
#include <sys/condvar.h> |
87 |
#include <sys/pmf.h> |
88 |
#endif
|
89 |
|
90 |
#include <prop/proplib.h> |
91 |
|
92 |
/*
|
93 |
* Minimal device structures.
|
94 |
* Note that all ``system'' device types are listed here.
|
95 |
*/
|
96 |
typedef enum devclass { |
97 |
DV_DULL, /* generic, no special info */
|
98 |
DV_CPU, /* CPU (carries resource utilization) */
|
99 |
DV_DISK, /* disk drive (label, etc) */
|
100 |
DV_IFNET, /* network interface */
|
101 |
DV_TAPE, /* tape device */
|
102 |
DV_TTY, /* serial line interface (?) */
|
103 |
DV_AUDIODEV, /* audio device */
|
104 |
DV_DISPLAYDEV, /* display device */
|
105 |
DV_BUS, /* bus device */
|
106 |
DV_VIRTUAL, /* unbacked virtual device */
|
107 |
} devclass_t; |
108 |
|
109 |
/*
|
110 |
* Actions for ca_activate.
|
111 |
*/
|
112 |
typedef enum devact { |
113 |
DVACT_DEACTIVATE /* deactivate the device */
|
114 |
} devact_t; |
115 |
|
116 |
typedef enum { |
117 |
DVA_SYSTEM, |
118 |
DVA_HARDWARE |
119 |
} devactive_t; |
120 |
|
121 |
typedef struct cfdata *cfdata_t; |
122 |
typedef struct cfdriver *cfdriver_t; |
123 |
typedef struct cfattach *cfattach_t; |
124 |
|
125 |
#ifdef _KERNEL
|
126 |
struct device_lock {
|
127 |
int dvl_nwait;
|
128 |
int dvl_nlock;
|
129 |
lwp_t *dvl_holder; |
130 |
kmutex_t dvl_mtx; |
131 |
kcondvar_t dvl_cv; |
132 |
}; |
133 |
|
134 |
struct device_suspensor {
|
135 |
const device_suspensor_t *ds_delegator;
|
136 |
char ds_name[32]; |
137 |
}; |
138 |
|
139 |
#define DEVICE_SUSPENSORS_MAX 16 |
140 |
|
141 |
struct device_garbage {
|
142 |
device_t *dg_devs; |
143 |
int dg_ndevs;
|
144 |
}; |
145 |
|
146 |
struct device {
|
147 |
devclass_t dv_class; /* this device's classification */
|
148 |
TAILQ_ENTRY(device) dv_list; /* entry on list of all devices */
|
149 |
cfdata_t dv_cfdata; /* config data that found us
|
150 |
(NULL if pseudo-device) */
|
151 |
cfdriver_t dv_cfdriver; /* our cfdriver */
|
152 |
cfattach_t dv_cfattach; /* our cfattach */
|
153 |
int dv_unit; /* device unit number */ |
154 |
char dv_xname[16]; /* external name (name + unit) */ |
155 |
device_t dv_parent; /* pointer to parent device
|
156 |
(NULL if pseudo- or root node) */
|
157 |
int dv_depth; /* number of parents until root */ |
158 |
int dv_flags; /* misc. flags; see below */ |
159 |
void *dv_private; /* this device's private storage */ |
160 |
int *dv_locators; /* our actual locators (optional) */ |
161 |
prop_dictionary_t dv_properties;/* properties dictionary */
|
162 |
|
163 |
size_t dv_activity_count; |
164 |
void (**dv_activity_handlers)(device_t, devactive_t);
|
165 |
|
166 |
bool (*dv_driver_suspend)(device_t, const pmf_qual_t *); |
167 |
bool (*dv_driver_resume)(device_t, const pmf_qual_t *); |
168 |
bool (*dv_driver_shutdown)(device_t, int); |
169 |
bool (*dv_driver_child_register)(device_t);
|
170 |
|
171 |
void *dv_bus_private;
|
172 |
bool (*dv_bus_suspend)(device_t, const pmf_qual_t *); |
173 |
bool (*dv_bus_resume)(device_t, const pmf_qual_t *); |
174 |
bool (*dv_bus_shutdown)(device_t, int); |
175 |
void (*dv_bus_deregister)(device_t);
|
176 |
|
177 |
void *dv_class_private;
|
178 |
bool (*dv_class_suspend)(device_t, const pmf_qual_t *); |
179 |
bool (*dv_class_resume)(device_t, const pmf_qual_t *); |
180 |
void (*dv_class_deregister)(device_t);
|
181 |
|
182 |
devgen_t dv_add_gen, |
183 |
dv_del_gen; |
184 |
|
185 |
struct device_lock dv_lock;
|
186 |
const device_suspensor_t
|
187 |
*dv_bus_suspensors[DEVICE_SUSPENSORS_MAX], |
188 |
*dv_driver_suspensors[DEVICE_SUSPENSORS_MAX], |
189 |
*dv_class_suspensors[DEVICE_SUSPENSORS_MAX]; |
190 |
struct device_garbage dv_garbage;
|
191 |
}; |
192 |
|
193 |
/* dv_flags */
|
194 |
#define DVF_ACTIVE 0x0001 /* device is activated */ |
195 |
#define DVF_PRIV_ALLOC 0x0002 /* device private storage != device */ |
196 |
#define DVF_POWER_HANDLERS 0x0004 /* device has suspend/resume support */ |
197 |
#define DVF_CLASS_SUSPENDED 0x0008 /* device class suspend was called */ |
198 |
#define DVF_DRIVER_SUSPENDED 0x0010 /* device driver suspend was called */ |
199 |
#define DVF_BUS_SUSPENDED 0x0020 /* device bus suspend was called */ |
200 |
#define DVF_DETACH_SHUTDOWN 0x0080 /* device detaches safely at shutdown */ |
201 |
|
202 |
TAILQ_HEAD(devicelist, device); |
203 |
|
204 |
enum deviter_flags {
|
205 |
DEVITER_F_RW = 0x1
|
206 |
, DEVITER_F_SHUTDOWN = 0x2
|
207 |
, DEVITER_F_LEAVES_FIRST = 0x4
|
208 |
, DEVITER_F_ROOT_FIRST = 0x8
|
209 |
}; |
210 |
|
211 |
typedef enum deviter_flags deviter_flags_t; |
212 |
|
213 |
struct deviter {
|
214 |
device_t di_prev; |
215 |
deviter_flags_t di_flags; |
216 |
int di_curdepth;
|
217 |
int di_maxdepth;
|
218 |
devgen_t di_gen; |
219 |
}; |
220 |
|
221 |
typedef struct deviter deviter_t; |
222 |
|
223 |
struct shutdown_state {
|
224 |
bool initialized;
|
225 |
deviter_t di; |
226 |
}; |
227 |
#endif
|
228 |
|
229 |
/*
|
230 |
* Description of a locator, as part of interface attribute definitions.
|
231 |
*/
|
232 |
struct cflocdesc {
|
233 |
const char *cld_name; |
234 |
const char *cld_defaultstr; /* NULL if no default */ |
235 |
int cld_default;
|
236 |
}; |
237 |
|
238 |
/*
|
239 |
* Description of an interface attribute, provided by potential
|
240 |
* parent device drivers, referred to by child device configuration data.
|
241 |
*/
|
242 |
struct cfiattrdata {
|
243 |
const char *ci_name; |
244 |
int ci_loclen;
|
245 |
const struct cflocdesc ci_locdesc[ |
246 |
#if defined(__GNUC__) && __GNUC__ <= 2 |
247 |
0
|
248 |
#endif
|
249 |
]; |
250 |
}; |
251 |
|
252 |
/*
|
253 |
* Description of a configuration parent. Each device attachment attaches
|
254 |
* to an "interface attribute", which is given in this structure. The parent
|
255 |
* *must* carry this attribute. Optionally, an individual device instance
|
256 |
* may also specify a specific parent device instance.
|
257 |
*/
|
258 |
struct cfparent {
|
259 |
const char *cfp_iattr; /* interface attribute */ |
260 |
const char *cfp_parent; /* optional specific parent */ |
261 |
int cfp_unit; /* optional specific unit |
262 |
(DVUNIT_ANY to wildcard) */
|
263 |
}; |
264 |
|
265 |
/*
|
266 |
* Configuration data (i.e., data placed in ioconf.c).
|
267 |
*/
|
268 |
struct cfdata {
|
269 |
const char *cf_name; /* driver name */ |
270 |
const char *cf_atname; /* attachment name */ |
271 |
short cf_unit; /* unit number */ |
272 |
short cf_fstate; /* finding state (below) */ |
273 |
int *cf_loc; /* locators (machine dependent) */ |
274 |
int cf_flags; /* flags from config */ |
275 |
const struct cfparent *cf_pspec;/* parent specification */ |
276 |
}; |
277 |
#define FSTATE_NOTFOUND 0 /* has not been found */ |
278 |
#define FSTATE_FOUND 1 /* has been found */ |
279 |
#define FSTATE_STAR 2 /* duplicable */ |
280 |
#define FSTATE_DSTAR 3 /* has not been found, and disabled */ |
281 |
#define FSTATE_DNOTFOUND 4 /* duplicate, and disabled */ |
282 |
|
283 |
/*
|
284 |
* Multiple configuration data tables may be maintained. This structure
|
285 |
* provides the linkage.
|
286 |
*/
|
287 |
struct cftable {
|
288 |
cfdata_t ct_cfdata; /* pointer to cfdata table */
|
289 |
TAILQ_ENTRY(cftable) ct_list; /* list linkage */
|
290 |
}; |
291 |
TAILQ_HEAD(cftablelist, cftable); |
292 |
|
293 |
typedef int (*cfsubmatch_t)(device_t, cfdata_t, const int *, void *); |
294 |
|
295 |
/*
|
296 |
* `configuration' attachment and driver (what the machine-independent
|
297 |
* autoconf uses). As devices are found, they are applied against all
|
298 |
* the potential matches. The one with the best match is taken, and a
|
299 |
* device structure (plus any other data desired) is allocated. Pointers
|
300 |
* to these are placed into an array of pointers. The array itself must
|
301 |
* be dynamic since devices can be found long after the machine is up
|
302 |
* and running.
|
303 |
*
|
304 |
* Devices can have multiple configuration attachments if they attach
|
305 |
* to different attributes (busses, or whatever), to allow specification
|
306 |
* of multiple match and attach functions. There is only one configuration
|
307 |
* driver per driver, so that things like unit numbers and the device
|
308 |
* structure array will be shared.
|
309 |
*/
|
310 |
struct cfattach {
|
311 |
const char *ca_name; /* name of attachment */ |
312 |
LIST_ENTRY(cfattach) ca_list; /* link on cfdriver's list */
|
313 |
size_t ca_devsize; /* size of dev data (for alloc) */
|
314 |
int ca_flags; /* flags for driver allocation etc */ |
315 |
int (*ca_match)(device_t, cfdata_t, void *); |
316 |
void (*ca_attach)(device_t, device_t, void *); |
317 |
int (*ca_detach)(device_t, int); |
318 |
int (*ca_activate)(device_t, devact_t);
|
319 |
/* technically, the next 2 belong into "struct cfdriver" */
|
320 |
int (*ca_rescan)(device_t, const char *, |
321 |
const int *); /* scan for new children */ |
322 |
void (*ca_childdetached)(device_t, device_t);
|
323 |
}; |
324 |
LIST_HEAD(cfattachlist, cfattach); |
325 |
|
326 |
#define CFATTACH_DECL3_NEW(name, ddsize, matfn, attfn, detfn, actfn, \
|
327 |
rescanfn, chdetfn, __flags) \ |
328 |
struct cfattach __CONCAT(name,_ca) = { \
|
329 |
.ca_name = ___STRING(name), \ |
330 |
.ca_devsize = ddsize, \ |
331 |
.ca_flags = (__flags) | DVF_PRIV_ALLOC, \ |
332 |
.ca_match = matfn, \ |
333 |
.ca_attach = attfn, \ |
334 |
.ca_detach = detfn, \ |
335 |
.ca_activate = actfn, \ |
336 |
.ca_rescan = rescanfn, \ |
337 |
.ca_childdetached = chdetfn, \ |
338 |
} |
339 |
|
340 |
#define CFATTACH_DECL2_NEW(name, ddsize, matfn, attfn, detfn, actfn, \
|
341 |
rescanfn, chdetfn) \ |
342 |
CFATTACH_DECL3_NEW(name, ddsize, matfn, attfn, detfn, actfn, \ |
343 |
rescanfn, chdetfn, 0)
|
344 |
|
345 |
#define CFATTACH_DECL_NEW(name, ddsize, matfn, attfn, detfn, actfn) \
|
346 |
CFATTACH_DECL2_NEW(name, ddsize, matfn, attfn, detfn, actfn, NULL, NULL) |
347 |
|
348 |
/* Flags given to config_detach(), and the ca_detach function. */
|
349 |
#define DETACH_FORCE 0x01 /* force detachment; hardware gone */ |
350 |
#define DETACH_QUIET 0x02 /* don't print a notice */ |
351 |
#define DETACH_SHUTDOWN 0x04 /* detach because of system shutdown */ |
352 |
|
353 |
struct cfdriver {
|
354 |
LIST_ENTRY(cfdriver) cd_list; /* link on allcfdrivers */
|
355 |
struct cfattachlist cd_attach; /* list of all attachments */ |
356 |
device_t *cd_devs; /* devices found */
|
357 |
const char *cd_name; /* device name */ |
358 |
enum devclass cd_class; /* device classification */ |
359 |
int cd_ndevs; /* size of cd_devs array */ |
360 |
const struct cfiattrdata * const *cd_attrs; /* attributes provided */ |
361 |
}; |
362 |
LIST_HEAD(cfdriverlist, cfdriver); |
363 |
|
364 |
#define CFDRIVER_DECL(name, class, attrs) \
|
365 |
struct cfdriver __CONCAT(name,_cd) = { \
|
366 |
.cd_name = ___STRING(name), \ |
367 |
.cd_class = class, \ |
368 |
.cd_attrs = attrs, \ |
369 |
} |
370 |
|
371 |
/*
|
372 |
* The cfattachinit is a data structure used to associate a list of
|
373 |
* cfattach's with cfdrivers as found in the static kernel configuration.
|
374 |
*/
|
375 |
struct cfattachinit {
|
376 |
const char *cfai_name; /* driver name */ |
377 |
struct cfattach * const *cfai_list;/* list of attachments */ |
378 |
}; |
379 |
/*
|
380 |
* the same, but with a non-constant list so it can be modified
|
381 |
* for module bookkeeping
|
382 |
*/
|
383 |
struct cfattachlkminit {
|
384 |
const char *cfai_name; /* driver name */ |
385 |
struct cfattach **cfai_list; /* list of attachments */ |
386 |
}; |
387 |
|
388 |
/*
|
389 |
* Configuration printing functions, and their return codes. The second
|
390 |
* argument is NULL if the device was configured; otherwise it is the name
|
391 |
* of the parent device. The return value is ignored if the device was
|
392 |
* configured, so most functions can return UNCONF unconditionally.
|
393 |
*/
|
394 |
typedef int (*cfprint_t)(void *, const char *); /* XXX const char * */ |
395 |
#define QUIET 0 /* print nothing */ |
396 |
#define UNCONF 1 /* print " not configured\n" */ |
397 |
#define UNSUPP 2 /* print " not supported\n" */ |
398 |
|
399 |
/*
|
400 |
* Pseudo-device attach information (function + number of pseudo-devs).
|
401 |
*/
|
402 |
struct pdevinit {
|
403 |
void (*pdev_attach)(int); |
404 |
int pdev_count;
|
405 |
}; |
406 |
|
407 |
/* This allows us to wildcard a device unit. */
|
408 |
#define DVUNIT_ANY -1 |
409 |
|
410 |
#ifdef _KERNEL
|
411 |
|
412 |
extern struct cfdriverlist allcfdrivers;/* list of all cfdrivers */ |
413 |
extern struct cftablelist allcftables; /* list of all cfdata tables */ |
414 |
extern device_t booted_device; /* the device we booted from */ |
415 |
extern int booted_partition; /* the partition on that device */ |
416 |
extern daddr_t booted_startblk; /* or the start of a wedge */ |
417 |
extern uint64_t booted_nblks; /* and the size of that wedge */ |
418 |
extern char *bootspec; /* and the device/wedge name */ |
419 |
|
420 |
struct vnode *opendisk(device_t);
|
421 |
int getdisksize(struct vnode *, uint64_t *, unsigned int *); |
422 |
struct dkwedge_info;
|
423 |
int getdiskinfo(struct vnode *, struct dkwedge_info *); |
424 |
|
425 |
void config_init(void); |
426 |
int config_init_component(struct cfdriver *const*, |
427 |
const struct cfattachinit *, struct cfdata *); |
428 |
int config_fini_component(struct cfdriver *const*, |
429 |
const struct cfattachinit *, struct cfdata *); |
430 |
void config_init_mi(void); |
431 |
void drvctl_init(void); |
432 |
|
433 |
int config_cfdriver_attach(struct cfdriver *); |
434 |
int config_cfdriver_detach(struct cfdriver *); |
435 |
|
436 |
int config_cfattach_attach(const char *, struct cfattach *); |
437 |
int config_cfattach_detach(const char *, struct cfattach *); |
438 |
|
439 |
int config_cfdata_attach(cfdata_t, int); |
440 |
int config_cfdata_detach(cfdata_t);
|
441 |
|
442 |
struct cfdriver *config_cfdriver_lookup(const char *); |
443 |
struct cfattach *config_cfattach_lookup(const char *, const char *); |
444 |
const struct cfiattrdata *cfiattr_lookup(const char *, const struct cfdriver *); |
445 |
|
446 |
const char *cfdata_ifattr(const struct cfdata *); |
447 |
|
448 |
int config_stdsubmatch(device_t, cfdata_t, const int *, void *); |
449 |
cfdata_t config_search_loc(cfsubmatch_t, device_t, |
450 |
const char *, const int *, void *); |
451 |
cfdata_t config_search_ia(cfsubmatch_t, device_t, |
452 |
const char *, void *); |
453 |
cfdata_t config_rootsearch(cfsubmatch_t, const char *, void *); |
454 |
device_t config_found_sm_loc(device_t, const char *, const int *, |
455 |
void *, cfprint_t, cfsubmatch_t);
|
456 |
device_t config_found_ia(device_t, const char *, void *, cfprint_t); |
457 |
device_t config_found(device_t, void *, cfprint_t);
|
458 |
device_t config_rootfound(const char *, void *); |
459 |
device_t config_attach_loc(device_t, cfdata_t, const int *, void *, cfprint_t); |
460 |
device_t config_attach(device_t, cfdata_t, void *, cfprint_t);
|
461 |
int config_match(device_t, cfdata_t, void *); |
462 |
|
463 |
bool ifattr_match(const char *, const char *); |
464 |
|
465 |
device_t config_attach_pseudo(cfdata_t); |
466 |
|
467 |
int config_detach(device_t, int); |
468 |
int config_detach_children(device_t, int flags); |
469 |
bool config_detach_all(int); |
470 |
int config_deactivate(device_t);
|
471 |
void config_defer(device_t, void (*)(device_t)); |
472 |
void config_deferred(device_t);
|
473 |
void config_interrupts(device_t, void (*)(device_t)); |
474 |
void config_mountroot(device_t, void (*)(device_t)); |
475 |
void config_pending_incr(device_t);
|
476 |
void config_pending_decr(device_t);
|
477 |
void config_create_interruptthreads(void); |
478 |
void config_create_mountrootthreads(void); |
479 |
|
480 |
int config_finalize_register(device_t, int (*)(device_t)); |
481 |
void config_finalize(void); |
482 |
void config_finalize_mountroot(void); |
483 |
|
484 |
void config_twiddle_init(void); |
485 |
void config_twiddle_fn(void *); |
486 |
|
487 |
void null_childdetached(device_t, device_t);
|
488 |
|
489 |
device_t device_lookup(cfdriver_t, int);
|
490 |
void *device_lookup_private(cfdriver_t, int); |
491 |
void device_register(device_t, void *); |
492 |
void device_register_post_config(device_t, void *); |
493 |
|
494 |
devclass_t device_class(device_t); |
495 |
cfdata_t device_cfdata(device_t); |
496 |
cfdriver_t device_cfdriver(device_t); |
497 |
cfattach_t device_cfattach(device_t); |
498 |
int device_unit(device_t);
|
499 |
const char *device_xname(device_t); |
500 |
device_t device_parent(device_t); |
501 |
bool device_is_active(device_t);
|
502 |
bool device_activation(device_t, devact_level_t);
|
503 |
bool device_is_enabled(device_t);
|
504 |
bool device_has_power(device_t);
|
505 |
int device_locator(device_t, u_int);
|
506 |
void *device_private(device_t);
|
507 |
prop_dictionary_t device_properties(device_t); |
508 |
|
509 |
device_t deviter_first(deviter_t *, deviter_flags_t); |
510 |
void deviter_init(deviter_t *, deviter_flags_t);
|
511 |
device_t deviter_next(deviter_t *); |
512 |
void deviter_release(deviter_t *);
|
513 |
|
514 |
bool device_active(device_t, devactive_t);
|
515 |
bool device_active_register(device_t,
|
516 |
void (*)(device_t, devactive_t));
|
517 |
void device_active_deregister(device_t,
|
518 |
void (*)(device_t, devactive_t));
|
519 |
|
520 |
bool device_is_a(device_t, const char *); |
521 |
|
522 |
device_t device_find_by_xname(const char *); |
523 |
device_t device_find_by_driver_unit(const char *, int); |
524 |
|
525 |
bool device_pmf_is_registered(device_t);
|
526 |
|
527 |
bool device_pmf_driver_suspend(device_t, const pmf_qual_t *); |
528 |
bool device_pmf_driver_resume(device_t, const pmf_qual_t *); |
529 |
bool device_pmf_driver_shutdown(device_t, int); |
530 |
|
531 |
bool device_pmf_driver_register(device_t,
|
532 |
bool (*)(device_t, const pmf_qual_t *), |
533 |
bool (*)(device_t, const pmf_qual_t *), |
534 |
bool (*)(device_t, int)); |
535 |
void device_pmf_driver_deregister(device_t);
|
536 |
|
537 |
bool device_pmf_driver_child_register(device_t);
|
538 |
void device_pmf_driver_set_child_register(device_t,
|
539 |
bool (*)(device_t));
|
540 |
|
541 |
void *device_pmf_bus_private(device_t);
|
542 |
bool device_pmf_bus_suspend(device_t, const pmf_qual_t *); |
543 |
bool device_pmf_bus_resume(device_t, const pmf_qual_t *); |
544 |
bool device_pmf_bus_shutdown(device_t, int); |
545 |
|
546 |
device_lock_t device_getlock(device_t); |
547 |
void device_pmf_unlock(device_t);
|
548 |
bool device_pmf_lock(device_t);
|
549 |
|
550 |
bool device_is_self_suspended(device_t);
|
551 |
void device_pmf_self_suspend(device_t, const pmf_qual_t *); |
552 |
void device_pmf_self_resume(device_t, const pmf_qual_t *); |
553 |
bool device_pmf_self_wait(device_t, const pmf_qual_t *); |
554 |
|
555 |
void device_pmf_bus_register(device_t, void *, |
556 |
bool (*)(device_t, const pmf_qual_t *), |
557 |
bool (*)(device_t, const pmf_qual_t *), |
558 |
bool (*)(device_t, int), |
559 |
void (*)(device_t));
|
560 |
void device_pmf_bus_deregister(device_t);
|
561 |
|
562 |
void *device_pmf_class_private(device_t);
|
563 |
bool device_pmf_class_suspend(device_t, const pmf_qual_t *); |
564 |
bool device_pmf_class_resume(device_t, const pmf_qual_t *); |
565 |
|
566 |
void device_pmf_class_register(device_t, void *, |
567 |
bool (*)(device_t, const pmf_qual_t *), |
568 |
bool (*)(device_t, const pmf_qual_t *), |
569 |
void (*)(device_t));
|
570 |
void device_pmf_class_deregister(device_t);
|
571 |
|
572 |
device_t shutdown_first(struct shutdown_state *);
|
573 |
device_t shutdown_next(struct shutdown_state *);
|
574 |
#endif /* _KERNEL */ |
575 |
|
576 |
#endif /* !_SYS_DEVICE_H_ */ |