1/*- 2 * Copyright (c) 2003 Poul-Henning Kamp 3 * All rights reserved. 4 * 5 * Redistribution and use in source and binary forms, with or without 6 * modification, are permitted provided that the following conditions 7 * are met: 8 * 1. Redistributions of source code must retain the above copyright 9 * notice, this list of conditions and the following disclaimer. 10 * 2. Redistributions in binary form must reproduce the above copyright 11 * notice, this list of conditions and the following disclaimer in the 12 * documentation and/or other materials provided with the distribution. 13 * 3. The names of the authors may not be used to endorse or promote 14 * products derived from this software without specific prior written 15 * permission. 16 * 17 * THIS SOFTWARE IS PROVIDED BY THE AUTHOR AND CONTRIBUTORS ``AS IS'' AND 18 * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE 19 * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE 20 * ARE DISCLAIMED. IN NO EVENT SHALL THE AUTHOR OR CONTRIBUTORS BE LIABLE 21 * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL 22 * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS 23 * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) 24 * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT 25 * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY 26 * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF 27 * SUCH DAMAGE. 28 *
| 1/*- 2 * Copyright (c) 2003 Poul-Henning Kamp 3 * All rights reserved. 4 * 5 * Redistribution and use in source and binary forms, with or without 6 * modification, are permitted provided that the following conditions 7 * are met: 8 * 1. Redistributions of source code must retain the above copyright 9 * notice, this list of conditions and the following disclaimer. 10 * 2. Redistributions in binary form must reproduce the above copyright 11 * notice, this list of conditions and the following disclaimer in the 12 * documentation and/or other materials provided with the distribution. 13 * 3. The names of the authors may not be used to endorse or promote 14 * products derived from this software without specific prior written 15 * permission. 16 * 17 * THIS SOFTWARE IS PROVIDED BY THE AUTHOR AND CONTRIBUTORS ``AS IS'' AND 18 * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE 19 * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE 20 * ARE DISCLAIMED. IN NO EVENT SHALL THE AUTHOR OR CONTRIBUTORS BE LIABLE 21 * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL 22 * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS 23 * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) 24 * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT 25 * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY 26 * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF 27 * SUCH DAMAGE. 28 *
|
29 * $FreeBSD: head/lib/libgeom/libgeom.h 182843 2008-09-07 13:54:57Z lulf $
| 29 * $FreeBSD: head/lib/libgeom/libgeom.h 202454 2010-01-17 06:20:30Z delphij $
|
30 */ 31#ifndef _LIBGEOM_H_ 32#define _LIBGEOM_H_ 33 34#include <sys/cdefs.h> 35 36#include <sys/queue.h> 37#include <sys/time.h> 38 39#include <geom/geom_ctl.h> 40 41__BEGIN_DECLS 42 43void geom_stats_close(void); 44void geom_stats_resync(void); 45int geom_stats_open(void); 46void *geom_stats_snapshot_get(void); 47void geom_stats_snapshot_free(void *); 48void geom_stats_snapshot_timestamp(void *, struct timespec *); 49void geom_stats_snapshot_reset(void *); 50struct devstat *geom_stats_snapshot_next(void *); 51 52char *geom_getxml(void); 53 54/* geom_xml2tree.c */ 55 56/* 57 * These structs are used to build the tree based on the XML. 58 * they're named as the kernel variant without the first '_'. 59 */ 60 61struct gclass; 62struct ggeom; 63struct gconsumer; 64struct gprovider; 65 66LIST_HEAD(gconf, gconfig); 67 68struct gident { 69 void *lg_id; 70 void *lg_ptr; 71 enum { ISCLASS, 72 ISGEOM, 73 ISPROVIDER, 74 ISCONSUMER } lg_what; 75}; 76 77struct gmesh { 78 LIST_HEAD(, gclass) lg_class; 79 struct gident *lg_ident; 80}; 81 82struct gconfig { 83 LIST_ENTRY(gconfig) lg_config; 84 char *lg_name; 85 char *lg_val; 86}; 87 88struct gclass { 89 void *lg_id; 90 char *lg_name; 91 LIST_ENTRY(gclass) lg_class; 92 LIST_HEAD(, ggeom) lg_geom; 93 struct gconf lg_config; 94}; 95 96struct ggeom { 97 void *lg_id; 98 struct gclass *lg_class; 99 char *lg_name; 100 u_int lg_rank; 101 LIST_ENTRY(ggeom) lg_geom; 102 LIST_HEAD(, gconsumer) lg_consumer; 103 LIST_HEAD(, gprovider) lg_provider; 104 struct gconf lg_config; 105}; 106 107struct gconsumer { 108 void *lg_id; 109 struct ggeom *lg_geom; 110 LIST_ENTRY(gconsumer) lg_consumer; 111 struct gprovider *lg_provider; 112 LIST_ENTRY(gconsumer) lg_consumers; 113 char *lg_mode; 114 struct gconf lg_config; 115}; 116 117struct gprovider { 118 void *lg_id; 119 char *lg_name; 120 struct ggeom *lg_geom; 121 LIST_ENTRY(gprovider) lg_provider; 122 LIST_HEAD(, gconsumer) lg_consumers; 123 char *lg_mode; 124 off_t lg_mediasize; 125 u_int lg_sectorsize;
| 30 */ 31#ifndef _LIBGEOM_H_ 32#define _LIBGEOM_H_ 33 34#include <sys/cdefs.h> 35 36#include <sys/queue.h> 37#include <sys/time.h> 38 39#include <geom/geom_ctl.h> 40 41__BEGIN_DECLS 42 43void geom_stats_close(void); 44void geom_stats_resync(void); 45int geom_stats_open(void); 46void *geom_stats_snapshot_get(void); 47void geom_stats_snapshot_free(void *); 48void geom_stats_snapshot_timestamp(void *, struct timespec *); 49void geom_stats_snapshot_reset(void *); 50struct devstat *geom_stats_snapshot_next(void *); 51 52char *geom_getxml(void); 53 54/* geom_xml2tree.c */ 55 56/* 57 * These structs are used to build the tree based on the XML. 58 * they're named as the kernel variant without the first '_'. 59 */ 60 61struct gclass; 62struct ggeom; 63struct gconsumer; 64struct gprovider; 65 66LIST_HEAD(gconf, gconfig); 67 68struct gident { 69 void *lg_id; 70 void *lg_ptr; 71 enum { ISCLASS, 72 ISGEOM, 73 ISPROVIDER, 74 ISCONSUMER } lg_what; 75}; 76 77struct gmesh { 78 LIST_HEAD(, gclass) lg_class; 79 struct gident *lg_ident; 80}; 81 82struct gconfig { 83 LIST_ENTRY(gconfig) lg_config; 84 char *lg_name; 85 char *lg_val; 86}; 87 88struct gclass { 89 void *lg_id; 90 char *lg_name; 91 LIST_ENTRY(gclass) lg_class; 92 LIST_HEAD(, ggeom) lg_geom; 93 struct gconf lg_config; 94}; 95 96struct ggeom { 97 void *lg_id; 98 struct gclass *lg_class; 99 char *lg_name; 100 u_int lg_rank; 101 LIST_ENTRY(ggeom) lg_geom; 102 LIST_HEAD(, gconsumer) lg_consumer; 103 LIST_HEAD(, gprovider) lg_provider; 104 struct gconf lg_config; 105}; 106 107struct gconsumer { 108 void *lg_id; 109 struct ggeom *lg_geom; 110 LIST_ENTRY(gconsumer) lg_consumer; 111 struct gprovider *lg_provider; 112 LIST_ENTRY(gconsumer) lg_consumers; 113 char *lg_mode; 114 struct gconf lg_config; 115}; 116 117struct gprovider { 118 void *lg_id; 119 char *lg_name; 120 struct ggeom *lg_geom; 121 LIST_ENTRY(gprovider) lg_provider; 122 LIST_HEAD(, gconsumer) lg_consumers; 123 char *lg_mode; 124 off_t lg_mediasize; 125 u_int lg_sectorsize;
|
| 126 off_t lg_stripeoffset; 127 off_t lg_stripesize;
|
126 struct gconf lg_config; 127}; 128 129struct gident * geom_lookupid(struct gmesh *, const void *); 130int geom_xml2tree(struct gmesh *, char *); 131int geom_gettree(struct gmesh *); 132void geom_deletetree(struct gmesh *); 133 134/* geom_ctl.c */ 135 136struct gctl_req; 137 138#ifdef _STDIO_H_ /* limit #include pollution */ 139void gctl_dump(struct gctl_req *, FILE *); 140#endif 141void gctl_free(struct gctl_req *); 142struct gctl_req *gctl_get_handle(void); 143const char *gctl_issue(struct gctl_req *); 144void gctl_ro_param(struct gctl_req *, const char *, int, const void *); 145void gctl_rw_param(struct gctl_req *, const char *, int, void *); 146 147/* geom_util.c */ 148int g_open(const char *, int); 149int g_close(int); 150off_t g_mediasize(int); 151ssize_t g_sectorsize(int);
| 128 struct gconf lg_config; 129}; 130 131struct gident * geom_lookupid(struct gmesh *, const void *); 132int geom_xml2tree(struct gmesh *, char *); 133int geom_gettree(struct gmesh *); 134void geom_deletetree(struct gmesh *); 135 136/* geom_ctl.c */ 137 138struct gctl_req; 139 140#ifdef _STDIO_H_ /* limit #include pollution */ 141void gctl_dump(struct gctl_req *, FILE *); 142#endif 143void gctl_free(struct gctl_req *); 144struct gctl_req *gctl_get_handle(void); 145const char *gctl_issue(struct gctl_req *); 146void gctl_ro_param(struct gctl_req *, const char *, int, const void *); 147void gctl_rw_param(struct gctl_req *, const char *, int, void *); 148 149/* geom_util.c */ 150int g_open(const char *, int); 151int g_close(int); 152off_t g_mediasize(int); 153ssize_t g_sectorsize(int);
|
| 154off_t g_stripeoffset(int); 155off_t g_stripesize(int);
|
152int g_flush(int); 153int g_delete(int, off_t, off_t); 154int g_get_ident(int, char *, size_t); 155int g_get_name(const char *, char *, size_t); 156int g_open_by_ident(const char *, int, char *, size_t); 157char *g_device_path(const char *); 158char *g_providername(int); 159 160__END_DECLS 161 162#endif /* _LIBGEOM_H_ */
| 156int g_flush(int); 157int g_delete(int, off_t, off_t); 158int g_get_ident(int, char *, size_t); 159int g_get_name(const char *, char *, size_t); 160int g_open_by_ident(const char *, int, char *, size_t); 161char *g_device_path(const char *); 162char *g_providername(int); 163 164__END_DECLS 165 166#endif /* _LIBGEOM_H_ */
|