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>
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 ": "
2014-09-02 17:08:43 +03:00
# define DRV_VER "1.4.1"
2006-05-11 10:00:21 +03:00
# define iser_dbg(fmt, arg...) \
2008-04-29 13:46:52 -07:00
do { \
2013-05-01 13:25:25 +00:00
if ( iser_debug_level > 2 ) \
2008-04-29 13:46:52 -07:00
printk ( KERN_DEBUG PFX " %s: " fmt , \
__func__ , # # arg ) ; \
} while ( 0 )
# define iser_warn(fmt, arg...) \
2013-05-01 13:25:25 +00:00
do { \
2013-07-28 12:35:36 +03:00
if ( iser_debug_level > 0 ) \
2013-05-01 13:25:25 +00:00
pr_warn ( PFX " %s: " fmt , \
__func__ , # # arg ) ; \
} while ( 0 )
# define iser_info(fmt, arg...) \
2006-05-11 10:00:21 +03:00
do { \
2013-07-28 12:35:36 +03:00
if ( iser_debug_level > 1 ) \
2013-05-01 13:25:25 +00:00
pr_info ( PFX " %s: " fmt , \
2006-05-11 10:00:21 +03:00
__func__ , # # arg ) ; \
} while ( 0 )
# define iser_err(fmt, arg...) \
do { \
printk ( KERN_ERR PFX " %s: " fmt , \
__func__ , # # arg ) ; \
} while ( 0 )
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))
2011-03-30 22:57:33 -03:00
/* support up to 512KB in one RDMA */
2006-09-11 12:22:30 +03:00
# define ISCSI_ISER_SG_TABLESIZE (0x80000 >> SHIFT_4K)
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-10-01 14:02:11 +03:00
# define ISER_WC_BATCH_COUNT 16
2014-10-01 14:02:12 +03:00
# define ISER_SIGNAL_CMD_COUNT 32
2014-10-01 14:02:11 +03:00
2006-05-11 10:00:21 +03:00
# define ISER_VER 0x10
# define ISER_WSV 0x08
# define ISER_RSV 0x04
2014-03-05 19:43:39 +02:00
# define ISER_FASTREG_LI_WRID 0xffffffffffffffffULL
2014-10-01 14:02:10 +03:00
# define ISER_BEACON_WRID 0xfffffffffffffffeULL
2014-01-23 12:31:28 +02:00
2006-05-11 10:00:21 +03:00
struct iser_hdr {
u8 flags ;
u8 rsvd [ 3 ] ;
__be32 write_stag ; /* write rkey */
__be64 write_va ;
__be32 read_stag ; /* read rkey */
__be64 read_va ;
} __attribute__ ( ( packed ) ) ;
2013-05-01 13:25:27 +00:00
# define ISER_ZBVA_NOT_SUPPORTED 0x80
# define ISER_SEND_W_INV_NOT_SUPPORTED 0x40
struct iser_cm_hdr {
u8 flags ;
u8 rsvd [ 3 ] ;
} __packed ;
2010-02-08 13:17:42 +00:00
/* Constant PDU lengths calculations */
# define ISER_HEADERS_LEN (sizeof(struct iser_hdr) + sizeof(struct iscsi_hdr))
# 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
} ;
struct iser_data_buf {
void * buf ; /* pointer to the sg list */
unsigned int size ; /* num entries of this sg */
unsigned long data_len ; /* total data len */
unsigned int dma_nents ; /* returned by dma_map_sg */
char * copy_buf ; /* allocated copy buf for SGs unaligned *
* for rdma which are copied */
struct scatterlist sg_single ; /* SG-ified clone of a non SG SC or *
* unaligned SG */
} ;
/* 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 ;
2006-05-11 10:00:21 +03:00
struct iser_mem_reg {
u32 lkey ;
u32 rkey ;
u64 va ;
u64 len ;
void * mem_h ;
2013-07-28 12:35:42 +03:00
int is_mr ;
2006-05-11 10:00:21 +03:00
} ;
struct iser_regd_buf {
struct iser_mem_reg reg ; /* memory registration info */
void * virt_addr ;
struct iser_device * device ; /* device->device for dma_unmap */
enum dma_data_direction direction ; /* direction for dma_unmap */
unsigned int data_size ;
} ;
enum iser_desc_type {
ISCSI_TX_CONTROL ,
ISCSI_TX_SCSI_COMMAND ,
ISCSI_TX_DATAOUT
} ;
2010-02-08 13:19:56 +00:00
struct iser_tx_desc {
2006-05-11 10:00:21 +03:00
struct iser_hdr iser_header ;
struct iscsi_hdr iscsi_header ;
enum iser_desc_type type ;
2010-02-08 13:19:56 +00:00
u64 dma_addr ;
/* sg[0] points to iser/iscsi headers, sg[1] optionally points to either
of immediate data , unsolicited data - out or control ( login , text ) */
struct ib_sge tx_sg [ 2 ] ;
int num_sge ;
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 + \
sizeof ( u64 ) + sizeof ( struct ib_sge ) ) )
struct iser_rx_desc {
struct iser_hdr iser_header ;
struct iscsi_hdr iscsi_header ;
char data [ ISER_RECV_DATA_SEG_LEN ] ;
u64 dma_addr ;
struct ib_sge rx_sg ;
char pad [ ISER_RX_PAD_SIZE ] ;
} __attribute__ ( ( packed ) ) ;
2012-09-23 15:17:44 +00:00
# define ISER_MAX_CQ 4
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
*
* @ device : pointer to device handle
2014-10-01 14:02:09 +03:00
* @ cq : completion queue
2014-10-01 14:02:11 +03:00
* @ wcs : work completion array
2014-10-01 14:02:07 +03:00
* @ tasklet : Tasklet handle
* @ active_qps : Number of active QPs attached
* to completion context
*/
struct iser_comp {
struct iser_device * device ;
2014-10-01 14:02:09 +03:00
struct ib_cq * cq ;
2014-10-01 14:02:11 +03:00
struct ib_wc wcs [ ISER_WC_BATCH_COUNT ] ;
2014-10-01 14:02:07 +03:00
struct tasklet_struct tasklet ;
int active_qps ;
} ;
2006-05-11 10:00:21 +03:00
struct iser_device {
struct ib_device * ib_device ;
struct ib_pd * pd ;
2014-03-05 19:43:42 +02:00
struct ib_device_attr dev_attr ;
2006-05-11 10:00:21 +03:00
struct ib_mr * mr ;
2010-05-05 17:30:10 +03:00
struct ib_event_handler event_handler ;
2006-05-11 10:00:21 +03:00
struct list_head ig_list ; /* entry in ig devices list */
int refcount ;
2014-10-01 14:02:07 +03:00
int comps_used ;
struct iser_comp comps [ ISER_MAX_CQ ] ;
2014-10-01 14:01:58 +03:00
int ( * iser_alloc_rdma_reg_res ) ( struct ib_conn * ib_conn ,
2013-07-28 12:35:39 +03:00
unsigned cmds_max ) ;
2014-10-01 14:01:58 +03:00
void ( * iser_free_rdma_reg_res ) ( struct ib_conn * ib_conn ) ;
2013-07-28 12:35:39 +03:00
int ( * iser_reg_rdma_mem ) ( struct iscsi_iser_task * iser_task ,
enum iser_data_dir cmd_dir ) ;
void ( * iser_unreg_rdma_mem ) ( struct iscsi_iser_task * iser_task ,
enum iser_data_dir cmd_dir ) ;
2006-05-11 10:00:21 +03:00
} ;
2014-03-05 19:43:48 +02:00
# define ISER_CHECK_GUARD 0xc0
# define ISER_CHECK_REFTAG 0x0f
# define ISER_CHECK_APPTAG 0x30
2014-03-05 19:43:43 +02:00
enum iser_reg_indicator {
2014-03-05 19:43:47 +02:00
ISER_DATA_KEY_VALID = 1 < < 0 ,
ISER_PROT_KEY_VALID = 1 < < 1 ,
ISER_SIG_KEY_VALID = 1 < < 2 ,
ISER_FASTREG_PROTECTED = 1 < < 3 ,
} ;
struct iser_pi_context {
struct ib_mr * prot_mr ;
struct ib_fast_reg_page_list * prot_frpl ;
struct ib_mr * sig_mr ;
2014-03-05 19:43:43 +02:00
} ;
2013-07-28 12:35:42 +03:00
struct fast_reg_descriptor {
struct list_head list ;
/* For fast registration - FRWR */
struct ib_mr * data_mr ;
struct ib_fast_reg_page_list * data_frpl ;
2014-03-05 19:43:47 +02:00
struct iser_pi_context * pi_ctx ;
2014-03-05 19:43:43 +02:00
/* registration indicators container */
u8 reg_indicators ;
2013-07-28 12:35:42 +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
* @ 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
2014-10-01 14:01:58 +03:00
* @ pi_support : Indicate device T10 - PI support
2014-10-01 14:02:10 +03:00
* @ beacon : beacon send wr to signal all flush errors were drained
2014-10-01 14:02:09 +03:00
* @ flush_comp : completes when all connection completions consumed
2014-10-01 14:01:58 +03:00
* @ lock : protects fmr / fastreg pool
* @ union . fmr :
* @ pool : FMR pool for fast registrations
* @ page_vec : page vector to hold mapped commands pages
* used for registration
* @ union . fastreg :
* @ pool : Fast registration descriptors pool for fast
* registrations
* @ pool_size : Size of pool
*/
struct ib_conn {
struct rdma_cm_id * cma_id ;
struct ib_qp * qp ;
int post_recv_buf_count ;
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 ;
2014-10-01 14:01:58 +03:00
bool pi_support ;
2014-10-01 14:02:10 +03:00
struct ib_send_wr beacon ;
2014-10-01 14:02:09 +03:00
struct completion flush_comp ;
2014-10-01 14:01:58 +03:00
spinlock_t lock ;
union {
struct {
struct ib_fmr_pool * pool ;
struct iser_page_vec * page_vec ;
} fmr ;
struct {
struct list_head pool ;
int pool_size ;
} fastreg ;
} ;
} ;
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:01:57 +03:00
enum iser_conn_state state ; /* rdma connection state */
2013-07-28 12:35:38 +03:00
unsigned qp_max_recv_dtos ; /* num of rx buffers */
unsigned qp_max_recv_dtos_mask ; /* above minus 1 */
unsigned min_posted_rx ; /* qp_max_recv_dtos >> 2 */
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 ;
2006-05-11 10:00:21 +03:00
struct list_head conn_list ; /* entry in ig conn list */
2010-02-08 13:17:42 +00:00
char * login_buf ;
2011-11-04 00:19:46 +02:00
char * login_req_buf , * login_resp_buf ;
u64 login_req_dma , login_resp_dma ;
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 ;
2006-05-11 10:00:21 +03:00
} ;
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 ;
2006-05-11 10:00:21 +03:00
int command_sent ; /* set if command sent */
int dir [ ISER_DIRS_NUM ] ; /* set if dir use*/
struct iser_regd_buf rdma_regd [ ISER_DIRS_NUM ] ; /* regd rdma buf */
struct iser_data_buf data [ ISER_DIRS_NUM ] ; /* orig. data des*/
struct iser_data_buf data_copy [ ISER_DIRS_NUM ] ; /* contig. copy */
2014-03-05 19:43:48 +02:00
struct iser_data_buf prot [ ISER_DIRS_NUM ] ; /* prot desc */
struct iser_data_buf prot_copy [ ISER_DIRS_NUM ] ; /* prot copy */
2006-05-11 10:00:21 +03:00
} ;
struct iser_page_vec {
u64 * pages ;
int length ;
int offset ;
int data_size ;
} ;
struct iser_global {
struct mutex device_list_mutex ; /* */
struct list_head device_list ; /* all iSER devices */
struct mutex connlist_mutex ;
struct list_head connlist ; /* all iSER IB connections */
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 ;
2006-05-11 10:00:21 +03:00
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 ,
struct iscsi_hdr * hdr ,
char * rx_data ,
int rx_data_len ) ;
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 ) ;
2010-02-08 13:17:42 +00:00
void iser_rcv_completion ( struct iser_rx_desc * desc ,
unsigned long dto_xfer_len ,
2014-10-01 14:01:58 +03:00
struct ib_conn * ib_conn ) ;
2006-05-11 10:00:21 +03:00
2014-10-01 14:01:57 +03:00
void iser_snd_completion ( struct iser_tx_desc * desc ,
2014-10-01 14:01:58 +03:00
struct ib_conn * ib_conn ) ;
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 ,
struct iser_data_buf * mem_copy ,
enum iser_data_dir cmd_dir ) ;
2006-05-11 10:00:21 +03:00
2013-07-28 12:35:41 +03:00
int iser_reg_rdma_mem_fmr ( struct iscsi_iser_task * task ,
enum iser_data_dir cmd_dir ) ;
2014-03-05 19:43:39 +02:00
int iser_reg_rdma_mem_fastreg ( struct iscsi_iser_task * 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_connect ( struct iser_conn * iser_conn ,
2014-07-31 13:27:44 +03:00
struct sockaddr * src_addr ,
struct sockaddr * dst_addr ,
2006-05-11 10:00:21 +03:00
int non_blocking ) ;
2014-10-01 14:01:58 +03:00
int iser_reg_page_vec ( struct ib_conn * ib_conn ,
2006-05-11 10:00:21 +03:00
struct iser_page_vec * page_vec ,
struct iser_mem_reg * mem_reg ) ;
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 ,
2006-09-27 16:43:06 +03:00
struct iser_data_buf * data ,
enum iser_data_dir iser_dir ,
enum dma_data_direction dma_dir ) ;
2014-03-05 19:43:44 +02:00
void iser_dma_unmap_task_data ( struct iscsi_iser_task * iser_task ,
struct iser_data_buf * data ) ;
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 ) ;
2014-10-01 14:01:58 +03:00
int iser_create_fmr_pool ( struct ib_conn * ib_conn , unsigned cmds_max ) ;
void iser_free_fmr_pool ( struct ib_conn * ib_conn ) ;
int iser_create_fastreg_pool ( struct ib_conn * ib_conn , unsigned cmds_max ) ;
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 ) ;
2006-05-11 10:00:21 +03:00
# endif