2011-11-16 09:46:48 -05:00
# ifndef TARGET_CORE_FABRIC_H
# define TARGET_CORE_FABRIC_H
[SCSI] target: Add LIO target core v4.0.0-rc6
LIO target is a full featured in-kernel target framework with the
following feature set:
High-performance, non-blocking, multithreaded architecture with SIMD
support.
Advanced SCSI feature set:
* Persistent Reservations (PRs)
* Asymmetric Logical Unit Assignment (ALUA)
* Protocol and intra-nexus multiplexing, load-balancing and failover (MC/S)
* Full Error Recovery (ERL=0,1,2)
* Active/active task migration and session continuation (ERL=2)
* Thin LUN provisioning (UNMAP and WRITE_SAMExx)
Multiprotocol target plugins
Storage media independence:
* Virtualization of all storage media; transparent mapping of IO to LUNs
* No hard limits on number of LUNs per Target; maximum LUN size ~750 TB
* Backstores: SATA, SAS, SCSI, BluRay, DVD, FLASH, USB, ramdisk, etc.
Standards compliance:
* Full compliance with IETF (RFC 3720)
* Full implementation of SPC-4 PRs and ALUA
Significant code cleanups done by Christoph Hellwig.
[jejb: fix up for new block bdev exclusive interface. Minor fixes from
Randy Dunlap and Dan Carpenter.]
Signed-off-by: Nicholas A. Bellinger <nab@linux-iscsi.org>
Signed-off-by: James Bottomley <James.Bottomley@suse.de>
2010-12-17 11:11:26 -08:00
struct target_core_fabric_ops {
struct configfs_subsystem * tf_subsys ;
char * ( * get_fabric_name ) ( void ) ;
u8 ( * get_fabric_proto_ident ) ( struct se_portal_group * ) ;
char * ( * tpg_get_wwn ) ( struct se_portal_group * ) ;
u16 ( * tpg_get_tag ) ( struct se_portal_group * ) ;
u32 ( * tpg_get_default_depth ) ( struct se_portal_group * ) ;
u32 ( * tpg_get_pr_transport_id ) ( struct se_portal_group * ,
struct se_node_acl * ,
struct t10_pr_registration * , int * ,
unsigned char * ) ;
u32 ( * tpg_get_pr_transport_id_len ) ( struct se_portal_group * ,
struct se_node_acl * ,
struct t10_pr_registration * , int * ) ;
char * ( * tpg_parse_pr_out_transport_id ) ( struct se_portal_group * ,
const char * , u32 * , char * * ) ;
int ( * tpg_check_demo_mode ) ( struct se_portal_group * ) ;
int ( * tpg_check_demo_mode_cache ) ( struct se_portal_group * ) ;
int ( * tpg_check_demo_mode_write_protect ) ( struct se_portal_group * ) ;
int ( * tpg_check_prod_mode_write_protect ) ( struct se_portal_group * ) ;
2011-07-26 17:48:43 -07:00
/*
* Optionally used by fabrics to allow demo - mode login , but not
* expose any TPG LUNs , and return ' not connected ' in standard
* inquiry response
*/
int ( * tpg_check_demo_mode_login_only ) ( struct se_portal_group * ) ;
[SCSI] target: Add LIO target core v4.0.0-rc6
LIO target is a full featured in-kernel target framework with the
following feature set:
High-performance, non-blocking, multithreaded architecture with SIMD
support.
Advanced SCSI feature set:
* Persistent Reservations (PRs)
* Asymmetric Logical Unit Assignment (ALUA)
* Protocol and intra-nexus multiplexing, load-balancing and failover (MC/S)
* Full Error Recovery (ERL=0,1,2)
* Active/active task migration and session continuation (ERL=2)
* Thin LUN provisioning (UNMAP and WRITE_SAMExx)
Multiprotocol target plugins
Storage media independence:
* Virtualization of all storage media; transparent mapping of IO to LUNs
* No hard limits on number of LUNs per Target; maximum LUN size ~750 TB
* Backstores: SATA, SAS, SCSI, BluRay, DVD, FLASH, USB, ramdisk, etc.
Standards compliance:
* Full compliance with IETF (RFC 3720)
* Full implementation of SPC-4 PRs and ALUA
Significant code cleanups done by Christoph Hellwig.
[jejb: fix up for new block bdev exclusive interface. Minor fixes from
Randy Dunlap and Dan Carpenter.]
Signed-off-by: Nicholas A. Bellinger <nab@linux-iscsi.org>
Signed-off-by: James Bottomley <James.Bottomley@suse.de>
2010-12-17 11:11:26 -08:00
struct se_node_acl * ( * tpg_alloc_fabric_acl ) (
struct se_portal_group * ) ;
void ( * tpg_release_fabric_acl ) ( struct se_portal_group * ,
struct se_node_acl * ) ;
u32 ( * tpg_get_inst_index ) ( struct se_portal_group * ) ;
/*
* Optional to release struct se_cmd and fabric dependent allocated
2011-11-02 03:33:16 -07:00
* I / O descriptor in transport_cmd_check_stop ( ) .
*
* Returning 1 will signal a descriptor has been released .
* Returning 0 will signal a descriptor has not been released .
[SCSI] target: Add LIO target core v4.0.0-rc6
LIO target is a full featured in-kernel target framework with the
following feature set:
High-performance, non-blocking, multithreaded architecture with SIMD
support.
Advanced SCSI feature set:
* Persistent Reservations (PRs)
* Asymmetric Logical Unit Assignment (ALUA)
* Protocol and intra-nexus multiplexing, load-balancing and failover (MC/S)
* Full Error Recovery (ERL=0,1,2)
* Active/active task migration and session continuation (ERL=2)
* Thin LUN provisioning (UNMAP and WRITE_SAMExx)
Multiprotocol target plugins
Storage media independence:
* Virtualization of all storage media; transparent mapping of IO to LUNs
* No hard limits on number of LUNs per Target; maximum LUN size ~750 TB
* Backstores: SATA, SAS, SCSI, BluRay, DVD, FLASH, USB, ramdisk, etc.
Standards compliance:
* Full compliance with IETF (RFC 3720)
* Full implementation of SPC-4 PRs and ALUA
Significant code cleanups done by Christoph Hellwig.
[jejb: fix up for new block bdev exclusive interface. Minor fixes from
Randy Dunlap and Dan Carpenter.]
Signed-off-by: Nicholas A. Bellinger <nab@linux-iscsi.org>
Signed-off-by: James Bottomley <James.Bottomley@suse.de>
2010-12-17 11:11:26 -08:00
*/
2011-11-02 03:33:16 -07:00
int ( * check_stop_free ) ( struct se_cmd * ) ;
2011-05-31 23:56:57 -04:00
void ( * release_cmd ) ( struct se_cmd * ) ;
2012-05-18 13:57:19 -07:00
void ( * put_session ) ( struct se_session * ) ;
[SCSI] target: Add LIO target core v4.0.0-rc6
LIO target is a full featured in-kernel target framework with the
following feature set:
High-performance, non-blocking, multithreaded architecture with SIMD
support.
Advanced SCSI feature set:
* Persistent Reservations (PRs)
* Asymmetric Logical Unit Assignment (ALUA)
* Protocol and intra-nexus multiplexing, load-balancing and failover (MC/S)
* Full Error Recovery (ERL=0,1,2)
* Active/active task migration and session continuation (ERL=2)
* Thin LUN provisioning (UNMAP and WRITE_SAMExx)
Multiprotocol target plugins
Storage media independence:
* Virtualization of all storage media; transparent mapping of IO to LUNs
* No hard limits on number of LUNs per Target; maximum LUN size ~750 TB
* Backstores: SATA, SAS, SCSI, BluRay, DVD, FLASH, USB, ramdisk, etc.
Standards compliance:
* Full compliance with IETF (RFC 3720)
* Full implementation of SPC-4 PRs and ALUA
Significant code cleanups done by Christoph Hellwig.
[jejb: fix up for new block bdev exclusive interface. Minor fixes from
Randy Dunlap and Dan Carpenter.]
Signed-off-by: Nicholas A. Bellinger <nab@linux-iscsi.org>
Signed-off-by: James Bottomley <James.Bottomley@suse.de>
2010-12-17 11:11:26 -08:00
/*
* Called with spin_lock_bh ( struct se_portal_group - > session_lock held .
*/
int ( * shutdown_session ) ( struct se_session * ) ;
void ( * close_session ) ( struct se_session * ) ;
u32 ( * sess_get_index ) ( struct se_session * ) ;
/*
* Used only for SCSI fabrics that contain multi - value TransportIDs
* ( like iSCSI ) . All other SCSI fabrics should set this to NULL .
*/
u32 ( * sess_get_initiator_sid ) ( struct se_session * ,
unsigned char * , u32 ) ;
int ( * write_pending ) ( struct se_cmd * ) ;
int ( * write_pending_status ) ( struct se_cmd * ) ;
void ( * set_default_node_attributes ) ( struct se_node_acl * ) ;
u32 ( * get_task_tag ) ( struct se_cmd * ) ;
int ( * get_cmd_state ) ( struct se_cmd * ) ;
int ( * queue_data_in ) ( struct se_cmd * ) ;
int ( * queue_status ) ( struct se_cmd * ) ;
2013-07-03 11:22:17 -04:00
void ( * queue_tm_rsp ) ( struct se_cmd * ) ;
2014-03-22 14:55:56 -07:00
void ( * aborted_task ) ( struct se_cmd * ) ;
[SCSI] target: Add LIO target core v4.0.0-rc6
LIO target is a full featured in-kernel target framework with the
following feature set:
High-performance, non-blocking, multithreaded architecture with SIMD
support.
Advanced SCSI feature set:
* Persistent Reservations (PRs)
* Asymmetric Logical Unit Assignment (ALUA)
* Protocol and intra-nexus multiplexing, load-balancing and failover (MC/S)
* Full Error Recovery (ERL=0,1,2)
* Active/active task migration and session continuation (ERL=2)
* Thin LUN provisioning (UNMAP and WRITE_SAMExx)
Multiprotocol target plugins
Storage media independence:
* Virtualization of all storage media; transparent mapping of IO to LUNs
* No hard limits on number of LUNs per Target; maximum LUN size ~750 TB
* Backstores: SATA, SAS, SCSI, BluRay, DVD, FLASH, USB, ramdisk, etc.
Standards compliance:
* Full compliance with IETF (RFC 3720)
* Full implementation of SPC-4 PRs and ALUA
Significant code cleanups done by Christoph Hellwig.
[jejb: fix up for new block bdev exclusive interface. Minor fixes from
Randy Dunlap and Dan Carpenter.]
Signed-off-by: Nicholas A. Bellinger <nab@linux-iscsi.org>
Signed-off-by: James Bottomley <James.Bottomley@suse.de>
2010-12-17 11:11:26 -08:00
/*
* fabric module calls for target_core_fabric_configfs . c
*/
struct se_wwn * ( * fabric_make_wwn ) ( struct target_fabric_configfs * ,
struct config_group * , const char * ) ;
void ( * fabric_drop_wwn ) ( struct se_wwn * ) ;
struct se_portal_group * ( * fabric_make_tpg ) ( struct se_wwn * ,
struct config_group * , const char * ) ;
void ( * fabric_drop_tpg ) ( struct se_portal_group * ) ;
int ( * fabric_post_link ) ( struct se_portal_group * ,
struct se_lun * ) ;
void ( * fabric_pre_unlink ) ( struct se_portal_group * ,
struct se_lun * ) ;
struct se_tpg_np * ( * fabric_make_np ) ( struct se_portal_group * ,
struct config_group * , const char * ) ;
void ( * fabric_drop_np ) ( struct se_tpg_np * ) ;
struct se_node_acl * ( * fabric_make_nodeacl ) ( struct se_portal_group * ,
struct config_group * , const char * ) ;
void ( * fabric_drop_nodeacl ) ( struct se_node_acl * ) ;
} ;
2011-11-16 09:46:48 -05:00
2014-04-02 12:52:38 -07:00
struct se_session * transport_init_session ( enum target_prot_op ) ;
2013-06-07 17:38:58 -07:00
int transport_alloc_session_tags ( struct se_session * , unsigned int ,
unsigned int ) ;
2014-04-02 12:52:38 -07:00
struct se_session * transport_init_session_tags ( unsigned int , unsigned int ,
enum target_prot_op ) ;
2011-11-16 09:46:48 -05:00
void __transport_register_session ( struct se_portal_group * ,
struct se_node_acl * , struct se_session * , void * ) ;
void transport_register_session ( struct se_portal_group * ,
struct se_node_acl * , struct se_session * , void * ) ;
2012-02-26 22:22:10 -08:00
void target_get_session ( struct se_session * ) ;
2012-05-11 10:35:08 -04:00
void target_put_session ( struct se_session * ) ;
2011-11-16 09:46:48 -05:00
void transport_free_session ( struct se_session * ) ;
2012-03-08 23:45:02 -08:00
void target_put_nacl ( struct se_node_acl * ) ;
2011-11-16 09:46:48 -05:00
void transport_deregister_session_configfs ( struct se_session * ) ;
void transport_deregister_session ( struct se_session * ) ;
void transport_init_se_cmd ( struct se_cmd * , struct target_core_fabric_ops * ,
struct se_session * , u32 , int , int , unsigned char * ) ;
2012-11-06 12:24:09 -08:00
sense_reason_t transport_lookup_cmd_lun ( struct se_cmd * , u32 ) ;
sense_reason_t target_setup_cmd_from_cdb ( struct se_cmd * , unsigned char * ) ;
2012-10-01 17:23:22 -07:00
int target_submit_cmd_map_sgls ( struct se_cmd * , struct se_session * ,
unsigned char * , unsigned char * , u32 , u32 , int , int , int ,
2013-12-23 20:38:30 +00:00
struct scatterlist * , u32 , struct scatterlist * , u32 ,
struct scatterlist * , u32 ) ;
2012-07-16 11:04:39 -07:00
int target_submit_cmd ( struct se_cmd * , struct se_session * , unsigned char * ,
2011-11-18 20:36:22 -08:00
unsigned char * , u32 , u32 , int , int , int ) ;
2012-02-25 01:40:24 -08:00
int target_submit_tmr ( struct se_cmd * se_cmd , struct se_session * se_sess ,
2012-01-19 13:39:21 -08:00
unsigned char * sense , u32 unpacked_lun ,
2012-02-25 05:10:04 -08:00
void * fabric_tmr_ptr , unsigned char tm_type ,
gfp_t , unsigned int , int ) ;
2011-11-16 09:46:48 -05:00
int transport_handle_cdb_direct ( struct se_cmd * ) ;
2012-11-06 12:24:09 -08:00
sense_reason_t transport_generic_new_cmd ( struct se_cmd * ) ;
2011-11-16 09:46:48 -05:00
2012-07-08 15:58:39 -04:00
void target_execute_cmd ( struct se_cmd * cmd ) ;
2011-11-16 09:46:48 -05:00
2013-05-31 00:46:11 -07:00
int transport_generic_free_cmd ( struct se_cmd * , int ) ;
2011-11-16 09:46:48 -05:00
bool transport_wait_for_tasks ( struct se_cmd * ) ;
int transport_check_aborted_status ( struct se_cmd * , int ) ;
2012-11-06 12:24:09 -08:00
int transport_send_check_condition_and_sense ( struct se_cmd * ,
sense_reason_t , int ) ;
2013-03-21 22:54:28 -07:00
int target_get_sess_cmd ( struct se_session * , struct se_cmd * , bool ) ;
2011-11-16 09:46:48 -05:00
int target_put_sess_cmd ( struct se_session * , struct se_cmd * ) ;
2012-07-16 11:04:42 -07:00
void target_sess_cmd_list_set_waiting ( struct se_session * ) ;
2013-05-15 00:44:07 -07:00
void target_wait_for_sess_cmds ( struct se_session * ) ;
2011-11-16 09:46:48 -05:00
int core_alua_check_nonop_delay ( struct se_cmd * ) ;
2012-01-19 13:39:17 -08:00
int core_tmr_alloc_req ( struct se_cmd * , void * , u8 , gfp_t ) ;
2011-11-16 09:46:48 -05:00
void core_tmr_release_req ( struct se_tmr_req * ) ;
int transport_generic_handle_tmr ( struct se_cmd * ) ;
2012-11-06 12:24:09 -08:00
void transport_generic_request_failure ( struct se_cmd * , sense_reason_t ) ;
2013-08-21 16:04:10 -07:00
void __target_execute_cmd ( struct se_cmd * ) ;
2011-11-16 09:46:48 -05:00
int transport_lookup_tmr_lun ( struct se_cmd * , u32 ) ;
2013-10-07 23:13:02 +02:00
struct se_node_acl * core_tpg_get_initiator_node_acl ( struct se_portal_group * tpg ,
unsigned char * ) ;
2011-11-16 09:46:48 -05:00
struct se_node_acl * core_tpg_check_initiator_node_acl ( struct se_portal_group * ,
unsigned char * ) ;
void core_tpg_clear_object_luns ( struct se_portal_group * ) ;
struct se_node_acl * core_tpg_add_initiator_node_acl ( struct se_portal_group * ,
struct se_node_acl * , const char * , u32 ) ;
int core_tpg_del_initiator_node_acl ( struct se_portal_group * ,
struct se_node_acl * , int ) ;
int core_tpg_set_initiator_node_queue_depth ( struct se_portal_group * ,
unsigned char * , u32 , int ) ;
2012-12-11 16:30:53 -08:00
int core_tpg_set_initiator_node_tag ( struct se_portal_group * ,
struct se_node_acl * , const char * ) ;
2011-11-16 09:46:48 -05:00
int core_tpg_register ( struct target_core_fabric_ops * , struct se_wwn * ,
struct se_portal_group * , void * , int ) ;
int core_tpg_deregister ( struct se_portal_group * ) ;
/* SAS helpers */
u8 sas_get_fabric_proto_ident ( struct se_portal_group * ) ;
u32 sas_get_pr_transport_id ( struct se_portal_group * , struct se_node_acl * ,
struct t10_pr_registration * , int * , unsigned char * ) ;
u32 sas_get_pr_transport_id_len ( struct se_portal_group * , struct se_node_acl * ,
struct t10_pr_registration * , int * ) ;
char * sas_parse_pr_out_transport_id ( struct se_portal_group * , const char * ,
u32 * , char * * ) ;
/* FC helpers */
u8 fc_get_fabric_proto_ident ( struct se_portal_group * ) ;
u32 fc_get_pr_transport_id ( struct se_portal_group * , struct se_node_acl * ,
struct t10_pr_registration * , int * , unsigned char * ) ;
u32 fc_get_pr_transport_id_len ( struct se_portal_group * , struct se_node_acl * ,
struct t10_pr_registration * , int * ) ;
char * fc_parse_pr_out_transport_id ( struct se_portal_group * , const char * ,
u32 * , char * * ) ;
/* iSCSI helpers */
u8 iscsi_get_fabric_proto_ident ( struct se_portal_group * ) ;
u32 iscsi_get_pr_transport_id ( struct se_portal_group * , struct se_node_acl * ,
struct t10_pr_registration * , int * , unsigned char * ) ;
u32 iscsi_get_pr_transport_id_len ( struct se_portal_group * , struct se_node_acl * ,
struct t10_pr_registration * , int * ) ;
char * iscsi_parse_pr_out_transport_id ( struct se_portal_group * , const char * ,
u32 * , char * * ) ;
2013-08-21 14:54:54 -07:00
/*
* The LIO target core uses DMA_TO_DEVICE to mean that data is going
* to the target ( eg handling a WRITE ) and DMA_FROM_DEVICE to mean
* that data is coming from the target ( eg handling a READ ) . However ,
* this is just the opposite of what we have to tell the DMA mapping
* layer - - eg when handling a READ , the HBA will have to DMA the data
* out of memory so it can send it to the initiator , which means we
* need to use DMA_TO_DEVICE when we map the data .
*/
static inline enum dma_data_direction
target_reverse_dma_direction ( struct se_cmd * se_cmd )
{
if ( se_cmd - > se_cmd_flags & SCF_BIDI )
return DMA_BIDIRECTIONAL ;
switch ( se_cmd - > data_direction ) {
case DMA_TO_DEVICE :
return DMA_FROM_DEVICE ;
case DMA_FROM_DEVICE :
return DMA_TO_DEVICE ;
case DMA_NONE :
default :
return DMA_NONE ;
}
}
2011-11-16 09:46:48 -05:00
# endif /* TARGET_CORE_FABRICH */