1b1876192SPoul-Henning Kamp /*- 2b1876192SPoul-Henning Kamp * Copyright (c) 2002 Poul-Henning Kamp 3b1876192SPoul-Henning Kamp * Copyright (c) 2002 Networks Associates Technology, Inc. 4b1876192SPoul-Henning Kamp * All rights reserved. 5b1876192SPoul-Henning Kamp * 6b1876192SPoul-Henning Kamp * This software was developed for the FreeBSD Project by Poul-Henning Kamp 7b1876192SPoul-Henning Kamp * and NAI Labs, the Security Research Division of Network Associates, Inc. 8b1876192SPoul-Henning Kamp * under DARPA/SPAWAR contract N66001-01-C-8035 ("CBOSS"), as part of the 9b1876192SPoul-Henning Kamp * DARPA CHATS research program. 10b1876192SPoul-Henning Kamp * 11b1876192SPoul-Henning Kamp * Redistribution and use in source and binary forms, with or without 12b1876192SPoul-Henning Kamp * modification, are permitted provided that the following conditions 13b1876192SPoul-Henning Kamp * are met: 14b1876192SPoul-Henning Kamp * 1. Redistributions of source code must retain the above copyright 15b1876192SPoul-Henning Kamp * notice, this list of conditions and the following disclaimer. 16b1876192SPoul-Henning Kamp * 2. Redistributions in binary form must reproduce the above copyright 17b1876192SPoul-Henning Kamp * notice, this list of conditions and the following disclaimer in the 18b1876192SPoul-Henning Kamp * documentation and/or other materials provided with the distribution. 19b1876192SPoul-Henning Kamp * 3. The names of the authors may not be used to endorse or promote 20b1876192SPoul-Henning Kamp * products derived from this software without specific prior written 21b1876192SPoul-Henning Kamp * permission. 22b1876192SPoul-Henning Kamp * 23b1876192SPoul-Henning Kamp * THIS SOFTWARE IS PROVIDED BY THE AUTHOR AND CONTRIBUTORS ``AS IS'' AND 24b1876192SPoul-Henning Kamp * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE 25b1876192SPoul-Henning Kamp * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE 26b1876192SPoul-Henning Kamp * ARE DISCLAIMED. IN NO EVENT SHALL THE AUTHOR OR CONTRIBUTORS BE LIABLE 27b1876192SPoul-Henning Kamp * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL 28b1876192SPoul-Henning Kamp * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS 29b1876192SPoul-Henning Kamp * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) 30b1876192SPoul-Henning Kamp * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT 31b1876192SPoul-Henning Kamp * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY 32b1876192SPoul-Henning Kamp * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF 33b1876192SPoul-Henning Kamp * SUCH DAMAGE. 34b1876192SPoul-Henning Kamp * 35b1876192SPoul-Henning Kamp * $FreeBSD$ 36b1876192SPoul-Henning Kamp */ 37b1876192SPoul-Henning Kamp 38b1876192SPoul-Henning Kamp LIST_HEAD(class_list_head, g_class); 39b1876192SPoul-Henning Kamp TAILQ_HEAD(g_tailq_head, g_geom); 40b1876192SPoul-Henning Kamp TAILQ_HEAD(event_tailq_head, g_event); 41b1876192SPoul-Henning Kamp 42b1876192SPoul-Henning Kamp extern struct event_tailq_head events; 43801bb689SPoul-Henning Kamp extern int g_collectstats; 44b1876192SPoul-Henning Kamp extern int g_debugflags; 455dcf28b2SPoul-Henning Kamp /* 1 G_T_TOPOLOGY */ 465dcf28b2SPoul-Henning Kamp /* 2 G_T_BIO */ 475dcf28b2SPoul-Henning Kamp /* 4 G_T_ACCESS */ 485dcf28b2SPoul-Henning Kamp /* 8 enable sanity checks */ 49b1876192SPoul-Henning Kamp 50b1876192SPoul-Henning Kamp /* 51b1876192SPoul-Henning Kamp * Various internal actions are tracked by tagging g_event[s] onto 52b1876192SPoul-Henning Kamp * an internal eventqueue. 53b1876192SPoul-Henning Kamp */ 54b1876192SPoul-Henning Kamp enum g_events { 55b1876192SPoul-Henning Kamp EV_NEW_CLASS, /* class */ 56b1876192SPoul-Henning Kamp EV_NEW_PROVIDER, /* provider */ 57b1876192SPoul-Henning Kamp EV_SPOILED, /* provider, consumer */ 58346cd5feSPoul-Henning Kamp EV_CALL_ME, /* func, arg */ 59b1876192SPoul-Henning Kamp EV_LAST 60b1876192SPoul-Henning Kamp }; 61b1876192SPoul-Henning Kamp 62b1876192SPoul-Henning Kamp struct g_event { 63b1876192SPoul-Henning Kamp enum g_events event; 64b1876192SPoul-Henning Kamp TAILQ_ENTRY(g_event) events; 65b1876192SPoul-Henning Kamp struct g_class *class; 66b1876192SPoul-Henning Kamp struct g_geom *geom; 67b1876192SPoul-Henning Kamp struct g_provider *provider; 68b1876192SPoul-Henning Kamp struct g_consumer *consumer; 69346cd5feSPoul-Henning Kamp void *arg; 70346cd5feSPoul-Henning Kamp g_call_me_t *func; 71b1876192SPoul-Henning Kamp }; 72b1876192SPoul-Henning Kamp 73b1876192SPoul-Henning Kamp /* geom_dump.c */ 742874f1cfSPoul-Henning Kamp void g_confxml(void *); 752874f1cfSPoul-Henning Kamp void g_conf_specific(struct sbuf *sb, struct g_class *mp, struct g_geom *gp, struct g_provider *pp, struct g_consumer *cp); 762874f1cfSPoul-Henning Kamp void g_confdot(void *); 77d518e539SPoul-Henning Kamp void g_conftxt(void *); 78b1876192SPoul-Henning Kamp 79b1876192SPoul-Henning Kamp 80b1876192SPoul-Henning Kamp /* geom_event.c */ 81b1876192SPoul-Henning Kamp void g_event_init(void); 82b1876192SPoul-Henning Kamp void g_post_event(enum g_events ev, struct g_class *mp, struct g_geom *gp, struct g_provider *pp, struct g_consumer *cp); 83b1876192SPoul-Henning Kamp void g_run_events(void); 84b1876192SPoul-Henning Kamp 85b1876192SPoul-Henning Kamp /* geom_subr.c */ 862654e1fcSPoul-Henning Kamp extern struct class_list_head g_classes; 87b1876192SPoul-Henning Kamp extern char *g_wait_event, *g_wait_sim, *g_wait_up, *g_wait_down; 88b1876192SPoul-Henning Kamp 89b1876192SPoul-Henning Kamp /* geom_io.c */ 90b1876192SPoul-Henning Kamp void g_io_init(void); 91b1876192SPoul-Henning Kamp void g_io_schedule_down(struct thread *tp); 92b1876192SPoul-Henning Kamp void g_io_schedule_up(struct thread *tp); 93b1876192SPoul-Henning Kamp 94b1876192SPoul-Henning Kamp /* geom_kern.c / geom_kernsim.c */ 95b1876192SPoul-Henning Kamp void g_init(void); 96