| 
									
										
										
										
											2017-03-20 18:26:50 +00:00
										 |  |  | /*-
 | 
					
						
							|  |  |  |  *   BSD LICENSE | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  *   Copyright (c) Intel Corporation. | 
					
						
							|  |  |  |  *   All rights reserved. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  *   Redistribution and use in source and binary forms, with or without | 
					
						
							|  |  |  |  *   modification, are permitted provided that the following conditions | 
					
						
							|  |  |  |  *   are met: | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  *     * Redistributions of source code must retain the above copyright | 
					
						
							|  |  |  |  *       notice, this list of conditions and the following disclaimer. | 
					
						
							|  |  |  |  *     * Redistributions in binary form must reproduce the above copyright | 
					
						
							|  |  |  |  *       notice, this list of conditions and the following disclaimer in | 
					
						
							|  |  |  |  *       the documentation and/or other materials provided with the | 
					
						
							|  |  |  |  *       distribution. | 
					
						
							|  |  |  |  *     * Neither the name of Intel Corporation nor the names of its | 
					
						
							|  |  |  |  *       contributors may be used to endorse or promote products derived | 
					
						
							|  |  |  |  *       from this software without specific prior written permission. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  *   THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS | 
					
						
							|  |  |  |  *   "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT | 
					
						
							|  |  |  |  *   LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR | 
					
						
							|  |  |  |  *   A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT | 
					
						
							|  |  |  |  *   OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, | 
					
						
							|  |  |  |  *   SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT | 
					
						
							|  |  |  |  *   LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, | 
					
						
							|  |  |  |  *   DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY | 
					
						
							|  |  |  |  *   THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT | 
					
						
							|  |  |  |  *   (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE | 
					
						
							|  |  |  |  *   OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /** \file
 | 
					
						
							|  |  |  |  * Blob Storage System | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * The blob storage system, or the blobstore for short, is a low level | 
					
						
							|  |  |  |  * library for placing opaque blobs of data onto a storage device such | 
					
						
							|  |  |  |  * that scattered physical blocks on the storage device appear as a | 
					
						
							|  |  |  |  * single, contiguous storage region. These blobs are also persistent, | 
					
						
							|  |  |  |  * which means they are rediscoverable after reboot or power loss. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * The blobstore is designed to be very high performance, and thus has | 
					
						
							|  |  |  |  * a few general rules regarding thread safety to avoid taking locks | 
					
						
							| 
									
										
										
										
											2018-02-21 20:54:53 +00:00
										 |  |  |  * in the I/O path.  This is primarily done by only allowing most | 
					
						
							|  |  |  |  * functions to be called on the metadata thread.  The metadata thread is | 
					
						
							|  |  |  |  * the thread which called spdk_bs_init() or spdk_bs_load(). | 
					
						
							| 
									
										
										
										
											2017-03-20 18:26:50 +00:00
										 |  |  |  * | 
					
						
							| 
									
										
										
										
											2018-02-21 21:37:37 +00:00
										 |  |  |  * Functions starting with the prefix "spdk_blob_io" are passed a channel | 
					
						
							| 
									
										
										
										
											2017-03-20 18:26:50 +00:00
										 |  |  |  * as an argument, and channels may only be used from the thread they were | 
					
						
							| 
									
										
										
										
											2018-02-21 20:54:53 +00:00
										 |  |  |  * created on. See \ref spdk_bs_alloc_io_channel.  These are the only | 
					
						
							|  |  |  |  * functions that may be called from a thread other than the metadata | 
					
						
							|  |  |  |  * thread. | 
					
						
							| 
									
										
										
										
											2017-03-20 18:26:50 +00:00
										 |  |  |  * | 
					
						
							| 
									
										
										
										
											2017-12-13 02:52:07 +00:00
										 |  |  |  * The blobstore returns errors using negated POSIX errno values, either | 
					
						
							| 
									
										
										
										
											2017-03-20 18:26:50 +00:00
										 |  |  |  * returned in the callback or as a return value. An errno value of 0 means | 
					
						
							|  |  |  |  * success. | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #ifndef SPDK_BLOB_H
 | 
					
						
							|  |  |  | #define SPDK_BLOB_H
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-05-01 20:22:48 +00:00
										 |  |  | #include "spdk/stdinc.h"
 | 
					
						
							| 
									
										
										
										
											2017-03-20 18:26:50 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-12-07 20:25:19 +00:00
										 |  |  | #ifdef __cplusplus
 | 
					
						
							|  |  |  | extern "C" { | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-03-20 18:26:50 +00:00
										 |  |  | typedef uint64_t spdk_blob_id; | 
					
						
							|  |  |  | #define SPDK_BLOBID_INVALID	(uint64_t)-1
 | 
					
						
							| 
									
										
										
										
											2017-09-27 13:03:23 +00:00
										 |  |  | #define SPDK_BLOBSTORE_TYPE_LENGTH 16
 | 
					
						
							| 
									
										
										
										
											2017-03-20 18:26:50 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | struct spdk_blob_store; | 
					
						
							|  |  |  | struct spdk_io_channel; | 
					
						
							|  |  |  | struct spdk_blob; | 
					
						
							|  |  |  | struct spdk_xattr_names; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | typedef void (*spdk_bs_op_complete)(void *cb_arg, int bserrno); | 
					
						
							|  |  |  | typedef void (*spdk_bs_op_with_handle_complete)(void *cb_arg, struct spdk_blob_store *bs, | 
					
						
							|  |  |  | 		int bserrno); | 
					
						
							|  |  |  | typedef void (*spdk_blob_op_complete)(void *cb_arg, int bserrno); | 
					
						
							|  |  |  | typedef void (*spdk_blob_op_with_id_complete)(void *cb_arg, spdk_blob_id blobid, int bserrno); | 
					
						
							|  |  |  | typedef void (*spdk_blob_op_with_handle_complete)(void *cb_arg, struct spdk_blob *blb, int bserrno); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /* Calls to function pointers of this type must obey all of the normal
 | 
					
						
							|  |  |  |    rules for channels. The channel passed to this completion must match | 
					
						
							|  |  |  |    the channel the operation was initiated on. */ | 
					
						
							|  |  |  | typedef void (*spdk_bs_dev_cpl)(struct spdk_io_channel *channel, | 
					
						
							|  |  |  | 				void *cb_arg, int bserrno); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | struct spdk_bs_dev_cb_args { | 
					
						
							|  |  |  | 	spdk_bs_dev_cpl		cb_fn; | 
					
						
							|  |  |  | 	struct spdk_io_channel	*channel; | 
					
						
							|  |  |  | 	void			*cb_arg; | 
					
						
							|  |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | struct spdk_bs_dev { | 
					
						
							|  |  |  | 	/* Create a new channel which is a software construct that is used
 | 
					
						
							|  |  |  | 	 * to submit I/O. */ | 
					
						
							|  |  |  | 	struct spdk_io_channel *(*create_channel)(struct spdk_bs_dev *dev); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	/* Destroy a previously created channel */ | 
					
						
							|  |  |  | 	void (*destroy_channel)(struct spdk_bs_dev *dev, struct spdk_io_channel *channel); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	/* Destroy this blobstore device.  Applications must not destroy the blobstore device,
 | 
					
						
							|  |  |  | 	 *  rather the blobstore will destroy it using this function pointer once all | 
					
						
							|  |  |  | 	 *  references to it during unload callback context have been completed. | 
					
						
							|  |  |  | 	 */ | 
					
						
							|  |  |  | 	void (*destroy)(struct spdk_bs_dev *dev); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	void (*read)(struct spdk_bs_dev *dev, struct spdk_io_channel *channel, void *payload, | 
					
						
							|  |  |  | 		     uint64_t lba, uint32_t lba_count, | 
					
						
							|  |  |  | 		     struct spdk_bs_dev_cb_args *cb_args); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	void (*write)(struct spdk_bs_dev *dev, struct spdk_io_channel *channel, void *payload, | 
					
						
							|  |  |  | 		      uint64_t lba, uint32_t lba_count, | 
					
						
							|  |  |  | 		      struct spdk_bs_dev_cb_args *cb_args); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-08-18 16:41:26 +00:00
										 |  |  | 	void (*readv)(struct spdk_bs_dev *dev, struct spdk_io_channel *channel, | 
					
						
							|  |  |  | 		      struct iovec *iov, int iovcnt, | 
					
						
							|  |  |  | 		      uint64_t lba, uint32_t lba_count, | 
					
						
							|  |  |  | 		      struct spdk_bs_dev_cb_args *cb_args); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	void (*writev)(struct spdk_bs_dev *dev, struct spdk_io_channel *channel, | 
					
						
							|  |  |  | 		       struct iovec *iov, int iovcnt, | 
					
						
							|  |  |  | 		       uint64_t lba, uint32_t lba_count, | 
					
						
							|  |  |  | 		       struct spdk_bs_dev_cb_args *cb_args); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-03-20 18:26:50 +00:00
										 |  |  | 	void (*flush)(struct spdk_bs_dev *dev, struct spdk_io_channel *channel, | 
					
						
							|  |  |  | 		      struct spdk_bs_dev_cb_args *cb_args); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-07-27 17:58:51 +00:00
										 |  |  | 	void (*write_zeroes)(struct spdk_bs_dev *dev, struct spdk_io_channel *channel, | 
					
						
							|  |  |  | 			     uint64_t lba, uint32_t lba_count, | 
					
						
							|  |  |  | 			     struct spdk_bs_dev_cb_args *cb_args); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-03-20 18:26:50 +00:00
										 |  |  | 	void (*unmap)(struct spdk_bs_dev *dev, struct spdk_io_channel *channel, | 
					
						
							|  |  |  | 		      uint64_t lba, uint32_t lba_count, | 
					
						
							|  |  |  | 		      struct spdk_bs_dev_cb_args *cb_args); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	uint64_t	blockcnt; | 
					
						
							|  |  |  | 	uint32_t	blocklen; /* In bytes */ | 
					
						
							|  |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-09-27 13:03:23 +00:00
										 |  |  | struct spdk_bs_type { | 
					
						
							|  |  |  | 	char bstype[SPDK_BLOBSTORE_TYPE_LENGTH]; | 
					
						
							|  |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-03-20 18:26:50 +00:00
										 |  |  | struct spdk_bs_opts { | 
					
						
							| 
									
										
										
										
											2018-02-15 20:51:38 +00:00
										 |  |  | 	/** Size of cluster in bytes. Must be multiple of 4KiB page size. */ | 
					
						
							|  |  |  | 	uint32_t cluster_sz; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	/** Count of the number of pages reserved for metadata */ | 
					
						
							|  |  |  | 	uint32_t num_md_pages; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	/** Maximum simultaneous metadata operations */ | 
					
						
							|  |  |  | 	uint32_t max_md_ops; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	/** Maximum simultaneous operations per channel */ | 
					
						
							|  |  |  | 	uint32_t max_channel_ops; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	/** Blobstore type */ | 
					
						
							|  |  |  | 	struct spdk_bs_type bstype; | 
					
						
							| 
									
										
										
										
											2018-02-15 20:46:41 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	/** Callback function to invoke for each blob. */ | 
					
						
							|  |  |  | 	spdk_blob_op_with_handle_complete iter_cb_fn; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	/** Argument passed to iter_cb_fn for each blob. */ | 
					
						
							|  |  |  | 	void *iter_cb_arg; | 
					
						
							| 
									
										
										
										
											2017-03-20 18:26:50 +00:00
										 |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-12-13 02:52:07 +00:00
										 |  |  | /**
 | 
					
						
							|  |  |  |  * Initialize a spdk_bs_opts structure to the default blobstore option values. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * \param opts The spdk_bs_opts structure to be initialized. | 
					
						
							|  |  |  |  */ | 
					
						
							| 
									
										
										
										
											2017-03-20 18:26:50 +00:00
										 |  |  | void spdk_bs_opts_init(struct spdk_bs_opts *opts); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-12-13 02:52:07 +00:00
										 |  |  | /**
 | 
					
						
							|  |  |  |  * Load a blobstore from the given device. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * \param dev Blobstore block device. | 
					
						
							|  |  |  |  * \param opts The structure which contains the option values for the blobstore. | 
					
						
							|  |  |  |  * \param cb_fn Called when the loading is complete. | 
					
						
							|  |  |  |  * \param cb_arg Argument passed to function cb_fn. | 
					
						
							|  |  |  |  */ | 
					
						
							| 
									
										
										
										
											2017-09-27 13:03:23 +00:00
										 |  |  | void spdk_bs_load(struct spdk_bs_dev *dev, struct spdk_bs_opts *opts, | 
					
						
							| 
									
										
										
										
											2017-03-20 18:26:50 +00:00
										 |  |  | 		  spdk_bs_op_with_handle_complete cb_fn, void *cb_arg); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-12-13 02:52:07 +00:00
										 |  |  | /**
 | 
					
						
							|  |  |  |  * Initialize a blobstore on the given device. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * \param dev Blobstore block device. | 
					
						
							|  |  |  |  * \param opts The structure which contains the option values for the blobstore. | 
					
						
							|  |  |  |  * \param cb_fn Called when the initialization is complete. | 
					
						
							|  |  |  |  * \param cb_arg Argument passed to function cb_fn. | 
					
						
							|  |  |  |  */ | 
					
						
							| 
									
										
										
										
											2017-03-20 18:26:50 +00:00
										 |  |  | void spdk_bs_init(struct spdk_bs_dev *dev, struct spdk_bs_opts *opts, | 
					
						
							|  |  |  | 		  spdk_bs_op_with_handle_complete cb_fn, void *cb_arg); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-12-13 02:52:07 +00:00
										 |  |  | /**
 | 
					
						
							|  |  |  |  * Destroy the blobstore. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * It will destroy the blobstore by zeroing the super block. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * \param bs blobstore to destroy. | 
					
						
							|  |  |  |  * \param cb_fn Called when the destruction is complete. | 
					
						
							|  |  |  |  * \param cb_arg Argument passed to function cb_fn. | 
					
						
							| 
									
										
										
										
											2017-10-20 12:52:19 +00:00
										 |  |  |  */ | 
					
						
							| 
									
										
										
										
											2017-12-04 18:05:49 +00:00
										 |  |  | void spdk_bs_destroy(struct spdk_blob_store *bs, spdk_bs_op_complete cb_fn, | 
					
						
							| 
									
										
										
										
											2017-10-20 12:52:19 +00:00
										 |  |  | 		     void *cb_arg); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-12-13 02:52:07 +00:00
										 |  |  | /**
 | 
					
						
							|  |  |  |  * Unload the blobstore. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * It will flush all volatile data to disk. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * \param bs blobstore to unload. | 
					
						
							|  |  |  |  * \param cb_fn Called when the unloading is complete. | 
					
						
							|  |  |  |  * \param cb_arg Argument passed to function cb_fn. | 
					
						
							|  |  |  |  */ | 
					
						
							| 
									
										
										
										
											2017-03-20 18:26:50 +00:00
										 |  |  | void spdk_bs_unload(struct spdk_blob_store *bs, spdk_bs_op_complete cb_fn, void *cb_arg); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-12-13 02:52:07 +00:00
										 |  |  | /**
 | 
					
						
							|  |  |  |  * Set a super blob on the given blobstore. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * This will be retrievable immediately after spdk_bs_load() on the next initializaiton. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * \param bs blobstore. | 
					
						
							|  |  |  |  * \param blobid The id of the blob which will be set as the super blob. | 
					
						
							|  |  |  |  * \param cb_fn Called when the setting is complete. | 
					
						
							|  |  |  |  * \param cb_arg Argument passed to function cb_fn. | 
					
						
							| 
									
										
										
										
											2017-03-20 18:26:50 +00:00
										 |  |  |  */ | 
					
						
							|  |  |  | void spdk_bs_set_super(struct spdk_blob_store *bs, spdk_blob_id blobid, | 
					
						
							|  |  |  | 		       spdk_bs_op_complete cb_fn, void *cb_arg); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-12-13 02:52:07 +00:00
										 |  |  | /**
 | 
					
						
							|  |  |  |  * Get the super blob. The obtained blob id will be passed to the callback function. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * \param bs blobstore. | 
					
						
							|  |  |  |  * \param cb_fn Called when the operation is complete. | 
					
						
							|  |  |  |  * \param cb_arg Argument passed to function cb_fn. | 
					
						
							|  |  |  |  */ | 
					
						
							| 
									
										
										
										
											2017-03-20 18:26:50 +00:00
										 |  |  | void spdk_bs_get_super(struct spdk_blob_store *bs, | 
					
						
							|  |  |  | 		       spdk_blob_op_with_id_complete cb_fn, void *cb_arg); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-12-13 02:52:07 +00:00
										 |  |  | /**
 | 
					
						
							|  |  |  |  * Get the cluster size in bytes. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * \param bs blobstore to query. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * \return cluster size. | 
					
						
							|  |  |  |  */ | 
					
						
							| 
									
										
										
										
											2017-03-20 18:26:50 +00:00
										 |  |  | uint64_t spdk_bs_get_cluster_size(struct spdk_blob_store *bs); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-12-13 02:52:07 +00:00
										 |  |  | /**
 | 
					
						
							|  |  |  |  * Get the page size in bytes. This is the write and read granularity of blobs. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * \param bs blobstore to query. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * \return page size. | 
					
						
							|  |  |  |  */ | 
					
						
							| 
									
										
										
										
											2017-03-20 18:26:50 +00:00
										 |  |  | uint64_t spdk_bs_get_page_size(struct spdk_blob_store *bs); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-12-13 02:52:07 +00:00
										 |  |  | /**
 | 
					
						
							|  |  |  |  * Get the number of free clusters. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * \param bs blobstore to query. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * \return the number of free clusters. | 
					
						
							|  |  |  |  */ | 
					
						
							| 
									
										
										
										
											2017-03-20 18:26:50 +00:00
										 |  |  | uint64_t spdk_bs_free_cluster_count(struct spdk_blob_store *bs); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-12-13 02:52:07 +00:00
										 |  |  | /**
 | 
					
						
							|  |  |  |  * Get the total number of clusters accessible by user. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * \param bs blobstore to query. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * \return the total number of clusters accessible by user. | 
					
						
							|  |  |  |  */ | 
					
						
							| 
									
										
										
										
											2017-11-08 13:41:37 +00:00
										 |  |  | uint64_t spdk_bs_total_data_cluster_count(struct spdk_blob_store *bs); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-12-13 02:52:07 +00:00
										 |  |  | /**
 | 
					
						
							|  |  |  |  * Get the blob id. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * \param blob Blob struct to query. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * \return blob id. | 
					
						
							|  |  |  |  */ | 
					
						
							| 
									
										
										
										
											2017-03-20 18:26:50 +00:00
										 |  |  | spdk_blob_id spdk_blob_get_id(struct spdk_blob *blob); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-12-13 02:52:07 +00:00
										 |  |  | /**
 | 
					
						
							|  |  |  |  * Get the number of pages allocated to the blob. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * \param blob Blob struct to query. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * \return the number of pages. | 
					
						
							|  |  |  |  */ | 
					
						
							| 
									
										
										
										
											2017-03-20 18:26:50 +00:00
										 |  |  | uint64_t spdk_blob_get_num_pages(struct spdk_blob *blob); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-12-13 02:52:07 +00:00
										 |  |  | /**
 | 
					
						
							|  |  |  |  * Get the number of clusters allocated to the blob. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * \param blob Blob struct to query. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * \return the number of clusters. | 
					
						
							|  |  |  |  */ | 
					
						
							| 
									
										
										
										
											2017-03-20 18:26:50 +00:00
										 |  |  | uint64_t spdk_blob_get_num_clusters(struct spdk_blob *blob); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-01-29 09:25:43 +00:00
										 |  |  | struct spdk_blob_xattr_opts { | 
					
						
							| 
									
										
										
										
											2017-12-11 09:30:21 +00:00
										 |  |  | 	/* Number of attributes */ | 
					
						
							| 
									
										
										
										
											2018-01-29 09:25:43 +00:00
										 |  |  | 	size_t	count; | 
					
						
							| 
									
										
										
										
											2017-12-11 09:30:21 +00:00
										 |  |  | 	/* Array of attribute names. Caller should free this array after use. */ | 
					
						
							| 
									
										
										
										
											2018-01-29 09:25:43 +00:00
										 |  |  | 	char	**names; | 
					
						
							| 
									
										
										
										
											2017-12-11 09:30:21 +00:00
										 |  |  | 	/* User context passed to get_xattr_value function */ | 
					
						
							| 
									
										
										
										
											2018-01-29 09:25:43 +00:00
										 |  |  | 	void	*ctx; | 
					
						
							| 
									
										
										
										
											2017-12-11 09:30:21 +00:00
										 |  |  | 	/* Callback that will return value for each attribute name. */ | 
					
						
							| 
									
										
										
										
											2018-01-29 09:25:43 +00:00
										 |  |  | 	void	(*get_value)(void *xattr_ctx, const char *name, | 
					
						
							|  |  |  | 			     const void **value, size_t *value_len); | 
					
						
							|  |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | struct spdk_blob_opts { | 
					
						
							|  |  |  | 	uint64_t  num_clusters; | 
					
						
							|  |  |  | 	bool	thin_provision; | 
					
						
							|  |  |  | 	struct spdk_blob_xattr_opts xattrs; | 
					
						
							| 
									
										
										
										
											2017-12-06 13:06:13 +00:00
										 |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-12-13 02:52:07 +00:00
										 |  |  | /**
 | 
					
						
							|  |  |  |  * Initialize a spdk_blob_opts structure to the default blob option values. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * \param opts spdk_blob_opts structure to initialize. | 
					
						
							|  |  |  |  */ | 
					
						
							| 
									
										
										
										
											2017-12-06 13:06:13 +00:00
										 |  |  | void spdk_blob_opts_init(struct spdk_blob_opts *opts); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-12-13 02:52:07 +00:00
										 |  |  | /**
 | 
					
						
							|  |  |  |  * Create a new blob with options on the given blobstore. The new blob id will | 
					
						
							|  |  |  |  * be passed to the callback function. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * \param bs blobstore. | 
					
						
							|  |  |  |  * \param opts The structure which contains the option values for the new blob. | 
					
						
							|  |  |  |  * \param cb_fn Called when the operation is complete. | 
					
						
							|  |  |  |  * \param cb_arg Argument passed to funcion cb_fn. | 
					
						
							|  |  |  |  */ | 
					
						
							| 
									
										
										
										
											2017-12-06 13:06:13 +00:00
										 |  |  | void spdk_bs_create_blob_ext(struct spdk_blob_store *bs, const struct spdk_blob_opts *opts, | 
					
						
							|  |  |  | 			     spdk_blob_op_with_id_complete cb_fn, void *cb_arg); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-12-13 02:52:07 +00:00
										 |  |  | /**
 | 
					
						
							|  |  |  |  * Create a new blob with default option values on the given blobstore. | 
					
						
							|  |  |  |  * The new blob id will be passed to the callback function. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * \param bs blobstore. | 
					
						
							|  |  |  |  * \param cb_fn Called when the operation is complete. | 
					
						
							|  |  |  |  * \param cb_arg Argument passed to function cb_fn. | 
					
						
							|  |  |  |  */ | 
					
						
							| 
									
										
										
										
											2017-12-08 21:09:12 +00:00
										 |  |  | void spdk_bs_create_blob(struct spdk_blob_store *bs, | 
					
						
							|  |  |  | 			 spdk_blob_op_with_id_complete cb_fn, void *cb_arg); | 
					
						
							| 
									
										
										
										
											2017-03-20 18:26:50 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-12-13 02:52:07 +00:00
										 |  |  | /**
 | 
					
						
							|  |  |  |  * Delete an existing blob from the given blobstore. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * \param bs blobstore. | 
					
						
							|  |  |  |  * \param blobid The id of the blob to delete. | 
					
						
							|  |  |  |  * \param cb_fn Called when the operation is complete. | 
					
						
							|  |  |  |  * \param cb_arg Argument passed to function cb_fn. | 
					
						
							|  |  |  |  */ | 
					
						
							| 
									
										
										
										
											2017-12-08 21:09:12 +00:00
										 |  |  | void spdk_bs_delete_blob(struct spdk_blob_store *bs, spdk_blob_id blobid, | 
					
						
							|  |  |  | 			 spdk_blob_op_complete cb_fn, void *cb_arg); | 
					
						
							| 
									
										
										
										
											2017-03-20 18:26:50 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-12-13 02:52:07 +00:00
										 |  |  | /**
 | 
					
						
							|  |  |  |  * Open a blob from the given blobstore. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * \param bs blobstore. | 
					
						
							|  |  |  |  * \param blobid The id of the blob to open. | 
					
						
							|  |  |  |  * \param cb_fn Called when the operation is complete. | 
					
						
							|  |  |  |  * \param cb_arg Argument passed to function cb_fn. | 
					
						
							|  |  |  |  */ | 
					
						
							| 
									
										
										
										
											2017-12-08 21:09:12 +00:00
										 |  |  | void spdk_bs_open_blob(struct spdk_blob_store *bs, spdk_blob_id blobid, | 
					
						
							|  |  |  | 		       spdk_blob_op_with_handle_complete cb_fn, void *cb_arg); | 
					
						
							| 
									
										
										
										
											2017-03-20 18:26:50 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-12-13 02:52:07 +00:00
										 |  |  | /**
 | 
					
						
							|  |  |  |  * Resize a blob to 'sz' clusters. These changes are not persisted to disk until | 
					
						
							|  |  |  |  * spdk_bs_md_sync_blob() is called. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * \param blob Blob to resize. | 
					
						
							|  |  |  |  * \param sz The new number of clusters. | 
					
						
							| 
									
										
										
										
											2017-03-20 18:26:50 +00:00
										 |  |  |  * | 
					
						
							| 
									
										
										
										
											2017-12-13 02:52:07 +00:00
										 |  |  |  * \return 0 on success, negative errno on failure. | 
					
						
							|  |  |  |  */ | 
					
						
							| 
									
										
										
										
											2017-12-08 16:38:33 +00:00
										 |  |  | int spdk_blob_resize(struct spdk_blob *blob, size_t sz); | 
					
						
							| 
									
										
										
										
											2017-03-20 18:26:50 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-12-13 02:52:07 +00:00
										 |  |  | /**
 | 
					
						
							|  |  |  |  * Set blob as read only. | 
					
						
							| 
									
										
										
										
											2018-01-10 15:46:10 +00:00
										 |  |  |  * | 
					
						
							| 
									
										
										
										
											2017-12-13 02:52:07 +00:00
										 |  |  |  * These changes do not take effect until spdk_blob_sync_md() is called. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * \param blob Blob to set. | 
					
						
							|  |  |  |  */ | 
					
						
							| 
									
										
										
										
											2018-02-21 21:24:02 +00:00
										 |  |  | int spdk_blob_set_read_only(struct spdk_blob *blob); | 
					
						
							| 
									
										
										
										
											2017-12-11 09:20:49 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-12-13 02:52:07 +00:00
										 |  |  | /**
 | 
					
						
							|  |  |  |  * Sync a blob. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * Make a blob persistent. This applies to open, resize, set xattr, and remove | 
					
						
							|  |  |  |  * xattr. These operations will not be persistent until the blob has been synced. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * \param blob Blob to sync. | 
					
						
							|  |  |  |  * \param cb_fn Called when the operation is complete. | 
					
						
							|  |  |  |  * \param cb_arg Argument passed to function cb_fn. | 
					
						
							| 
									
										
										
										
											2017-03-20 18:26:50 +00:00
										 |  |  |  */ | 
					
						
							| 
									
										
										
										
											2017-12-08 16:38:33 +00:00
										 |  |  | void spdk_blob_sync_md(struct spdk_blob *blob, spdk_blob_op_complete cb_fn, void *cb_arg); | 
					
						
							| 
									
										
										
										
											2017-03-20 18:26:50 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-12-13 02:52:07 +00:00
										 |  |  | /**
 | 
					
						
							|  |  |  |  * Close a blob. This will automatically sync. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * \param blob Blob to close. | 
					
						
							|  |  |  |  * \param cb_fn Called when the operation is complete. | 
					
						
							|  |  |  |  * \param cb_arg Argument passed to function cb_fn. | 
					
						
							|  |  |  |  */ | 
					
						
							| 
									
										
										
										
											2017-12-12 20:42:56 +00:00
										 |  |  | void spdk_blob_close(struct spdk_blob *blob, spdk_blob_op_complete cb_fn, void *cb_arg); | 
					
						
							| 
									
										
										
										
											2017-03-20 18:26:50 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-12-13 02:52:07 +00:00
										 |  |  | /**
 | 
					
						
							|  |  |  |  * Allocate an I/O channel for the given blobstore. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * \param bs blobstore. | 
					
						
							|  |  |  |  * \return a pointer to the allocated I/O channel. | 
					
						
							|  |  |  |  */ | 
					
						
							| 
									
										
										
										
											2017-05-18 17:48:04 +00:00
										 |  |  | struct spdk_io_channel *spdk_bs_alloc_io_channel(struct spdk_blob_store *bs); | 
					
						
							| 
									
										
										
										
											2017-03-20 18:26:50 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-12-13 02:52:07 +00:00
										 |  |  | /**
 | 
					
						
							|  |  |  |  * Free the I/O channel. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * \param channel I/O channel to free. | 
					
						
							|  |  |  |  */ | 
					
						
							| 
									
										
										
										
											2017-03-20 18:26:50 +00:00
										 |  |  | void spdk_bs_free_io_channel(struct spdk_io_channel *channel); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-12-13 02:52:07 +00:00
										 |  |  | /**
 | 
					
						
							|  |  |  |  * Write data to a blob. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * \param blob Blob to write. | 
					
						
							|  |  |  |  * \param channel The I/O channel used to submit requests. | 
					
						
							|  |  |  |  * \param payload The specified buffer which should contain the data to be written. | 
					
						
							|  |  |  |  * \param offset Offset is in pages from the beginning of the blob. | 
					
						
							|  |  |  |  * \param length Size of data in pages. | 
					
						
							|  |  |  |  * \param cb_fn Called when the operation is complete. | 
					
						
							|  |  |  |  * \param cb_arg Argument passed to function cb_fn. | 
					
						
							|  |  |  |  */ | 
					
						
							| 
									
										
										
										
											2018-02-21 21:37:37 +00:00
										 |  |  | void spdk_blob_io_write(struct spdk_blob *blob, struct spdk_io_channel *channel, | 
					
						
							|  |  |  | 			void *payload, uint64_t offset, uint64_t length, | 
					
						
							|  |  |  | 			spdk_blob_op_complete cb_fn, void *cb_arg); | 
					
						
							| 
									
										
										
										
											2017-03-20 18:26:50 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-12-13 02:52:07 +00:00
										 |  |  | /**
 | 
					
						
							|  |  |  |  * Read data from a blob. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * \param blob Blob to read. | 
					
						
							|  |  |  |  * \param channel The I/O channel used to submit requests. | 
					
						
							|  |  |  |  * \param payload The specified buffer which will store the obtained data. | 
					
						
							|  |  |  |  * \param offset Offset is in pages from the beginning of the blob. | 
					
						
							|  |  |  |  * \param length Size of data in pages. | 
					
						
							|  |  |  |  * \param cb_fn Called when the operation is complete. | 
					
						
							|  |  |  |  * \param cb_arg Argument passed to function cb_fn. | 
					
						
							|  |  |  |  */ | 
					
						
							| 
									
										
										
										
											2018-02-21 21:37:37 +00:00
										 |  |  | void spdk_blob_io_read(struct spdk_blob *blob, struct spdk_io_channel *channel, | 
					
						
							|  |  |  | 		       void *payload, uint64_t offset, uint64_t length, | 
					
						
							|  |  |  | 		       spdk_blob_op_complete cb_fn, void *cb_arg); | 
					
						
							| 
									
										
										
										
											2017-03-20 18:26:50 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-12-13 02:52:07 +00:00
										 |  |  | /**
 | 
					
						
							|  |  |  |  * Write the data described by 'iov' to 'length' pages beginning at 'offset' pages | 
					
						
							|  |  |  |  * into the blob. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * \param blob Blob to write. | 
					
						
							|  |  |  |  * \param channel I/O channel used to submit requests. | 
					
						
							|  |  |  |  * \param iov The pointer points to an array of iovec structures. | 
					
						
							|  |  |  |  * \param iovcnt The number of buffers. | 
					
						
							|  |  |  |  * \param offset Offset is in pages from the beginning of the blob. | 
					
						
							|  |  |  |  * \param length Size of data in pages. | 
					
						
							|  |  |  |  * \param cb_fn Called when the operation is complete. | 
					
						
							|  |  |  |  * \param cb_arg Argument passed to function cb_fn. | 
					
						
							|  |  |  |  */ | 
					
						
							| 
									
										
										
										
											2018-02-21 21:37:37 +00:00
										 |  |  | void spdk_blob_io_writev(struct spdk_blob *blob, struct spdk_io_channel *channel, | 
					
						
							|  |  |  | 			 struct iovec *iov, int iovcnt, uint64_t offset, uint64_t length, | 
					
						
							|  |  |  | 			 spdk_blob_op_complete cb_fn, void *cb_arg); | 
					
						
							| 
									
										
										
										
											2017-08-18 16:41:26 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-12-13 02:52:07 +00:00
										 |  |  | /**
 | 
					
						
							|  |  |  |  * Read 'length' pages starting at 'offset' pages into the blob into the memory | 
					
						
							|  |  |  |  * described by 'iov'. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * \param blob Blob to read. | 
					
						
							|  |  |  |  * \param channel I/O channel used to submit requests. | 
					
						
							|  |  |  |  * \param iov The pointer points to an array of iovec structures. | 
					
						
							|  |  |  |  * \param iovcnt The number of buffers. | 
					
						
							|  |  |  |  * \param offset Offset is in pages from the beginning of the blob. | 
					
						
							|  |  |  |  * \param length Size of data in pages. | 
					
						
							|  |  |  |  * \param cb_fn Called when the operation is complete. | 
					
						
							|  |  |  |  * \param cb_arg Argument passed to function cb_fn. | 
					
						
							|  |  |  |  */ | 
					
						
							| 
									
										
										
										
											2018-02-21 21:37:37 +00:00
										 |  |  | void spdk_blob_io_readv(struct spdk_blob *blob, struct spdk_io_channel *channel, | 
					
						
							|  |  |  | 			struct iovec *iov, int iovcnt, uint64_t offset, uint64_t length, | 
					
						
							|  |  |  | 			spdk_blob_op_complete cb_fn, void *cb_arg); | 
					
						
							| 
									
										
										
										
											2017-08-18 16:41:26 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-12-13 02:52:07 +00:00
										 |  |  | /**
 | 
					
						
							|  |  |  |  * Unmap 'length' pages beginning at 'offset' pages on the blob as unused. Unmapped | 
					
						
							|  |  |  |  * pages may allow the underlying storage media to behave more effciently. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * \param blob Blob to unmap. | 
					
						
							|  |  |  |  * \param channel I/O channel used to submit requests. | 
					
						
							|  |  |  |  * \param offset Offset is in pages from the beginning of the blob. | 
					
						
							|  |  |  |  * \param length Size of unmap area in pages. | 
					
						
							|  |  |  |  * \param cb_fn Called when the operation is complete. | 
					
						
							|  |  |  |  * \param cb_arg Argument passed to function cb_fn. | 
					
						
							|  |  |  |  */ | 
					
						
							| 
									
										
										
										
											2018-02-21 21:37:37 +00:00
										 |  |  | void spdk_blob_io_unmap(struct spdk_blob *blob, struct spdk_io_channel *channel, | 
					
						
							|  |  |  | 			uint64_t offset, uint64_t length, spdk_blob_op_complete cb_fn, void *cb_arg); | 
					
						
							| 
									
										
										
										
											2017-11-15 13:18:56 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-12-13 02:52:07 +00:00
										 |  |  | /**
 | 
					
						
							|  |  |  |  * Write zeros into area of a blob. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * \param blob Blob to write. | 
					
						
							|  |  |  |  * \param channel I/O channel used to submit requests. | 
					
						
							|  |  |  |  * \param offset Offset is in pages from the beginning of the blob. | 
					
						
							|  |  |  |  * \param length Size of data in pages. | 
					
						
							|  |  |  |  * \param cb_fn Called when the operation is complete. | 
					
						
							|  |  |  |  * \param cb_arg Argument passed to function cb_fn. | 
					
						
							|  |  |  |  */ | 
					
						
							| 
									
										
										
										
											2018-02-21 21:37:37 +00:00
										 |  |  | void spdk_blob_io_write_zeroes(struct spdk_blob *blob, struct spdk_io_channel *channel, | 
					
						
							|  |  |  | 			       uint64_t offset, uint64_t length, spdk_blob_op_complete cb_fn, void *cb_arg); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /*
 | 
					
						
							|  |  |  |  * The following spdk_bs_io prefixed functions are deprecated in favor of their corresponding spdk_blob_io | 
					
						
							|  |  |  |  * function above. | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | void spdk_bs_io_write_blob(struct spdk_blob *blob, struct spdk_io_channel *channel, | 
					
						
							|  |  |  | 			   void *payload, uint64_t offset, uint64_t length, | 
					
						
							|  |  |  | 			   spdk_blob_op_complete cb_fn, void *cb_arg) __attribute__((deprecated)); | 
					
						
							|  |  |  | void spdk_bs_io_read_blob(struct spdk_blob *blob, struct spdk_io_channel *channel, | 
					
						
							|  |  |  | 			  void *payload, uint64_t offset, uint64_t length, | 
					
						
							|  |  |  | 			  spdk_blob_op_complete cb_fn, void *cb_arg) __attribute__((deprecated)); | 
					
						
							|  |  |  | void spdk_bs_io_writev_blob(struct spdk_blob *blob, struct spdk_io_channel *channel, | 
					
						
							|  |  |  | 			    struct iovec *iov, int iovcnt, uint64_t offset, uint64_t length, | 
					
						
							|  |  |  | 			    spdk_blob_op_complete cb_fn, void *cb_arg) __attribute__((deprecated)); | 
					
						
							|  |  |  | void spdk_bs_io_readv_blob(struct spdk_blob *blob, struct spdk_io_channel *channel, | 
					
						
							|  |  |  | 			   struct iovec *iov, int iovcnt, uint64_t offset, uint64_t length, | 
					
						
							|  |  |  | 			   spdk_blob_op_complete cb_fn, void *cb_arg) __attribute__((deprecated)); | 
					
						
							|  |  |  | void spdk_bs_io_unmap_blob(struct spdk_blob *blob, struct spdk_io_channel *channel, | 
					
						
							|  |  |  | 			   uint64_t offset, uint64_t length, | 
					
						
							|  |  |  | 			   spdk_blob_op_complete cb_fn, void *cb_arg)  __attribute__((deprecated)); | 
					
						
							| 
									
										
										
										
											2017-11-15 13:18:56 +00:00
										 |  |  | void spdk_bs_io_write_zeroes_blob(struct spdk_blob *blob, struct spdk_io_channel *channel, | 
					
						
							| 
									
										
										
										
											2018-02-21 21:37:37 +00:00
										 |  |  | 				  uint64_t offset, uint64_t length, | 
					
						
							|  |  |  | 				  spdk_blob_op_complete cb_fn, void *cb_arg)  __attribute__((deprecated)); | 
					
						
							| 
									
										
										
										
											2017-11-15 13:18:56 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-12-13 02:52:07 +00:00
										 |  |  | /**
 | 
					
						
							|  |  |  |  * Get the first blob of the blobstore. The obtained blob will be passed to | 
					
						
							|  |  |  |  * the callback function. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * \param bs blobstore to traverse. | 
					
						
							|  |  |  |  * \param cb_fn Called when the operation is complete. | 
					
						
							|  |  |  |  * \param cb_arg Argument passed to function cb_fn. | 
					
						
							|  |  |  |  */ | 
					
						
							| 
									
										
										
										
											2017-12-08 21:09:12 +00:00
										 |  |  | void spdk_bs_iter_first(struct spdk_blob_store *bs, | 
					
						
							|  |  |  | 			spdk_blob_op_with_handle_complete cb_fn, void *cb_arg); | 
					
						
							| 
									
										
										
										
											2017-12-13 02:52:07 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | /**
 | 
					
						
							|  |  |  |  * Get the next blob by using the current blob. The obtained blob will be passed | 
					
						
							|  |  |  |  * to the callback function. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * \param bs blobstore to traverse. | 
					
						
							|  |  |  |  * \param blob The current blob. | 
					
						
							|  |  |  |  * \param cb_fn Called when the operation is complete. | 
					
						
							|  |  |  |  * \param cb_arg Argument passed to function cb_fn. | 
					
						
							|  |  |  |  */ | 
					
						
							| 
									
										
										
										
											2017-12-12 20:53:10 +00:00
										 |  |  | void spdk_bs_iter_next(struct spdk_blob_store *bs, struct spdk_blob *blob, | 
					
						
							| 
									
										
										
										
											2017-12-08 21:09:12 +00:00
										 |  |  | 		       spdk_blob_op_with_handle_complete cb_fn, void *cb_arg); | 
					
						
							| 
									
										
										
										
											2017-03-20 18:26:50 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-12-13 02:52:07 +00:00
										 |  |  | /**
 | 
					
						
							|  |  |  |  * Set an extended attribute for the given blob. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * \param blob Blob to set attribute. | 
					
						
							|  |  |  |  * \param name Name of the extended attribute. | 
					
						
							|  |  |  |  * \param value Value of the extended attribute. | 
					
						
							|  |  |  |  * \param value_len Length of the value. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * \return 0 on success, -1 on failure. | 
					
						
							|  |  |  |  */ | 
					
						
							| 
									
										
										
										
											2017-12-08 16:38:33 +00:00
										 |  |  | int spdk_blob_set_xattr(struct spdk_blob *blob, const char *name, const void *value, | 
					
						
							|  |  |  | 			uint16_t value_len); | 
					
						
							| 
									
										
										
										
											2017-12-13 02:52:07 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | /**
 | 
					
						
							|  |  |  |  * Remove the extended attribute from the given blob. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * \param blob Blob to remove attribute. | 
					
						
							|  |  |  |  * \param name Name of the extended attribute. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * \return 0 on success, negative errno on failure. | 
					
						
							|  |  |  |  */ | 
					
						
							| 
									
										
										
										
											2017-12-08 16:38:33 +00:00
										 |  |  | int spdk_blob_remove_xattr(struct spdk_blob *blob, const char *name); | 
					
						
							| 
									
										
										
										
											2017-12-13 02:52:07 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | /**
 | 
					
						
							|  |  |  |  * Get the value of the specified extended attribute. The obtained value and its | 
					
						
							|  |  |  |  * size will be stored in value and value_len. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * \param blob Blob to query. | 
					
						
							|  |  |  |  * \param name Name of the extended attribute. | 
					
						
							|  |  |  |  * \param value Parameter as output. | 
					
						
							|  |  |  |  * \param value_len Parameter as output. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * \return 0 on success, negative errno on failure. | 
					
						
							|  |  |  |  */ | 
					
						
							| 
									
										
										
										
											2017-12-08 16:38:33 +00:00
										 |  |  | int spdk_blob_get_xattr_value(struct spdk_blob *blob, const char *name, | 
					
						
							|  |  |  | 			      const void **value, size_t *value_len); | 
					
						
							| 
									
										
										
										
											2017-12-13 02:52:07 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | /**
 | 
					
						
							|  |  |  |  * Iterate through all extended attributes of the blob. Get the names of all extended | 
					
						
							|  |  |  |  * attributes that will be stored in names. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * \param blob Blob to query. | 
					
						
							|  |  |  |  * \param names Parameter as output. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * \return 0 on success, negative errno on failure. | 
					
						
							|  |  |  |  */ | 
					
						
							| 
									
										
										
										
											2017-12-08 16:38:33 +00:00
										 |  |  | int spdk_blob_get_xattr_names(struct spdk_blob *blob, struct spdk_xattr_names **names); | 
					
						
							| 
									
										
										
										
											2017-03-20 18:26:50 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-12-13 02:52:07 +00:00
										 |  |  | /**
 | 
					
						
							|  |  |  |  * Get the number of extended attributes. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * \param names Names of total extended attributes of the blob. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * \return the number of extended attributes. | 
					
						
							|  |  |  |  */ | 
					
						
							| 
									
										
										
										
											2017-03-20 18:26:50 +00:00
										 |  |  | uint32_t spdk_xattr_names_get_count(struct spdk_xattr_names *names); | 
					
						
							| 
									
										
										
										
											2017-12-13 02:52:07 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | /**
 | 
					
						
							|  |  |  |  * Get the attribute name specified by the index. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * \param names Names of total extended attributes of the blob. | 
					
						
							|  |  |  |  * \param index Index position of the specified attribute. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * \return attribute name. | 
					
						
							|  |  |  |  */ | 
					
						
							| 
									
										
										
										
											2017-03-20 18:26:50 +00:00
										 |  |  | const char *spdk_xattr_names_get_name(struct spdk_xattr_names *names, uint32_t index); | 
					
						
							| 
									
										
										
										
											2017-12-13 02:52:07 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | /**
 | 
					
						
							|  |  |  |  * Free the attribute names. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * \param names Names of total extended attributes of the blob. | 
					
						
							|  |  |  |  */ | 
					
						
							| 
									
										
										
										
											2017-03-20 18:26:50 +00:00
										 |  |  | void spdk_xattr_names_free(struct spdk_xattr_names *names); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-12-13 02:52:07 +00:00
										 |  |  | /**
 | 
					
						
							|  |  |  |  * Get blobstore type of the given device. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * \param bs blobstore to query. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * \return blobstore type. | 
					
						
							|  |  |  |  */ | 
					
						
							| 
									
										
										
										
											2017-09-27 13:03:23 +00:00
										 |  |  | struct spdk_bs_type spdk_bs_get_bstype(struct spdk_blob_store *bs); | 
					
						
							| 
									
										
										
										
											2017-12-13 02:52:07 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | /**
 | 
					
						
							|  |  |  |  * Set blobstore type to the given device. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * \param bs blobstore to set to. | 
					
						
							|  |  |  |  * \param bstype Type label to set. | 
					
						
							|  |  |  |  */ | 
					
						
							| 
									
										
										
										
											2017-09-27 13:03:23 +00:00
										 |  |  | void spdk_bs_set_bstype(struct spdk_blob_store *bs, struct spdk_bs_type bstype); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-12-07 20:25:19 +00:00
										 |  |  | #ifdef __cplusplus
 | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-03-20 18:26:50 +00:00
										 |  |  | #endif /* SPDK_BLOB_H_ */
 |