2006-05-11 10:00:21 +03:00
/*
* iSER transport for the Open iSCSI Initiator & iSER transport internals
*
* Copyright ( C ) 2004 Dmitry Yusupov
* Copyright ( C ) 2004 Alex Aizman
* Copyright ( C ) 2005 Mike Christie
* based on code maintained by open - iscsi @ googlegroups . com
*
* Copyright ( c ) 2004 , 2005 , 2006 Voltaire , Inc . All rights reserved .
* Copyright ( c ) 2005 , 2006 Cisco Systems . All rights reserved .
2014-04-01 16:28:41 +03:00
* Copyright ( c ) 2013 - 2014 Mellanox Technologies . All rights reserved .
2006-05-11 10:00:21 +03:00
*
* This software is available to you under a choice of one of two
* licenses . You may choose to be licensed under the terms of the GNU
* General Public License ( GPL ) Version 2 , available from the file
* COPYING in the main directory of this source tree , or the
* OpenIB . org BSD license below :
*
* 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 .
*
* THE SOFTWARE IS PROVIDED " AS IS " , WITHOUT WARRANTY OF ANY KIND ,
* EXPRESS OR IMPLIED , INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
* MERCHANTABILITY , FITNESS FOR A PARTICULAR PURPOSE AND
* NONINFRINGEMENT . IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS
* BE LIABLE FOR ANY CLAIM , DAMAGES OR OTHER LIABILITY , WHETHER IN AN
* ACTION OF CONTRACT , TORT OR OTHERWISE , ARISING FROM , OUT OF OR IN
* CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
* SOFTWARE .
*/
# ifndef __ISCSI_ISER_H__
# define __ISCSI_ISER_H__
# include <linux/types.h>
# include <linux/net.h>
2013-05-01 13:25:25 +00:00
# include <linux/printk.h>
2006-05-11 10:00:21 +03:00
# include <scsi/libiscsi.h>
# include <scsi/scsi_transport_iscsi.h>
2014-03-05 19:43:48 +02:00
# include <scsi/scsi_cmnd.h>
# include <scsi/scsi_device.h>
2015-12-09 14:12:03 +02:00
# include <scsi/iser.h>
2006-05-11 10:00:21 +03:00
2011-06-06 10:43:46 +00:00
# include <linux/interrupt.h>
2006-05-11 10:00:21 +03:00
# include <linux/wait.h>
# include <linux/sched.h>
# include <linux/list.h>
# include <linux/slab.h>
# include <linux/dma-mapping.h>
# include <linux/mutex.h>
# include <linux/mempool.h>
# include <linux/uio.h>
# include <linux/socket.h>
# include <linux/in.h>
# include <linux/in6.h>
# include <rdma/ib_verbs.h>
# include <rdma/ib_fmr_pool.h>
# include <rdma/rdma_cm.h>
# define DRV_NAME "iser"
# define PFX DRV_NAME ": "
2015-04-14 18:08:27 +03:00
# define DRV_VER "1.6"
2006-05-11 10:00:21 +03:00
2014-10-01 14:02:14 +03:00
# define iser_dbg(fmt, arg...) \
do { \
2014-12-07 16:10:04 +02:00
if ( unlikely ( iser_debug_level > 2 ) ) \
2014-10-01 14:02:14 +03:00
printk ( KERN_DEBUG PFX " %s: " fmt , \
__func__ , # # arg ) ; \
2008-04-29 13:46:52 -07:00
} while ( 0 )
# define iser_warn(fmt, arg...) \
2013-05-01 13:25:25 +00:00
do { \
2014-12-07 16:10:04 +02:00
if ( unlikely ( iser_debug_level > 0 ) ) \
2014-10-01 14:02:14 +03:00
pr_warn ( PFX " %s: " fmt , \
2013-05-01 13:25:25 +00:00
__func__ , # # arg ) ; \
} while ( 0 )
# define iser_info(fmt, arg...) \
2006-05-11 10:00:21 +03:00
do { \
2014-12-07 16:10:04 +02:00
if ( unlikely ( iser_debug_level > 1 ) ) \
2014-10-01 14:02:14 +03:00
pr_info ( PFX " %s: " fmt , \
2006-05-11 10:00:21 +03:00
__func__ , # # arg ) ; \
} while ( 0 )
2014-12-07 16:10:04 +02:00
# define iser_err(fmt, arg...) \
pr_err ( PFX " %s: " fmt , __func__ , # # arg )
2006-05-11 10:00:21 +03:00
2006-09-11 12:22:30 +03:00
# define SHIFT_4K 12
2011-08-01 21:12:09 +00:00
# define SIZE_4K (1ULL << SHIFT_4K)
2006-09-11 12:22:30 +03:00
# define MASK_4K (~(SIZE_4K-1))
2015-08-06 18:33:04 +03:00
/* Default support is 512KB I/O size */
# define ISER_DEF_MAX_SECTORS 1024
2019-09-12 10:35:34 +00:00
# define ISCSI_ISER_DEF_SG_TABLESIZE \
( ( ISER_DEF_MAX_SECTORS * SECTOR_SIZE ) > > SHIFT_4K )
/* Maximum support is 16MB I/O size */
# define ISCSI_ISER_MAX_SG_TABLESIZE ((32768 * SECTOR_SIZE) >> SHIFT_4K)
2015-08-06 18:33:04 +03:00
2013-07-28 12:35:38 +03:00
# define ISER_DEF_XMIT_CMDS_DEFAULT 512
# if ISCSI_DEF_XMIT_CMDS_MAX > ISER_DEF_XMIT_CMDS_DEFAULT
# define ISER_DEF_XMIT_CMDS_MAX ISCSI_DEF_XMIT_CMDS_MAX
# else
# define ISER_DEF_XMIT_CMDS_MAX ISER_DEF_XMIT_CMDS_DEFAULT
# endif
# define ISER_DEF_CMD_PER_LUN ISER_DEF_XMIT_CMDS_MAX
2006-05-11 10:00:21 +03:00
/* QP settings */
/* Maximal bounds on received asynchronous PDUs */
# define ISER_MAX_RX_MISC_PDUS 4 /* NOOP_IN(2) , ASYNC_EVENT(2) */
# define ISER_MAX_TX_MISC_PDUS 6 / * NOOP_OUT(2), TEXT(1), *
* SCSI_TMFUNC ( 2 ) , LOGOUT ( 1 ) */
2013-07-28 12:35:38 +03:00
# define ISER_QP_MAX_RECV_DTOS (ISER_DEF_XMIT_CMDS_MAX)
2010-02-08 13:17:42 +00:00
2013-07-28 12:35:38 +03:00
# define ISER_MIN_POSTED_RX (ISER_DEF_XMIT_CMDS_MAX >> 2)
2006-05-11 10:00:21 +03:00
/* the max TX (send) WR supported by the iSER QP is defined by *
* max_send_wr = T * ( 1 + D ) + C ; D is how many inflight dataouts we expect *
* to have at max for SCSI command . The tx posting & completion handling code *
* supports - EAGAIN scheme where tx is suspended till the QP has room for more *
* send WR . D = 8 comes from 64 K / 8 K */
# define ISER_INFLIGHT_DATAOUTS 8
2013-07-28 12:35:38 +03:00
# define ISER_QP_MAX_REQ_DTOS (ISER_DEF_XMIT_CMDS_MAX * \
2006-05-11 10:00:21 +03:00
( 1 + ISER_INFLIGHT_DATAOUTS ) + \
ISER_MAX_TX_MISC_PDUS + \
ISER_MAX_RX_MISC_PDUS )
2014-03-05 19:43:47 +02:00
/* Max registration work requests per command */
# define ISER_MAX_REG_WR_PER_CMD 5
/* For Signature we don't support DATAOUTs so no need to make room for them */
# define ISER_QP_SIG_MAX_REQ_DTOS (ISER_DEF_XMIT_CMDS_MAX * \
( 1 + ISER_MAX_REG_WR_PER_CMD ) + \
ISER_MAX_TX_MISC_PDUS + \
ISER_MAX_RX_MISC_PDUS )
2014-12-07 16:09:52 +02:00
# define ISER_GET_MAX_XMIT_CMDS(send_wr) ((send_wr \
- ISER_MAX_TX_MISC_PDUS \
- ISER_MAX_RX_MISC_PDUS ) / \
( 1 + ISER_INFLIGHT_DATAOUTS ) )
2014-10-01 14:02:12 +03:00
# define ISER_SIGNAL_CMD_COUNT 32
2014-10-01 14:02:11 +03:00
2010-02-08 13:17:42 +00:00
/* Constant PDU lengths calculations */
2015-12-09 14:12:03 +02:00
# define ISER_HEADERS_LEN (sizeof(struct iser_ctrl) + sizeof(struct iscsi_hdr))
2010-02-08 13:17:42 +00:00
# define ISER_RECV_DATA_SEG_LEN 128
# define ISER_RX_PAYLOAD_SIZE (ISER_HEADERS_LEN + ISER_RECV_DATA_SEG_LEN)
# define ISER_RX_LOGIN_SIZE (ISER_HEADERS_LEN + ISCSI_DEF_MAX_RECV_SEG_LEN)
2006-05-11 10:00:21 +03:00
/* Length of an object name string */
# define ISER_OBJECT_NAME_SIZE 64
2014-10-01 14:01:57 +03:00
enum iser_conn_state {
2006-05-11 10:00:21 +03:00
ISER_CONN_INIT , /* descriptor allocd, no conn */
ISER_CONN_PENDING , /* in the process of being established */
ISER_CONN_UP , /* up and running */
ISER_CONN_TERMINATING , /* in the process of being terminated */
ISER_CONN_DOWN , /* shut down */
ISER_CONN_STATES_NUM
} ;
enum iser_task_status {
ISER_TASK_STATUS_INIT = 0 ,
ISER_TASK_STATUS_STARTED ,
ISER_TASK_STATUS_COMPLETED
} ;
enum iser_data_dir {
ISER_DIR_IN = 0 , /* to initiator */
ISER_DIR_OUT , /* from initiator */
ISER_DIRS_NUM
} ;
2014-10-01 14:02:15 +03:00
/**
* struct iser_data_buf - iSER data buffer
*
2015-04-14 18:08:15 +03:00
* @ sg : pointer to the sg list
2014-10-01 14:02:15 +03:00
* @ size : num entries of this sg
* @ data_len : total beffer byte len
* @ dma_nents : returned by dma_map_sg
*/
2006-05-11 10:00:21 +03:00
struct iser_data_buf {
2015-04-14 18:08:15 +03:00
struct scatterlist * sg ;
2015-10-13 19:11:33 +03:00
int size ;
2014-10-01 14:02:15 +03:00
unsigned long data_len ;
2019-02-26 12:22:11 +02:00
int dma_nents ;
2015-10-13 19:12:58 +03:00
} ;
2006-05-11 10:00:21 +03:00
/* fwd declarations */
struct iser_device ;
2008-05-21 15:54:11 -05:00
struct iscsi_iser_task ;
2008-05-21 15:54:14 -05:00
struct iscsi_endpoint ;
2015-08-06 18:33:02 +03:00
struct iser_reg_resources ;
2006-05-11 10:00:21 +03:00
2014-10-01 14:02:15 +03:00
/**
* struct iser_mem_reg - iSER memory registration info
*
2015-04-14 18:08:24 +03:00
* @ sge : memory region sg element
* @ rkey : memory region remote key
2014-10-01 14:02:15 +03:00
* @ mem_h : pointer to registration context ( FMR / Fastreg )
*/
2006-05-11 10:00:21 +03:00
struct iser_mem_reg {
2015-04-14 18:08:24 +03:00
struct ib_sge sge ;
u32 rkey ;
void * mem_h ;
2006-05-11 10:00:21 +03:00
} ;
enum iser_desc_type {
ISCSI_TX_CONTROL ,
ISCSI_TX_SCSI_COMMAND ,
ISCSI_TX_DATAOUT
} ;
2014-10-01 14:02:15 +03:00
/**
2015-12-11 11:54:28 -08:00
* struct iser_tx_desc - iSER TX descriptor
2014-10-01 14:02:15 +03:00
*
* @ iser_header : iser header
* @ iscsi_header : iscsi header
* @ type : command / control / dataout
* @ dam_addr : header buffer dma_address
* @ tx_sg : sg [ 0 ] points to iser / iscsi headers
* sg [ 1 ] optionally points to either of immediate data
* unsolicited data - out or control
* @ num_sge : number sges used on this TX task
2015-08-06 18:32:50 +03:00
* @ mapped : Is the task header mapped
2019-06-11 18:52:48 +03:00
* reg_wr : registration WR
* send_wr : send WR
* inv_wr : invalidate WR
2014-10-01 14:02:15 +03:00
*/
2010-02-08 13:19:56 +00:00
struct iser_tx_desc {
2015-12-09 14:12:03 +02:00
struct iser_ctrl iser_header ;
2006-05-11 10:00:21 +03:00
struct iscsi_hdr iscsi_header ;
enum iser_desc_type type ;
2010-02-08 13:19:56 +00:00
u64 dma_addr ;
struct ib_sge tx_sg [ 2 ] ;
int num_sge ;
2015-12-11 11:54:28 -08:00
struct ib_cqe cqe ;
2015-08-06 18:32:50 +03:00
bool mapped ;
2019-06-11 18:52:48 +03:00
struct ib_reg_wr reg_wr ;
struct ib_send_wr send_wr ;
struct ib_send_wr inv_wr ;
2006-05-11 10:00:21 +03:00
} ;
2010-02-08 13:17:42 +00:00
# define ISER_RX_PAD_SIZE (256 - (ISER_RX_PAYLOAD_SIZE + \
2015-12-11 11:54:28 -08:00
sizeof ( u64 ) + sizeof ( struct ib_sge ) + \
sizeof ( struct ib_cqe ) ) )
2014-10-01 14:02:15 +03:00
/**
2015-12-11 11:54:28 -08:00
* struct iser_rx_desc - iSER RX descriptor
2014-10-01 14:02:15 +03:00
*
* @ iser_header : iser header
* @ iscsi_header : iscsi header
* @ data : received data segment
* @ dma_addr : receive buffer dma address
* @ rx_sg : ib_sge of receive buffer
* @ pad : for sense data TODO : Modify to maximum sense length supported
*/
2010-02-08 13:17:42 +00:00
struct iser_rx_desc {
2015-12-09 14:12:03 +02:00
struct iser_ctrl iser_header ;
2010-02-08 13:17:42 +00:00
struct iscsi_hdr iscsi_header ;
char data [ ISER_RECV_DATA_SEG_LEN ] ;
u64 dma_addr ;
struct ib_sge rx_sg ;
2015-12-11 11:54:28 -08:00
struct ib_cqe cqe ;
2010-02-08 13:17:42 +00:00
char pad [ ISER_RX_PAD_SIZE ] ;
2015-12-11 11:54:28 -08:00
} __packed ;
2015-11-04 10:50:31 +02:00
/**
* struct iser_login_desc - iSER login descriptor
*
* @ req : pointer to login request buffer
* @ resp : pointer to login response buffer
* @ req_dma : DMA address of login request buffer
* @ rsp_dma : DMA address of login response buffer
* @ sge : IB sge for login post recv
2015-12-11 11:54:28 -08:00
* @ cqe : completion handler
2015-11-04 10:50:31 +02:00
*/
struct iser_login_desc {
void * req ;
void * rsp ;
u64 req_dma ;
u64 rsp_dma ;
struct ib_sge sge ;
2015-12-11 11:54:28 -08:00
struct ib_cqe cqe ;
2019-02-25 08:52:30 +02:00
} __packed ;
2010-02-08 13:17:42 +00:00
2013-07-28 12:35:39 +03:00
struct iser_conn ;
2014-10-01 14:01:58 +03:00
struct ib_conn ;
2013-07-28 12:35:39 +03:00
struct iscsi_iser_task ;
2014-10-01 14:02:07 +03:00
/**
* struct iser_comp - iSER completion context
*
2014-10-01 14:02:09 +03:00
* @ cq : completion queue
2014-10-01 14:02:07 +03:00
* @ active_qps : Number of active QPs attached
* to completion context
*/
struct iser_comp {
2014-10-01 14:02:09 +03:00
struct ib_cq * cq ;
2014-10-01 14:02:07 +03:00
int active_qps ;
} ;
2015-08-06 18:32:56 +03:00
/**
* struct iser_device - Memory registration operations
* per - device registration schemes
*
* @ alloc_reg_res : Allocate registration resources
* @ free_reg_res : Free registration resources
2015-08-06 18:33:02 +03:00
* @ fast_reg_mem : Register memory buffers
* @ unreg_mem : Un - register memory buffers
2015-08-06 18:33:01 +03:00
* @ reg_desc_get : Get a registration descriptor for pool
* @ reg_desc_put : Get a registration descriptor to pool
2015-08-06 18:32:56 +03:00
*/
struct iser_reg_ops {
int ( * alloc_reg_res ) ( struct ib_conn * ib_conn ,
2015-08-06 18:33:03 +03:00
unsigned cmds_max ,
unsigned int size ) ;
2015-08-06 18:32:56 +03:00
void ( * free_reg_res ) ( struct ib_conn * ib_conn ) ;
2015-08-06 18:33:02 +03:00
int ( * reg_mem ) ( struct iscsi_iser_task * iser_task ,
struct iser_data_buf * mem ,
struct iser_reg_resources * rsc ,
struct iser_mem_reg * reg ) ;
void ( * unreg_mem ) ( struct iscsi_iser_task * iser_task ,
enum iser_data_dir cmd_dir ) ;
2015-08-06 18:33:01 +03:00
struct iser_fr_desc * ( * reg_desc_get ) ( struct ib_conn * ib_conn ) ;
void ( * reg_desc_put ) ( struct ib_conn * ib_conn ,
struct iser_fr_desc * desc ) ;
2015-08-06 18:32:56 +03:00
} ;
2014-10-01 14:02:15 +03:00
/**
* struct iser_device - iSER device handle
*
* @ ib_device : RDMA device
* @ pd : Protection Domain for this device
* @ mr : Global DMA memory region
* @ event_handler : IB events handle routine
* @ ig_list : entry in devices list
* @ refcount : Reference counter , dominated by open iser connections
* @ comps_used : Number of completion contexts used , Min between online
* cpus and device max completion vectors
* @ comps : Dinamically allocated array of completion handlers
2015-08-06 18:32:56 +03:00
* @ reg_ops : Registration ops
2015-12-24 12:20:48 +02:00
* @ remote_inv_sup : Remote invalidate is supported on this device
2014-10-01 14:02:15 +03:00
*/
2006-05-11 10:00:21 +03:00
struct iser_device {
struct ib_device * ib_device ;
struct ib_pd * pd ;
2010-05-05 17:30:10 +03:00
struct ib_event_handler event_handler ;
2014-10-01 14:02:15 +03:00
struct list_head ig_list ;
2006-05-11 10:00:21 +03:00
int refcount ;
2014-10-01 14:02:07 +03:00
int comps_used ;
2014-12-07 16:10:03 +02:00
struct iser_comp * comps ;
2015-11-28 16:52:04 +01:00
const struct iser_reg_ops * reg_ops ;
2015-12-24 12:20:48 +02:00
bool remote_inv_sup ;
2006-05-11 10:00:21 +03:00
} ;
2015-08-06 18:32:53 +03:00
/**
* struct iser_reg_resources - Fast registration recources
*
* @ mr : memory region
2015-08-06 18:32:59 +03:00
* @ fmr_pool : pool of fmrs
2019-06-11 18:52:47 +03:00
* @ sig_mr : signature memory region
2015-08-06 18:32:59 +03:00
* @ page_vec : fast reg page list used by fmr pool
2015-08-06 18:32:53 +03:00
* @ mr_valid : is mr valid indicator
*/
struct iser_reg_resources {
2015-08-06 18:32:59 +03:00
union {
struct ib_mr * mr ;
struct ib_fmr_pool * fmr_pool ;
} ;
2019-06-11 18:52:47 +03:00
struct ib_mr * sig_mr ;
2015-10-13 19:11:33 +03:00
struct iser_page_vec * page_vec ;
2015-08-06 18:32:53 +03:00
u8 mr_valid : 1 ;
2014-03-05 19:43:47 +02:00
} ;
2014-10-01 14:02:15 +03:00
/**
2015-08-06 18:32:54 +03:00
* struct iser_fr_desc - Fast registration descriptor
2014-10-01 14:02:15 +03:00
*
* @ list : entry in connection fastreg pool
2015-08-06 18:32:53 +03:00
* @ rsc : data buffer registration resources
2019-06-11 18:52:47 +03:00
* @ sig_protected : is region protected indicator
2014-10-01 14:02:15 +03:00
*/
2015-08-06 18:32:54 +03:00
struct iser_fr_desc {
2013-07-28 12:35:42 +03:00
struct list_head list ;
2015-08-06 18:32:53 +03:00
struct iser_reg_resources rsc ;
2019-06-11 18:52:47 +03:00
bool sig_protected ;
2017-02-27 20:16:33 +02:00
struct list_head all_list ;
2013-07-28 12:35:42 +03:00
} ;
2015-08-06 18:32:58 +03:00
/**
* struct iser_fr_pool : connection fast registration pool
*
2015-08-06 18:32:59 +03:00
* @ list : list of fastreg descriptors
2015-08-06 18:32:58 +03:00
* @ lock : protects fmr / fastreg pool
2015-08-06 18:32:59 +03:00
* @ size : size of the pool
2015-08-06 18:32:58 +03:00
*/
struct iser_fr_pool {
2015-08-06 18:32:59 +03:00
struct list_head list ;
spinlock_t lock ;
int size ;
2017-02-27 20:16:33 +02:00
struct list_head all_list ;
2015-08-06 18:32:58 +03:00
} ;
2014-10-01 14:01:58 +03:00
/**
* struct ib_conn - Infiniband related objects
*
* @ cma_id : rdma_cm connection maneger handle
* @ qp : Connection Queue - pair
* @ post_recv_buf_count : post receive counter
2014-12-07 16:09:56 +02:00
* @ sig_count : send work request signal count
2014-10-01 14:01:58 +03:00
* @ rx_wr : receive work request for batch posts
* @ device : reference to iser device
2014-10-01 14:02:07 +03:00
* @ comp : iser completion context
2015-08-06 18:32:58 +03:00
* @ fr_pool : connection fast registration poool
2015-12-11 11:54:28 -08:00
* @ pi_support : Indicate device T10 - PI support
2014-10-01 14:01:58 +03:00
*/
struct ib_conn {
struct rdma_cm_id * cma_id ;
struct ib_qp * qp ;
int post_recv_buf_count ;
2014-12-07 16:09:56 +02:00
u8 sig_count ;
2014-10-01 14:01:58 +03:00
struct ib_recv_wr rx_wr [ ISER_MIN_POSTED_RX ] ;
struct iser_device * device ;
2014-10-01 14:02:07 +03:00
struct iser_comp * comp ;
2015-08-06 18:32:58 +03:00
struct iser_fr_pool fr_pool ;
2015-12-11 11:54:28 -08:00
bool pi_support ;
struct ib_cqe reg_cqe ;
2014-10-01 14:01:58 +03:00
} ;
2014-10-01 14:02:15 +03:00
/**
* struct iser_conn - iSER connection context
*
* @ ib_conn : connection RDMA resources
* @ iscsi_conn : link to matching iscsi connection
* @ ep : transport handle
* @ state : connection logical state
* @ qp_max_recv_dtos : maximum number of data outs , corresponds
* to max number of post recvs
* @ qp_max_recv_dtos_mask : ( qp_max_recv_dtos - 1 )
* @ min_posted_rx : ( qp_max_recv_dtos > > 2 )
2014-12-07 16:09:52 +02:00
* @ max_cmds : maximum cmds allowed for this connection
2014-10-01 14:02:15 +03:00
* @ name : connection peer portal
* @ release_work : deffered work for release job
* @ state_mutex : protects iser onnection state
* @ stop_completion : conn_stop completion
* @ ib_completion : RDMA cleanup completion
* @ up_completion : connection establishment completed
* ( state is ISER_CONN_UP )
* @ conn_list : entry in ig conn list
2015-11-04 10:50:31 +02:00
* @ login_desc : login descriptor
2014-10-01 14:02:15 +03:00
* @ rx_desc_head : head of rx_descs cyclic buffer
* @ rx_descs : rx buffers array ( cyclic buffer )
* @ num_rx_descs : number of rx descriptors
2015-08-06 18:33:04 +03:00
* @ scsi_sg_tablesize : scsi host sg_tablesize
2018-05-21 18:55:53 +03:00
* @ pages_per_mr : maximum pages available for registration
2014-10-01 14:02:15 +03:00
*/
2006-05-11 10:00:21 +03:00
struct iser_conn {
2014-10-01 14:01:58 +03:00
struct ib_conn ib_conn ;
2014-04-01 16:28:39 +03:00
struct iscsi_conn * iscsi_conn ;
2008-05-21 15:54:14 -05:00
struct iscsi_endpoint * ep ;
2014-10-01 14:02:15 +03:00
enum iser_conn_state state ;
unsigned qp_max_recv_dtos ;
unsigned qp_max_recv_dtos_mask ;
unsigned min_posted_rx ;
2014-12-07 16:09:52 +02:00
u16 max_cmds ;
2006-05-11 10:00:21 +03:00
char name [ ISER_OBJECT_NAME_SIZE ] ;
2014-05-22 11:00:18 +03:00
struct work_struct release_work ;
2014-07-31 13:27:49 +03:00
struct mutex state_mutex ;
2014-10-01 14:02:01 +03:00
struct completion stop_completion ;
struct completion ib_completion ;
2014-07-31 13:27:50 +03:00
struct completion up_completion ;
2014-10-01 14:02:15 +03:00
struct list_head conn_list ;
2015-11-04 10:50:31 +02:00
struct iser_login_desc login_desc ;
2010-02-08 13:17:42 +00:00
unsigned int rx_desc_head ;
struct iser_rx_desc * rx_descs ;
2014-10-01 14:02:09 +03:00
u32 num_rx_descs ;
2015-08-06 18:33:04 +03:00
unsigned short scsi_sg_tablesize ;
2018-05-21 18:55:53 +03:00
unsigned short pages_per_mr ;
2015-12-24 12:20:48 +02:00
bool snd_w_inv ;
2006-05-11 10:00:21 +03:00
} ;
2014-10-01 14:02:15 +03:00
/**
* struct iscsi_iser_task - iser task context
*
* @ desc : TX descriptor
* @ iser_conn : link to iser connection
* @ status : current task status
* @ sc : link to scsi command
* @ command_sent : indicate if command was sent
* @ dir : iser data direction
2015-04-14 18:08:19 +03:00
* @ rdma_reg : task rdma registration desc
2014-10-01 14:02:15 +03:00
* @ data : iser data buffer desc
* @ prot : iser protection buffer desc
*/
2008-05-21 15:54:11 -05:00
struct iscsi_iser_task {
2010-02-08 13:19:56 +00:00
struct iser_tx_desc desc ;
2014-10-01 14:01:57 +03:00
struct iser_conn * iser_conn ;
2006-05-11 10:00:21 +03:00
enum iser_task_status status ;
2014-03-05 19:43:48 +02:00
struct scsi_cmnd * sc ;
2014-10-01 14:02:15 +03:00
int command_sent ;
int dir [ ISER_DIRS_NUM ] ;
2015-04-14 18:08:19 +03:00
struct iser_mem_reg rdma_reg [ ISER_DIRS_NUM ] ;
2014-10-01 14:02:15 +03:00
struct iser_data_buf data [ ISER_DIRS_NUM ] ;
struct iser_data_buf prot [ ISER_DIRS_NUM ] ;
2006-05-11 10:00:21 +03:00
} ;
struct iser_page_vec {
u64 * pages ;
2015-12-09 14:12:00 +02:00
int npages ;
struct ib_mr fake_mr ;
2006-05-11 10:00:21 +03:00
} ;
2014-10-01 14:02:15 +03:00
/**
* struct iser_global : iSER global context
*
* @ device_list_mutex : protects device_list
* @ device_list : iser devices global list
* @ connlist_mutex : protects connlist
* @ connlist : iser connections global list
* @ desc_cache : kmem cache for tx dataout
*/
2006-05-11 10:00:21 +03:00
struct iser_global {
2014-10-01 14:02:15 +03:00
struct mutex device_list_mutex ;
struct list_head device_list ;
2006-05-11 10:00:21 +03:00
struct mutex connlist_mutex ;
2014-10-01 14:02:15 +03:00
struct list_head connlist ;
2006-11-29 15:33:07 -08:00
struct kmem_cache * desc_cache ;
2006-05-11 10:00:21 +03:00
} ;
extern struct iser_global ig ;
extern int iser_debug_level ;
2014-03-05 19:43:46 +02:00
extern bool iser_pi_enable ;
extern int iser_pi_guard ;
2015-08-06 18:33:04 +03:00
extern unsigned int iser_max_sectors ;
2015-09-24 10:34:22 +03:00
extern bool iser_always_reg ;
2006-05-11 10:00:21 +03:00
2015-08-06 18:32:56 +03:00
int iser_assign_reg_ops ( struct iser_device * device ) ;
2008-05-21 15:54:08 -05:00
int iser_send_control ( struct iscsi_conn * conn ,
2008-05-21 15:54:11 -05:00
struct iscsi_task * task ) ;
2006-05-11 10:00:21 +03:00
2008-05-21 15:54:08 -05:00
int iser_send_command ( struct iscsi_conn * conn ,
2008-05-21 15:54:11 -05:00
struct iscsi_task * task ) ;
2006-05-11 10:00:21 +03:00
2008-05-21 15:54:08 -05:00
int iser_send_data_out ( struct iscsi_conn * conn ,
2008-05-21 15:54:11 -05:00
struct iscsi_task * task ,
2008-05-21 15:54:08 -05:00
struct iscsi_data * hdr ) ;
2006-05-11 10:00:21 +03:00
void iscsi_iser_recv ( struct iscsi_conn * conn ,
2014-10-01 14:02:15 +03:00
struct iscsi_hdr * hdr ,
char * rx_data ,
int rx_data_len ) ;
2006-05-11 10:00:21 +03:00
2014-10-01 14:01:57 +03:00
void iser_conn_init ( struct iser_conn * iser_conn ) ;
2006-05-11 10:00:21 +03:00
2014-10-01 14:01:57 +03:00
void iser_conn_release ( struct iser_conn * iser_conn ) ;
2006-05-11 10:00:21 +03:00
2014-10-01 14:02:01 +03:00
int iser_conn_terminate ( struct iser_conn * iser_conn ) ;
2006-05-11 10:00:21 +03:00
2014-05-22 11:00:18 +03:00
void iser_release_work ( struct work_struct * work ) ;
2015-12-11 11:54:28 -08:00
void iser_err_comp ( struct ib_wc * wc , const char * type ) ;
void iser_login_rsp ( struct ib_cq * cq , struct ib_wc * wc ) ;
void iser_task_rsp ( struct ib_cq * cq , struct ib_wc * wc ) ;
void iser_cmd_comp ( struct ib_cq * cq , struct ib_wc * wc ) ;
void iser_ctrl_comp ( struct ib_cq * cq , struct ib_wc * wc ) ;
void iser_dataout_comp ( struct ib_cq * cq , struct ib_wc * wc ) ;
void iser_reg_comp ( struct ib_cq * cq , struct ib_wc * wc ) ;
2006-05-11 10:00:21 +03:00
2008-05-21 15:54:11 -05:00
void iser_task_rdma_init ( struct iscsi_iser_task * task ) ;
2006-05-11 10:00:21 +03:00
2008-05-21 15:54:11 -05:00
void iser_task_rdma_finalize ( struct iscsi_iser_task * task ) ;
2006-05-11 10:00:21 +03:00
2014-10-01 14:01:57 +03:00
void iser_free_rx_descriptors ( struct iser_conn * iser_conn ) ;
2010-02-08 13:17:42 +00:00
2014-03-05 19:43:44 +02:00
void iser_finalize_rdma_unaligned_sg ( struct iscsi_iser_task * iser_task ,
struct iser_data_buf * mem ,
enum iser_data_dir cmd_dir ) ;
2006-05-11 10:00:21 +03:00
2015-08-06 18:33:02 +03:00
int iser_reg_rdma_mem ( struct iscsi_iser_task * task ,
2015-12-09 14:12:01 +02:00
enum iser_data_dir dir ,
bool all_imm ) ;
2015-08-06 18:33:02 +03:00
void iser_unreg_rdma_mem ( struct iscsi_iser_task * task ,
enum iser_data_dir dir ) ;
2006-05-11 10:00:21 +03:00
2014-10-01 14:02:15 +03:00
int iser_connect ( struct iser_conn * iser_conn ,
struct sockaddr * src_addr ,
struct sockaddr * dst_addr ,
int non_blocking ) ;
2006-05-11 10:00:21 +03:00
2013-07-28 12:35:41 +03:00
void iser_unreg_mem_fmr ( struct iscsi_iser_task * iser_task ,
enum iser_data_dir cmd_dir ) ;
2014-03-05 19:43:39 +02:00
void iser_unreg_mem_fastreg ( struct iscsi_iser_task * iser_task ,
enum iser_data_dir cmd_dir ) ;
2006-05-11 10:00:21 +03:00
2014-10-01 14:01:57 +03:00
int iser_post_recvl ( struct iser_conn * iser_conn ) ;
int iser_post_recvm ( struct iser_conn * iser_conn , int count ) ;
2014-10-01 14:02:12 +03:00
int iser_post_send ( struct ib_conn * ib_conn , struct iser_tx_desc * tx_desc ,
bool signal ) ;
2006-05-11 10:00:21 +03:00
2008-05-21 15:54:11 -05:00
int iser_dma_map_task_data ( struct iscsi_iser_task * iser_task ,
2014-10-01 14:02:15 +03:00
struct iser_data_buf * data ,
enum iser_data_dir iser_dir ,
enum dma_data_direction dma_dir ) ;
2006-09-27 16:43:06 +03:00
2014-03-05 19:43:44 +02:00
void iser_dma_unmap_task_data ( struct iscsi_iser_task * iser_task ,
2014-12-28 14:26:11 +02:00
struct iser_data_buf * data ,
enum dma_data_direction dir ) ;
2010-02-08 13:19:56 +00:00
int iser_initialize_task_headers ( struct iscsi_task * task ,
struct iser_tx_desc * tx_desc ) ;
2014-10-01 14:01:57 +03:00
int iser_alloc_rx_descriptors ( struct iser_conn * iser_conn ,
struct iscsi_session * session ) ;
2015-08-06 18:33:03 +03:00
int iser_alloc_fmr_pool ( struct ib_conn * ib_conn ,
unsigned cmds_max ,
unsigned int size ) ;
2014-10-01 14:01:58 +03:00
void iser_free_fmr_pool ( struct ib_conn * ib_conn ) ;
2015-08-06 18:33:03 +03:00
int iser_alloc_fastreg_pool ( struct ib_conn * ib_conn ,
unsigned cmds_max ,
unsigned int size ) ;
2014-10-01 14:01:58 +03:00
void iser_free_fastreg_pool ( struct ib_conn * ib_conn ) ;
2014-03-05 19:43:50 +02:00
u8 iser_check_task_pi_status ( struct iscsi_iser_task * iser_task ,
enum iser_data_dir cmd_dir , sector_t * sector ) ;
2015-08-06 18:32:54 +03:00
struct iser_fr_desc *
2015-08-06 18:33:01 +03:00
iser_reg_desc_get_fr ( struct ib_conn * ib_conn ) ;
2015-04-14 18:08:21 +03:00
void
2015-08-06 18:33:01 +03:00
iser_reg_desc_put_fr ( struct ib_conn * ib_conn ,
struct iser_fr_desc * desc ) ;
struct iser_fr_desc *
iser_reg_desc_get_fmr ( struct ib_conn * ib_conn ) ;
void
iser_reg_desc_put_fmr ( struct ib_conn * ib_conn ,
struct iser_fr_desc * desc ) ;
2015-08-06 18:33:06 +03:00
2015-11-04 10:50:32 +02:00
static inline struct iser_conn *
to_iser_conn ( struct ib_conn * ib_conn )
{
return container_of ( ib_conn , struct iser_conn , ib_conn ) ;
}
2015-12-11 11:54:28 -08:00
static inline struct iser_rx_desc *
iser_rx ( struct ib_cqe * cqe )
{
return container_of ( cqe , struct iser_rx_desc , cqe ) ;
}
static inline struct iser_tx_desc *
iser_tx ( struct ib_cqe * cqe )
{
return container_of ( cqe , struct iser_tx_desc , cqe ) ;
}
static inline struct iser_login_desc *
iser_login ( struct ib_cqe * cqe )
{
return container_of ( cqe , struct iser_login_desc , cqe ) ;
}
2006-05-11 10:00:21 +03:00
# endif