| 
									
										
										
										
											2022-06-03 19:15:11 +00:00
										 |  |  | /*   SPDX-License-Identifier: BSD-3-Clause
 | 
					
						
							| 
									
										
										
										
											2022-11-01 20:26:26 +00:00
										 |  |  |  *   Copyright (C) 2018 Intel Corporation. | 
					
						
							| 
									
										
										
										
											2018-12-01 15:09:46 +00:00
										 |  |  |  *   All rights reserved. | 
					
						
							| 
									
										
										
										
											2021-06-18 09:23:14 +00:00
										 |  |  |  *   Copyright (c) 2021 NVIDIA CORPORATION & AFFILIATES. All rights reserved. | 
					
						
							| 
									
										
										
										
											2018-12-01 15:09:46 +00:00
										 |  |  |  */ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #ifndef SPDK_VBDEV_COMPRESS_H
 | 
					
						
							|  |  |  | #define SPDK_VBDEV_COMPRESS_H
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #include "spdk/stdinc.h"
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #include "spdk/bdev.h"
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-07-02 16:43:41 +00:00
										 |  |  | #define LB_SIZE_4K	0x1000UL
 | 
					
						
							|  |  |  | #define LB_SIZE_512B	0x200UL
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-08-20 17:12:59 +00:00
										 |  |  | /**
 | 
					
						
							|  |  |  |  * Get the first compression bdev. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * \return the first compression bdev. | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | struct vbdev_compress *compress_bdev_first(void); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /**
 | 
					
						
							|  |  |  |  * Get the next compression bdev. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * \param prev previous compression bdev. | 
					
						
							|  |  |  |  * \return the next compression bdev. | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | struct vbdev_compress *compress_bdev_next(struct vbdev_compress *prev); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /**
 | 
					
						
							|  |  |  |  * Test to see if a compression bdev orphan exists. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * \param name The name of the compression bdev. | 
					
						
							|  |  |  |  * \return true if found, false if not. | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | bool compress_has_orphan(const char *name); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /**
 | 
					
						
							|  |  |  |  * Get the name of a compression bdev. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * \param comp_bdev The compression bdev. | 
					
						
							|  |  |  |  * \return the name of the compression bdev. | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | const char *compress_get_name(const struct vbdev_compress *comp_bdev); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-12-01 15:09:46 +00:00
										 |  |  | typedef void (*spdk_delete_compress_complete)(void *cb_arg, int bdeverrno); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /**
 | 
					
						
							|  |  |  |  * Create new compression bdev. | 
					
						
							|  |  |  |  * | 
					
						
							| 
									
										
										
										
											2018-12-05 23:35:02 +00:00
										 |  |  |  * \param bdev_name Bdev on which compression bdev will be created. | 
					
						
							| 
									
										
										
										
											2019-04-26 15:27:45 +00:00
										 |  |  |  * \param pm_path Path to persistent memory. | 
					
						
							| 
									
										
										
										
											2020-07-02 16:43:41 +00:00
										 |  |  |  * \param lb_size Logical block size for the compressed volume in bytes. Must be 4K or 512. | 
					
						
							| 
									
										
										
										
											2018-12-01 15:09:46 +00:00
										 |  |  |  * \return 0 on success, other on failure. | 
					
						
							|  |  |  |  */ | 
					
						
							| 
									
										
										
										
											2020-07-02 16:43:41 +00:00
										 |  |  | int create_compress_bdev(const char *bdev_name, const char *pm_path, uint32_t lb_size); | 
					
						
							| 
									
										
										
										
											2018-12-01 15:09:46 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | /**
 | 
					
						
							|  |  |  |  * Delete compress bdev. | 
					
						
							|  |  |  |  * | 
					
						
							| 
									
										
										
										
											2019-08-20 21:39:03 +00:00
										 |  |  |  * \param bdev_name Bdev on which compression bdev will be deleted. | 
					
						
							| 
									
										
										
										
											2018-12-01 15:09:46 +00:00
										 |  |  |  * \param cb_fn Function to call after deletion. | 
					
						
							|  |  |  |  * \param cb_arg Argument to pass to cb_fn. | 
					
						
							|  |  |  |  */ | 
					
						
							| 
									
										
										
										
											2019-08-20 21:39:03 +00:00
										 |  |  | void bdev_compress_delete(const char *bdev_name, spdk_delete_compress_complete cb_fn, | 
					
						
							| 
									
										
										
										
											2018-12-01 15:09:46 +00:00
										 |  |  | 			  void *cb_arg); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #endif /* SPDK_VBDEV_COMPRESS_H */
 |