diff options
| author | Alasdair G Kergon <agk@redhat.com> | 2006-06-26 03:27:33 -0400 |
|---|---|---|
| committer | Linus Torvalds <torvalds@g5.osdl.org> | 2006-06-26 12:58:36 -0400 |
| commit | 17b2f66f2a39a4e4d1ed456f35ee3bb598e41d35 (patch) | |
| tree | 64801e095918f685fa83bface7f8289e33bb9bcd /include/linux | |
| parent | 2b06cfff12f0f87c4bc4d4c4dd76997e72c360ba (diff) | |
[PATCH] dm: add exports
Move definitions of core device-mapper functions for manipulating mapped
devices and their tables to <linux/device-mapper.h> advertising their
availability for use elsewhere in the kernel.
Protect the contents of device-mapper.h with ifdef __KERNEL__. And throw
in a few formatting clean-ups and extra comments.
Signed-off-by: Alasdair G Kergon <agk@redhat.com>
Signed-off-by: Andrew Morton <akpm@osdl.org>
Signed-off-by: Linus Torvalds <torvalds@osdl.org>
Diffstat (limited to 'include/linux')
| -rw-r--r-- | include/linux/device-mapper.h | 104 |
1 files changed, 102 insertions, 2 deletions
diff --git a/include/linux/device-mapper.h b/include/linux/device-mapper.h index aee10b2ea4c6..010c8c5eeb37 100644 --- a/include/linux/device-mapper.h +++ b/include/linux/device-mapper.h | |||
| @@ -8,9 +8,12 @@ | |||
| 8 | #ifndef _LINUX_DEVICE_MAPPER_H | 8 | #ifndef _LINUX_DEVICE_MAPPER_H |
| 9 | #define _LINUX_DEVICE_MAPPER_H | 9 | #define _LINUX_DEVICE_MAPPER_H |
| 10 | 10 | ||
| 11 | #ifdef __KERNEL__ | ||
| 12 | |||
| 11 | struct dm_target; | 13 | struct dm_target; |
| 12 | struct dm_table; | 14 | struct dm_table; |
| 13 | struct dm_dev; | 15 | struct dm_dev; |
| 16 | struct mapped_device; | ||
| 14 | 17 | ||
| 15 | typedef enum { STATUSTYPE_INFO, STATUSTYPE_TABLE } status_type_t; | 18 | typedef enum { STATUSTYPE_INFO, STATUSTYPE_TABLE } status_type_t; |
| 16 | 19 | ||
| @@ -78,7 +81,7 @@ void dm_put_device(struct dm_target *ti, struct dm_dev *d); | |||
| 78 | struct target_type { | 81 | struct target_type { |
| 79 | const char *name; | 82 | const char *name; |
| 80 | struct module *module; | 83 | struct module *module; |
| 81 | unsigned version[3]; | 84 | unsigned version[3]; |
| 82 | dm_ctr_fn ctr; | 85 | dm_ctr_fn ctr; |
| 83 | dm_dtr_fn dtr; | 86 | dm_dtr_fn dtr; |
| 84 | dm_map_fn map; | 87 | dm_map_fn map; |
| @@ -128,4 +131,101 @@ struct dm_target { | |||
| 128 | int dm_register_target(struct target_type *t); | 131 | int dm_register_target(struct target_type *t); |
| 129 | int dm_unregister_target(struct target_type *t); | 132 | int dm_unregister_target(struct target_type *t); |
| 130 | 133 | ||
| 131 | #endif /* _LINUX_DEVICE_MAPPER_H */ | 134 | |
| 135 | /*----------------------------------------------------------------- | ||
| 136 | * Functions for creating and manipulating mapped devices. | ||
| 137 | * Drop the reference with dm_put when you finish with the object. | ||
| 138 | *---------------------------------------------------------------*/ | ||
| 139 | |||
| 140 | /* | ||
| 141 | * DM_ANY_MINOR chooses the next available minor number. | ||
| 142 | */ | ||
| 143 | #define DM_ANY_MINOR (-1) | ||
| 144 | int dm_create(int minor, struct mapped_device **md); | ||
| 145 | |||
| 146 | /* | ||
| 147 | * Reference counting for md. | ||
| 148 | */ | ||
| 149 | struct mapped_device *dm_get_md(dev_t dev); | ||
| 150 | void dm_get(struct mapped_device *md); | ||
| 151 | void dm_put(struct mapped_device *md); | ||
| 152 | |||
| 153 | /* | ||
| 154 | * An arbitrary pointer may be stored alongside a mapped device. | ||
| 155 | */ | ||
| 156 | void dm_set_mdptr(struct mapped_device *md, void *ptr); | ||
| 157 | void *dm_get_mdptr(struct mapped_device *md); | ||
| 158 | |||
| 159 | /* | ||
| 160 | * A device can still be used while suspended, but I/O is deferred. | ||
| 161 | */ | ||
| 162 | int dm_suspend(struct mapped_device *md, int with_lockfs); | ||
| 163 | int dm_resume(struct mapped_device *md); | ||
| 164 | |||
| 165 | /* | ||
| 166 | * Event functions. | ||
| 167 | */ | ||
| 168 | uint32_t dm_get_event_nr(struct mapped_device *md); | ||
| 169 | int dm_wait_event(struct mapped_device *md, int event_nr); | ||
| 170 | |||
| 171 | /* | ||
| 172 | * Info functions. | ||
| 173 | */ | ||
| 174 | struct gendisk *dm_disk(struct mapped_device *md); | ||
| 175 | int dm_suspended(struct mapped_device *md); | ||
| 176 | |||
| 177 | /* | ||
| 178 | * Geometry functions. | ||
| 179 | */ | ||
| 180 | int dm_get_geometry(struct mapped_device *md, struct hd_geometry *geo); | ||
| 181 | int dm_set_geometry(struct mapped_device *md, struct hd_geometry *geo); | ||
| 182 | |||
| 183 | |||
| 184 | /*----------------------------------------------------------------- | ||
| 185 | * Functions for manipulating device-mapper tables. | ||
| 186 | *---------------------------------------------------------------*/ | ||
| 187 | |||
| 188 | /* | ||
| 189 | * First create an empty table. | ||
| 190 | */ | ||
| 191 | int dm_table_create(struct dm_table **result, int mode, | ||
| 192 | unsigned num_targets, struct mapped_device *md); | ||
| 193 | |||
| 194 | /* | ||
| 195 | * Then call this once for each target. | ||
| 196 | */ | ||
| 197 | int dm_table_add_target(struct dm_table *t, const char *type, | ||
| 198 | sector_t start, sector_t len, char *params); | ||
| 199 | |||
| 200 | /* | ||
| 201 | * Finally call this to make the table ready for use. | ||
| 202 | */ | ||
| 203 | int dm_table_complete(struct dm_table *t); | ||
| 204 | |||
| 205 | /* | ||
| 206 | * Table reference counting. | ||
| 207 | */ | ||
| 208 | struct dm_table *dm_get_table(struct mapped_device *md); | ||
| 209 | void dm_table_get(struct dm_table *t); | ||
| 210 | void dm_table_put(struct dm_table *t); | ||
| 211 | |||
| 212 | /* | ||
| 213 | * Queries | ||
| 214 | */ | ||
| 215 | sector_t dm_table_get_size(struct dm_table *t); | ||
| 216 | unsigned int dm_table_get_num_targets(struct dm_table *t); | ||
| 217 | int dm_table_get_mode(struct dm_table *t); | ||
| 218 | struct mapped_device *dm_table_get_md(struct dm_table *t); | ||
| 219 | |||
| 220 | /* | ||
| 221 | * Trigger an event. | ||
| 222 | */ | ||
| 223 | void dm_table_event(struct dm_table *t); | ||
| 224 | |||
| 225 | /* | ||
| 226 | * The device must be suspended before calling this method. | ||
| 227 | */ | ||
| 228 | int dm_swap_table(struct mapped_device *md, struct dm_table *t); | ||
| 229 | |||
| 230 | #endif /* __KERNEL__ */ | ||
| 231 | #endif /* _LINUX_DEVICE_MAPPER_H */ | ||
