| 
									
										
										
										
											2017-03-22 20:35:00 +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
 | 
					
						
							|  |  |  |  * SPDK Filesystem | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #ifndef SPDK_FS_H
 | 
					
						
							|  |  |  | #define SPDK_FS_H
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-05-01 20:22:48 +00:00
										 |  |  | #include "spdk/stdinc.h"
 | 
					
						
							| 
									
										
										
										
											2017-03-22 20:35:00 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | #include "spdk/blob.h"
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-12-07 20:25:19 +00:00
										 |  |  | #ifdef __cplusplus
 | 
					
						
							|  |  |  | extern "C" { | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-03-22 20:35:00 +00:00
										 |  |  | #define SPDK_FILE_NAME_MAX	255
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | struct spdk_file; | 
					
						
							|  |  |  | struct spdk_filesystem; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | typedef struct spdk_file *spdk_fs_iter; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-01-05 01:46:54 +00:00
										 |  |  | struct spdk_blobfs_opts { | 
					
						
							|  |  |  | 	uint32_t	cluster_sz; | 
					
						
							|  |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-03-22 20:35:00 +00:00
										 |  |  | struct spdk_file_stat { | 
					
						
							|  |  |  | 	spdk_blob_id	blobid; | 
					
						
							|  |  |  | 	uint64_t	size; | 
					
						
							|  |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-04-16 04:14:09 +00:00
										 |  |  | /**
 | 
					
						
							|  |  |  |  * Filesystem operation completion callback with handle. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * \param ctx Context for the operation. | 
					
						
							|  |  |  |  * \param fs Handle to a blobfs. | 
					
						
							|  |  |  |  * \param fserrno 0 if it completed successfully, or negative errno if it failed. | 
					
						
							|  |  |  |  */ | 
					
						
							| 
									
										
										
										
											2017-03-22 20:35:00 +00:00
										 |  |  | typedef void (*spdk_fs_op_with_handle_complete)(void *ctx, struct spdk_filesystem *fs, | 
					
						
							|  |  |  | 		int fserrno); | 
					
						
							| 
									
										
										
										
											2018-04-16 04:14:09 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | /**
 | 
					
						
							|  |  |  |  * File operation completion callback with handle. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * \param ctx Context for the operation. | 
					
						
							|  |  |  |  * \param f Handle to a file. | 
					
						
							|  |  |  |  * \param fserrno 0 if it completed successfully, or negative errno if it failed. | 
					
						
							|  |  |  |  */ | 
					
						
							| 
									
										
										
										
											2017-03-22 20:35:00 +00:00
										 |  |  | typedef void (*spdk_file_op_with_handle_complete)(void *ctx, struct spdk_file *f, int fserrno); | 
					
						
							|  |  |  | typedef spdk_bs_op_complete spdk_fs_op_complete; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-04-16 04:14:09 +00:00
										 |  |  | /**
 | 
					
						
							|  |  |  |  * File operation completion callback. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * \param ctx Context for the operation. | 
					
						
							|  |  |  |  * \param fserrno 0 if it completed successfully, or negative errno if it failed. | 
					
						
							|  |  |  |  */ | 
					
						
							| 
									
										
										
										
											2017-03-22 20:35:00 +00:00
										 |  |  | typedef void (*spdk_file_op_complete)(void *ctx, int fserrno); | 
					
						
							| 
									
										
										
										
											2018-04-16 04:14:09 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | /**
 | 
					
						
							|  |  |  |  * File stat operation completion callback. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * \param ctx Context for the operation. | 
					
						
							|  |  |  |  * \param stat Handle to the stat about the file. | 
					
						
							|  |  |  |  * \param fserrno 0 if it completed successfully, or negative errno if it failed. | 
					
						
							|  |  |  |  */ | 
					
						
							| 
									
										
										
										
											2017-03-22 20:35:00 +00:00
										 |  |  | typedef void (*spdk_file_stat_op_complete)(void *ctx, struct spdk_file_stat *stat, int fserrno); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-04-16 04:14:09 +00:00
										 |  |  | /**
 | 
					
						
							|  |  |  |  * Function for a request of file system. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * \param arg Argument to the request function. | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | typedef void (*fs_request_fn)(void *arg); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /**
 | 
					
						
							|  |  |  |  * Function for sending request. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * This function will be invoked any time when the filesystem wants to pass a | 
					
						
							|  |  |  |  * message to the main dispatch thread. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * \param fs_request_fn A pointer to the request function. | 
					
						
							|  |  |  |  * \param arg Argument to the request function. | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | typedef void (*fs_send_request_fn)(fs_request_fn, void *arg); | 
					
						
							| 
									
										
										
										
											2017-03-22 20:35:00 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-12-13 02:26:15 +00:00
										 |  |  | /**
 | 
					
						
							|  |  |  |  * Initialize a spdk_blobfs_opts structure to the default option values. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * \param opts spdk_blobf_opts struture to intialize. | 
					
						
							|  |  |  |  */ | 
					
						
							| 
									
										
										
										
											2018-01-05 01:46:54 +00:00
										 |  |  | void spdk_fs_opts_init(struct spdk_blobfs_opts *opts); | 
					
						
							| 
									
										
										
										
											2017-12-13 02:26:15 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | /**
 | 
					
						
							|  |  |  |  * Initialize blobstore filesystem. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * Initialize the blobstore filesystem on the blobstore block device which has | 
					
						
							|  |  |  |  * been created by the function spdk_bdev_create_bs_dev() in the blob_bdev.h. | 
					
						
							|  |  |  |  * The obtained blobstore filesystem will be passed to the callback function. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * \param dev Blobstore block device used by this blobstore filesystem. | 
					
						
							|  |  |  |  * \param opt Initialization options used for this blobstore filesystem. | 
					
						
							|  |  |  |  * \param send_request_fn The function for sending request. This function will | 
					
						
							|  |  |  |  * be invoked any time when the blobstore filesystem wants to pass a message to | 
					
						
							|  |  |  |  * the main dispatch thread. | 
					
						
							|  |  |  |  * \param cb_fn Called when the initialization is complete. | 
					
						
							|  |  |  |  * \param cb_arg Argument passed to function cb_fn. | 
					
						
							|  |  |  |  */ | 
					
						
							| 
									
										
										
										
											2018-01-05 01:46:54 +00:00
										 |  |  | void spdk_fs_init(struct spdk_bs_dev *dev, struct spdk_blobfs_opts *opt, | 
					
						
							|  |  |  | 		  fs_send_request_fn send_request_fn, | 
					
						
							| 
									
										
										
										
											2017-03-22 20:35:00 +00:00
										 |  |  | 		  spdk_fs_op_with_handle_complete cb_fn, void *cb_arg); | 
					
						
							| 
									
										
										
										
											2017-12-13 02:26:15 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | /**
 | 
					
						
							|  |  |  |  * Load blobstore filesystem from the given blobstore block device. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * The obtained blobstore filesystem will be passed to the callback function. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * \param dev Blobstore block device used by this blobstore filesystem. | 
					
						
							|  |  |  |  * \param send_request_fn The function for sending request. This function will | 
					
						
							|  |  |  |  * be invoked any time when the blobstore filesystem wants to pass a message to | 
					
						
							|  |  |  |  * the main dispatch thread. | 
					
						
							|  |  |  |  * \param cb_fn Called when the loading is complete. | 
					
						
							|  |  |  |  * \param cb_arg Argument passed to function cb_fn. | 
					
						
							|  |  |  |  */ | 
					
						
							| 
									
										
										
										
											2017-03-22 20:35:00 +00:00
										 |  |  | void spdk_fs_load(struct spdk_bs_dev *dev, fs_send_request_fn send_request_fn, | 
					
						
							|  |  |  | 		  spdk_fs_op_with_handle_complete cb_fn, void *cb_arg); | 
					
						
							| 
									
										
										
										
											2017-12-13 02:26:15 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | /**
 | 
					
						
							|  |  |  |  * Unload blobstore filesystem. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * \param fs Blobstore filesystem to unload. | 
					
						
							|  |  |  |  * \param cb_fn Called when the unloading is complete. | 
					
						
							|  |  |  |  * \param cb_arg Argument passed to function cb_fn. | 
					
						
							|  |  |  |  */ | 
					
						
							| 
									
										
										
										
											2017-03-22 20:35:00 +00:00
										 |  |  | void spdk_fs_unload(struct spdk_filesystem *fs, spdk_fs_op_complete cb_fn, void *cb_arg); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-12-13 02:26:15 +00:00
										 |  |  | /**
 | 
					
						
							|  |  |  |  * Allocate an I/O channel for asynchronous operations. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * \param fs Blobstore filesystem to allocate I/O channel. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * \return a pointer to the I/O channel on success or NULL otherwise. | 
					
						
							|  |  |  |  */ | 
					
						
							| 
									
										
										
										
											2017-05-18 17:48:04 +00:00
										 |  |  | struct spdk_io_channel *spdk_fs_alloc_io_channel(struct spdk_filesystem *fs); | 
					
						
							| 
									
										
										
										
											2017-03-22 20:35:00 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-12-13 02:26:15 +00:00
										 |  |  | /**
 | 
					
						
							|  |  |  |  * Free I/O channel. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * This function will decrease the references of this I/O channel. If the reference | 
					
						
							|  |  |  |  * is reduced to 0, the I/O channel will be freed. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * \param channel I/O channel to free. | 
					
						
							|  |  |  |  */ | 
					
						
							| 
									
										
										
										
											2017-03-22 20:35:00 +00:00
										 |  |  | void spdk_fs_free_io_channel(struct spdk_io_channel *channel); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-03-28 18:25:48 +00:00
										 |  |  | /**
 | 
					
						
							|  |  |  |  * Allocate a context for synchronous operations. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * \param fs Blobstore filesystem for this context. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * \return a pointer to the context on success or NULL otherwise. | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | struct spdk_fs_thread_ctx *spdk_fs_alloc_thread_ctx(struct spdk_filesystem *fs); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /**
 | 
					
						
							|  |  |  |  * Free thread context. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * \param ctx Thread context to free. | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | void spdk_fs_free_thread_ctx(struct spdk_fs_thread_ctx *ctx); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-12-13 02:26:15 +00:00
										 |  |  | /**
 | 
					
						
							|  |  |  |  * Get statistics about the file including the underlying blob id and the file size. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * \param fs Blobstore filesystem. | 
					
						
							| 
									
										
										
										
											2019-03-28 18:25:48 +00:00
										 |  |  |  * \param ctx The thread context for this operation | 
					
						
							| 
									
										
										
										
											2017-12-13 02:26:15 +00:00
										 |  |  |  * \param name The file name used to look up the matched file in the blobstore filesystem. | 
					
						
							|  |  |  |  * \param stat Caller allocated structure to store the obtained information about | 
					
						
							|  |  |  |  * this file. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * \return 0 on success, negative errno on failure. | 
					
						
							|  |  |  |  */ | 
					
						
							| 
									
										
										
										
											2019-03-28 18:25:48 +00:00
										 |  |  | int spdk_fs_file_stat(struct spdk_filesystem *fs, struct spdk_fs_thread_ctx *ctx, | 
					
						
							| 
									
										
										
										
											2017-03-22 20:35:00 +00:00
										 |  |  | 		      const char *name, struct spdk_file_stat *stat); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #define SPDK_BLOBFS_OPEN_CREATE	(1ULL << 0)
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-12-13 02:26:15 +00:00
										 |  |  | /**
 | 
					
						
							|  |  |  |  * Create a new file on the given blobstore filesystem. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * \param fs Blobstore filesystem. | 
					
						
							| 
									
										
										
										
											2019-03-28 18:25:48 +00:00
										 |  |  |  * \param ctx The thread context for this operation | 
					
						
							| 
									
										
										
										
											2017-12-13 02:26:15 +00:00
										 |  |  |  * \param name The file name for this new file. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * \return 0 on success, negative errno on failure. | 
					
						
							|  |  |  |  */ | 
					
						
							| 
									
										
										
										
											2019-03-28 18:25:48 +00:00
										 |  |  | int spdk_fs_create_file(struct spdk_filesystem *fs, struct spdk_fs_thread_ctx *ctx, | 
					
						
							| 
									
										
										
										
											2017-03-22 20:35:00 +00:00
										 |  |  | 			const char *name); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-12-13 02:26:15 +00:00
										 |  |  | /**
 | 
					
						
							|  |  |  |  * Open the file. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * \param fs Blobstore filesystem. | 
					
						
							| 
									
										
										
										
											2019-03-28 18:25:48 +00:00
										 |  |  |  * \param ctx The thread context for this operation | 
					
						
							| 
									
										
										
										
											2017-12-13 02:26:15 +00:00
										 |  |  |  * \param name The file name used to look up the matched file in the blobstore filesystem. | 
					
						
							|  |  |  |  * \param flags This flags will be used to control the open mode. | 
					
						
							|  |  |  |  * \param file It will point to the open file if sccessful or NULL otherwirse. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * \return 0 on success, negative errno on failure. | 
					
						
							|  |  |  |  */ | 
					
						
							| 
									
										
										
										
											2019-03-28 18:25:48 +00:00
										 |  |  | int spdk_fs_open_file(struct spdk_filesystem *fs, struct spdk_fs_thread_ctx *ctx, | 
					
						
							| 
									
										
										
										
											2017-03-22 20:35:00 +00:00
										 |  |  | 		      const char *name, uint32_t flags, struct spdk_file **file); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-12-13 02:26:15 +00:00
										 |  |  | /**
 | 
					
						
							|  |  |  |  * Close the file. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * \param file File to close. | 
					
						
							| 
									
										
										
										
											2019-03-28 18:25:48 +00:00
										 |  |  |  * \param ctx The thread context for this operation | 
					
						
							| 
									
										
										
										
											2017-12-13 02:26:15 +00:00
										 |  |  |  * | 
					
						
							|  |  |  |  * \return 0 on success, negative errno on failure. | 
					
						
							|  |  |  |  */ | 
					
						
							| 
									
										
										
										
											2019-03-28 18:25:48 +00:00
										 |  |  | int spdk_file_close(struct spdk_file *file, struct spdk_fs_thread_ctx *ctx); | 
					
						
							| 
									
										
										
										
											2017-03-22 20:35:00 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-12-13 02:26:15 +00:00
										 |  |  | /**
 | 
					
						
							|  |  |  |  * Change the file name. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * This operation will overwrite an existing file if there is a file with the | 
					
						
							|  |  |  |  * same name. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * \param fs Blobstore filesystem. | 
					
						
							| 
									
										
										
										
											2019-03-28 18:25:48 +00:00
										 |  |  |  * \param ctx The thread context for this operation | 
					
						
							| 
									
										
										
										
											2017-12-13 02:26:15 +00:00
										 |  |  |  * \param old_name Old name of the file. | 
					
						
							|  |  |  |  * \param new_name New name of the file. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * \return 0 on success, negative errno on failure. | 
					
						
							|  |  |  |  */ | 
					
						
							| 
									
										
										
										
											2019-03-28 18:25:48 +00:00
										 |  |  | int spdk_fs_rename_file(struct spdk_filesystem *fs, struct spdk_fs_thread_ctx *ctx, | 
					
						
							| 
									
										
										
										
											2017-03-22 20:35:00 +00:00
										 |  |  | 			const char *old_name, const char *new_name); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-12-13 02:26:15 +00:00
										 |  |  | /**
 | 
					
						
							|  |  |  |  * Delete the file. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * \param fs Blobstore filesystem. | 
					
						
							| 
									
										
										
										
											2019-03-28 18:25:48 +00:00
										 |  |  |  * \param ctx The thread context for this operation | 
					
						
							| 
									
										
										
										
											2017-12-13 02:26:15 +00:00
										 |  |  |  * \param name The name of the file to be deleted. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * \return 0 on success, negative errno on failure. | 
					
						
							|  |  |  |  */ | 
					
						
							| 
									
										
										
										
											2019-03-28 18:25:48 +00:00
										 |  |  | int spdk_fs_delete_file(struct spdk_filesystem *fs, struct spdk_fs_thread_ctx *ctx, | 
					
						
							| 
									
										
										
										
											2017-03-22 20:35:00 +00:00
										 |  |  | 			const char *name); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-12-13 02:26:15 +00:00
										 |  |  | /**
 | 
					
						
							|  |  |  |  * Get the first file in the blobstore filesystem. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * \param fs Blobstore filesystem to traverse. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * \return an iterator which points to the first file in the blobstore filesystem. | 
					
						
							|  |  |  |  */ | 
					
						
							| 
									
										
										
										
											2017-03-22 20:35:00 +00:00
										 |  |  | spdk_fs_iter spdk_fs_iter_first(struct spdk_filesystem *fs); | 
					
						
							| 
									
										
										
										
											2017-12-13 02:26:15 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | /**
 | 
					
						
							|  |  |  |  * Get the next file in the blobstore filesystem by using the input iterator. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * \param iter The iterator which points to the current file struct. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * \return an iterator which points to the next file in the blobstore filesystem. | 
					
						
							|  |  |  |  */ | 
					
						
							| 
									
										
										
										
											2017-03-22 20:35:00 +00:00
										 |  |  | spdk_fs_iter spdk_fs_iter_next(spdk_fs_iter iter); | 
					
						
							| 
									
										
										
										
											2017-12-13 02:26:15 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-03-22 20:35:00 +00:00
										 |  |  | #define spdk_fs_iter_get_file(iter)	((struct spdk_file *)(iter))
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-12-13 02:26:15 +00:00
										 |  |  | /**
 | 
					
						
							|  |  |  |  * Truncate the file. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * \param file File to truncate. | 
					
						
							| 
									
										
										
										
											2019-03-28 18:25:48 +00:00
										 |  |  |  * \param ctx The thread context for this operation | 
					
						
							| 
									
										
										
										
											2017-12-13 02:26:15 +00:00
										 |  |  |  * \param length New size in bytes of the file. | 
					
						
							| 
									
										
										
										
											2018-07-23 06:35:51 +00:00
										 |  |  |  * | 
					
						
							|  |  |  |  * \return 0 on success, negative errno on failure. | 
					
						
							| 
									
										
										
										
											2017-12-13 02:26:15 +00:00
										 |  |  |  */ | 
					
						
							| 
									
										
										
										
											2019-03-28 18:25:48 +00:00
										 |  |  | int spdk_file_truncate(struct spdk_file *file, struct spdk_fs_thread_ctx *ctx, | 
					
						
							| 
									
										
										
										
											2018-07-23 06:35:51 +00:00
										 |  |  | 		       uint64_t length); | 
					
						
							| 
									
										
										
										
											2017-03-22 20:35:00 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-12-13 02:26:15 +00:00
										 |  |  | /**
 | 
					
						
							|  |  |  |  * Get file name. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * \param file File to query. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * \return the name of the file. | 
					
						
							|  |  |  |  */ | 
					
						
							| 
									
										
										
										
											2017-03-22 20:35:00 +00:00
										 |  |  | const char *spdk_file_get_name(struct spdk_file *file); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-12-13 02:26:15 +00:00
										 |  |  | /**
 | 
					
						
							|  |  |  |  * Obtain the size of the file. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * \param file File to query. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * \return the size in bytes of the file. | 
					
						
							|  |  |  |  */ | 
					
						
							| 
									
										
										
										
											2017-03-22 20:35:00 +00:00
										 |  |  | uint64_t spdk_file_get_length(struct spdk_file *file); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-12-13 02:26:15 +00:00
										 |  |  | /**
 | 
					
						
							|  |  |  |  * Write data to the given file. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * \param file File to write. | 
					
						
							| 
									
										
										
										
											2019-03-28 18:25:48 +00:00
										 |  |  |  * \param ctx The thread context for this operation | 
					
						
							| 
									
										
										
										
											2017-12-13 02:26:15 +00:00
										 |  |  |  * \param payload The specified buffer which should contain the data to be transmitted. | 
					
						
							|  |  |  |  * \param offset The beginning position to write data. | 
					
						
							|  |  |  |  * \param length The size in bytes of data to write. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * \return 0 on success, negative errno on failure. | 
					
						
							|  |  |  |  */ | 
					
						
							| 
									
										
										
										
											2019-03-28 18:25:48 +00:00
										 |  |  | int spdk_file_write(struct spdk_file *file, struct spdk_fs_thread_ctx *ctx, | 
					
						
							| 
									
										
										
										
											2017-03-22 20:35:00 +00:00
										 |  |  | 		    void *payload, uint64_t offset, uint64_t length); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-12-13 02:26:15 +00:00
										 |  |  | /**
 | 
					
						
							|  |  |  |  * Read data to user buffer from the given file. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * \param file File to read. | 
					
						
							| 
									
										
										
										
											2019-03-28 18:25:48 +00:00
										 |  |  |  * \param ctx The thread context for this operation | 
					
						
							| 
									
										
										
										
											2017-12-13 02:26:15 +00:00
										 |  |  |  * \param payload The specified buffer which will store the obtained data. | 
					
						
							|  |  |  |  * \param offset The beginning position to read. | 
					
						
							|  |  |  |  * \param length The size in bytes of data to read. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * \return the end position of this read operation on success, negated errno on failure. | 
					
						
							|  |  |  |  */ | 
					
						
							| 
									
										
										
										
											2019-03-28 18:25:48 +00:00
										 |  |  | int64_t spdk_file_read(struct spdk_file *file, struct spdk_fs_thread_ctx *ctx, | 
					
						
							| 
									
										
										
										
											2017-03-22 20:35:00 +00:00
										 |  |  | 		       void *payload, uint64_t offset, uint64_t length); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-12-13 02:26:15 +00:00
										 |  |  | /**
 | 
					
						
							|  |  |  |  * Set cache size for the blobstore filesystem. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * \param size_in_mb Cache size in megabytes. | 
					
						
							| 
									
										
										
										
											2019-10-21 15:15:20 +00:00
										 |  |  |  * | 
					
						
							|  |  |  |  * \return 0 on success, negative errno on failure. | 
					
						
							| 
									
										
										
										
											2017-12-13 02:26:15 +00:00
										 |  |  |  */ | 
					
						
							| 
									
										
										
										
											2019-10-21 15:15:20 +00:00
										 |  |  | int spdk_fs_set_cache_size(uint64_t size_in_mb); | 
					
						
							| 
									
										
										
										
											2017-12-13 02:26:15 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | /**
 | 
					
						
							|  |  |  |  * Obtain the cache size. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * \return cache size in megabytes. | 
					
						
							|  |  |  |  */ | 
					
						
							| 
									
										
										
										
											2017-03-22 20:35:00 +00:00
										 |  |  | uint64_t spdk_fs_get_cache_size(void); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #define SPDK_FILE_PRIORITY_LOW	0 /* default */
 | 
					
						
							|  |  |  | #define SPDK_FILE_PRIORITY_HIGH	1
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-12-13 02:26:15 +00:00
										 |  |  | /**
 | 
					
						
							|  |  |  |  * Set priority for the file. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * \param file File to set priority. | 
					
						
							|  |  |  |  * \param priority Priority level (SPDK_FILE_PRIORITY_LOW or SPDK_FILE_PRIORITY_HIGH). | 
					
						
							|  |  |  |  */ | 
					
						
							| 
									
										
										
										
											2017-03-22 20:35:00 +00:00
										 |  |  | void spdk_file_set_priority(struct spdk_file *file, uint32_t priority); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-12-13 02:26:15 +00:00
										 |  |  | /**
 | 
					
						
							|  |  |  |  * Synchronize the data from the cache to the disk. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * \param file File to sync. | 
					
						
							| 
									
										
										
										
											2019-03-28 18:25:48 +00:00
										 |  |  |  * \param ctx The thread context for this operation | 
					
						
							| 
									
										
										
										
											2017-12-13 02:26:15 +00:00
										 |  |  |  * | 
					
						
							|  |  |  |  * \return 0 on success. | 
					
						
							|  |  |  |  */ | 
					
						
							| 
									
										
										
										
											2019-03-28 18:25:48 +00:00
										 |  |  | int spdk_file_sync(struct spdk_file *file, struct spdk_fs_thread_ctx *ctx); | 
					
						
							| 
									
										
										
										
											2017-03-22 20:35:00 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-08-27 08:54:54 +00:00
										 |  |  | /**
 | 
					
						
							|  |  |  |  * Get the unique ID for the file. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * \param file File to get the ID. | 
					
						
							|  |  |  |  * \param id ID buffer. | 
					
						
							|  |  |  |  * \param size Size of the ID buffer. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * \return the length of ID on success. | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | int spdk_file_get_id(struct spdk_file *file, void *id, size_t size); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-05-06 02:19:14 +00:00
										 |  |  | /**
 | 
					
						
							|  |  |  |  * Read data to user buffer from the given file. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * \param file File to read. | 
					
						
							|  |  |  |  * \param channel I/O channel for asynchronous operations. | 
					
						
							|  |  |  |  * \param iovs A scatter gather list of buffers to be read into. | 
					
						
							|  |  |  |  * \param iovcnt The number of elements in iov. | 
					
						
							|  |  |  |  * \param offset The beginning position to read. | 
					
						
							|  |  |  |  * \param length The size in bytes of data to read. | 
					
						
							|  |  |  |  * \param cb_fn Called when the request is complete. | 
					
						
							|  |  |  |  * \param cb_arg Argument passed to cb_fn. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * \return None. | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | void spdk_file_readv_async(struct spdk_file *file, struct spdk_io_channel *channel, | 
					
						
							|  |  |  | 			   struct iovec *iovs, uint32_t iovcnt, uint64_t offset, uint64_t length, | 
					
						
							|  |  |  | 			   spdk_file_op_complete cb_fn, void *cb_arg); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /**
 | 
					
						
							|  |  |  |  * Write data to the given file. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * \param file File to write. | 
					
						
							|  |  |  |  * \param channel I/O channel for asynchronous operations. | 
					
						
							|  |  |  |  * \param iovs A scatter gather list of buffers to be written from. | 
					
						
							|  |  |  |  * \param iovcnt The number of elements in iov. | 
					
						
							|  |  |  |  * \param offset The beginning position to write. | 
					
						
							|  |  |  |  * \param length The size in bytes of data to write. | 
					
						
							|  |  |  |  * \param cb_fn Called when the request is complete. | 
					
						
							|  |  |  |  * \param cb_arg Argument passed to cb_fn. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * \return None. | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | void spdk_file_writev_async(struct spdk_file *file, struct spdk_io_channel *channel, | 
					
						
							|  |  |  | 			    struct iovec *iovs, uint32_t iovcnt, uint64_t offset, uint64_t length, | 
					
						
							|  |  |  | 			    spdk_file_op_complete cb_fn, void *cb_arg); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-06-11 00:59:22 +00:00
										 |  |  | /**
 | 
					
						
							|  |  |  |  * Get statistics about the file including the underlying blob id and the file size. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * \param fs Blobstore filesystem. | 
					
						
							|  |  |  |  * \param name The file name used to look up the matched file in the blobstore filesystem. | 
					
						
							|  |  |  |  * \param cb_fn Called when the request is complete. | 
					
						
							|  |  |  |  * \param cb_arg Argument passed to cb_fn. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * return None. | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | void spdk_fs_file_stat_async(struct spdk_filesystem *fs, const char *name, | 
					
						
							|  |  |  | 			     spdk_file_stat_op_complete cb_fn, void *cb_arg); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /**
 | 
					
						
							|  |  |  |  * Create a new file on the given blobstore filesystem. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * \param fs Blobstore filesystem. | 
					
						
							|  |  |  |  * \param name The file name for this new file. | 
					
						
							|  |  |  |  * \param cb_fn Called when the request is complete. | 
					
						
							|  |  |  |  * \param cb_arg Argument passed to cb_fn. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * return None. | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | void spdk_fs_create_file_async(struct spdk_filesystem *fs, const char *name, | 
					
						
							|  |  |  | 			       spdk_file_op_complete cb_fn, void *cb_arg); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /**
 | 
					
						
							|  |  |  |  * Open the file. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * \param fs Blobstore filesystem. | 
					
						
							|  |  |  |  * \param name The file name used to look up the matched file in the blobstore filesystem. | 
					
						
							|  |  |  |  * \param flags This flags will be used to control the open mode. | 
					
						
							|  |  |  |  * \param cb_fn Called when the request is complete. | 
					
						
							|  |  |  |  * \param cb_arg Argument passed to cb_fn. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * return None. | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | void spdk_fs_open_file_async(struct spdk_filesystem *fs, const char *name, uint32_t flags, | 
					
						
							|  |  |  | 			     spdk_file_op_with_handle_complete cb_fn, void *cb_arg); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /**
 | 
					
						
							|  |  |  |  * Close the file. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * \param file File to close. | 
					
						
							|  |  |  |  * \param cb_fn Called when the request is complete. | 
					
						
							|  |  |  |  * \param cb_arg Argument passed to cb_fn. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * return None. | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | void spdk_file_close_async(struct spdk_file *file, spdk_file_op_complete cb_fn, void *cb_arg); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /**
 | 
					
						
							|  |  |  |  * Change the file name. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * This operation will overwrite an existing file if there is a file with the | 
					
						
							|  |  |  |  * same name. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * \param fs Blobstore filesystem. | 
					
						
							|  |  |  |  * \param old_name Old name of the file. | 
					
						
							|  |  |  |  * \param new_name New name of the file. | 
					
						
							|  |  |  |  * \param cb_fn Called when the request is complete. | 
					
						
							|  |  |  |  * \param cb_arg Argument passed to cb_fn. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * return None. | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | void spdk_fs_rename_file_async(struct spdk_filesystem *fs, const char *old_name, | 
					
						
							|  |  |  | 			       const char *new_name, spdk_fs_op_complete cb_fn, | 
					
						
							|  |  |  | 			       void *cb_arg); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /**
 | 
					
						
							|  |  |  |  * Delete the file. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * \param fs Blobstore filesystem. | 
					
						
							|  |  |  |  * \param name The name of the file to be deleted. | 
					
						
							|  |  |  |  * \param cb_fn Called when the request is complete. | 
					
						
							|  |  |  |  * \param cb_arg Argument passed to cb_fn. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * return None. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | void spdk_fs_delete_file_async(struct spdk_filesystem *fs, const char *name, | 
					
						
							|  |  |  | 			       spdk_file_op_complete cb_fn, void *cb_arg); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /**
 | 
					
						
							|  |  |  |  * Truncate the file. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * \param file File to truncate. | 
					
						
							|  |  |  |  * \param length New size in bytes of the file. | 
					
						
							|  |  |  |  * \param cb_fn Called when the request is complete. | 
					
						
							|  |  |  |  * \param cb_arg Argument passed to cb_fn. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * return None. | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | void spdk_file_truncate_async(struct spdk_file *file, uint64_t length, | 
					
						
							|  |  |  | 			      spdk_file_op_complete cb_fn, void *cb_arg); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /**
 | 
					
						
							|  |  |  |  * Write data to the given file. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * \param file File to write. | 
					
						
							|  |  |  |  * \param channel I/O channel for asynchronous operations. | 
					
						
							|  |  |  |  * \param payload The specified buffer which should contain the data to be transmitted. | 
					
						
							|  |  |  |  * \param offset The beginning position to write data. | 
					
						
							|  |  |  |  * \param length The size in bytes of data to write. | 
					
						
							|  |  |  |  * \param cb_fn Called when the request is complete. | 
					
						
							|  |  |  |  * \param cb_arg Argument passed to cb_fn. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * return None. | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | void spdk_file_write_async(struct spdk_file *file, struct spdk_io_channel *channel, | 
					
						
							|  |  |  | 			   void *payload, uint64_t offset, uint64_t length, | 
					
						
							|  |  |  | 			   spdk_file_op_complete cb_fn, void *cb_arg); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /**
 | 
					
						
							|  |  |  |  * Read data to user buffer from the given file. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * \param file File to write. | 
					
						
							|  |  |  |  * \param channel I/O channel for asynchronous operations. | 
					
						
							|  |  |  |  * \param payload The specified buffer which will store the obtained data. | 
					
						
							|  |  |  |  * \param offset The beginning position to read. | 
					
						
							|  |  |  |  * \param length The size in bytes of data to read. | 
					
						
							|  |  |  |  * \param cb_fn Called when the request is complete. | 
					
						
							|  |  |  |  * \param cb_arg Argument passed to cb_fn. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * return None. | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | void spdk_file_read_async(struct spdk_file *file, struct spdk_io_channel *channel, | 
					
						
							|  |  |  | 			  void *payload, uint64_t offset, uint64_t length, | 
					
						
							|  |  |  | 			  spdk_file_op_complete cb_fn, void *cb_arg); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /**
 | 
					
						
							|  |  |  |  * Sync all dirty cache buffers to the backing block device.  For async | 
					
						
							|  |  |  |  *  usage models, completion of the sync indicates only that data written | 
					
						
							|  |  |  |  *  when the sync command was issued have been flushed to disk - it does | 
					
						
							|  |  |  |  *  not guarantee any writes submitted after the sync have been flushed, | 
					
						
							|  |  |  |  *  even if those writes are completed before the sync. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * \param file File to write. | 
					
						
							|  |  |  |  * \param channel I/O channel for asynchronous operations. | 
					
						
							|  |  |  |  * \param cb_fn Called when the request is complete. | 
					
						
							|  |  |  |  * \param cb_arg Argument passed to cb_fn. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * return None. | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | void spdk_file_sync_async(struct spdk_file *file, struct spdk_io_channel *channel, | 
					
						
							|  |  |  | 			  spdk_file_op_complete cb_fn, void *cb_arg); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-12-07 20:25:19 +00:00
										 |  |  | #ifdef __cplusplus
 | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-03-22 20:35:00 +00:00
										 |  |  | #endif /* SPDK_FS_H_ */
 |