/usr/include/rbd/librbd.h is in librbd-dev 0.79-0ubuntu1.
This file is owned by root:root, with mode 0o644.
The actual contents of the file can be viewed below.
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 150 151 152 153 154 155 156 157 158 159 160 161 162 163 164 165 166 167 168 169 170 171 172 173 174 175 176 177 178 179 180 181 182 183 184 185 186 187 188 189 190 191 192 193 194 195 196 197 198 199 200 201 202 203 204 205 206 207 208 209 210 211 212 213 214 215 216 217 218 219 220 221 222 223 224 225 226 227 228 229 230 231 232 233 234 235 236 237 238 239 240 241 242 243 244 245 246 247 248 249 250 251 252 253 254 255 256 257 258 259 260 261 262 263 264 265 266 267 268 269 270 271 272 273 274 275 276 277 278 279 280 281 282 283 284 285 286 287 288 289 290 291 292 293 294 295 296 297 298 299 300 301 302 303 304 305 306 307 308 309 310 311 312 313 314 315 316 317 318 319 320 321 322 323 324 325 326 327 328 329 330 331 332 333 334 335 336 337 338 339 340 341 342 343 344 345 346 347 348 349 350 351 352 353 354 355 356 357 358 359 360 361 362 363 364 365 366 367 368 369 370 371 372 373 374 375 376 377 378 379 380 381 382 383 | // -*- mode:C++; tab-width:8; c-basic-offset:2; indent-tabs-mode:t -*-
// vim: ts=8 sw=2 smarttab
/*
* Ceph - scalable distributed file system
*
* Copyright (C) 2011 New Dream Network
*
* This is free software; you can redistribute it and/or
* modify it under the terms of the GNU General Public
* License version 2.1, as published by the Free Software
* Foundation. See file COPYING.
*
*/
#ifndef CEPH_LIBRBD_H
#define CEPH_LIBRBD_H
#ifdef __cplusplus
extern "C" {
#endif
#include <netinet/in.h>
#if defined(__linux__)
#include <linux/types.h>
#elif defined(__FreeBSD__)
#include <sys/types.h>
#endif
#include <string.h>
#include "../rados/librados.h"
#include "features.h"
#define LIBRBD_VER_MAJOR 0
#define LIBRBD_VER_MINOR 1
#define LIBRBD_VER_EXTRA 8
#define LIBRBD_VERSION(maj, min, extra) ((maj << 16) + (min << 8) + extra)
#define LIBRBD_VERSION_CODE LIBRBD_VERSION(LIBRBD_VER_MAJOR, LIBRBD_VER_MINOR, LIBRBD_VER_EXTRA)
#define LIBRBD_SUPPORTS_WATCH 0
#define LIBRBD_SUPPORTS_AIO_FLUSH 1
typedef void *rbd_snap_t;
typedef void *rbd_image_t;
typedef int (*librbd_progress_fn_t)(uint64_t offset, uint64_t total, void *ptr);
typedef struct {
uint64_t id;
uint64_t size;
const char *name;
} rbd_snap_info_t;
#define RBD_MAX_IMAGE_NAME_SIZE 96
#define RBD_MAX_BLOCK_NAME_SIZE 24
typedef struct {
uint64_t size;
uint64_t obj_size;
uint64_t num_objs;
int order;
char block_name_prefix[RBD_MAX_BLOCK_NAME_SIZE];
int64_t parent_pool; /* deprecated */
char parent_name[RBD_MAX_IMAGE_NAME_SIZE]; /* deprecated */
} rbd_image_info_t;
void rbd_version(int *major, int *minor, int *extra);
/* images */
int rbd_list(rados_ioctx_t io, char *names, size_t *size);
int rbd_create(rados_ioctx_t io, const char *name, uint64_t size, int *order);
int rbd_create2(rados_ioctx_t io, const char *name, uint64_t size,
uint64_t features, int *order);
/**
* create new rbd image
*
* The stripe_unit must be a factor of the object size (1 << order).
* The stripe_count can be one (no intra-object striping) or greater
* than one. The RBD_FEATURE_STRIPINGV2 must be specified if the
* stripe_unit != the object size and the stripe_count is != 1.
*
* @param io ioctx
* @param name image name
* @param size image size in bytes
* @param features initial feature bits
* @param order object/block size, as a power of two (object size == 1 << order)
* @param stripe_unit stripe unit size, in bytes.
* @param stripe_count number of objects to stripe over before looping
* @return 0 on success, or negative error code
*/
int rbd_create3(rados_ioctx_t io, const char *name, uint64_t size,
uint64_t features, int *order,
uint64_t stripe_unit, uint64_t stripe_count);
int rbd_clone(rados_ioctx_t p_ioctx, const char *p_name,
const char *p_snapname, rados_ioctx_t c_ioctx,
const char *c_name, uint64_t features, int *c_order);
int rbd_clone2(rados_ioctx_t p_ioctx, const char *p_name,
const char *p_snapname, rados_ioctx_t c_ioctx,
const char *c_name, uint64_t features, int *c_order,
uint64_t stripe_unit, int stripe_count);
int rbd_remove(rados_ioctx_t io, const char *name);
int rbd_remove_with_progress(rados_ioctx_t io, const char *name,
librbd_progress_fn_t cb, void *cbdata);
int rbd_rename(rados_ioctx_t src_io_ctx, const char *srcname, const char *destname);
int rbd_open(rados_ioctx_t io, const char *name, rbd_image_t *image, const char *snap_name);
/**
* Open an image in read-only mode.
*
* This is intended for use by clients that cannot write to a block
* device due to cephx restrictions. There will be no watch
* established on the header object, since a watch is a write. This
* means the metadata reported about this image (parents, snapshots,
* size, etc.) may become stale. This should not be used for
* long-running operations, unless you can be sure that one of these
* properties changing is safe.
*
* Attempting to write to a read-only image will return -EROFS.
*
* @param io ioctx to determine the pool the image is in
* @param name image name
* @param image where to store newly opened image handle
* @param snap_name name of snapshot to open at, or NULL for no snapshot
* @returns 0 on success, negative error code on failure
*/
int rbd_open_read_only(rados_ioctx_t io, const char *name, rbd_image_t *image,
const char *snap_name);
int rbd_close(rbd_image_t image);
int rbd_resize(rbd_image_t image, uint64_t size);
int rbd_resize_with_progress(rbd_image_t image, uint64_t size,
librbd_progress_fn_t cb, void *cbdata);
int rbd_stat(rbd_image_t image, rbd_image_info_t *info, size_t infosize);
int rbd_get_old_format(rbd_image_t image, uint8_t *old);
int rbd_get_size(rbd_image_t image, uint64_t *size);
int rbd_get_features(rbd_image_t image, uint64_t *features);
int rbd_get_stripe_unit(rbd_image_t image, uint64_t *stripe_unit);
int rbd_get_stripe_count(rbd_image_t image, uint64_t *stripe_count);
int rbd_get_overlap(rbd_image_t image, uint64_t *overlap);
int rbd_get_parent_info(rbd_image_t image,
char *parent_poolname, size_t ppoolnamelen,
char *parent_name, size_t pnamelen,
char *parent_snapname, size_t psnapnamelen);
int rbd_copy(rbd_image_t image, rados_ioctx_t dest_io_ctx, const char *destname);
int rbd_copy2(rbd_image_t src, rbd_image_t dest);
int rbd_copy_with_progress(rbd_image_t image, rados_ioctx_t dest_p, const char *destname,
librbd_progress_fn_t cb, void *cbdata);
int rbd_copy_with_progress2(rbd_image_t src, rbd_image_t dest,
librbd_progress_fn_t cb, void *cbdata);
/* snapshots */
int rbd_snap_list(rbd_image_t image, rbd_snap_info_t *snaps, int *max_snaps);
void rbd_snap_list_end(rbd_snap_info_t *snaps);
int rbd_snap_create(rbd_image_t image, const char *snapname);
int rbd_snap_remove(rbd_image_t image, const char *snapname);
int rbd_snap_rollback(rbd_image_t image, const char *snapname);
int rbd_snap_rollback_with_progress(rbd_image_t image, const char *snapname,
librbd_progress_fn_t cb, void *cbdata);
/**
* Prevent a snapshot from being deleted until it is unprotected.
*
* @param snap_name which snapshot to protect
* @returns 0 on success, negative error code on failure
* @returns -EBUSY if snap is already protected
*/
int rbd_snap_protect(rbd_image_t image, const char *snap_name);
/**
* Allow a snaphshot to be deleted.
*
* @param snap_name which snapshot to unprotect
* @returns 0 on success, negative error code on failure
* @returns -EINVAL if snap is not protected
*/
int rbd_snap_unprotect(rbd_image_t image, const char *snap_name);
/**
* Determine whether a snapshot is protected.
*
* @param snap_name which snapshot query
* @param is_protected where to store the result (0 or 1)
* @returns 0 on success, negative error code on failure
*/
int rbd_snap_is_protected(rbd_image_t image, const char *snap_name,
int *is_protected);
int rbd_snap_set(rbd_image_t image, const char *snapname);
int rbd_flatten(rbd_image_t image);
/**
* List all images that are cloned from the image at the
* snapshot that is set via rbd_snap_set().
*
* This iterates over all pools, so it should be run by a user with
* read access to all of them. pools_len and images_len are filled in
* with the number of bytes put into the pools and images buffers.
*
* If the provided buffers are too short, the required lengths are
* still filled in, but the data is not and -ERANGE is returned.
* Otherwise, the buffers are filled with the pool and image names
* of the children, with a '\0' after each.
*
* @param image which image (and implicitly snapshot) to list clones of
* @param pools buffer in which to store pool names
* @param pools_len number of bytes in pools buffer
* @param images buffer in which to store image names
* @param images_len number of bytes in images buffer
* @returns number of children on success, negative error code on failure
* @returns -ERANGE if either buffer is too short
*/
ssize_t rbd_list_children(rbd_image_t image, char *pools, size_t *pools_len,
char *images, size_t *images_len);
/**
* @defgroup librbd_h_locking Advisory Locking
*
* An rbd image may be locking exclusively, or shared, to facilitate
* e.g. live migration where the image may be open in two places at once.
* These locks are intended to guard against more than one client
* writing to an image without coordination. They don't need to
* be used for snapshots, since snapshots are read-only.
*
* Currently locks only guard against locks being acquired.
* They do not prevent anything else.
*
* A locker is identified by the internal rados client id of the
* holder and a user-defined cookie. This (client id, cookie) pair
* must be unique for each locker.
*
* A shared lock also has a user-defined tag associated with it. Each
* additional shared lock must specify the same tag or lock
* acquisition will fail. This can be used by e.g. groups of hosts
* using a clustered filesystem on top of an rbd image to make sure
* they're accessing the correct image.
*
* @{
*/
/**
* List clients that have locked the image and information about the lock.
*
* The number of bytes required in each buffer is put in the
* corresponding size out parameter. If any of the provided buffers
* are too short, -ERANGE is returned after these sizes are filled in.
*
* @param exclusive where to store whether the lock is exclusive (1) or shared (0)
* @param tag where to store the tag associated with the image
* @param tag_len number of bytes in tag buffer
* @param clients buffer in which locker clients are stored, separated by '\0'
* @param clients_len number of bytes in the clients buffer
* @param cookies buffer in which locker cookies are stored, separated by '\0'
* @param cookies_len number of bytes in the cookies buffer
* @param addrs buffer in which locker addresses are stored, separated by '\0'
* @param addrs_len number of bytes in the clients buffer
* @returns number of lockers on success, negative error code on failure
* @returns -ERANGE if any of the buffers are too short
*/
ssize_t rbd_list_lockers(rbd_image_t image, int *exclusive,
char *tag, size_t *tag_len,
char *clients, size_t *clients_len,
char *cookies, size_t *cookies_len,
char *addrs, size_t *addrs_len);
/**
* Take an exclusive lock on the image.
*
* @param image the image to lock
* @param cookie user-defined identifier for this instance of the lock
* @returns 0 on success, negative error code on failure
* @returns -EBUSY if the lock is already held by another (client, cookie) pair
* @returns -EEXIST if the lock is already held by the same (client, cookie) pair
*/
int rbd_lock_exclusive(rbd_image_t image, const char *cookie);
/**
* Take a shared lock on the image.
*
* Other clients may also take a shared lock, as lock as they use the
* same tag.
*
* @param image the image to lock
* @param cookie user-defined identifier for this instance of the lock
* @param tag user-defined identifier for this shared use of the lock
* @returns 0 on success, negative error code on failure
* @returns -EBUSY if the lock is already held by another (client, cookie) pair
* @returns -EEXIST if the lock is already held by the same (client, cookie) pair
*/
int rbd_lock_shared(rbd_image_t image, const char *cookie, const char *tag);
/**
* Release a shared or exclusive lock on the image.
*
* @param image the image to unlock
* @param cookie user-defined identifier for the instance of the lock
* @returns 0 on success, negative error code on failure
* @returns -ENOENT if the lock is not held by the specified (client, cookie) pair
*/
int rbd_unlock(rbd_image_t image, const char *cookie);
/**
* Release a shared or exclusive lock that was taken by the specified client.
*
* @param image the image to unlock
* @param client the entity holding the lock (as given by rbd_list_lockers())
* @param cookie user-defined identifier for the instance of the lock to break
* @returns 0 on success, negative error code on failure
* @returns -ENOENT if the lock is not held by the specified (client, cookie) pair
*/
int rbd_break_lock(rbd_image_t image, const char *client, const char *cookie);
/** @} locking */
/* I/O */
typedef void *rbd_completion_t;
typedef void (*rbd_callback_t)(rbd_completion_t cb, void *arg);
ssize_t rbd_read(rbd_image_t image, uint64_t ofs, size_t len, char *buf);
/* DEPRECATED; use rbd_read_iterate2 */
int64_t rbd_read_iterate(rbd_image_t image, uint64_t ofs, size_t len,
int (*cb)(uint64_t, size_t, const char *, void *), void *arg);
/**
* iterate read over an image
*
* Reads each region of the image and calls the callback. If the
* buffer pointer passed to the callback is NULL, the given extent is
* defined to be zeros (a hole). Normally the granularity for the
* callback is the image stripe size.
*
* @param image image to read
* @param ofs offset to start from
* @param len bytes of source image to cover
* @param cb callback for each region
* @returns 0 success, error otherwise
*/
int rbd_read_iterate2(rbd_image_t image, uint64_t ofs, uint64_t len,
int (*cb)(uint64_t, size_t, const char *, void *), void *arg);
/**
* get difference between two versions of an image
*
* This will return the differences between two versions of an image
* via a callback, which gets the offset and length and a flag
* indicating whether the extent exists (1), or is known/defined to
* be zeros (a hole, 0). If the source snapshot name is NULL, we
* interpret that as the beginning of time and return all allocated
* regions of the image. The end version is whatever is currently
* selected for the image handle (either a snapshot or the writeable
* head).
*
* @param fromsnapname start snapshot name, or NULL
* @param ofs start offset
* @param len len in bytes of region to report on
* @param cb callback to call for each allocated region
* @param arg argument to pass to the callback
* @returns 0 on success, or negative error code on error
*/
int rbd_diff_iterate(rbd_image_t image,
const char *fromsnapname,
uint64_t ofs, uint64_t len,
int (*cb)(uint64_t, size_t, int, void *), void *arg);
ssize_t rbd_write(rbd_image_t image, uint64_t ofs, size_t len, const char *buf);
int rbd_discard(rbd_image_t image, uint64_t ofs, uint64_t len);
int rbd_aio_write(rbd_image_t image, uint64_t off, size_t len, const char *buf, rbd_completion_t c);
int rbd_aio_read(rbd_image_t image, uint64_t off, size_t len, char *buf, rbd_completion_t c);
int rbd_aio_discard(rbd_image_t image, uint64_t off, uint64_t len, rbd_completion_t c);
int rbd_aio_create_completion(void *cb_arg, rbd_callback_t complete_cb, rbd_completion_t *c);
int rbd_aio_is_complete(rbd_completion_t c);
int rbd_aio_wait_for_complete(rbd_completion_t c);
ssize_t rbd_aio_get_return_value(rbd_completion_t c);
void rbd_aio_release(rbd_completion_t c);
int rbd_flush(rbd_image_t image);
/**
* Start a flush if caching is enabled. Get a callback when
* the currently pending writes are on disk.
*
* @param image the image to flush writes to
* @param c what to call when flushing is complete
* @returns 0 on success, negative error code on failure
*/
int rbd_aio_flush(rbd_image_t image, rbd_completion_t c);
#ifdef __cplusplus
}
#endif
#endif
|