| 
									
										
										
										
											2016-07-27 16:32: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 | 
					
						
							| 
									
										
										
										
											2017-07-13 04:08:53 +00:00
										 |  |  |  * SCSI to bdev translation layer | 
					
						
							| 
									
										
										
										
											2016-07-27 16:32:00 +00:00
										 |  |  |  */ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #ifndef SPDK_SCSI_H
 | 
					
						
							|  |  |  | #define SPDK_SCSI_H
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-05-01 20:22:48 +00:00
										 |  |  | #include "spdk/stdinc.h"
 | 
					
						
							| 
									
										
										
										
											2016-07-27 16:32:00 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-07-05 07:32:48 +00:00
										 |  |  | #include "spdk/bdev.h"
 | 
					
						
							| 
									
										
										
										
											2016-07-27 16:32:00 +00:00
										 |  |  | #include "spdk/queue.h"
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-12-07 20:25:19 +00:00
										 |  |  | #ifdef __cplusplus
 | 
					
						
							|  |  |  | extern "C" { | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-08-04 15:54:16 +00:00
										 |  |  | /* Defines for SPDK tracing framework */ | 
					
						
							|  |  |  | #define OWNER_SCSI_DEV				0x10
 | 
					
						
							|  |  |  | #define OBJECT_SCSI_TASK			0x10
 | 
					
						
							|  |  |  | #define TRACE_GROUP_SCSI			0x2
 | 
					
						
							|  |  |  | #define TRACE_SCSI_TASK_DONE	SPDK_TPOINT_ID(TRACE_GROUP_SCSI, 0x0)
 | 
					
						
							|  |  |  | #define TRACE_SCSI_TASK_START	SPDK_TPOINT_ID(TRACE_GROUP_SCSI, 0x1)
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-07-27 16:32:00 +00:00
										 |  |  | #define SPDK_SCSI_MAX_DEVS			1024
 | 
					
						
							|  |  |  | #define SPDK_SCSI_DEV_MAX_LUN			64
 | 
					
						
							|  |  |  | #define SPDK_SCSI_DEV_MAX_PORTS			4
 | 
					
						
							|  |  |  | #define SPDK_SCSI_DEV_MAX_NAME			255
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #define SPDK_SCSI_PORT_MAX_NAME_LENGTH		255
 | 
					
						
							| 
									
										
										
										
											2018-11-27 12:38:35 +00:00
										 |  |  | #define SPDK_SCSI_MAX_TRANSPORT_ID_LENGTH	255
 | 
					
						
							| 
									
										
										
										
											2016-07-27 16:32:00 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | enum spdk_scsi_data_dir { | 
					
						
							|  |  |  | 	SPDK_SCSI_DIR_NONE = 0, | 
					
						
							|  |  |  | 	SPDK_SCSI_DIR_TO_DEV = 1, | 
					
						
							|  |  |  | 	SPDK_SCSI_DIR_FROM_DEV = 2, | 
					
						
							|  |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | enum spdk_scsi_task_func { | 
					
						
							|  |  |  | 	SPDK_SCSI_TASK_FUNC_ABORT_TASK = 0, | 
					
						
							|  |  |  | 	SPDK_SCSI_TASK_FUNC_ABORT_TASK_SET, | 
					
						
							|  |  |  | 	SPDK_SCSI_TASK_FUNC_CLEAR_TASK_SET, | 
					
						
							|  |  |  | 	SPDK_SCSI_TASK_FUNC_LUN_RESET, | 
					
						
							|  |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-08-02 17:43:00 +00:00
										 |  |  | /*
 | 
					
						
							|  |  |  |  * SAM does not define the value for these service responses.  Each transport | 
					
						
							|  |  |  |  *  (i.e. SAS, FC, iSCSI) will map these value to transport-specific codes, | 
					
						
							|  |  |  |  *  and may add their own. | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | enum spdk_scsi_task_mgmt_resp { | 
					
						
							|  |  |  | 	SPDK_SCSI_TASK_MGMT_RESP_COMPLETE, | 
					
						
							|  |  |  | 	SPDK_SCSI_TASK_MGMT_RESP_SUCCESS, | 
					
						
							|  |  |  | 	SPDK_SCSI_TASK_MGMT_RESP_REJECT, | 
					
						
							|  |  |  | 	SPDK_SCSI_TASK_MGMT_RESP_INVALID_LUN, | 
					
						
							|  |  |  | 	SPDK_SCSI_TASK_MGMT_RESP_TARGET_FAILURE, | 
					
						
							|  |  |  | 	SPDK_SCSI_TASK_MGMT_RESP_REJECT_FUNC_NOT_SUPPORTED | 
					
						
							|  |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-06-08 20:45:41 +00:00
										 |  |  | struct spdk_scsi_task; | 
					
						
							|  |  |  | typedef void (*spdk_scsi_task_cpl)(struct spdk_scsi_task *task); | 
					
						
							|  |  |  | typedef void (*spdk_scsi_task_free)(struct spdk_scsi_task *task); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-07-27 16:32:00 +00:00
										 |  |  | struct spdk_scsi_task { | 
					
						
							|  |  |  | 	uint8_t				status; | 
					
						
							|  |  |  | 	uint8_t				function; /* task mgmt function */ | 
					
						
							|  |  |  | 	uint8_t				response; /* task mgmt response */ | 
					
						
							| 
									
										
										
										
											2017-12-28 22:09:28 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-07-27 16:32:00 +00:00
										 |  |  | 	struct spdk_scsi_lun		*lun; | 
					
						
							|  |  |  | 	struct spdk_scsi_port		*target_port; | 
					
						
							|  |  |  | 	struct spdk_scsi_port		*initiator_port; | 
					
						
							| 
									
										
										
										
											2017-06-08 20:45:41 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	spdk_scsi_task_cpl		cpl_fn; | 
					
						
							|  |  |  | 	spdk_scsi_task_free		free_fn; | 
					
						
							| 
									
										
										
										
											2016-07-27 16:32:00 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	uint32_t ref; | 
					
						
							|  |  |  | 	uint32_t transfer_len; | 
					
						
							|  |  |  | 	uint32_t dxfer_dir; | 
					
						
							|  |  |  | 	uint32_t length; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	/**
 | 
					
						
							|  |  |  | 	 * Amount of data actually transferred.  Can be less than requested | 
					
						
							|  |  |  | 	 *  transfer_len - i.e. SCSI INQUIRY. | 
					
						
							|  |  |  | 	 */ | 
					
						
							|  |  |  | 	uint32_t data_transferred; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	uint64_t offset; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	uint8_t *cdb; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-11-04 18:45:54 +00:00
										 |  |  | 	/**
 | 
					
						
							|  |  |  | 	 * \internal | 
					
						
							|  |  |  | 	 * Size of internal buffer or zero when iov.iov_base is not internally managed. | 
					
						
							|  |  |  | 	 */ | 
					
						
							|  |  |  | 	uint32_t alloc_len; | 
					
						
							|  |  |  | 	/**
 | 
					
						
							|  |  |  | 	 * \internal | 
					
						
							|  |  |  | 	 * iov is internal buffer. Use iovs to access elements of IO. | 
					
						
							|  |  |  | 	 */ | 
					
						
							| 
									
										
										
										
											2016-10-04 15:10:35 +00:00
										 |  |  | 	struct iovec iov; | 
					
						
							|  |  |  | 	struct iovec *iovs; | 
					
						
							|  |  |  | 	uint16_t iovcnt; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-07-27 16:32:00 +00:00
										 |  |  | 	uint8_t sense_data[32]; | 
					
						
							|  |  |  | 	size_t sense_data_len; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-07-13 04:08:53 +00:00
										 |  |  | 	void *bdev_io; | 
					
						
							| 
									
										
										
										
											2016-07-27 16:32:00 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	TAILQ_ENTRY(spdk_scsi_task) scsi_link; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	uint32_t abort_id; | 
					
						
							| 
									
										
										
										
											2018-07-05 07:32:48 +00:00
										 |  |  | 	struct spdk_bdev_io_wait_entry bdev_io_wait; | 
					
						
							| 
									
										
										
										
											2016-07-27 16:32:00 +00:00
										 |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-05-03 19:41:55 +00:00
										 |  |  | struct spdk_scsi_port; | 
					
						
							| 
									
										
										
										
											2017-05-02 17:56:08 +00:00
										 |  |  | struct spdk_scsi_dev; | 
					
						
							| 
									
										
										
										
											2017-05-01 20:32:34 +00:00
										 |  |  | struct spdk_scsi_lun; | 
					
						
							| 
									
										
										
										
											2019-04-11 02:01:30 +00:00
										 |  |  | struct spdk_scsi_lun_desc; | 
					
						
							| 
									
										
										
										
											2018-07-10 07:11:20 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-04-11 02:01:30 +00:00
										 |  |  | typedef void (*spdk_scsi_lun_remove_cb_t)(struct spdk_scsi_lun *, void *); | 
					
						
							| 
									
										
										
										
											2019-04-11 09:10:47 +00:00
										 |  |  | typedef void (*spdk_scsi_dev_destruct_cb_t)(void *cb_arg, int rc); | 
					
						
							| 
									
										
										
										
											2016-08-02 17:43:00 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-05-15 06:26:56 +00:00
										 |  |  | /**
 | 
					
						
							|  |  |  |  * Initialize SCSI layer. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * \return 0 on success, -1 on failure. | 
					
						
							|  |  |  |  */ | 
					
						
							| 
									
										
										
										
											2017-06-14 23:20:25 +00:00
										 |  |  | int spdk_scsi_init(void); | 
					
						
							| 
									
										
										
										
											2017-06-13 17:30:46 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-05-15 06:26:56 +00:00
										 |  |  | /**
 | 
					
						
							|  |  |  |  * Stop and clean the SCSI layer. | 
					
						
							|  |  |  |  */ | 
					
						
							| 
									
										
										
										
											2017-10-06 14:17:38 +00:00
										 |  |  | void spdk_scsi_fini(void); | 
					
						
							| 
									
										
										
										
											2017-06-13 17:30:46 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-05-15 06:26:56 +00:00
										 |  |  | /**
 | 
					
						
							|  |  |  |  * Get the LUN id of the given logical unit. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * \param lun Logical unit. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * \return LUN id of the logical unit. | 
					
						
							|  |  |  |  */ | 
					
						
							| 
									
										
										
										
											2017-05-01 20:32:34 +00:00
										 |  |  | int spdk_scsi_lun_get_id(const struct spdk_scsi_lun *lun); | 
					
						
							| 
									
										
										
										
											2018-05-15 06:26:56 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | /**
 | 
					
						
							|  |  |  |  * Get the name of the bdev associated with the given logical unit. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * \param lun Logical unit. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * \return the name of the bdev associated with the logical unit. | 
					
						
							|  |  |  |  */ | 
					
						
							| 
									
										
										
										
											2018-01-10 05:55:53 +00:00
										 |  |  | const char *spdk_scsi_lun_get_bdev_name(const struct spdk_scsi_lun *lun); | 
					
						
							| 
									
										
										
										
											2018-05-15 06:26:56 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | /**
 | 
					
						
							|  |  |  |  * Get the SCSI device associated with the given logical unit. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * \param lun Logical unit. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * \return the SCSI device associated with the logical unit. | 
					
						
							|  |  |  |  */ | 
					
						
							| 
									
										
										
										
											2017-06-28 10:21:21 +00:00
										 |  |  | const struct spdk_scsi_dev *spdk_scsi_lun_get_dev(const struct spdk_scsi_lun *lun); | 
					
						
							| 
									
										
										
										
											2016-08-02 17:43:00 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-07-04 05:23:55 +00:00
										 |  |  | /**
 | 
					
						
							|  |  |  |  * Check if the logical unit is hot removing. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * \param lun Logical unit | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * \return true if removing, false otherwise. | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | bool spdk_scsi_lun_is_removing(const struct spdk_scsi_lun *lun); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-05-15 06:26:56 +00:00
										 |  |  | /**
 | 
					
						
							|  |  |  |  * Get the name of the given SCSI device. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * \param dev SCSI device. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * \return the name of the SCSI device on success, or NULL on failure. | 
					
						
							|  |  |  |  */ | 
					
						
							| 
									
										
										
										
											2017-05-02 17:56:08 +00:00
										 |  |  | const char *spdk_scsi_dev_get_name(const struct spdk_scsi_dev *dev); | 
					
						
							| 
									
										
										
										
											2018-05-15 06:26:56 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | /**
 | 
					
						
							|  |  |  |  * Get the id of the given SCSI device. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * \param dev SCSI device. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * \return the id of the SCSI device. | 
					
						
							|  |  |  |  */ | 
					
						
							| 
									
										
										
										
											2017-05-02 17:56:08 +00:00
										 |  |  | int spdk_scsi_dev_get_id(const struct spdk_scsi_dev *dev); | 
					
						
							| 
									
										
										
										
											2018-05-15 06:26:56 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | /**
 | 
					
						
							|  |  |  |  * Get the logical unit of the given SCSI device whose id is lun_id. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * \param dev SCSI device. | 
					
						
							| 
									
										
										
										
											2018-06-19 10:56:11 +00:00
										 |  |  |  * \param lun_id Id of the logical unit. | 
					
						
							| 
									
										
										
										
											2018-05-15 06:26:56 +00:00
										 |  |  |  * | 
					
						
							|  |  |  |  * \return the logical unit on success, or NULL on failure. | 
					
						
							|  |  |  |  */ | 
					
						
							| 
									
										
										
										
											2017-05-02 17:56:08 +00:00
										 |  |  | struct spdk_scsi_lun *spdk_scsi_dev_get_lun(struct spdk_scsi_dev *dev, int lun_id); | 
					
						
							| 
									
										
										
										
											2018-05-15 06:26:56 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | /**
 | 
					
						
							|  |  |  |  * Check whether the SCSI device has any pending task. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * \param dev SCSI device. | 
					
						
							| 
									
										
										
										
											2019-10-15 07:46:15 +00:00
										 |  |  |  * \param initiator_port Check tasks only from the initiator if specified, or | 
					
						
							|  |  |  |  * all all tasks otherwise. | 
					
						
							| 
									
										
										
										
											2018-05-15 06:26:56 +00:00
										 |  |  |  * | 
					
						
							|  |  |  |  * \return true if the SCSI device has any pending task, or false otherwise. | 
					
						
							|  |  |  |  */ | 
					
						
							| 
									
										
										
										
											2019-10-15 07:46:15 +00:00
										 |  |  | bool spdk_scsi_dev_has_pending_tasks(const struct spdk_scsi_dev *dev, | 
					
						
							|  |  |  | 				     const struct spdk_scsi_port *initiator_port); | 
					
						
							| 
									
										
										
										
											2018-05-15 06:26:56 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | /**
 | 
					
						
							|  |  |  |  * Destruct the SCSI decice. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * \param dev SCSI device. | 
					
						
							| 
									
										
										
										
											2019-04-11 09:10:47 +00:00
										 |  |  |  * \param cb_fn Callback function. | 
					
						
							|  |  |  |  * \param cb_arg Argument to callback function. | 
					
						
							| 
									
										
										
										
											2018-05-15 06:26:56 +00:00
										 |  |  |  */ | 
					
						
							| 
									
										
										
										
											2019-04-11 09:10:47 +00:00
										 |  |  | void spdk_scsi_dev_destruct(struct spdk_scsi_dev *dev, | 
					
						
							|  |  |  | 			    spdk_scsi_dev_destruct_cb_t cb_fn, void *cb_arg); | 
					
						
							| 
									
										
										
										
											2018-05-15 06:26:56 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | /**
 | 
					
						
							|  |  |  |  * Execute the SCSI management task. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * The task can be constructed by the function spdk_scsi_task_construct(). | 
					
						
							| 
									
										
										
										
											2018-12-09 22:57:30 +00:00
										 |  |  |  * Code of task management function to be executed is set before calling this API. | 
					
						
							| 
									
										
										
										
											2018-05-15 06:26:56 +00:00
										 |  |  |  * | 
					
						
							|  |  |  |  * \param dev SCSI device. | 
					
						
							|  |  |  |  * \param task SCSI task to be executed. | 
					
						
							|  |  |  |  */ | 
					
						
							| 
									
										
										
										
											2018-12-09 22:57:30 +00:00
										 |  |  | void spdk_scsi_dev_queue_mgmt_task(struct spdk_scsi_dev *dev, struct spdk_scsi_task *task); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-05-15 06:26:56 +00:00
										 |  |  | /**
 | 
					
						
							|  |  |  |  * Execute the SCSI task. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * The task can be constructed by the function spdk_scsi_task_construct(). | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * \param dev SCSI device. | 
					
						
							|  |  |  |  * \param task Task to be executed. | 
					
						
							|  |  |  |  */ | 
					
						
							| 
									
										
										
										
											2016-07-27 16:32:00 +00:00
										 |  |  | void spdk_scsi_dev_queue_task(struct spdk_scsi_dev *dev, struct spdk_scsi_task *task); | 
					
						
							| 
									
										
										
										
											2018-05-15 06:26:56 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | /**
 | 
					
						
							|  |  |  |  * Add a new port to the given SCSI device. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * \param dev SCSI device. | 
					
						
							|  |  |  |  * \param id Port id. | 
					
						
							|  |  |  |  * \param name Port name. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * \return 0 on success, -1 on failure. | 
					
						
							|  |  |  |  */ | 
					
						
							| 
									
										
										
										
											2016-07-27 16:32:00 +00:00
										 |  |  | int spdk_scsi_dev_add_port(struct spdk_scsi_dev *dev, uint64_t id, const char *name); | 
					
						
							| 
									
										
										
										
											2018-05-15 06:26:56 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | /**
 | 
					
						
							|  |  |  |  * Delete a specified port of the given SCSI device. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * \param dev SCSI device. | 
					
						
							|  |  |  |  * \param id Port id. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * \return 0 on success, -1 on failure. | 
					
						
							|  |  |  |  */ | 
					
						
							| 
									
										
										
										
											2017-10-11 07:28:32 +00:00
										 |  |  | int spdk_scsi_dev_delete_port(struct spdk_scsi_dev *dev, uint64_t id); | 
					
						
							| 
									
										
										
										
											2018-05-15 06:26:56 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | /**
 | 
					
						
							|  |  |  |  * Get the port of the given SCSI device whose port ID is id. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * \param dev SCSI device. | 
					
						
							|  |  |  |  * \param id Port id. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * \return the port of the SCSI device on success, or NULL on failure. | 
					
						
							|  |  |  |  */ | 
					
						
							| 
									
										
										
										
											2016-07-27 16:32:00 +00:00
										 |  |  | struct spdk_scsi_port *spdk_scsi_dev_find_port_by_id(struct spdk_scsi_dev *dev, uint64_t id); | 
					
						
							| 
									
										
										
										
											2018-05-15 06:26:56 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | /**
 | 
					
						
							|  |  |  |  * Allocate I/O channels for all LUNs of the given SCSI device. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * \param dev SCSI device. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * \return 0 on success, -1 on failure. | 
					
						
							|  |  |  |  */ | 
					
						
							| 
									
										
										
										
											2016-09-20 19:46:28 +00:00
										 |  |  | int spdk_scsi_dev_allocate_io_channels(struct spdk_scsi_dev *dev); | 
					
						
							| 
									
										
										
										
											2018-05-15 06:26:56 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | /**
 | 
					
						
							|  |  |  |  * Free I/O channels from all LUNs of the given SCSI device. | 
					
						
							|  |  |  |  */ | 
					
						
							| 
									
										
										
										
											2016-09-20 19:46:28 +00:00
										 |  |  | void spdk_scsi_dev_free_io_channels(struct spdk_scsi_dev *dev); | 
					
						
							| 
									
										
										
										
											2016-07-27 16:32:00 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | /**
 | 
					
						
							| 
									
										
										
										
											2018-05-15 06:26:56 +00:00
										 |  |  |  * Construct a SCSI device object using the given parameters. | 
					
						
							| 
									
										
										
										
											2017-04-25 17:35:22 +00:00
										 |  |  |  * | 
					
						
							|  |  |  |  * \param name Name for the SCSI device. | 
					
						
							| 
									
										
										
										
											2018-01-10 05:55:53 +00:00
										 |  |  |  * \param bdev_name_list List of bdev names to attach to the LUNs for this SCSI | 
					
						
							| 
									
										
										
										
											2018-05-15 06:26:56 +00:00
										 |  |  |  * device. | 
					
						
							|  |  |  |  * \param lun_id_list List of LUN IDs for the LUN in this SCSI device. Caller is | 
					
						
							|  |  |  |  * responsible for managing the memory containing this list. lun_id_list[x] is | 
					
						
							|  |  |  |  * the LUN ID for lun_list[x]. | 
					
						
							| 
									
										
										
										
											2017-04-25 17:35:22 +00:00
										 |  |  |  * \param num_luns Number of entries in lun_list and lun_id_list. | 
					
						
							| 
									
										
										
										
											2018-06-18 14:39:39 +00:00
										 |  |  |  * \param protocol_id SCSI SPC protocol identifier to report in INQUIRY data | 
					
						
							| 
									
										
										
										
											2018-05-15 06:26:56 +00:00
										 |  |  |  * \param hotremove_cb Callback to lun hotremoval. Will be called once hotremove | 
					
						
							|  |  |  |  * is first triggered. | 
					
						
							|  |  |  |  * \param hotremove_ctx Additional argument to hotremove_cb. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * \return the constructed spdk_scsi_dev object. | 
					
						
							| 
									
										
										
										
											2017-04-25 17:35:22 +00:00
										 |  |  |  */ | 
					
						
							| 
									
										
										
										
											2016-07-27 16:32:00 +00:00
										 |  |  | struct spdk_scsi_dev *spdk_scsi_dev_construct(const char *name, | 
					
						
							| 
									
										
										
										
											2018-01-10 05:55:53 +00:00
										 |  |  | 		const char *bdev_name_list[], | 
					
						
							| 
									
										
										
										
											2016-07-27 16:32:00 +00:00
										 |  |  | 		int *lun_id_list, | 
					
						
							| 
									
										
										
										
											2017-05-24 14:08:25 +00:00
										 |  |  | 		int num_luns, | 
					
						
							| 
									
										
										
										
											2017-06-28 10:21:21 +00:00
										 |  |  | 		uint8_t protocol_id, | 
					
						
							|  |  |  | 		void (*hotremove_cb)(const struct spdk_scsi_lun *, void *), | 
					
						
							|  |  |  | 		void *hotremove_ctx); | 
					
						
							| 
									
										
										
										
											2016-07-27 16:32:00 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-09-08 15:32:48 +00:00
										 |  |  | /**
 | 
					
						
							|  |  |  |  * Construct a SCSI device object using the more given parameters. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * \param name Name for the SCSI device. | 
					
						
							|  |  |  |  * \param bdev_name_list List of bdev names to attach to the LUNs for this SCSI | 
					
						
							|  |  |  |  * device. | 
					
						
							|  |  |  |  * \param lun_id_list List of LUN IDs for the LUN in this SCSI device. Caller is | 
					
						
							|  |  |  |  * responsible for managing the memory containing this list. lun_id_list[x] is | 
					
						
							|  |  |  |  * the LUN ID for lun_list[x]. | 
					
						
							|  |  |  |  * \param num_luns Number of entries in lun_list and lun_id_list. | 
					
						
							|  |  |  |  * \param protocol_id SCSI SPC protocol identifier to report in INQUIRY data | 
					
						
							|  |  |  |  * \param resize_cb Callback of lun resize. | 
					
						
							|  |  |  |  * \param resize_ctx Additional argument to resize_cb. | 
					
						
							|  |  |  |  * \param hotremove_cb Callback to lun hotremoval. Will be called once hotremove | 
					
						
							|  |  |  |  * is first triggered. | 
					
						
							|  |  |  |  * \param hotremove_ctx Additional argument to hotremove_cb. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * \return the constructed spdk_scsi_dev object. | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | struct spdk_scsi_dev *spdk_scsi_dev_construct_ext(const char *name, | 
					
						
							|  |  |  | 		const char *bdev_name_list[], | 
					
						
							|  |  |  | 		int *lun_id_list, | 
					
						
							|  |  |  | 		int num_luns, | 
					
						
							|  |  |  | 		uint8_t protocol_id, | 
					
						
							|  |  |  | 		void (*resize_cb)(const struct spdk_scsi_lun *, void *), | 
					
						
							|  |  |  | 		void *resize_ctx, | 
					
						
							|  |  |  | 		void (*hotremove_cb)(const struct spdk_scsi_lun *, void *), | 
					
						
							|  |  |  | 		void *hotremove_ctx); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-05-15 06:26:56 +00:00
										 |  |  | /**
 | 
					
						
							|  |  |  |  * Delete a logical unit of the given SCSI device. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * \param dev SCSI device. | 
					
						
							|  |  |  |  * \param lun Logical unit to delete. | 
					
						
							|  |  |  |  */ | 
					
						
							| 
									
										
										
										
											2016-07-27 16:32:00 +00:00
										 |  |  | void spdk_scsi_dev_delete_lun(struct spdk_scsi_dev *dev, struct spdk_scsi_lun *lun); | 
					
						
							| 
									
										
										
										
											2018-05-15 06:26:56 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | /**
 | 
					
						
							|  |  |  |  * Add a new logical unit to the given SCSI device. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * \param dev SCSI device. | 
					
						
							|  |  |  |  * \param bdev_name Name of the bdev attached to the logical unit. | 
					
						
							|  |  |  |  * \param lun_id LUN id for the new logical unit. | 
					
						
							|  |  |  |  * \param hotremove_cb Callback to lun hotremoval. Will be called once hotremove | 
					
						
							|  |  |  |  * is first triggered. | 
					
						
							|  |  |  |  * \param hotremove_ctx Additional argument to hotremove_cb. | 
					
						
							|  |  |  |  */ | 
					
						
							| 
									
										
										
										
											2018-01-12 00:42:02 +00:00
										 |  |  | int spdk_scsi_dev_add_lun(struct spdk_scsi_dev *dev, const char *bdev_name, int lun_id, | 
					
						
							|  |  |  | 			  void (*hotremove_cb)(const struct spdk_scsi_lun *, void *), | 
					
						
							|  |  |  | 			  void *hotremove_ctx); | 
					
						
							| 
									
										
										
										
											2016-07-27 16:32:00 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-09-08 15:32:48 +00:00
										 |  |  | /**
 | 
					
						
							|  |  |  |  * Add a new logical unit to the given SCSI device with more callbacks. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * \param dev SCSI device. | 
					
						
							|  |  |  |  * \param bdev_name Name of the bdev attached to the logical unit. | 
					
						
							|  |  |  |  * \param lun_id LUN id for the new logical unit. | 
					
						
							|  |  |  |  * \param resize_cb Callback of lun resize. | 
					
						
							|  |  |  |  * \param resize_ctx Additional argument to resize_cb. | 
					
						
							|  |  |  |  * \param hotremove_cb Callback to lun hotremoval. Will be called once hotremove | 
					
						
							|  |  |  |  * is first triggered. | 
					
						
							|  |  |  |  * \param hotremove_ctx Additional argument to hotremove_cb. | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | int spdk_scsi_dev_add_lun_ext(struct spdk_scsi_dev *dev, const char *bdev_name, int lun_id, | 
					
						
							|  |  |  | 			      void (*resize_cb)(const struct spdk_scsi_lun *, void *), | 
					
						
							|  |  |  | 			      void *resize_ctx, | 
					
						
							|  |  |  | 			      void (*hotremove_cb)(const struct spdk_scsi_lun *, void *), | 
					
						
							|  |  |  | 			      void *hotremove_ctx); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-05-15 06:26:56 +00:00
										 |  |  | /**
 | 
					
						
							|  |  |  |  * Create a new SCSI port. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * \param id Port id. | 
					
						
							|  |  |  |  * \param index Port index. | 
					
						
							|  |  |  |  * \param name Port Name. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * \return a pointer to the created SCSI port on success, or NULL on failure. | 
					
						
							|  |  |  |  */ | 
					
						
							| 
									
										
										
										
											2017-05-03 19:41:55 +00:00
										 |  |  | struct spdk_scsi_port *spdk_scsi_port_create(uint64_t id, uint16_t index, const char *name); | 
					
						
							| 
									
										
										
										
											2018-05-15 06:26:56 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | /**
 | 
					
						
							|  |  |  |  * Free the SCSI port. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * \param pport SCSI port to free. | 
					
						
							|  |  |  |  */ | 
					
						
							| 
									
										
										
										
											2017-05-03 19:41:55 +00:00
										 |  |  | void spdk_scsi_port_free(struct spdk_scsi_port **pport); | 
					
						
							| 
									
										
										
										
											2016-07-27 16:32:00 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-05-15 06:26:56 +00:00
										 |  |  | /**
 | 
					
						
							|  |  |  |  * Get the name of the SCSI port. | 
					
						
							|  |  |  |  * | 
					
						
							| 
									
										
										
										
											2018-06-19 10:56:11 +00:00
										 |  |  |  * \param port SCSI port to query. | 
					
						
							| 
									
										
										
										
											2018-05-15 06:26:56 +00:00
										 |  |  |  * | 
					
						
							|  |  |  |  * \return the name of the SCSI port. | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | const char *spdk_scsi_port_get_name(const struct spdk_scsi_port *port); | 
					
						
							| 
									
										
										
										
											2016-07-27 16:32:00 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-05-15 06:26:56 +00:00
										 |  |  | /**
 | 
					
						
							|  |  |  |  * Construct a new SCSI task. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * \param task SCSI task to consturct. | 
					
						
							|  |  |  |  * \param cpl_fn Called when the task is completed. | 
					
						
							|  |  |  |  * \param free_fn Called when the task is freed | 
					
						
							|  |  |  |  */ | 
					
						
							| 
									
										
										
										
											2017-05-13 00:16:44 +00:00
										 |  |  | void spdk_scsi_task_construct(struct spdk_scsi_task *task, | 
					
						
							| 
									
										
										
										
											2017-06-08 20:45:41 +00:00
										 |  |  | 			      spdk_scsi_task_cpl cpl_fn, | 
					
						
							| 
									
										
										
										
											2018-01-04 21:03:34 +00:00
										 |  |  | 			      spdk_scsi_task_free free_fn); | 
					
						
							| 
									
										
										
										
											2018-05-15 06:26:56 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | /**
 | 
					
						
							|  |  |  |  * Put the SCSI task. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * \param task SCSI task to put. | 
					
						
							|  |  |  |  */ | 
					
						
							| 
									
										
										
										
											2016-09-28 06:49:06 +00:00
										 |  |  | void spdk_scsi_task_put(struct spdk_scsi_task *task); | 
					
						
							| 
									
										
										
										
											2016-11-04 18:45:54 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | /**
 | 
					
						
							|  |  |  |  * Set internal buffer to given one. Caller is owner of that buffer. | 
					
						
							|  |  |  |  * | 
					
						
							| 
									
										
										
										
											2018-05-15 06:26:56 +00:00
										 |  |  |  * \param task SCSI task. | 
					
						
							|  |  |  |  * \param data Pointer to buffer. | 
					
						
							|  |  |  |  * \param len Buffer length. | 
					
						
							| 
									
										
										
										
											2016-11-04 18:45:54 +00:00
										 |  |  |  */ | 
					
						
							|  |  |  | void spdk_scsi_task_set_data(struct spdk_scsi_task *task, void *data, uint32_t len); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-05-15 06:26:56 +00:00
										 |  |  | /**
 | 
					
						
							|  |  |  |  * Single buffer -> vector of buffers. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * \param task SCSI task. | 
					
						
							|  |  |  |  * \param src A pointer to the data buffer read from. | 
					
						
							|  |  |  |  * \param len Length of the data buffer read from. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * \return the total length of the vector of buffers written into on success, or | 
					
						
							|  |  |  |  * -1 on failure. | 
					
						
							|  |  |  |  */ | 
					
						
							| 
									
										
										
										
											2016-11-14 19:14:12 +00:00
										 |  |  | int spdk_scsi_task_scatter_data(struct spdk_scsi_task *task, const void *src, size_t len); | 
					
						
							| 
									
										
										
										
											2018-05-15 06:26:56 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | /**
 | 
					
						
							|  |  |  |  * Vector of buffers -> single buffer. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * \param task SCSI task, | 
					
						
							|  |  |  |  * \param len Length of the buffer allocated and written into. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * \return a pointer to the buffer allocated and written into. | 
					
						
							|  |  |  |  */ | 
					
						
							| 
									
										
										
										
											2016-11-14 19:14:12 +00:00
										 |  |  | void *spdk_scsi_task_gather_data(struct spdk_scsi_task *task, int *len); | 
					
						
							| 
									
										
										
										
											2018-05-15 06:26:56 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | /**
 | 
					
						
							|  |  |  |  * Build sense data for the SCSI task. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * \param task SCSI task. | 
					
						
							|  |  |  |  * \param sk Sense key. | 
					
						
							|  |  |  |  * \param asc Additional sense code. | 
					
						
							|  |  |  |  * \param ascq Additional sense code qualifier. | 
					
						
							|  |  |  |  */ | 
					
						
							| 
									
										
										
										
											2016-10-09 07:03:43 +00:00
										 |  |  | void spdk_scsi_task_build_sense_data(struct spdk_scsi_task *task, int sk, int asc, | 
					
						
							|  |  |  | 				     int ascq); | 
					
						
							| 
									
										
										
										
											2018-05-15 06:26:56 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | /**
 | 
					
						
							|  |  |  |  * Set SCSI status code to the SCSI task. When the status code is CHECK CONDITION, | 
					
						
							|  |  |  |  * sense data is build too. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * \param task SCSI task. | 
					
						
							|  |  |  |  * \param sc Sense code | 
					
						
							|  |  |  |  * \param sk Sense key. | 
					
						
							|  |  |  |  * \param asc Additional sense code. | 
					
						
							|  |  |  |  * \param ascq Additional sense code qualifier. | 
					
						
							|  |  |  |  */ | 
					
						
							| 
									
										
										
										
											2016-10-28 19:56:36 +00:00
										 |  |  | void spdk_scsi_task_set_status(struct spdk_scsi_task *task, int sc, int sk, int asc, | 
					
						
							|  |  |  | 			       int ascq); | 
					
						
							| 
									
										
										
										
											2018-05-15 06:26:56 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | /**
 | 
					
						
							|  |  |  |  * Copy SCSI status. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * \param dst SCSI task whose status is written to. | 
					
						
							|  |  |  |  * \param src SCSI task whose status is read from. | 
					
						
							|  |  |  |  */ | 
					
						
							| 
									
										
										
										
											2018-06-11 04:20:23 +00:00
										 |  |  | void spdk_scsi_task_copy_status(struct spdk_scsi_task *dst, struct spdk_scsi_task *src); | 
					
						
							| 
									
										
										
										
											2018-05-15 06:26:56 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | /**
 | 
					
						
							|  |  |  |  * Process the SCSI task when no LUN is attached. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * \param task SCSI task. | 
					
						
							|  |  |  |  */ | 
					
						
							| 
									
										
										
										
											2017-02-26 12:41:06 +00:00
										 |  |  | void spdk_scsi_task_process_null_lun(struct spdk_scsi_task *task); | 
					
						
							| 
									
										
										
										
											2016-07-27 16:32:00 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-12-04 13:24:34 +00:00
										 |  |  | /**
 | 
					
						
							|  |  |  |  * Process the aborted SCSI task. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * \param task SCSI task. | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | void spdk_scsi_task_process_abort(struct spdk_scsi_task *task); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-07-10 07:11:20 +00:00
										 |  |  | /**
 | 
					
						
							|  |  |  |  * Open a logical unit for I/O operations. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * The registered callback function must get all tasks from the upper layer | 
					
						
							|  |  |  |  *  (e.g. iSCSI) to the LUN done, free the IO channel of the LUN if allocated, | 
					
						
							|  |  |  |  *  and then close the LUN. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * \param lun Logical unit to open. | 
					
						
							|  |  |  |  * \param hotremove_cb Callback function for hot removal of the logical unit. | 
					
						
							|  |  |  |  * \param hotremove_ctx Param for hot removal callback function. | 
					
						
							|  |  |  |  * \param desc Output parameter for the descriptor when operation is successful. | 
					
						
							|  |  |  |  * \return 0 if operation is successful, suitable errno value otherwise | 
					
						
							|  |  |  |  */ | 
					
						
							| 
									
										
										
										
											2019-04-11 02:01:30 +00:00
										 |  |  | int spdk_scsi_lun_open(struct spdk_scsi_lun *lun, spdk_scsi_lun_remove_cb_t hotremove_cb, | 
					
						
							|  |  |  | 		       void *hotremove_ctx, struct spdk_scsi_lun_desc **desc); | 
					
						
							| 
									
										
										
										
											2018-07-10 07:11:20 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | /**
 | 
					
						
							|  |  |  |  * Close an opened logical unit. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * \param desc Descriptor of the logical unit. | 
					
						
							|  |  |  |  */ | 
					
						
							| 
									
										
										
										
											2019-04-11 02:01:30 +00:00
										 |  |  | void spdk_scsi_lun_close(struct spdk_scsi_lun_desc *desc); | 
					
						
							| 
									
										
										
										
											2018-07-10 07:11:20 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-06-28 02:42:52 +00:00
										 |  |  | /**
 | 
					
						
							|  |  |  |  * Allocate I/O channel for the LUN | 
					
						
							|  |  |  |  * | 
					
						
							| 
									
										
										
										
											2018-07-10 07:17:34 +00:00
										 |  |  |  * \param desc Descriptor of the logical unit. | 
					
						
							| 
									
										
										
										
											2018-06-28 02:42:52 +00:00
										 |  |  |  * | 
					
						
							|  |  |  |  * \return 0 on success, -1 on failure. | 
					
						
							|  |  |  |  */ | 
					
						
							| 
									
										
										
										
											2019-04-11 02:01:30 +00:00
										 |  |  | int spdk_scsi_lun_allocate_io_channel(struct spdk_scsi_lun_desc *desc); | 
					
						
							| 
									
										
										
										
											2018-06-28 02:42:52 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | /**
 | 
					
						
							|  |  |  |  * Free I/O channel from the logical unit | 
					
						
							|  |  |  |  * | 
					
						
							| 
									
										
										
										
											2018-07-10 07:17:34 +00:00
										 |  |  |  * \param desc Descriptor of the logical unit. | 
					
						
							| 
									
										
										
										
											2018-06-28 02:42:52 +00:00
										 |  |  |  */ | 
					
						
							| 
									
										
										
										
											2019-04-11 02:01:30 +00:00
										 |  |  | void spdk_scsi_lun_free_io_channel(struct spdk_scsi_lun_desc *desc); | 
					
						
							| 
									
										
										
										
											2018-06-28 02:42:52 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-02-26 06:53:10 +00:00
										 |  |  | /**
 | 
					
						
							|  |  |  |  * Get DIF context for SCSI LUN and SCSI command. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * \param lun Logical unit. | 
					
						
							| 
									
										
										
										
											2019-10-28 04:05:46 +00:00
										 |  |  |  * \param task SCSI task which has the payload. | 
					
						
							| 
									
										
										
										
											2019-02-26 06:53:10 +00:00
										 |  |  |  * \param dif_ctx Output parameter which will contain initialized DIF context. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * \return true on success or false otherwise. | 
					
						
							|  |  |  |  */ | 
					
						
							| 
									
										
										
										
											2019-10-28 04:05:46 +00:00
										 |  |  | bool spdk_scsi_lun_get_dif_ctx(struct spdk_scsi_lun *lun, struct spdk_scsi_task *task, | 
					
						
							|  |  |  | 			       struct spdk_dif_ctx *dif_ctx); | 
					
						
							| 
									
										
										
										
											2018-11-27 12:38:35 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | /**
 | 
					
						
							|  |  |  |  * Set iSCSI Initiator port TransportID | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * \param port SCSI initiator port. | 
					
						
							|  |  |  |  * \param iscsi_name Initiator name. | 
					
						
							|  |  |  |  * \param isid Session ID. | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | void spdk_scsi_port_set_iscsi_transport_id(struct spdk_scsi_port *port, | 
					
						
							|  |  |  | 		char *iscsi_name, uint64_t isid); | 
					
						
							| 
									
										
										
										
											2019-04-03 02:38:22 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | /**
 | 
					
						
							|  |  |  |  * Convert LUN ID from integer to LUN format | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * \param lun_id Integer LUN ID | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * \return LUN format of LUN ID | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | uint64_t spdk_scsi_lun_id_int_to_fmt(int lun_id); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /**
 | 
					
						
							|  |  |  |  * Convert LUN ID from LUN format to integer | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * \param fmt_lun LUN format of LUN ID | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * \return integer LUN ID | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | int spdk_scsi_lun_id_fmt_to_int(uint64_t fmt_lun); | 
					
						
							| 
									
										
										
										
											2017-12-07 20:25:19 +00:00
										 |  |  | #ifdef __cplusplus
 | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-07-27 16:32:00 +00:00
										 |  |  | #endif /* SPDK_SCSI_H */
 |