geom_kern.c revision 104060
1/*- 2 * Copyright (c) 2002 Poul-Henning Kamp 3 * Copyright (c) 2002 Networks Associates Technology, Inc. 4 * All rights reserved. 5 * 6 * This software was developed for the FreeBSD Project by Poul-Henning Kamp 7 * and NAI Labs, the Security Research Division of Network Associates, Inc. 8 * under DARPA/SPAWAR contract N66001-01-C-8035 ("CBOSS"), as part of the 9 * DARPA CHATS research program. 10 * 11 * Redistribution and use in source and binary forms, with or without 12 * modification, are permitted provided that the following conditions 13 * are met: 14 * 1. Redistributions of source code must retain the above copyright 15 * notice, this list of conditions and the following disclaimer. 16 * 2. Redistributions in binary form must reproduce the above copyright 17 * notice, this list of conditions and the following disclaimer in the 18 * documentation and/or other materials provided with the distribution. 19 * 3. The names of the authors may not be used to endorse or promote 20 * products derived from this software without specific prior written 21 * permission. 22 * 23 * THIS SOFTWARE IS PROVIDED BY THE AUTHOR AND CONTRIBUTORS ``AS IS'' AND 24 * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE 25 * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE 26 * ARE DISCLAIMED. IN NO EVENT SHALL THE AUTHOR OR CONTRIBUTORS BE LIABLE 27 * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL 28 * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS 29 * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) 30 * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT 31 * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY 32 * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF 33 * SUCH DAMAGE. 34 * 35 * $FreeBSD: head/sys/geom/geom_kern.c 104060 2002-09-27 21:05:05Z phk $ 36 */ 37 38#include <sys/param.h> 39#include <sys/systm.h> 40#include <sys/kernel.h> 41#include <sys/malloc.h> 42#include <sys/bio.h> 43#include <sys/sysctl.h> 44#include <sys/proc.h> 45#include <sys/kthread.h> 46#include <sys/lock.h> 47#include <sys/mutex.h> 48#include <sys/sx.h> 49#include <sys/sbuf.h> 50#include <sys/errno.h> 51#include <geom/geom.h> 52#include <geom/geom_int.h> 53 54MALLOC_DEFINE(M_GEOM, "GEOM", "Geom data structures"); 55 56struct sx topology_lock; 57 58static struct proc *g_up_proc; 59 60int g_debugflags; 61 62static void 63g_up_procbody(void) 64{ 65 struct proc *p = g_up_proc; 66 struct thread *tp = FIRST_THREAD_IN_PROC(p); 67 68 curthread->td_base_pri = PRIBIO; 69 for(;;) { 70 g_io_schedule_up(tp); 71 tsleep(&g_wait_up, PRIBIO, "g_up", hz/10); 72 } 73} 74 75struct kproc_desc g_up_kp = { 76 "g_up", 77 g_up_procbody, 78 &g_up_proc, 79}; 80 81static struct proc *g_down_proc; 82 83static void 84g_down_procbody(void) 85{ 86 struct proc *p = g_down_proc; 87 struct thread *tp = FIRST_THREAD_IN_PROC(p); 88 89 curthread->td_base_pri = PRIBIO; 90 for(;;) { 91 g_io_schedule_down(tp); 92 tsleep(&g_wait_down, PRIBIO, "g_down", hz/10); 93 } 94} 95 96struct kproc_desc g_down_kp = { 97 "g_down", 98 g_down_procbody, 99 &g_down_proc, 100}; 101 102static struct proc *g_event_proc; 103 104static void 105g_event_procbody(void) 106{ 107 108 curthread->td_base_pri = PRIBIO; 109 for(;;) { 110 g_run_events(); 111 tsleep(&g_wait_event, PRIBIO, "g_events", hz/10); 112 } 113} 114 115struct kproc_desc g_event_kp = { 116 "g_event", 117 g_event_procbody, 118 &g_event_proc, 119}; 120 121void 122g_init(void) 123{ 124 printf("Initializing GEOMetry subsystem\n"); 125 if (bootverbose) 126 g_debugflags |= G_T_TOPOLOGY; 127 sx_init(&topology_lock, "GEOM topology"); 128 g_io_init(); 129 g_event_init(); 130 mtx_lock(&Giant); 131 kproc_start(&g_event_kp); 132 kproc_start(&g_up_kp); 133 kproc_start(&g_down_kp); 134 mtx_unlock(&Giant); 135} 136 137static int 138sysctl_debug_geomdot(SYSCTL_HANDLER_ARGS) 139{ 140 int i, error; 141 struct sbuf *sb; 142 143 i = 0; 144 sb = g_confdot(); 145 error = sysctl_handle_opaque(oidp, sbuf_data(sb), sbuf_len(sb), req); 146 sbuf_delete(sb); 147 return (error); 148} 149 150SYSCTL_PROC(_debug, OID_AUTO, geomdot, CTLTYPE_STRING|CTLFLAG_RD, 151 0, 0, sysctl_debug_geomdot, "A", 152 "Dump the GEOM config"); 153 154static int 155sysctl_debug_geomconf(SYSCTL_HANDLER_ARGS) 156{ 157 int i, error; 158 struct sbuf *sb; 159 160 i = 0; 161 sb = g_conf(); 162 error = sysctl_handle_opaque(oidp, sbuf_data(sb), sbuf_len(sb), req); 163 sbuf_delete(sb); 164 return (error); 165} 166 167SYSCTL_PROC(_debug, OID_AUTO, geomconf, CTLTYPE_STRING|CTLFLAG_RD, 168 0, 0, sysctl_debug_geomconf, "A", 169 "Dump the GEOM config"); 170 171SYSCTL_INT(_debug, OID_AUTO, geomdebugflags, CTLTYPE_INT|CTLFLAG_RW, 172 &g_debugflags, 0, ""); 173 174SYSCTL_INT(_debug_sizeof, OID_AUTO, g_class, CTLTYPE_INT|CTLFLAG_RD, 175 0, sizeof(struct g_class), ""); 176SYSCTL_INT(_debug_sizeof, OID_AUTO, g_geom, CTLTYPE_INT|CTLFLAG_RD, 177 0, sizeof(struct g_geom), ""); 178SYSCTL_INT(_debug_sizeof, OID_AUTO, g_provider, CTLTYPE_INT|CTLFLAG_RD, 179 0, sizeof(struct g_provider), ""); 180SYSCTL_INT(_debug_sizeof, OID_AUTO, g_consumer, CTLTYPE_INT|CTLFLAG_RD, 181 0, sizeof(struct g_consumer), ""); 182SYSCTL_INT(_debug_sizeof, OID_AUTO, g_bioq, CTLTYPE_INT|CTLFLAG_RD, 183 0, sizeof(struct g_bioq), ""); 184SYSCTL_INT(_debug_sizeof, OID_AUTO, g_event, CTLTYPE_INT|CTLFLAG_RD, 185 0, sizeof(struct g_event), ""); 186