2019-05-27 08:55:05 +02:00
// SPDX-License-Identifier: GPL-2.0-or-later
[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
/*******************************************************************************
* Filename : target_core_transport . c
*
* This file contains the Generic Target Engine Core .
*
2013-09-05 15:29:12 -07:00
* ( c ) Copyright 2002 - 2013 Datera , Inc .
[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
*
* Nicholas A . Bellinger < nab @ kernel . org >
*
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
# include <linux/net.h>
# include <linux/delay.h>
# include <linux/string.h>
# include <linux/timer.h>
# include <linux/slab.h>
# include <linux/spinlock.h>
# include <linux/kthread.h>
# include <linux/in.h>
# include <linux/cdrom.h>
2011-08-30 14:20:44 -04:00
# include <linux/module.h>
2012-02-13 16:18:17 -08:00
# include <linux/ratelimit.h>
2015-05-28 11:35:41 -07:00
# include <linux/vmalloc.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
# include <asm/unaligned.h>
# include <net/sock.h>
# include <net/tcp.h>
2015-05-08 10:11:12 +02:00
# include <scsi/scsi_proto.h>
2015-07-08 17:58:53 +03:00
# include <scsi/scsi_common.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
# include <target/target_core_base.h>
2011-11-16 09:46:48 -05:00
# include <target/target_core_backend.h>
# include <target/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
2011-11-14 12:30:30 -05:00
# include "target_core_internal.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
# include "target_core_alua.h"
# include "target_core_pr.h"
# include "target_core_ua.h"
2013-06-26 17:36:17 -07:00
# define CREATE_TRACE_POINTS
# include <trace/events/target.h>
2011-10-17 13:56:53 -04:00
static struct workqueue_struct * target_completion_wq ;
2021-02-27 10:59:57 -06:00
static struct workqueue_struct * target_submission_wq ;
[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
static struct kmem_cache * se_sess_cache ;
struct kmem_cache * se_ua_cache ;
struct kmem_cache * t10_pr_reg_cache ;
struct kmem_cache * t10_alua_lu_gp_cache ;
struct kmem_cache * t10_alua_lu_gp_mem_cache ;
struct kmem_cache * t10_alua_tg_pt_gp_cache ;
2013-12-17 09:18:50 +01:00
struct kmem_cache * t10_alua_lba_map_cache ;
struct kmem_cache * t10_alua_lba_map_mem_cache ;
[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
static void transport_complete_task_attr ( struct se_cmd * cmd ) ;
2018-06-22 14:53:05 -07:00
static void translate_sense_reason ( struct se_cmd * cmd , sense_reason_t reason ) ;
2011-06-13 14:46:09 -07:00
static void transport_handle_queue_full ( struct se_cmd * cmd ,
2016-10-30 17:28:16 -07:00
struct se_device * dev , int err , bool write_pending ) ;
2011-10-17 13:56:53 -04:00
static void target_complete_ok_work ( struct work_struct * work ) ;
[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-07-19 08:55:10 +00:00
int init_se_kmem_caches ( void )
[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
{
se_sess_cache = kmem_cache_create ( " se_sess_cache " ,
sizeof ( struct se_session ) , __alignof__ ( struct se_session ) ,
0 , NULL ) ;
2011-06-08 10:36:43 -07:00
if ( ! se_sess_cache ) {
pr_err ( " kmem_cache_create() for 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
" failed \n " ) ;
2012-01-19 13:39:17 -08:00
goto out ;
[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
}
se_ua_cache = kmem_cache_create ( " se_ua_cache " ,
sizeof ( struct se_ua ) , __alignof__ ( struct se_ua ) ,
0 , NULL ) ;
2011-06-08 10:36:43 -07:00
if ( ! se_ua_cache ) {
pr_err ( " kmem_cache_create() for struct se_ua failed \n " ) ;
2011-10-17 13:56:53 -04:00
goto out_free_sess_cache ;
[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
}
t10_pr_reg_cache = kmem_cache_create ( " t10_pr_reg_cache " ,
sizeof ( struct t10_pr_registration ) ,
__alignof__ ( struct t10_pr_registration ) , 0 , NULL ) ;
2011-06-08 10:36:43 -07:00
if ( ! t10_pr_reg_cache ) {
pr_err ( " kmem_cache_create() for struct t10_pr_registration "
[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
" failed \n " ) ;
2011-10-17 13:56:53 -04:00
goto out_free_ua_cache ;
[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
}
t10_alua_lu_gp_cache = kmem_cache_create ( " t10_alua_lu_gp_cache " ,
sizeof ( struct t10_alua_lu_gp ) , __alignof__ ( struct t10_alua_lu_gp ) ,
0 , NULL ) ;
2011-06-08 10:36:43 -07:00
if ( ! t10_alua_lu_gp_cache ) {
pr_err ( " kmem_cache_create() for t10_alua_lu_gp_cache "
[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
" failed \n " ) ;
2011-10-17 13:56:53 -04:00
goto out_free_pr_reg_cache ;
[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
}
t10_alua_lu_gp_mem_cache = kmem_cache_create ( " t10_alua_lu_gp_mem_cache " ,
sizeof ( struct t10_alua_lu_gp_member ) ,
__alignof__ ( struct t10_alua_lu_gp_member ) , 0 , NULL ) ;
2011-06-08 10:36:43 -07:00
if ( ! t10_alua_lu_gp_mem_cache ) {
pr_err ( " kmem_cache_create() for t10_alua_lu_gp_mem_ "
[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
" cache failed \n " ) ;
2011-10-17 13:56:53 -04:00
goto out_free_lu_gp_cache ;
[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
}
t10_alua_tg_pt_gp_cache = kmem_cache_create ( " t10_alua_tg_pt_gp_cache " ,
sizeof ( struct t10_alua_tg_pt_gp ) ,
__alignof__ ( struct t10_alua_tg_pt_gp ) , 0 , NULL ) ;
2011-06-08 10:36:43 -07:00
if ( ! t10_alua_tg_pt_gp_cache ) {
pr_err ( " kmem_cache_create() for t10_alua_tg_pt_gp_ "
[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
" cache failed \n " ) ;
2011-10-17 13:56:53 -04:00
goto out_free_lu_gp_mem_cache ;
[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
}
2013-12-17 09:18:50 +01:00
t10_alua_lba_map_cache = kmem_cache_create (
" t10_alua_lba_map_cache " ,
sizeof ( struct t10_alua_lba_map ) ,
__alignof__ ( struct t10_alua_lba_map ) , 0 , NULL ) ;
if ( ! t10_alua_lba_map_cache ) {
pr_err ( " kmem_cache_create() for t10_alua_lba_map_ "
" cache failed \n " ) ;
2015-05-25 21:33:08 -07:00
goto out_free_tg_pt_gp_cache ;
2013-12-17 09:18:50 +01:00
}
t10_alua_lba_map_mem_cache = kmem_cache_create (
" t10_alua_lba_map_mem_cache " ,
sizeof ( struct t10_alua_lba_map_member ) ,
__alignof__ ( struct t10_alua_lba_map_member ) , 0 , NULL ) ;
if ( ! t10_alua_lba_map_mem_cache ) {
pr_err ( " kmem_cache_create() for t10_alua_lba_map_mem_ "
" cache failed \n " ) ;
goto out_free_lba_map_cache ;
}
[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-10-17 13:56:53 -04:00
target_completion_wq = alloc_workqueue ( " target_completion " ,
WQ_MEM_RECLAIM , 0 ) ;
if ( ! target_completion_wq )
2013-12-17 09:18:50 +01:00
goto out_free_lba_map_mem_cache ;
2011-10-17 13:56:53 -04:00
2021-02-27 10:59:57 -06:00
target_submission_wq = alloc_workqueue ( " target_submission " ,
WQ_MEM_RECLAIM , 0 ) ;
if ( ! target_submission_wq )
goto out_free_completion_wq ;
[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
return 0 ;
2011-10-17 13:56:53 -04:00
2021-02-27 10:59:57 -06:00
out_free_completion_wq :
destroy_workqueue ( target_completion_wq ) ;
2013-12-17 09:18:50 +01:00
out_free_lba_map_mem_cache :
kmem_cache_destroy ( t10_alua_lba_map_mem_cache ) ;
out_free_lba_map_cache :
kmem_cache_destroy ( t10_alua_lba_map_cache ) ;
2011-10-17 13:56:53 -04:00
out_free_tg_pt_gp_cache :
kmem_cache_destroy ( t10_alua_tg_pt_gp_cache ) ;
out_free_lu_gp_mem_cache :
kmem_cache_destroy ( t10_alua_lu_gp_mem_cache ) ;
out_free_lu_gp_cache :
kmem_cache_destroy ( t10_alua_lu_gp_cache ) ;
out_free_pr_reg_cache :
kmem_cache_destroy ( t10_pr_reg_cache ) ;
out_free_ua_cache :
kmem_cache_destroy ( se_ua_cache ) ;
out_free_sess_cache :
kmem_cache_destroy ( se_sess_cache ) ;
[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
out :
2011-07-19 08:55:10 +00:00
return - ENOMEM ;
[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-07-19 08:55:10 +00:00
void release_se_kmem_caches ( void )
[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
{
2021-02-27 10:59:57 -06:00
destroy_workqueue ( target_submission_wq ) ;
2011-10-17 13:56:53 -04:00
destroy_workqueue ( target_completion_wq ) ;
[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
kmem_cache_destroy ( se_sess_cache ) ;
kmem_cache_destroy ( se_ua_cache ) ;
kmem_cache_destroy ( t10_pr_reg_cache ) ;
kmem_cache_destroy ( t10_alua_lu_gp_cache ) ;
kmem_cache_destroy ( t10_alua_lu_gp_mem_cache ) ;
kmem_cache_destroy ( t10_alua_tg_pt_gp_cache ) ;
2013-12-17 09:18:50 +01:00
kmem_cache_destroy ( t10_alua_lba_map_cache ) ;
kmem_cache_destroy ( t10_alua_lba_map_mem_cache ) ;
[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-07-19 08:55:10 +00:00
/* This code ensures unique mib indexes are handed out. */
static DEFINE_SPINLOCK ( scsi_mib_index_lock ) ;
static u32 scsi_mib_index [ SCSI_INDEX_TYPE_MAX ] ;
2011-02-09 15:35:03 -08:00
/*
* Allocate a new row index for the entry type specified
*/
u32 scsi_get_new_index ( scsi_index_t type )
{
u32 new_index ;
2011-07-19 08:55:10 +00:00
BUG_ON ( ( type < 0 ) | | ( type > = SCSI_INDEX_TYPE_MAX ) ) ;
2011-02-09 15:35:03 -08:00
2011-07-19 08:55:10 +00:00
spin_lock ( & scsi_mib_index_lock ) ;
new_index = + + scsi_mib_index [ type ] ;
spin_unlock ( & scsi_mib_index_lock ) ;
2011-02-09 15:35:03 -08:00
return new_index ;
}
2011-10-22 01:03:54 -07:00
void transport_subsystem_check_init ( void )
[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
{
int ret ;
2012-07-30 15:54:17 -07:00
static int sub_api_initialized ;
[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-10-22 01:03:54 -07:00
if ( sub_api_initialized )
return ;
2018-10-20 09:45:16 -07:00
ret = IS_ENABLED ( CONFIG_TCM_IBLOCK ) & & request_module ( " target_core_iblock " ) ;
[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
if ( ret ! = 0 )
2011-06-08 10:36:43 -07:00
pr_err ( " Unable to load target_core_iblock \n " ) ;
[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
2018-10-20 09:45:16 -07:00
ret = IS_ENABLED ( CONFIG_TCM_FILEIO ) & & request_module ( " target_core_file " ) ;
[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
if ( ret ! = 0 )
2011-06-08 10:36:43 -07:00
pr_err ( " Unable to load target_core_file \n " ) ;
[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
2018-10-20 09:45:16 -07:00
ret = IS_ENABLED ( CONFIG_TCM_PSCSI ) & & request_module ( " target_core_pscsi " ) ;
[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
if ( ret ! = 0 )
2011-06-08 10:36:43 -07:00
pr_err ( " Unable to load target_core_pscsi \n " ) ;
[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
2018-10-20 09:45:16 -07:00
ret = IS_ENABLED ( CONFIG_TCM_USER2 ) & & request_module ( " target_core_user " ) ;
2014-10-01 16:07:05 -07:00
if ( ret ! = 0 )
pr_err ( " Unable to load target_core_user \n " ) ;
2011-07-19 08:55:10 +00:00
sub_api_initialized = 1 ;
[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
}
2018-11-27 15:51:58 -08:00
static void target_release_sess_cmd_refcnt ( struct percpu_ref * ref )
{
struct se_session * sess = container_of ( ref , typeof ( * sess ) , cmd_count ) ;
2020-11-01 12:59:32 -06:00
wake_up ( & sess - > cmd_count_wq ) ;
2018-11-27 15:51:58 -08:00
}
2018-06-22 14:52:52 -07:00
/**
* transport_init_session - initialize a session object
* @ se_sess : Session object pointer .
*
* The caller must have zero - initialized @ se_sess before calling this function .
*/
2018-11-27 15:51:58 -08:00
int transport_init_session ( struct se_session * se_sess )
2018-06-22 14:52:52 -07:00
{
INIT_LIST_HEAD ( & se_sess - > sess_list ) ;
INIT_LIST_HEAD ( & se_sess - > sess_acl_list ) ;
spin_lock_init ( & se_sess - > sess_cmd_lock ) ;
2020-11-01 12:59:32 -06:00
init_waitqueue_head ( & se_sess - > cmd_count_wq ) ;
init_completion ( & se_sess - > stop_done ) ;
atomic_set ( & se_sess - > stopped , 0 ) ;
2018-11-27 15:51:58 -08:00
return percpu_ref_init ( & se_sess - > cmd_count ,
target_release_sess_cmd_refcnt , 0 , GFP_KERNEL ) ;
2018-06-22 14:52:52 -07:00
}
EXPORT_SYMBOL ( transport_init_session ) ;
2020-07-01 20:43:18 -05:00
void transport_uninit_session ( struct se_session * se_sess )
{
2020-11-01 12:59:28 -06:00
/*
2020-11-01 12:59:32 -06:00
* Drivers like iscsi and loop do not call target_stop_session
* during session shutdown so we have to drop the ref taken at init
* time here .
2020-11-01 12:59:28 -06:00
*/
2020-11-01 12:59:32 -06:00
if ( ! atomic_read ( & se_sess - > stopped ) )
2020-11-01 12:59:28 -06:00
percpu_ref_put ( & se_sess - > cmd_count ) ;
2020-07-01 20:43:18 -05:00
percpu_ref_exit ( & se_sess - > cmd_count ) ;
}
2018-06-22 14:52:51 -07:00
/**
* transport_alloc_session - allocate a session object and initialize it
* @ sup_prot_ops : bitmask that defines which T10 - PI modes are supported .
*/
struct se_session * transport_alloc_session ( enum target_prot_op sup_prot_ops )
[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_session * se_sess ;
2018-11-27 15:51:58 -08:00
int ret ;
[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
se_sess = kmem_cache_zalloc ( se_sess_cache , GFP_KERNEL ) ;
2011-06-08 10:36:43 -07:00
if ( ! se_sess ) {
pr_err ( " Unable to allocate struct se_session from "
[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
" se_sess_cache \n " ) ;
return ERR_PTR ( - ENOMEM ) ;
}
2018-11-27 15:51:58 -08:00
ret = transport_init_session ( se_sess ) ;
if ( ret < 0 ) {
2018-12-17 12:19:53 +00:00
kmem_cache_free ( se_sess_cache , se_sess ) ;
2018-11-27 15:51:58 -08:00
return ERR_PTR ( ret ) ;
}
2014-04-02 12:52:38 -07:00
se_sess - > sup_prot_ops = sup_prot_ops ;
[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
return se_sess ;
}
2018-06-22 14:52:51 -07:00
EXPORT_SYMBOL ( transport_alloc_session ) ;
/**
* transport_alloc_session_tags - allocate target driver private data
* @ se_sess : Session pointer .
* @ tag_num : Maximum number of in - flight commands between initiator and target .
* @ tag_size : Size in bytes of the private data a target driver associates with
* each command .
*/
2013-06-07 17:38:58 -07:00
int transport_alloc_session_tags ( struct se_session * se_sess ,
unsigned int tag_num , unsigned int tag_size )
{
int rc ;
2018-11-27 15:51:56 -08:00
se_sess - > sess_cmd_map = kvcalloc ( tag_size , tag_num ,
GFP_KERNEL | __GFP_RETRY_MAYFAIL ) ;
2013-06-07 17:38:58 -07:00
if ( ! se_sess - > sess_cmd_map ) {
2018-11-27 15:51:56 -08:00
pr_err ( " Unable to allocate se_sess->sess_cmd_map \n " ) ;
return - ENOMEM ;
2013-06-07 17:38:58 -07:00
}
2018-06-12 12:05:44 -07:00
rc = sbitmap_queue_init_node ( & se_sess - > sess_tag_pool , tag_num , - 1 ,
false , GFP_KERNEL , NUMA_NO_NODE ) ;
2013-06-07 17:38:58 -07:00
if ( rc < 0 ) {
pr_err ( " Unable to init se_sess->sess_tag_pool, "
" tag_num: %u \n " , tag_num ) ;
2015-06-30 14:59:24 -07:00
kvfree ( se_sess - > sess_cmd_map ) ;
2013-06-07 17:38:58 -07:00
se_sess - > sess_cmd_map = NULL ;
return - ENOMEM ;
}
return 0 ;
}
EXPORT_SYMBOL ( transport_alloc_session_tags ) ;
2018-06-22 14:52:51 -07:00
/**
* transport_init_session_tags - allocate a session and target driver private data
* @ tag_num : Maximum number of in - flight commands between initiator and target .
* @ tag_size : Size in bytes of the private data a target driver associates with
* each command .
* @ sup_prot_ops : bitmask that defines which T10 - PI modes are supported .
*/
2018-08-02 12:12:22 -05:00
static struct se_session *
transport_init_session_tags ( unsigned int tag_num , unsigned int tag_size ,
enum target_prot_op sup_prot_ops )
2013-06-07 17:38:58 -07:00
{
struct se_session * se_sess ;
int rc ;
2016-01-09 05:29:24 -08:00
if ( tag_num ! = 0 & & ! tag_size ) {
pr_err ( " init_session_tags called with percpu-ida tag_num: "
" %u, but zero tag_size \n " , tag_num ) ;
return ERR_PTR ( - EINVAL ) ;
}
if ( ! tag_num & & tag_size ) {
pr_err ( " init_session_tags called with percpu-ida tag_size: "
" %u, but zero tag_num \n " , tag_size ) ;
return ERR_PTR ( - EINVAL ) ;
}
2018-06-22 14:52:51 -07:00
se_sess = transport_alloc_session ( sup_prot_ops ) ;
2013-06-07 17:38:58 -07:00
if ( IS_ERR ( se_sess ) )
return se_sess ;
rc = transport_alloc_session_tags ( se_sess , tag_num , tag_size ) ;
if ( rc < 0 ) {
transport_free_session ( se_sess ) ;
return ERR_PTR ( - ENOMEM ) ;
}
return se_sess ;
}
[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-08-31 12:34:39 -07:00
* Called with spin_lock_irqsave ( & struct se_portal_group - > session_lock called .
[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
*/
void __transport_register_session (
struct se_portal_group * se_tpg ,
struct se_node_acl * se_nacl ,
struct se_session * se_sess ,
void * fabric_sess_ptr )
{
2015-04-08 20:01:35 +02:00
const struct target_core_fabric_ops * tfo = se_tpg - > se_tpg_tfo ;
[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
unsigned char buf [ PR_REG_ISID_LEN ] ;
2018-08-02 12:12:20 -05:00
unsigned long flags ;
[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
se_sess - > se_tpg = se_tpg ;
se_sess - > fabric_sess_ptr = fabric_sess_ptr ;
/*
* Used by struct se_node_acl ' s under ConfigFS to locate active se_session - t
*
* Only set for struct se_session ' s that will actually be moving I / O .
* eg : * NOT * discovery sessions .
*/
if ( se_nacl ) {
2015-04-14 11:52:22 -07:00
/*
*
* Determine if fabric allows for T10 - PI feature bits exposed to
* initiators for device backends with ! dev - > dev_attrib . pi_prot_type .
*
* If so , then always save prot_type on a per se_node_acl node
* basis and re - instate the previous sess_prot_type to avoid
* disabling PI from below any previously initiator side
* registered LUNs .
*/
if ( se_nacl - > saved_prot_type )
se_sess - > sess_prot_type = se_nacl - > saved_prot_type ;
else if ( tfo - > tpg_check_prot_fabric_only )
se_sess - > sess_prot_type = se_nacl - > saved_prot_type =
tfo - > tpg_check_prot_fabric_only ( se_tpg ) ;
[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
/*
* If the fabric module supports an ISID based TransportID ,
* save this value in binary from the fabric I_T Nexus now .
*/
2011-07-19 08:55:10 +00:00
if ( se_tpg - > se_tpg_tfo - > sess_get_initiator_sid ! = NULL ) {
[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
memset ( & buf [ 0 ] , 0 , PR_REG_ISID_LEN ) ;
2011-07-19 08:55:10 +00:00
se_tpg - > se_tpg_tfo - > sess_get_initiator_sid ( se_sess ,
[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
& buf [ 0 ] , PR_REG_ISID_LEN ) ;
se_sess - > sess_bin_isid = get_unaligned_be64 ( & buf [ 0 ] ) ;
}
2012-03-08 23:45:02 -08:00
2018-08-02 12:12:20 -05:00
spin_lock_irqsave ( & se_nacl - > nacl_sess_lock , flags ) ;
[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
/*
* The se_nacl - > nacl_sess pointer will be set to the
* last active I_T Nexus for each struct se_node_acl .
*/
se_nacl - > nacl_sess = se_sess ;
list_add_tail ( & se_sess - > sess_acl_list ,
& se_nacl - > acl_sess_list ) ;
2018-08-02 12:12:20 -05:00
spin_unlock_irqrestore ( & se_nacl - > nacl_sess_lock , flags ) ;
[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
}
list_add_tail ( & se_sess - > sess_list , & se_tpg - > tpg_sess_list ) ;
2011-06-08 10:36:43 -07:00
pr_debug ( " TARGET_CORE[%s]: Registered fabric_sess_ptr: %p \n " ,
2018-11-23 18:36:12 +01:00
se_tpg - > se_tpg_tfo - > fabric_name , se_sess - > fabric_sess_ptr ) ;
[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
}
EXPORT_SYMBOL ( __transport_register_session ) ;
void transport_register_session (
struct se_portal_group * se_tpg ,
struct se_node_acl * se_nacl ,
struct se_session * se_sess ,
void * fabric_sess_ptr )
{
2011-08-31 12:34:39 -07:00
unsigned long flags ;
spin_lock_irqsave ( & se_tpg - > session_lock , flags ) ;
[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
__transport_register_session ( se_tpg , se_nacl , se_sess , fabric_sess_ptr ) ;
2011-08-31 12:34:39 -07:00
spin_unlock_irqrestore ( & se_tpg - > session_lock , flags ) ;
[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
}
EXPORT_SYMBOL ( transport_register_session ) ;
2016-01-09 05:29:24 -08:00
struct se_session *
2018-08-02 12:12:23 -05:00
target_setup_session ( struct se_portal_group * tpg ,
2016-01-09 05:29:24 -08:00
unsigned int tag_num , unsigned int tag_size ,
enum target_prot_op prot_op ,
const char * initiatorname , void * private ,
int ( * callback ) ( struct se_portal_group * ,
struct se_session * , void * ) )
{
struct se_session * sess ;
/*
* If the fabric driver is using percpu - ida based pre allocation
* of I / O descriptor tags , go ahead and perform that setup now . .
*/
if ( tag_num ! = 0 )
sess = transport_init_session_tags ( tag_num , tag_size , prot_op ) ;
else
2018-06-22 14:52:51 -07:00
sess = transport_alloc_session ( prot_op ) ;
2016-01-09 05:29:24 -08:00
if ( IS_ERR ( sess ) )
return sess ;
sess - > se_node_acl = core_tpg_check_initiator_node_acl ( tpg ,
( unsigned char * ) initiatorname ) ;
if ( ! sess - > se_node_acl ) {
transport_free_session ( sess ) ;
return ERR_PTR ( - EACCES ) ;
}
/*
* Go ahead and perform any remaining fabric setup that is
* required before transport_register_session ( ) .
*/
if ( callback ! = NULL ) {
int rc = callback ( tpg , sess , private ) ;
if ( rc ) {
transport_free_session ( sess ) ;
return ERR_PTR ( rc ) ;
}
}
transport_register_session ( tpg , sess - > se_node_acl , sess , private ) ;
return sess ;
}
2018-08-02 12:12:23 -05:00
EXPORT_SYMBOL ( target_setup_session ) ;
2016-01-09 05:29:24 -08:00
2015-03-06 20:34:32 -08:00
ssize_t target_show_dynamic_sessions ( struct se_portal_group * se_tpg , char * page )
{
struct se_session * se_sess ;
ssize_t len = 0 ;
spin_lock_bh ( & se_tpg - > session_lock ) ;
list_for_each_entry ( se_sess , & se_tpg - > tpg_sess_list , sess_list ) {
if ( ! se_sess - > se_node_acl )
continue ;
if ( ! se_sess - > se_node_acl - > dynamic_node_acl )
continue ;
if ( strlen ( se_sess - > se_node_acl - > initiatorname ) + 1 + len > PAGE_SIZE )
break ;
len + = snprintf ( page + len , PAGE_SIZE - len , " %s \n " ,
se_sess - > se_node_acl - > initiatorname ) ;
len + = 1 ; /* Include NULL terminator */
}
spin_unlock_bh ( & se_tpg - > session_lock ) ;
return len ;
}
EXPORT_SYMBOL ( target_show_dynamic_sessions ) ;
2012-03-08 23:45:02 -08:00
static void target_complete_nacl ( struct kref * kref )
{
struct se_node_acl * nacl = container_of ( kref ,
struct se_node_acl , acl_kref ) ;
2016-12-07 12:55:54 -08:00
struct se_portal_group * se_tpg = nacl - > se_tpg ;
2012-03-08 23:45:02 -08:00
2016-12-07 12:55:54 -08:00
if ( ! nacl - > dynamic_stop ) {
complete ( & nacl - > acl_free_comp ) ;
return ;
}
mutex_lock ( & se_tpg - > acl_node_mutex ) ;
2017-08-06 16:10:03 -07:00
list_del_init ( & nacl - > acl_list ) ;
2016-12-07 12:55:54 -08:00
mutex_unlock ( & se_tpg - > acl_node_mutex ) ;
core_tpg_wait_for_nacl_pr_ref ( nacl ) ;
core_free_device_list_for_node ( nacl , se_tpg ) ;
kfree ( nacl ) ;
2012-03-08 23:45:02 -08:00
}
void target_put_nacl ( struct se_node_acl * nacl )
{
kref_put ( & nacl - > acl_kref , target_complete_nacl ) ;
}
2016-01-07 22:09:27 -08:00
EXPORT_SYMBOL ( target_put_nacl ) ;
2012-03-08 23:45:02 -08:00
[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
void transport_deregister_session_configfs ( struct se_session * se_sess )
{
struct se_node_acl * se_nacl ;
2011-06-22 01:02:21 -07:00
unsigned long flags ;
[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
/*
* Used by struct se_node_acl ' s under ConfigFS to locate active struct se_session
*/
se_nacl = se_sess - > se_node_acl ;
2011-06-08 10:36:43 -07:00
if ( se_nacl ) {
2011-06-22 01:02:21 -07:00
spin_lock_irqsave ( & se_nacl - > nacl_sess_lock , flags ) ;
2016-05-02 15:45:20 +02:00
if ( ! list_empty ( & se_sess - > sess_acl_list ) )
list_del_init ( & se_sess - > sess_acl_list ) ;
[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
/*
* If the session list is empty , then clear the pointer .
* Otherwise , set the struct se_session pointer from the tail
* element of the per struct se_node_acl active session list .
*/
if ( list_empty ( & se_nacl - > acl_sess_list ) )
se_nacl - > nacl_sess = NULL ;
else {
se_nacl - > nacl_sess = container_of (
se_nacl - > acl_sess_list . prev ,
struct se_session , sess_acl_list ) ;
}
2011-06-22 01:02:21 -07:00
spin_unlock_irqrestore ( & se_nacl - > nacl_sess_lock , flags ) ;
[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
}
}
EXPORT_SYMBOL ( transport_deregister_session_configfs ) ;
void transport_free_session ( struct se_session * se_sess )
{
2016-01-07 22:09:27 -08:00
struct se_node_acl * se_nacl = se_sess - > se_node_acl ;
2016-12-07 12:55:54 -08:00
2016-01-07 22:09:27 -08:00
/*
* Drop the se_node_acl - > nacl_kref obtained from within
* core_tpg_get_initiator_node_acl ( ) .
*/
if ( se_nacl ) {
2016-12-07 12:55:54 -08:00
struct se_portal_group * se_tpg = se_nacl - > se_tpg ;
const struct target_core_fabric_ops * se_tfo = se_tpg - > se_tpg_tfo ;
unsigned long flags ;
2016-01-07 22:09:27 -08:00
se_sess - > se_node_acl = NULL ;
2016-12-07 12:55:54 -08:00
/*
* Also determine if we need to drop the extra - > cmd_kref if
* it had been previously dynamically generated , and
* the endpoint is not caching dynamic ACLs .
*/
mutex_lock ( & se_tpg - > acl_node_mutex ) ;
if ( se_nacl - > dynamic_node_acl & &
! se_tfo - > tpg_check_demo_mode_cache ( se_tpg ) ) {
spin_lock_irqsave ( & se_nacl - > nacl_sess_lock , flags ) ;
if ( list_empty ( & se_nacl - > acl_sess_list ) )
se_nacl - > dynamic_stop = true ;
spin_unlock_irqrestore ( & se_nacl - > nacl_sess_lock , flags ) ;
if ( se_nacl - > dynamic_stop )
2017-08-06 16:10:03 -07:00
list_del_init ( & se_nacl - > acl_list ) ;
2016-12-07 12:55:54 -08:00
}
mutex_unlock ( & se_tpg - > acl_node_mutex ) ;
if ( se_nacl - > dynamic_stop )
target_put_nacl ( se_nacl ) ;
2016-01-07 22:09:27 -08:00
target_put_nacl ( se_nacl ) ;
}
2013-06-07 17:38:58 -07:00
if ( se_sess - > sess_cmd_map ) {
2018-06-12 12:05:44 -07:00
sbitmap_queue_free ( & se_sess - > sess_tag_pool ) ;
2015-06-30 14:59:24 -07:00
kvfree ( se_sess - > sess_cmd_map ) ;
2013-06-07 17:38:58 -07:00
}
2020-07-01 20:43:18 -05:00
transport_uninit_session ( se_sess ) ;
[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
kmem_cache_free ( se_sess_cache , se_sess ) ;
}
EXPORT_SYMBOL ( transport_free_session ) ;
2019-11-13 14:05:07 -08:00
static int target_release_res ( struct se_device * dev , void * data )
{
struct se_session * sess = data ;
if ( dev - > reservation_holder = = sess )
target_release_reservation ( dev ) ;
return 0 ;
}
[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
void transport_deregister_session ( struct se_session * se_sess )
{
struct se_portal_group * se_tpg = se_sess - > se_tpg ;
2011-08-12 16:01:02 -07:00
unsigned long flags ;
[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-06-08 10:36:43 -07:00
if ( ! se_tpg ) {
[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
transport_free_session ( se_sess ) ;
return ;
}
2011-08-12 16:01:02 -07:00
spin_lock_irqsave ( & se_tpg - > session_lock , flags ) ;
[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
list_del ( & se_sess - > sess_list ) ;
se_sess - > se_tpg = NULL ;
se_sess - > fabric_sess_ptr = NULL ;
2011-08-12 16:01:02 -07:00
spin_unlock_irqrestore ( & se_tpg - > session_lock , flags ) ;
[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
2019-11-13 14:05:07 -08:00
/*
* Since the session is being removed , release SPC - 2
* reservations held by the session that is disappearing .
*/
target_for_each_device ( target_release_res , se_sess ) ;
2011-06-08 10:36:43 -07:00
pr_debug ( " TARGET_CORE[%s]: Deregistered fabric_sess \n " ,
2018-11-23 18:36:12 +01:00
se_tpg - > se_tpg_tfo - > fabric_name ) ;
2012-03-10 14:32:52 -08:00
/*
2013-11-19 09:07:46 +01:00
* If last kref is dropping now for an explicit NodeACL , awake sleeping
2012-03-08 23:45:02 -08:00
* - > acl_free_comp caller to wakeup configfs se_node_acl - > acl_group
2016-01-07 22:09:27 -08:00
* removal context from within transport_free_session ( ) code .
2016-12-07 12:55:54 -08:00
*
* For dynamic ACL , target_put_nacl ( ) uses target_complete_nacl ( )
* to release all remaining generate_node_acl = 1 created ACL resources .
2012-03-10 14:32:52 -08:00
*/
2012-03-08 23:45:02 -08:00
transport_free_session ( se_sess ) ;
[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
}
EXPORT_SYMBOL ( transport_deregister_session ) ;
2018-08-02 12:12:24 -05:00
void target_remove_session ( struct se_session * se_sess )
{
transport_deregister_session_configfs ( se_sess ) ;
transport_deregister_session ( se_sess ) ;
}
EXPORT_SYMBOL ( target_remove_session ) ;
2012-04-24 00:25:05 -04:00
static void target_remove_from_state_list ( struct se_cmd * 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
{
2011-10-12 11:07:00 -04:00
struct se_device * dev = cmd - > se_dev ;
[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
unsigned long flags ;
2011-10-12 11:07:00 -04:00
if ( ! dev )
return ;
[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
2020-11-01 12:59:33 -06:00
spin_lock_irqsave ( & dev - > queues [ cmd - > cpuid ] . lock , flags ) ;
2012-04-24 00:25:05 -04:00
if ( cmd - > state_active ) {
list_del ( & cmd - > state_list ) ;
cmd - > state_active = false ;
[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
}
2020-11-01 12:59:33 -06:00
spin_unlock_irqrestore ( & dev - > queues [ cmd - > cpuid ] . lock , flags ) ;
[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
}
2021-10-18 16:57:53 +03:00
static void target_remove_from_tmr_list ( struct se_cmd * cmd )
{
struct se_device * dev = NULL ;
unsigned long flags ;
if ( cmd - > se_cmd_flags & SCF_SCSI_TMR_CDB )
dev = cmd - > se_tmr_req - > tmr_dev ;
if ( dev ) {
spin_lock_irqsave ( & dev - > se_tmr_lock , flags ) ;
if ( cmd - > se_tmr_req - > tmr_dev )
list_del_init ( & cmd - > se_tmr_req - > tmr_list ) ;
spin_unlock_irqrestore ( & dev - > se_tmr_lock , flags ) ;
}
}
2018-06-22 14:52:54 -07:00
/*
* This function is called by the target core after the target core has
* finished processing a SCSI command or SCSI TMF . Both the regular command
* processing code and the code for aborting commands can call this
* function . CMD_T_STOP is set if and only if another thread is waiting
* inside transport_wait_for_tasks ( ) for t_transport_stop_comp .
*/
2017-02-01 16:58:35 -08:00
static int transport_cmd_check_stop_to_fabric ( struct se_cmd * 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
{
unsigned long flags ;
2016-01-11 21:31:09 -08:00
spin_lock_irqsave ( & cmd - > t_state_lock , flags ) ;
[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
/*
* Determine if frontend context caller is requesting the stopping of
2011-07-19 08:55:10 +00:00
* this command for frontend exceptions .
[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-12-21 14:13:47 -05:00
if ( cmd - > transport_state & CMD_T_STOP ) {
2015-04-14 13:26:44 +02:00
pr_debug ( " %s:%d CMD_T_STOP for ITT: 0x%08llx \n " ,
__func__ , __LINE__ , cmd - > tag ) ;
[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-05-02 17:12:10 -07:00
spin_unlock_irqrestore ( & cmd - > t_state_lock , flags ) ;
[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
2014-06-09 23:36:51 +00:00
complete_all ( & cmd - > t_transport_stop_comp ) ;
[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
return 1 ;
}
2012-07-08 15:58:38 -04:00
cmd - > transport_state & = ~ CMD_T_ACTIVE ;
2011-05-02 17:12:10 -07:00
spin_unlock_irqrestore ( & cmd - > t_state_lock , flags ) ;
[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
2017-02-01 16:58:35 -08:00
/*
* Some fabric modules like tcm_loop can release their internally
* allocated I / O reference and struct se_cmd now .
*
* Fabric modules are expected to return ' 1 ' here if the se_cmd being
* passed is released at this point , or zero if not being released .
*/
2017-03-08 00:09:59 -08:00
return cmd - > se_tfo - > check_stop_free ( 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
}
2020-02-09 21:12:02 -08:00
static void transport_lun_remove_cmd ( struct se_cmd * cmd )
{
struct se_lun * lun = cmd - > se_lun ;
if ( ! lun )
return ;
2021-10-18 16:57:53 +03:00
target_remove_from_state_list ( cmd ) ;
target_remove_from_tmr_list ( cmd ) ;
2020-02-09 21:12:02 -08:00
if ( cmpxchg ( & cmd - > lun_ref_active , true , false ) )
percpu_ref_put ( & lun - > lun_ref ) ;
2021-10-18 16:57:53 +03:00
/*
* Clear struct se_cmd - > se_lun before the handoff to FE .
*/
cmd - > se_lun = NULL ;
2020-02-09 21:12:02 -08:00
}
2011-10-17 13:56:53 -04:00
static void target_complete_failure_work ( struct work_struct * work )
{
struct se_cmd * cmd = container_of ( work , struct se_cmd , work ) ;
2021-08-03 17:54:09 +03:00
transport_generic_request_failure ( cmd , cmd - > sense_reason ) ;
2011-10-17 13:56:53 -04:00
}
2012-09-05 17:09:13 +02:00
/*
2012-09-05 17:09:15 +02:00
* Used when asking transport to copy Sense Data from the underlying
* Linux / SCSI struct scsi_cmnd
2012-09-05 17:09:13 +02:00
*/
2012-09-05 17:09:15 +02:00
static unsigned char * transport_get_sense_buffer ( struct se_cmd * cmd )
2012-09-05 17:09:13 +02:00
{
struct se_device * dev = cmd - > se_dev ;
WARN_ON ( ! cmd - > se_lun ) ;
if ( ! dev )
2012-09-05 17:09:15 +02:00
return NULL ;
2012-09-05 17:09:13 +02:00
2012-09-05 17:09:15 +02:00
if ( cmd - > se_cmd_flags & SCF_SENT_CHECK_CONDITION )
return NULL ;
2012-09-05 17:09:13 +02:00
2012-08-15 14:35:25 -07:00
cmd - > scsi_sense_length = TRANSPORT_SENSE_BUFFER ;
2012-09-05 17:09:13 +02:00
2012-09-05 17:09:15 +02:00
pr_debug ( " HBA_[%u]_PLUG[%s]: Requesting sense for SAM STATUS: 0x%02x \n " ,
2012-09-05 17:09:13 +02:00
dev - > se_hba - > hba_id , dev - > transport - > name , cmd - > scsi_status ) ;
2012-08-15 14:35:25 -07:00
return cmd - > sense_buffer ;
2012-09-05 17:09:13 +02:00
}
2017-05-31 15:52:39 -05:00
void transport_copy_sense_to_cmd ( struct se_cmd * cmd , unsigned char * sense )
{
unsigned char * cmd_sense_buf ;
unsigned long flags ;
spin_lock_irqsave ( & cmd - > t_state_lock , flags ) ;
cmd_sense_buf = transport_get_sense_buffer ( cmd ) ;
if ( ! cmd_sense_buf ) {
spin_unlock_irqrestore ( & cmd - > t_state_lock , flags ) ;
return ;
}
cmd - > se_cmd_flags | = SCF_TRANSPORT_TASK_SENSE ;
memcpy ( cmd_sense_buf , sense , cmd - > scsi_sense_length ) ;
spin_unlock_irqrestore ( & cmd - > t_state_lock , flags ) ;
}
EXPORT_SYMBOL ( transport_copy_sense_to_cmd ) ;
2018-11-27 15:52:03 -08:00
static void target_handle_abort ( struct se_cmd * cmd )
{
bool tas = cmd - > transport_state & CMD_T_TAS ;
bool ack_kref = cmd - > se_cmd_flags & SCF_ACK_KREF ;
int ret ;
pr_debug ( " tag %#llx: send_abort_response = %d \n " , cmd - > tag , tas ) ;
if ( tas ) {
if ( ! ( cmd - > se_cmd_flags & SCF_SCSI_TMR_CDB ) ) {
cmd - > scsi_status = SAM_STAT_TASK_ABORTED ;
pr_debug ( " Setting SAM_STAT_TASK_ABORTED status for CDB: 0x%02x, ITT: 0x%08llx \n " ,
cmd - > t_task_cdb [ 0 ] , cmd - > tag ) ;
trace_target_cmd_complete ( cmd ) ;
ret = cmd - > se_tfo - > queue_status ( cmd ) ;
if ( ret ) {
transport_handle_queue_full ( cmd , cmd - > se_dev ,
ret , false ) ;
return ;
}
} else {
cmd - > se_tmr_req - > response = TMR_FUNCTION_REJECTED ;
cmd - > se_tfo - > queue_tm_rsp ( cmd ) ;
}
} else {
/*
* Allow the fabric driver to unmap any resources before
* releasing the descriptor via TFO - > release_cmd ( ) .
*/
cmd - > se_tfo - > aborted_task ( cmd ) ;
if ( ack_kref )
WARN_ON_ONCE ( target_put_sess_cmd ( cmd ) ! = 0 ) ;
/*
* To do : establish a unit attention condition on the I_T
* nexus associated with cmd . See also the paragraph " Aborting
* commands " in SAM.
*/
}
WARN_ON_ONCE ( kref_read ( & cmd - > cmd_kref ) = = 0 ) ;
2020-02-09 21:12:02 -08:00
transport_lun_remove_cmd ( cmd ) ;
2018-11-27 15:52:03 -08:00
transport_cmd_check_stop_to_fabric ( cmd ) ;
}
static void target_abort_work ( struct work_struct * work )
{
struct se_cmd * cmd = container_of ( work , struct se_cmd , work ) ;
target_handle_abort ( cmd ) ;
}
static bool target_cmd_interrupted ( struct se_cmd * cmd )
{
int post_ret ;
if ( cmd - > transport_state & CMD_T_ABORTED ) {
if ( cmd - > transport_complete_callback )
cmd - > transport_complete_callback ( cmd , false , & post_ret ) ;
INIT_WORK ( & cmd - > work , target_abort_work ) ;
queue_work ( target_completion_wq , & cmd - > work ) ;
return true ;
} else if ( cmd - > transport_state & CMD_T_STOP ) {
if ( cmd - > transport_complete_callback )
cmd - > transport_complete_callback ( cmd , false , & post_ret ) ;
complete_all ( & cmd - > t_transport_stop_comp ) ;
return true ;
}
return false ;
}
/* May be called from interrupt context so must not sleep. */
2021-08-03 17:54:09 +03:00
void target_complete_cmd_with_sense ( struct se_cmd * cmd , u8 scsi_status ,
sense_reason_t sense_reason )
[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
{
2021-02-27 11:00:06 -06:00
struct se_wwn * wwn = cmd - > se_sess - > se_tpg - > se_tpg_wwn ;
int success , cpu ;
[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
unsigned long flags ;
2018-11-27 15:52:03 -08:00
if ( target_cmd_interrupted ( cmd ) )
return ;
2012-04-24 00:25:06 -04:00
cmd - > scsi_status = scsi_status ;
2021-08-03 17:54:09 +03:00
cmd - > sense_reason = sense_reason ;
2012-04-24 00:25:06 -04:00
2011-05-02 17:12:10 -07:00
spin_lock_irqsave ( & cmd - > t_state_lock , flags ) ;
2017-05-31 15:52:43 -05:00
switch ( cmd - > scsi_status ) {
case SAM_STAT_CHECK_CONDITION :
2012-09-05 17:09:15 +02:00
if ( cmd - > se_cmd_flags & SCF_TRANSPORT_TASK_SENSE )
[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
success = 1 ;
2017-05-31 15:52:43 -05:00
else
success = 0 ;
break ;
default :
2017-05-31 15:52:38 -05:00
success = 1 ;
2017-05-31 15:52:43 -05:00
break ;
[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-10-17 13:56:53 -04:00
cmd - > t_state = TRANSPORT_COMPLETE ;
2012-02-13 02:38:14 -08:00
cmd - > transport_state | = ( CMD_T_COMPLETE | CMD_T_ACTIVE ) ;
2011-05-02 17:12:10 -07:00
spin_unlock_irqrestore ( & cmd - > t_state_lock , flags ) ;
[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
2018-11-27 15:52:04 -08:00
INIT_WORK ( & cmd - > work , success ? target_complete_ok_work :
target_complete_failure_work ) ;
2021-02-27 11:00:06 -06:00
2021-07-21 00:55:22 +02:00
if ( ! wwn | | wwn - > cmd_compl_affinity = = SE_COMPL_AFFINITY_CPUID )
2021-02-27 11:00:06 -06:00
cpu = cmd - > cpuid ;
else
cpu = wwn - > cmd_compl_affinity ;
queue_work_on ( cpu , target_completion_wq , & cmd - > work ) ;
[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
}
2021-08-03 17:54:09 +03:00
EXPORT_SYMBOL ( target_complete_cmd_with_sense ) ;
void target_complete_cmd ( struct se_cmd * cmd , u8 scsi_status )
{
target_complete_cmd_with_sense ( cmd , scsi_status , scsi_status ?
TCM_LOGICAL_UNIT_COMMUNICATION_FAILURE :
TCM_NO_SENSE ) ;
}
2012-04-23 11:35:33 -04:00
EXPORT_SYMBOL ( target_complete_cmd ) ;
2021-02-09 10:22:01 +03:00
void target_set_cmd_data_length ( struct se_cmd * cmd , int length )
2014-06-10 11:07:47 -07:00
{
2021-02-09 10:22:01 +03:00
if ( length < cmd - > data_length ) {
2014-06-10 11:07:47 -07:00
if ( cmd - > se_cmd_flags & SCF_UNDERFLOW_BIT ) {
cmd - > residual_count + = cmd - > data_length - length ;
} else {
cmd - > se_cmd_flags | = SCF_UNDERFLOW_BIT ;
cmd - > residual_count = cmd - > data_length - length ;
}
cmd - > data_length = length ;
}
2021-02-09 10:22:01 +03:00
}
EXPORT_SYMBOL ( target_set_cmd_data_length ) ;
void target_complete_cmd_with_length ( struct se_cmd * cmd , u8 scsi_status , int length )
{
if ( scsi_status = = SAM_STAT_GOOD | |
cmd - > se_cmd_flags & SCF_TREAT_READ_AS_NORMAL ) {
target_set_cmd_data_length ( cmd , length ) ;
}
2014-06-10 11:07:47 -07:00
target_complete_cmd ( cmd , scsi_status ) ;
}
EXPORT_SYMBOL ( target_complete_cmd_with_length ) ;
2012-04-24 00:25:05 -04:00
static void target_add_to_state_list ( struct se_cmd * 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
{
2012-04-24 00:25:05 -04:00
struct se_device * dev = cmd - > se_dev ;
unsigned long flags ;
[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
2020-11-01 12:59:33 -06:00
spin_lock_irqsave ( & dev - > queues [ cmd - > cpuid ] . lock , flags ) ;
2012-04-24 00:25:05 -04:00
if ( ! cmd - > state_active ) {
2020-11-01 12:59:33 -06:00
list_add_tail ( & cmd - > state_list ,
& dev - > queues [ cmd - > cpuid ] . state_list ) ;
2012-04-24 00:25:05 -04:00
cmd - > state_active = true ;
[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
}
2020-11-01 12:59:33 -06:00
spin_unlock_irqrestore ( & dev - > queues [ cmd - > cpuid ] . lock , flags ) ;
[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-06-13 14:46:09 -07:00
/*
2011-10-25 23:57:41 -07:00
* Handle QUEUE_FULL / - EAGAIN and - ENOMEM status
2011-06-13 14:46:09 -07:00
*/
2012-07-08 15:58:47 -04:00
static void transport_write_pending_qf ( struct se_cmd * cmd ) ;
static void transport_complete_qf ( struct se_cmd * cmd ) ;
2011-06-13 14:46:09 -07:00
2012-10-08 00:03:19 -04:00
void target_qf_do_work ( struct work_struct * work )
2011-06-13 14:46:09 -07:00
{
struct se_device * dev = container_of ( work , struct se_device ,
qf_work_queue ) ;
2011-08-27 21:33:16 -07:00
LIST_HEAD ( qf_cmd_list ) ;
2011-06-13 14:46:09 -07:00
struct se_cmd * cmd , * cmd_tmp ;
spin_lock_irq ( & dev - > qf_cmd_lock ) ;
2011-08-27 21:33:16 -07:00
list_splice_init ( & dev - > qf_cmd_list , & qf_cmd_list ) ;
spin_unlock_irq ( & dev - > qf_cmd_lock ) ;
2011-06-13 14:46:09 -07:00
2011-08-27 21:33:16 -07:00
list_for_each_entry_safe ( cmd , cmd_tmp , & qf_cmd_list , se_qf_node ) {
2011-06-13 14:46:09 -07:00
list_del ( & cmd - > se_qf_node ) ;
2014-09-16 16:23:12 -04:00
atomic_dec_mb ( & dev - > dev_qf_count ) ;
2011-06-13 14:46:09 -07:00
2011-06-08 10:36:43 -07:00
pr_debug ( " Processing %s cmd: %p QUEUE_FULL in work queue "
2018-11-23 18:36:12 +01:00
" context: %s \n " , cmd - > se_tfo - > fabric_name , cmd ,
2011-10-17 13:56:41 -04:00
( cmd - > t_state = = TRANSPORT_COMPLETE_QF_OK ) ? " COMPLETE_OK " :
2011-06-13 14:46:09 -07:00
( cmd - > t_state = = TRANSPORT_COMPLETE_QF_WP ) ? " WRITE_PENDING "
: " UNKNOWN " ) ;
2011-10-17 13:56:42 -04:00
2012-07-08 15:58:47 -04:00
if ( cmd - > t_state = = TRANSPORT_COMPLETE_QF_WP )
transport_write_pending_qf ( cmd ) ;
2016-10-30 17:28:16 -07:00
else if ( cmd - > t_state = = TRANSPORT_COMPLETE_QF_OK | |
cmd - > t_state = = TRANSPORT_COMPLETE_QF_ERR )
2012-07-08 15:58:47 -04:00
transport_complete_qf ( cmd ) ;
2011-06-13 14:46:09 -07:00
}
}
[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
unsigned char * transport_dump_cmd_direction ( struct se_cmd * cmd )
{
switch ( cmd - > data_direction ) {
case DMA_NONE :
return " NONE " ;
case DMA_FROM_DEVICE :
return " READ " ;
case DMA_TO_DEVICE :
return " WRITE " ;
case DMA_BIDIRECTIONAL :
return " BIDI " ;
default :
break ;
}
return " UNKNOWN " ;
}
void transport_dump_dev_state (
struct se_device * dev ,
char * b ,
int * bl )
{
* bl + = sprintf ( b + * bl , " Status: " ) ;
2012-10-08 00:03:19 -04:00
if ( dev - > export_count )
[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
* bl + = sprintf ( b + * bl , " ACTIVATED " ) ;
2012-10-08 00:03:19 -04:00
else
[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
* bl + = sprintf ( b + * bl , " DEACTIVATED " ) ;
2012-05-20 14:34:44 -04:00
* bl + = sprintf ( b + * bl , " Max Queue Depth: %d " , dev - > queue_depth ) ;
2012-05-09 12:42:09 -07:00
* bl + = sprintf ( b + * bl , " SectorSize: %u HwMaxSectors: %u \n " ,
2012-10-08 00:03:19 -04:00
dev - > dev_attrib . block_size ,
dev - > dev_attrib . hw_max_sectors ) ;
[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
* bl + = sprintf ( b + * bl , " " ) ;
}
void transport_dump_vpd_proto_id (
struct t10_vpd * vpd ,
unsigned char * p_buf ,
int p_buf_len )
{
unsigned char buf [ VPD_TMP_BUF_SIZE ] ;
int len ;
memset ( buf , 0 , VPD_TMP_BUF_SIZE ) ;
len = sprintf ( buf , " T10 VPD Protocol Identifier: " ) ;
switch ( vpd - > protocol_identifier ) {
case 0x00 :
sprintf ( buf + len , " Fibre Channel \n " ) ;
break ;
case 0x10 :
sprintf ( buf + len , " Parallel SCSI \n " ) ;
break ;
case 0x20 :
sprintf ( buf + len , " SSA \n " ) ;
break ;
case 0x30 :
sprintf ( buf + len , " IEEE 1394 \n " ) ;
break ;
case 0x40 :
sprintf ( buf + len , " SCSI Remote Direct Memory Access "
" Protocol \n " ) ;
break ;
case 0x50 :
sprintf ( buf + len , " Internet SCSI (iSCSI) \n " ) ;
break ;
case 0x60 :
sprintf ( buf + len , " SAS Serial SCSI Protocol \n " ) ;
break ;
case 0x70 :
sprintf ( buf + len , " Automation/Drive Interface Transport "
" Protocol \n " ) ;
break ;
case 0x80 :
sprintf ( buf + len , " AT Attachment Interface ATA/ATAPI \n " ) ;
break ;
default :
sprintf ( buf + len , " Unknown 0x%02x \n " ,
vpd - > protocol_identifier ) ;
break ;
}
if ( p_buf )
strncpy ( p_buf , buf , p_buf_len ) ;
else
2011-06-08 10:36:43 -07:00
pr_debug ( " %s " , buf ) ;
[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
}
void
transport_set_vpd_proto_id ( struct t10_vpd * vpd , unsigned char * page_83 )
{
/*
* Check if the Protocol Identifier Valid ( PIV ) bit is set . .
*
* from spc3r23 . pdf section 7.5 .1
*/
if ( page_83 [ 1 ] & 0x80 ) {
vpd - > protocol_identifier = ( page_83 [ 0 ] & 0xf0 ) ;
vpd - > protocol_identifier_set = 1 ;
transport_dump_vpd_proto_id ( vpd , NULL , 0 ) ;
}
}
EXPORT_SYMBOL ( transport_set_vpd_proto_id ) ;
int transport_dump_vpd_assoc (
struct t10_vpd * vpd ,
unsigned char * p_buf ,
int p_buf_len )
{
unsigned char buf [ VPD_TMP_BUF_SIZE ] ;
2011-07-19 08:55:10 +00:00
int ret = 0 ;
int len ;
[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
memset ( buf , 0 , VPD_TMP_BUF_SIZE ) ;
len = sprintf ( buf , " T10 VPD Identifier Association: " ) ;
switch ( vpd - > association ) {
case 0x00 :
sprintf ( buf + len , " addressed logical unit \n " ) ;
break ;
case 0x10 :
sprintf ( buf + len , " target port \n " ) ;
break ;
case 0x20 :
sprintf ( buf + len , " SCSI target device \n " ) ;
break ;
default :
sprintf ( buf + len , " Unknown 0x%02x \n " , vpd - > association ) ;
2011-07-19 08:55:10 +00:00
ret = - EINVAL ;
[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
break ;
}
if ( p_buf )
strncpy ( p_buf , buf , p_buf_len ) ;
else
2011-06-08 10:36:43 -07:00
pr_debug ( " %s " , buf ) ;
[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
return ret ;
}
int transport_set_vpd_assoc ( struct t10_vpd * vpd , unsigned char * page_83 )
{
/*
* The VPD identification association . .
*
* from spc3r23 . pdf Section 7.6 .3 .1 Table 297
*/
vpd - > association = ( page_83 [ 1 ] & 0x30 ) ;
return transport_dump_vpd_assoc ( vpd , NULL , 0 ) ;
}
EXPORT_SYMBOL ( transport_set_vpd_assoc ) ;
int transport_dump_vpd_ident_type (
struct t10_vpd * vpd ,
unsigned char * p_buf ,
int p_buf_len )
{
unsigned char buf [ VPD_TMP_BUF_SIZE ] ;
2011-07-19 08:55:10 +00:00
int ret = 0 ;
int len ;
[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
memset ( buf , 0 , VPD_TMP_BUF_SIZE ) ;
len = sprintf ( buf , " T10 VPD Identifier Type: " ) ;
switch ( vpd - > device_identifier_type ) {
case 0x00 :
sprintf ( buf + len , " Vendor specific \n " ) ;
break ;
case 0x01 :
sprintf ( buf + len , " T10 Vendor ID based \n " ) ;
break ;
case 0x02 :
sprintf ( buf + len , " EUI-64 based \n " ) ;
break ;
case 0x03 :
sprintf ( buf + len , " NAA \n " ) ;
break ;
case 0x04 :
sprintf ( buf + len , " Relative target port identifier \n " ) ;
break ;
case 0x08 :
sprintf ( buf + len , " SCSI name string \n " ) ;
break ;
default :
sprintf ( buf + len , " Unsupported: 0x%02x \n " ,
vpd - > device_identifier_type ) ;
2011-07-19 08:55:10 +00:00
ret = - EINVAL ;
[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
break ;
}
2011-07-19 08:55:10 +00:00
if ( p_buf ) {
if ( p_buf_len < strlen ( buf ) + 1 )
return - EINVAL ;
[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
strncpy ( p_buf , buf , p_buf_len ) ;
2011-07-19 08:55:10 +00:00
} else {
2011-06-08 10:36:43 -07:00
pr_debug ( " %s " , buf ) ;
2011-07-19 08:55:10 +00:00
}
[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
return ret ;
}
int transport_set_vpd_ident_type ( struct t10_vpd * vpd , unsigned char * page_83 )
{
/*
* The VPD identifier type . .
*
* from spc3r23 . pdf Section 7.6 .3 .1 Table 298
*/
vpd - > device_identifier_type = ( page_83 [ 1 ] & 0x0f ) ;
return transport_dump_vpd_ident_type ( vpd , NULL , 0 ) ;
}
EXPORT_SYMBOL ( transport_set_vpd_ident_type ) ;
int transport_dump_vpd_ident (
struct t10_vpd * vpd ,
unsigned char * p_buf ,
int p_buf_len )
{
unsigned char buf [ VPD_TMP_BUF_SIZE ] ;
int ret = 0 ;
memset ( buf , 0 , VPD_TMP_BUF_SIZE ) ;
switch ( vpd - > device_identifier_code_set ) {
case 0x01 : /* Binary */
2013-01-18 16:05:12 +03:00
snprintf ( buf , sizeof ( buf ) ,
" T10 VPD Binary Device Identifier: %s \n " ,
[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
& vpd - > device_identifier [ 0 ] ) ;
break ;
case 0x02 : /* ASCII */
2013-01-18 16:05:12 +03:00
snprintf ( buf , sizeof ( buf ) ,
" T10 VPD ASCII Device Identifier: %s \n " ,
[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
& vpd - > device_identifier [ 0 ] ) ;
break ;
case 0x03 : /* UTF-8 */
2013-01-18 16:05:12 +03:00
snprintf ( buf , sizeof ( buf ) ,
" T10 VPD UTF-8 Device Identifier: %s \n " ,
[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
& vpd - > device_identifier [ 0 ] ) ;
break ;
default :
sprintf ( buf , " T10 VPD Device Identifier encoding unsupported: "
" 0x%02x " , vpd - > device_identifier_code_set ) ;
2011-07-19 08:55:10 +00:00
ret = - EINVAL ;
[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
break ;
}
if ( p_buf )
strncpy ( p_buf , buf , p_buf_len ) ;
else
2011-06-08 10:36:43 -07:00
pr_debug ( " %s " , buf ) ;
[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
return ret ;
}
int
transport_set_vpd_ident ( struct t10_vpd * vpd , unsigned char * page_83 )
{
static const char hex_str [ ] = " 0123456789abcdef " ;
2012-08-16 22:43:13 +09:00
int j = 0 , i = 4 ; /* offset to start of the identifier */
[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
/*
* The VPD Code Set ( encoding )
*
* from spc3r23 . pdf Section 7.6 .3 .1 Table 296
*/
vpd - > device_identifier_code_set = ( page_83 [ 0 ] & 0x0f ) ;
switch ( vpd - > device_identifier_code_set ) {
case 0x01 : /* Binary */
vpd - > device_identifier [ j + + ] =
hex_str [ vpd - > device_identifier_type ] ;
while ( i < ( 4 + page_83 [ 3 ] ) ) {
vpd - > device_identifier [ j + + ] =
hex_str [ ( page_83 [ i ] & 0xf0 ) > > 4 ] ;
vpd - > device_identifier [ j + + ] =
hex_str [ page_83 [ i ] & 0x0f ] ;
i + + ;
}
break ;
case 0x02 : /* ASCII */
case 0x03 : /* UTF-8 */
while ( i < ( 4 + page_83 [ 3 ] ) )
vpd - > device_identifier [ j + + ] = page_83 [ i + + ] ;
break ;
default :
break ;
}
return transport_dump_vpd_ident ( vpd , NULL , 0 ) ;
}
EXPORT_SYMBOL ( transport_set_vpd_ident ) ;
2015-07-30 18:28:13 -07:00
static sense_reason_t
target_check_max_data_sg_nents ( struct se_cmd * cmd , struct se_device * dev ,
unsigned int size )
{
u32 mtl ;
if ( ! cmd - > se_tfo - > max_data_sg_nents )
return TCM_NO_SENSE ;
/*
* Check if fabric enforced maximum SGL entries per I / O descriptor
* exceeds se_cmd - > data_length . If true , set SCF_UNDERFLOW_BIT +
* residual_count and reduce original cmd - > data_length to maximum
* length based on single PAGE_SIZE entry scatter - lists .
*/
mtl = ( cmd - > se_tfo - > max_data_sg_nents * PAGE_SIZE ) ;
if ( cmd - > data_length > mtl ) {
/*
* If an existing CDB overflow is present , calculate new residual
* based on CDB size minus fabric maximum transfer length .
*
* If an existing CDB underflow is present , calculate new residual
* based on original cmd - > data_length minus fabric maximum transfer
* length .
*
* Otherwise , set the underflow residual based on cmd - > data_length
* minus fabric maximum transfer length .
*/
if ( cmd - > se_cmd_flags & SCF_OVERFLOW_BIT ) {
cmd - > residual_count = ( size - mtl ) ;
} else if ( cmd - > se_cmd_flags & SCF_UNDERFLOW_BIT ) {
u32 orig_dl = size + cmd - > residual_count ;
cmd - > residual_count = ( orig_dl - mtl ) ;
} else {
cmd - > se_cmd_flags | = SCF_UNDERFLOW_BIT ;
cmd - > residual_count = ( cmd - > data_length - mtl ) ;
}
cmd - > data_length = mtl ;
/*
* Reset sbc_check_prot ( ) calculated protection payload
* length based upon the new smaller MTL .
*/
if ( cmd - > prot_length ) {
u32 sectors = ( mtl / dev - > dev_attrib . block_size ) ;
cmd - > prot_length = dev - > prot_length * sectors ;
}
}
return TCM_NO_SENSE ;
}
2019-11-07 13:54:58 -08:00
/**
* target_cmd_size_check - Check whether there will be a residual .
* @ cmd : SCSI command .
* @ size : Data buffer size derived from CDB . The data buffer size provided by
* the SCSI transport driver is available in @ cmd - > data_length .
*
* Compare the data buffer size from the CDB with the data buffer limit from the transport
* header . Set @ cmd - > residual_count and SCF_OVERFLOW_BIT or SCF_UNDERFLOW_BIT if necessary .
*
2021-02-27 10:59:44 -06:00
* Note : target drivers set @ cmd - > data_length by calling __target_init_cmd ( ) .
2019-11-07 13:54:58 -08:00
*
* Return : TCM_NO_SENSE
*/
2012-11-06 12:24:09 -08:00
sense_reason_t
target_cmd_size_check ( struct se_cmd * cmd , unsigned int size )
2012-05-20 11:59:12 -04:00
{
struct se_device * dev = cmd - > se_dev ;
if ( cmd - > unknown_data_length ) {
cmd - > data_length = size ;
} else if ( size ! = cmd - > data_length ) {
2017-05-11 01:07:24 -07:00
pr_warn_ratelimited ( " TARGET_CORE[%s]: Expected Transfer Length: "
2012-05-20 11:59:12 -04:00
" %u does not match SCSI CDB Length: %u for SAM Opcode: "
2018-11-23 18:36:12 +01:00
" 0x%02x \n " , cmd - > se_tfo - > fabric_name ,
2012-05-20 11:59:12 -04:00
cmd - > data_length , size , cmd - > t_task_cdb [ 0 ] ) ;
2020-12-03 11:20:34 +03:00
/*
* For READ command for the overflow case keep the existing
* fabric provided - > data_length . Otherwise for the underflow
* case , reset - > data_length to the smaller SCSI expected data
* transfer length .
*/
if ( size > cmd - > data_length ) {
cmd - > se_cmd_flags | = SCF_OVERFLOW_BIT ;
cmd - > residual_count = ( size - cmd - > data_length ) ;
} else {
cmd - > se_cmd_flags | = SCF_UNDERFLOW_BIT ;
cmd - > residual_count = ( cmd - > data_length - size ) ;
/*
* Do not truncate - > data_length for WRITE command to
* dump all payload
*/
if ( cmd - > data_direction = = DMA_FROM_DEVICE ) {
cmd - > data_length = size ;
}
}
2012-05-20 11:59:12 -04:00
2017-05-11 01:07:24 -07:00
if ( cmd - > data_direction = = DMA_TO_DEVICE ) {
if ( cmd - > se_cmd_flags & SCF_SCSI_DATA_CDB ) {
pr_err_ratelimited ( " Rejecting underflow/overflow "
" for WRITE data CDB \n " ) ;
2020-12-03 11:20:35 +03:00
return TCM_INVALID_FIELD_IN_COMMAND_IU ;
2017-05-11 01:07:24 -07:00
}
/*
* Some fabric drivers like iscsi - target still expect to
* always reject overflow writes . Reject this case until
* full fabric driver level support for overflow writes
* is introduced tree - wide .
*/
if ( size > cmd - > data_length ) {
pr_err_ratelimited ( " Rejecting overflow for "
" WRITE control CDB \n " ) ;
return TCM_INVALID_CDB_FIELD ;
}
2012-05-20 11:59:12 -04:00
}
}
2015-07-30 18:28:13 -07:00
return target_check_max_data_sg_nents ( cmd , dev , size ) ;
2012-05-20 11:59:12 -04:00
}
[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
/*
* Used by fabric modules containing a local struct se_cmd within their
* fabric dependent per I / O descriptor .
2015-04-14 13:26:44 +02:00
*
* Preserves the value of @ cmd - > tag .
[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
*/
2021-02-27 10:59:44 -06:00
void __target_init_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
struct se_cmd * cmd ,
2015-04-08 20:01:35 +02:00
const struct target_core_fabric_ops * tfo ,
[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_session * se_sess ,
u32 data_length ,
int data_direction ,
int task_attr ,
2020-06-07 19:58:31 +00:00
unsigned char * sense_buffer , u64 unpacked_lun )
[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-07-19 10:26:37 +00:00
INIT_LIST_HEAD ( & cmd - > se_delayed_node ) ;
2011-06-13 14:46:09 -07:00
INIT_LIST_HEAD ( & cmd - > se_qf_node ) ;
2012-04-24 00:25:05 -04:00
INIT_LIST_HEAD ( & cmd - > state_list ) ;
2011-05-02 17:12:10 -07:00
init_completion ( & cmd - > t_transport_stop_comp ) ;
2018-11-27 15:52:00 -08:00
cmd - > free_compl = NULL ;
cmd - > abrt_compl = NULL ;
2011-05-02 17:12:10 -07:00
spin_lock_init ( & cmd - > t_state_lock ) ;
2017-05-23 16:48:24 -07:00
INIT_WORK ( & cmd - > work , NULL ) ;
2014-05-17 06:49:22 -04:00
kref_init ( & cmd - > cmd_kref ) ;
[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
2021-02-27 10:59:42 -06:00
cmd - > t_task_cdb = & cmd - > __t_task_cdb [ 0 ] ;
[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
cmd - > se_tfo = tfo ;
cmd - > se_sess = se_sess ;
cmd - > data_length = data_length ;
cmd - > data_direction = data_direction ;
cmd - > sam_task_attr = task_attr ;
cmd - > sense_buffer = sense_buffer ;
2020-06-07 19:58:31 +00:00
cmd - > orig_fe_lun = unpacked_lun ;
2012-04-24 00:25:05 -04:00
2020-11-01 12:59:33 -06:00
if ( ! ( cmd - > se_cmd_flags & SCF_USE_CPUID ) )
2021-05-15 16:03:15 +09:00
cmd - > cpuid = raw_smp_processor_id ( ) ;
2020-11-01 12:59:33 -06:00
2012-04-24 00:25:05 -04:00
cmd - > state_active = false ;
[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
}
2021-02-27 10:59:44 -06:00
EXPORT_SYMBOL ( __target_init_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
2012-11-06 12:24:09 -08:00
static sense_reason_t
transport_check_alloc_task_attr ( struct se_cmd * 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
{
2012-10-10 17:37:14 -04:00
struct se_device * dev = cmd - > se_dev ;
[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
/*
* Check if SAM Task Attribute emulation is enabled for this
* struct se_device storage object
*/
2020-04-27 17:08:22 +02:00
if ( dev - > transport_flags & TRANSPORT_FLAG_PASSTHROUGH )
[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
return 0 ;
2014-11-24 07:07:25 -08:00
if ( cmd - > sam_task_attr = = TCM_ACA_TAG ) {
2011-06-08 10:36:43 -07:00
pr_debug ( " SAM Task Attribute ACA "
[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
" emulation is not supported \n " ) ;
2012-11-06 12:24:09 -08:00
return TCM_INVALID_CDB_FIELD ;
[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
}
2015-07-21 17:45:32 -07:00
[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
return 0 ;
}
2012-11-06 12:24:09 -08:00
sense_reason_t
2021-02-27 10:59:56 -06:00
target_cmd_init_cdb ( struct se_cmd * cmd , unsigned char * cdb , gfp_t gfp )
[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
{
2012-11-06 12:24:09 -08:00
sense_reason_t ret ;
[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
/*
* Ensure that the received CDB is less than the max ( 252 + 8 ) bytes
* for VARIABLE_LENGTH_CMD
*/
if ( scsi_command_size ( cdb ) > SCSI_MAX_VARLEN_CDB_SIZE ) {
2011-06-08 10:36:43 -07:00
pr_err ( " Received SCSI CDB with command_size: %d that "
[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
" exceeds SCSI_MAX_VARLEN_CDB_SIZE: %d \n " ,
scsi_command_size ( cdb ) , SCSI_MAX_VARLEN_CDB_SIZE ) ;
2020-06-07 19:58:32 +00:00
ret = TCM_INVALID_CDB_FIELD ;
goto err ;
[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
}
/*
* If the received CDB is larger than TCM_MAX_COMMAND_SIZE ,
* allocate the additional extended CDB buffer now . . Otherwise
* setup the pointer from __t_task_cdb to t_task_cdb .
*/
2011-05-02 17:12:10 -07:00
if ( scsi_command_size ( cdb ) > sizeof ( cmd - > __t_task_cdb ) ) {
2021-02-27 10:59:56 -06:00
cmd - > t_task_cdb = kzalloc ( scsi_command_size ( cdb ) , gfp ) ;
2011-06-08 10:36:43 -07:00
if ( ! cmd - > t_task_cdb ) {
pr_err ( " Unable to allocate cmd->t_task_cdb "
2011-05-02 17:12:10 -07:00
" %u > sizeof(cmd->__t_task_cdb): %lu ops \n " ,
[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
scsi_command_size ( cdb ) ,
2011-05-02 17:12:10 -07:00
( unsigned long ) sizeof ( cmd - > __t_task_cdb ) ) ;
2020-06-07 19:58:32 +00:00
ret = TCM_OUT_OF_RESOURCES ;
goto err ;
[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
}
2020-06-07 19:58:32 +00:00
}
[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-05-02 17:12:10 -07:00
* Copy the original CDB into 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
*/
2011-05-02 17:12:10 -07:00
memcpy ( cmd - > t_task_cdb , cdb , scsi_command_size ( cdb ) ) ;
2012-05-20 11:59:10 -04:00
2013-06-26 17:36:17 -07:00
trace_target_sequencer_start ( cmd ) ;
2020-06-07 19:58:30 +00:00
return 0 ;
2020-06-07 19:58:32 +00:00
err :
/*
* Copy the CDB here to allow trace_target_cmd_complete ( ) to
* print the cdb to the trace buffers .
*/
memcpy ( cmd - > t_task_cdb , cdb , min ( scsi_command_size ( cdb ) ,
( unsigned int ) TCM_MAX_COMMAND_SIZE ) ) ;
return ret ;
2020-06-07 19:58:30 +00:00
}
EXPORT_SYMBOL ( target_cmd_init_cdb ) ;
sense_reason_t
2020-06-07 19:58:33 +00:00
target_cmd_parse_cdb ( struct se_cmd * cmd )
2020-06-07 19:58:30 +00:00
{
struct se_device * dev = cmd - > se_dev ;
sense_reason_t ret ;
2013-06-26 17:36:17 -07:00
2012-10-08 00:03:19 -04:00
ret = dev - > transport - > parse_cdb ( cmd ) ;
2015-07-22 15:01:36 -07:00
if ( ret = = TCM_UNSUPPORTED_SCSI_OPCODE )
2021-09-29 14:50:00 +03:00
pr_debug_ratelimited ( " %s/%s: Unsupported SCSI Opcode 0x%02x, sending CHECK_CONDITION. \n " ,
cmd - > se_tfo - > fabric_name ,
cmd - > se_sess - > se_node_acl - > initiatorname ,
cmd - > t_task_cdb [ 0 ] ) ;
2012-11-06 12:24:09 -08:00
if ( ret )
return ret ;
ret = transport_check_alloc_task_attr ( cmd ) ;
if ( ret )
[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
return ret ;
2012-05-20 11:59:10 -04:00
cmd - > se_cmd_flags | = SCF_SUPPORTED_SAM_OPCODE ;
2015-05-19 00:03:07 -07:00
atomic_long_inc ( & cmd - > se_lun - > lun_stats . cmd_pdus ) ;
[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
return 0 ;
}
2020-06-07 19:58:33 +00:00
EXPORT_SYMBOL ( target_cmd_parse_cdb ) ;
[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-06-03 20:59:19 -07:00
/*
* Used by fabric module frontends to queue tasks directly .
2015-10-22 15:52:01 -07:00
* May only be used from process context .
2011-06-03 20:59:19 -07:00
*/
int transport_handle_cdb_direct (
struct se_cmd * cmd )
{
2012-11-06 12:24:09 -08:00
sense_reason_t ret ;
2011-07-30 05:03:58 -07:00
2020-12-20 21:36:38 +01:00
might_sleep ( ) ;
2011-06-03 20:59:19 -07:00
if ( ! cmd - > se_lun ) {
dump_stack ( ) ;
2011-06-08 10:36:43 -07:00
pr_err ( " cmd->se_lun is NULL \n " ) ;
2011-06-03 20:59:19 -07:00
return - EINVAL ;
}
2020-12-20 21:36:38 +01:00
2011-07-30 05:03:58 -07:00
/*
2012-07-08 15:58:49 -04:00
* Set TRANSPORT_NEW_CMD state and CMD_T_ACTIVE to ensure that
* outstanding descriptors are handled correctly during shutdown via
* transport_wait_for_tasks ( )
2011-07-30 05:03:58 -07:00
*
* Also , we don ' t take cmd - > t_state_lock here as we only expect
* this to be called for initial descriptor submission .
*/
cmd - > t_state = TRANSPORT_NEW_CMD ;
2011-12-21 14:13:47 -05:00
cmd - > transport_state | = CMD_T_ACTIVE ;
2011-07-30 05:03:58 -07:00
/*
* transport_generic_new_cmd ( ) is already handling QUEUE_FULL ,
* so follow TRANSPORT_NEW_CMD processing thread context usage
* and call transport_generic_request_failure ( ) if necessary . .
*/
ret = transport_generic_new_cmd ( cmd ) ;
2012-11-06 12:24:09 -08:00
if ( ret )
transport_generic_request_failure ( cmd , ret ) ;
2011-07-30 05:03:58 -07:00
return 0 ;
2011-06-03 20:59:19 -07:00
}
EXPORT_SYMBOL ( transport_handle_cdb_direct ) ;
2013-08-22 11:58:43 -07:00
sense_reason_t
2012-11-06 12:24:09 -08:00
transport_generic_map_mem_to_cmd ( struct se_cmd * cmd , struct scatterlist * sgl ,
u32 sgl_count , struct scatterlist * sgl_bidi , u32 sgl_bidi_count )
{
if ( ! sgl | | ! sgl_count )
return 0 ;
/*
* Reject SCSI data overflow with map_mem_to_cmd ( ) as incoming
* scatterlists already have been set to follow what the fabric
* passes for the original expected data transfer length .
*/
if ( cmd - > se_cmd_flags & SCF_OVERFLOW_BIT ) {
pr_warn ( " Rejecting SCSI DATA overflow for fabric using "
" SCF_PASSTHROUGH_SG_TO_MEM_NOALLOC \n " ) ;
return TCM_INVALID_CDB_FIELD ;
}
cmd - > t_data_sg = sgl ;
cmd - > t_data_nents = sgl_count ;
2015-04-23 21:30:07 +03:00
cmd - > t_bidi_data_sg = sgl_bidi ;
cmd - > t_bidi_data_nents = sgl_bidi_count ;
2012-11-06 12:24:09 -08:00
cmd - > se_cmd_flags | = SCF_PASSTHROUGH_SG_TO_MEM_NOALLOC ;
return 0 ;
}
2018-04-14 10:51:04 -07:00
/**
2021-02-27 10:59:45 -06:00
* target_init_cmd - initialize se_cmd
* @ se_cmd : command descriptor to init
2011-11-18 20:36:22 -08:00
* @ se_sess : associated se_sess for endpoint
* @ sense : pointer to SCSI sense buffer
* @ unpacked_lun : unpacked LUN to reference for struct se_lun
* @ data_length : fabric expected data transfer length
2018-04-14 10:51:04 -07:00
* @ task_attr : SAM task attribute
2011-11-18 20:36:22 -08:00
* @ data_dir : DMA data direction
* @ flags : flags for command submission from target_sc_flags_tables
*
2015-04-14 13:26:44 +02:00
* Task tags are supported if the caller has set @ se_cmd - > tag .
*
2021-02-27 10:59:45 -06:00
* Returns :
* - less than zero to signal active I / O shutdown failure .
* - zero on success .
2012-07-16 11:04:39 -07:00
*
2021-02-27 10:59:45 -06:00
* If the fabric driver calls target_stop_session , then it must check the
* return code and handle failures . This will never fail for other drivers ,
* and the return code can be ignored .
2012-10-01 17:23:22 -07:00
*/
2021-02-27 10:59:45 -06:00
int target_init_cmd ( struct se_cmd * se_cmd , struct se_session * se_sess ,
unsigned char * sense , u64 unpacked_lun ,
u32 data_length , int task_attr , int data_dir , int flags )
2011-11-18 20:36:22 -08:00
{
struct se_portal_group * se_tpg ;
2020-12-20 21:36:37 +01:00
2011-11-18 20:36:22 -08:00
se_tpg = se_sess - > se_tpg ;
BUG_ON ( ! se_tpg ) ;
BUG_ON ( se_cmd - > se_tfo | | se_cmd - > se_sess ) ;
2020-11-01 12:59:33 -06:00
if ( flags & TARGET_SCF_USE_CPUID )
se_cmd - > se_cmd_flags | = SCF_USE_CPUID ;
2021-02-27 10:59:45 -06:00
/*
* Signal bidirectional data payloads to target - core
*/
if ( flags & TARGET_SCF_BIDI_OP )
se_cmd - > se_cmd_flags | = SCF_BIDI ;
if ( flags & TARGET_SCF_UNKNOWN_SIZE )
se_cmd - > unknown_data_length = 1 ;
2011-11-18 20:36:22 -08:00
/*
* Initialize se_cmd for target operation . From this point
* exceptions are handled by sending exception status via
* target_core_fabric_ops - > queue_status ( ) callback
*/
2021-02-27 10:59:45 -06:00
__target_init_cmd ( se_cmd , se_tpg - > se_tpg_tfo , se_sess , data_length ,
data_dir , task_attr , sense , unpacked_lun ) ;
2016-02-10 18:59:13 -05:00
2011-11-18 20:36:22 -08:00
/*
2020-11-01 12:59:32 -06:00
* Obtain struct se_cmd - > cmd_kref reference . A second kref_get here is
* necessary for fabrics using TARGET_SCF_ACK_KREF that expect a second
2011-11-18 20:36:22 -08:00
* kref_put ( ) to happen during fabric packet acknowledgement .
*/
2021-02-27 10:59:45 -06:00
return target_get_sess_cmd ( se_cmd , flags & TARGET_SCF_ACK_KREF ) ;
}
EXPORT_SYMBOL_GPL ( target_init_cmd ) ;
/**
* target_submit_prep - prepare cmd for submission
* @ se_cmd : command descriptor to prep
* @ cdb : pointer to SCSI CDB
* @ sgl : struct scatterlist memory for unidirectional mapping
* @ sgl_count : scatterlist count for unidirectional mapping
* @ sgl_bidi : struct scatterlist memory for bidirectional READ mapping
* @ sgl_bidi_count : scatterlist count for bidirectional READ mapping
* @ sgl_prot : struct scatterlist memory protection information
* @ sgl_prot_count : scatterlist count for protection information
2021-02-27 10:59:56 -06:00
* @ gfp : gfp allocation type
2021-02-27 10:59:45 -06:00
*
* Returns :
* - less than zero to signal failure .
* - zero on success .
2021-03-18 17:58:58 -05:00
*
2021-02-27 10:59:45 -06:00
* If failure is returned , lio will the callers queue_status to complete
* the cmd .
*/
int target_submit_prep ( struct se_cmd * se_cmd , unsigned char * cdb ,
struct scatterlist * sgl , u32 sgl_count ,
struct scatterlist * sgl_bidi , u32 sgl_bidi_count ,
2021-02-27 10:59:56 -06:00
struct scatterlist * sgl_prot , u32 sgl_prot_count ,
gfp_t gfp )
2021-02-27 10:59:45 -06:00
{
sense_reason_t rc ;
2020-06-07 19:58:32 +00:00
2021-02-27 10:59:56 -06:00
rc = target_cmd_init_cdb ( se_cmd , cdb , gfp ) ;
2021-02-27 10:59:45 -06:00
if ( rc )
goto send_cc_direct ;
2020-06-07 19:58:32 +00:00
2011-11-18 20:36:22 -08:00
/*
* Locate se_lun pointer and attach it to struct se_cmd
*/
2020-06-07 19:58:31 +00:00
rc = transport_lookup_cmd_lun ( se_cmd ) ;
2021-02-27 10:59:45 -06:00
if ( rc )
goto send_cc_direct ;
2014-02-19 17:50:17 +02:00
2020-06-07 19:58:33 +00:00
rc = target_cmd_parse_cdb ( se_cmd ) ;
2021-02-27 10:59:45 -06:00
if ( rc ! = 0 )
goto generic_fail ;
2014-02-19 17:50:17 +02:00
2013-12-23 20:38:30 +00:00
/*
* Save pointers for SGLs containing protection information ,
* if present .
*/
if ( sgl_prot_count ) {
se_cmd - > t_prot_sg = sgl_prot ;
se_cmd - > t_prot_nents = sgl_prot_count ;
2015-05-01 15:23:49 +09:00
se_cmd - > se_cmd_flags | = SCF_PASSTHROUGH_PROT_SG_TO_MEM_NOALLOC ;
2013-12-23 20:38:30 +00:00
}
2012-05-20 11:59:14 -04:00
2012-10-01 17:23:22 -07:00
/*
* When a non zero sgl_count has been passed perform SGL passthrough
* mapping for pre - allocated fabric memory instead of having target
* core perform an internal SGL allocation . .
*/
if ( sgl_count ! = 0 ) {
BUG_ON ( ! sgl ) ;
2021-02-27 10:59:45 -06:00
rc = transport_generic_map_mem_to_cmd ( se_cmd , sgl , sgl_count ,
sgl_bidi , sgl_bidi_count ) ;
if ( rc ! = 0 )
goto generic_fail ;
}
return 0 ;
send_cc_direct :
transport_send_check_condition_and_sense ( se_cmd , rc , 0 ) ;
target_put_sess_cmd ( se_cmd ) ;
return - EIO ;
generic_fail :
transport_generic_request_failure ( se_cmd , rc ) ;
return - EIO ;
}
EXPORT_SYMBOL_GPL ( target_submit_prep ) ;
/**
* target_submit - perform final initialization and submit cmd to LIO core
* @ se_cmd : command descriptor to submit
*
* target_submit_prep must have been called on the cmd , and this must be
* called from process context .
*/
void target_submit ( struct se_cmd * se_cmd )
{
struct scatterlist * sgl = se_cmd - > t_data_sg ;
unsigned char * buf = NULL ;
might_sleep ( ) ;
if ( se_cmd - > t_data_nents ! = 0 ) {
BUG_ON ( ! sgl ) ;
2012-10-02 14:00:33 -07:00
/*
* A work - around for tcm_loop as some userspace code via
* scsi - generic do not memset their associated read buffers ,
* so go ahead and do that here for type non - data CDBs . Also
* note that this is currently guaranteed to be a single SGL
* for this case by target core in target_setup_cmd_from_cdb ( )
* - > transport_generic_cmd_sequencer ( ) .
*/
if ( ! ( se_cmd - > se_cmd_flags & SCF_SCSI_DATA_CDB ) & &
se_cmd - > data_direction = = DMA_FROM_DEVICE ) {
if ( sgl )
buf = kmap ( sg_page ( sgl ) ) + sgl - > offset ;
if ( buf ) {
memset ( buf , 0 , sgl - > length ) ;
kunmap ( sg_page ( sgl ) ) ;
}
}
2012-10-01 17:23:22 -07:00
}
2013-12-23 20:38:30 +00:00
2012-04-03 15:51:28 -07:00
/*
* Check if we need to delay processing because of ALUA
* Active / NonOptimized primary access state . .
*/
core_alua_check_nonop_delay ( se_cmd ) ;
2011-11-18 20:36:22 -08:00
transport_handle_cdb_direct ( se_cmd ) ;
2021-02-27 10:59:45 -06:00
}
EXPORT_SYMBOL_GPL ( target_submit ) ;
/**
2021-02-27 10:59:55 -06:00
* target_submit_cmd - lookup unpacked lun and submit uninitialized se_cmd
2021-02-27 10:59:45 -06:00
*
* @ se_cmd : command descriptor to submit
* @ se_sess : associated se_sess for endpoint
* @ cdb : pointer to SCSI CDB
* @ sense : pointer to SCSI sense buffer
* @ unpacked_lun : unpacked LUN to reference for struct se_lun
* @ data_length : fabric expected data transfer length
* @ task_attr : SAM task attribute
* @ data_dir : DMA data direction
* @ flags : flags for command submission from target_sc_flags_tables
*
* Task tags are supported if the caller has set @ se_cmd - > tag .
*
* This may only be called from process context , and also currently
* assumes internal allocation of fabric payload buffer by target - core .
2021-02-27 10:59:55 -06:00
*
* It also assumes interal target core SGL memory allocation .
*
* This function must only be used by drivers that do their own
* sync during shutdown and does not use target_stop_session . If there
* is a failure this function will call into the fabric driver ' s
* queue_status with a CHECK_CONDITION .
2021-02-27 10:59:45 -06:00
*/
2021-02-27 10:59:55 -06:00
void target_submit_cmd ( struct se_cmd * se_cmd , struct se_session * se_sess ,
2021-02-27 10:59:45 -06:00
unsigned char * cdb , unsigned char * sense , u64 unpacked_lun ,
2021-02-27 10:59:55 -06:00
u32 data_length , int task_attr , int data_dir , int flags )
2021-02-27 10:59:45 -06:00
{
int rc ;
2021-02-27 10:59:55 -06:00
rc = target_init_cmd ( se_cmd , se_sess , sense , unpacked_lun , data_length ,
task_attr , data_dir , flags ) ;
WARN ( rc , " Invalid target_submit_cmd use. Driver must not use target_stop_session or call target_init_cmd directly. \n " ) ;
if ( rc )
return ;
2021-02-27 10:59:45 -06:00
2021-02-27 10:59:56 -06:00
if ( target_submit_prep ( se_cmd , cdb , NULL , 0 , NULL , 0 , NULL , 0 ,
GFP_KERNEL ) )
2021-02-27 10:59:55 -06:00
return ;
2021-02-27 10:59:45 -06:00
target_submit ( se_cmd ) ;
2012-10-01 17:23:22 -07:00
}
2011-11-18 20:36:22 -08:00
EXPORT_SYMBOL ( target_submit_cmd ) ;
2021-02-27 11:00:02 -06:00
static struct se_dev_plug * target_plug_device ( struct se_device * se_dev )
{
struct se_dev_plug * se_plug ;
if ( ! se_dev - > transport - > plug_device )
return NULL ;
se_plug = se_dev - > transport - > plug_device ( se_dev ) ;
if ( ! se_plug )
return NULL ;
se_plug - > se_dev = se_dev ;
/*
* We have a ref to the lun at this point , but the cmds could
* complete before we unplug , so grab a ref to the se_device so we
* can call back into the backend .
*/
config_group_get ( & se_dev - > dev_group ) ;
return se_plug ;
}
static void target_unplug_device ( struct se_dev_plug * se_plug )
{
struct se_device * se_dev = se_plug - > se_dev ;
se_dev - > transport - > unplug_device ( se_plug ) ;
config_group_put ( & se_dev - > dev_group ) ;
}
2021-02-27 10:59:57 -06:00
void target_queued_submit_work ( struct work_struct * work )
{
struct se_cmd_queue * sq = container_of ( work , struct se_cmd_queue , work ) ;
struct se_cmd * se_cmd , * next_cmd ;
2021-02-27 11:00:02 -06:00
struct se_dev_plug * se_plug = NULL ;
struct se_device * se_dev = NULL ;
2021-02-27 10:59:57 -06:00
struct llist_node * cmd_list ;
cmd_list = llist_del_all ( & sq - > cmd_list ) ;
if ( ! cmd_list )
/* Previous call took what we were queued to submit */
return ;
cmd_list = llist_reverse_order ( cmd_list ) ;
2021-02-27 11:00:02 -06:00
llist_for_each_entry_safe ( se_cmd , next_cmd , cmd_list , se_cmd_list ) {
if ( ! se_dev ) {
se_dev = se_cmd - > se_dev ;
se_plug = target_plug_device ( se_dev ) ;
}
2021-02-27 10:59:57 -06:00
target_submit ( se_cmd ) ;
2021-02-27 11:00:02 -06:00
}
if ( se_plug )
target_unplug_device ( se_plug ) ;
2021-02-27 10:59:57 -06:00
}
/**
* target_queue_submission - queue the cmd to run on the LIO workqueue
* @ se_cmd : command descriptor to submit
*/
void target_queue_submission ( struct se_cmd * se_cmd )
{
struct se_device * se_dev = se_cmd - > se_dev ;
int cpu = se_cmd - > cpuid ;
struct se_cmd_queue * sq ;
sq = & se_dev - > queues [ cpu ] . sq ;
llist_add ( & se_cmd - > se_cmd_list , & sq - > cmd_list ) ;
queue_work_on ( cpu , target_submission_wq , & sq - > work ) ;
}
EXPORT_SYMBOL_GPL ( target_queue_submission ) ;
2012-02-25 05:02:48 -08:00
static void target_complete_tmr_failure ( struct work_struct * work )
{
struct se_cmd * se_cmd = container_of ( work , struct se_cmd , work ) ;
se_cmd - > se_tmr_req - > response = TMR_LUN_DOES_NOT_EXIST ;
se_cmd - > se_tfo - > queue_tm_rsp ( se_cmd ) ;
2013-01-02 12:47:59 -08:00
2020-02-09 21:12:02 -08:00
transport_lun_remove_cmd ( se_cmd ) ;
2013-01-02 12:47:59 -08:00
transport_cmd_check_stop_to_fabric ( se_cmd ) ;
2012-02-25 05:02:48 -08:00
}
2012-01-19 13:39:21 -08:00
/**
* target_submit_tmr - lookup unpacked lun and submit uninitialized se_cmd
* for TMR CDBs
*
* @ se_cmd : command descriptor to submit
* @ se_sess : associated se_sess for endpoint
* @ sense : pointer to SCSI sense buffer
* @ unpacked_lun : unpacked LUN to reference for struct se_lun
2018-04-14 10:51:03 -07:00
* @ fabric_tmr_ptr : fabric context for TMR req
2012-01-19 13:39:21 -08:00
* @ tm_type : Type of TM request
2012-02-25 05:10:04 -08:00
* @ gfp : gfp type for caller
* @ tag : referenced task tag for TMR_ABORT_TASK
2012-02-25 01:40:24 -08:00
* @ flags : submit cmd flags
2012-01-19 13:39:21 -08:00
*
* Callable from all contexts .
* */
2012-02-25 01:40:24 -08:00
int target_submit_tmr ( struct se_cmd * se_cmd , struct se_session * se_sess ,
2015-06-10 08:41:22 +02:00
unsigned char * sense , u64 unpacked_lun ,
2012-02-25 05:10:04 -08:00
void * fabric_tmr_ptr , unsigned char tm_type ,
2016-01-05 14:46:39 +01:00
gfp_t gfp , u64 tag , int flags )
2012-01-19 13:39:21 -08:00
{
struct se_portal_group * se_tpg ;
int ret ;
se_tpg = se_sess - > se_tpg ;
BUG_ON ( ! se_tpg ) ;
2021-02-27 10:59:44 -06:00
__target_init_cmd ( se_cmd , se_tpg - > se_tpg_tfo , se_sess ,
0 , DMA_NONE , TCM_SIMPLE_TAG , sense , unpacked_lun ) ;
2012-02-25 01:40:24 -08:00
/*
* FIXME : Currently expect caller to handle se_cmd - > se_tmr_req
* allocation failure .
*/
2012-02-25 05:10:04 -08:00
ret = core_tmr_alloc_req ( se_cmd , fabric_tmr_ptr , tm_type , gfp ) ;
2012-02-25 01:40:24 -08:00
if ( ret < 0 )
return - ENOMEM ;
2012-01-19 13:39:21 -08:00
2012-02-25 05:10:04 -08:00
if ( tm_type = = TMR_ABORT_TASK )
se_cmd - > se_tmr_req - > ref_task_tag = tag ;
2012-01-19 13:39:21 -08:00
/* See target_submit_cmd for commentary */
2015-04-27 13:52:36 +02:00
ret = target_get_sess_cmd ( se_cmd , flags & TARGET_SCF_ACK_KREF ) ;
target: Check sess_tearing_down in target_get_sess_cmd()
Target core code assumes that target_splice_sess_cmd_list() has set
sess_tearing_down and moved the list of pending commands to
sess_wait_list, no more commands will be added to the session; if any
are added, nothing keeps the se_session from being freed while the
command is still in flight, which e.g. leads to use-after-free of
se_cmd->se_sess in target_release_cmd_kref().
To enforce this invariant, put a check of sess_tearing_down inside of
sess_cmd_lock in target_get_sess_cmd(); any checks before this are
racy and can lead to the use-after-free described above. For example,
the qla_target check in qlt_do_work() checks sess_tearing_down from
work thread context but then drops all locks before calling
target_submit_cmd() (as it must, since that is a sleeping function).
However, since no locks are held, anything can happen with respect to
the session it has looked up -- although it does correctly get
sess_kref within its lock, so the memory won't be freed while
target_submit_cmd() is actually running, nothing stops eg an ACL from
being dropped and calling ->shutdown_session() (which calls into
target_splice_sess_cmd_list()) before we get to target_get_sess_cmd().
Once this happens, the se_session memory can be freed as soon as
target_submit_cmd() returns and qlt_do_work() drops its reference,
even though we've just added a command to sess_cmd_list.
To prevent this use-after-free, check sess_tearing_down inside of
sess_cmd_lock right before target_get_sess_cmd() adds a command to
sess_cmd_list; this is synchronized with target_splice_sess_cmd_list()
so that every command is either waited for or not added to the queue.
(nab: Keep target_submit_cmd() returning void for now..)
Signed-off-by: Roland Dreier <roland@purestorage.com>
Signed-off-by: Nicholas Bellinger <nab@linux-iscsi.org>
2012-07-16 11:04:40 -07:00
if ( ret ) {
core_tmr_release_req ( se_cmd - > se_tmr_req ) ;
return ret ;
}
2012-01-19 13:39:21 -08:00
2020-06-07 19:58:31 +00:00
ret = transport_lookup_tmr_lun ( se_cmd ) ;
2017-06-03 06:55:50 -07:00
if ( ret )
goto failure ;
2012-01-19 13:39:21 -08:00
transport_generic_handle_tmr ( se_cmd ) ;
2012-02-25 01:40:24 -08:00
return 0 ;
2017-06-03 06:55:50 -07:00
/*
* For callback during failure handling , push this work off
* to process context with TMR_LUN_DOES_NOT_EXIST status .
*/
failure :
INIT_WORK ( & se_cmd - > work , target_complete_tmr_failure ) ;
schedule_work ( & se_cmd - > work ) ;
return 0 ;
2012-01-19 13:39:21 -08:00
}
EXPORT_SYMBOL ( target_submit_tmr ) ;
[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
/*
* Handle SAM - esque emulation for generic transport request failures .
*/
2012-11-06 12:24:09 -08:00
void transport_generic_request_failure ( struct se_cmd * cmd ,
sense_reason_t sense_reason )
[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
{
2018-11-05 16:44:59 -08:00
int ret = 0 , post_ret ;
2011-06-13 14:46:09 -07:00
2017-05-23 16:48:28 -07:00
pr_debug ( " -----[ Storage Engine Exception; sense_reason %d \n " ,
sense_reason ) ;
target_show_cmd ( " -----[ " , 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
/*
* For SAM Task Attribute emulation for failed struct se_cmd
*/
2012-10-10 17:37:14 -04:00
transport_complete_task_attr ( cmd ) ;
2017-09-29 16:03:24 -07:00
2018-10-15 08:51:39 -07:00
if ( cmd - > transport_complete_callback )
2018-11-05 16:44:59 -08:00
cmd - > transport_complete_callback ( cmd , false , & post_ret ) ;
[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
2018-11-27 15:52:03 -08:00
if ( cmd - > transport_state & CMD_T_ABORTED ) {
INIT_WORK ( & cmd - > work , target_abort_work ) ;
queue_work ( target_completion_wq , & cmd - > work ) ;
2017-09-29 16:03:24 -07:00
return ;
2018-11-27 15:52:03 -08:00
}
2017-09-29 16:03:24 -07:00
2012-11-06 12:24:09 -08:00
switch ( sense_reason ) {
2011-11-04 02:36:16 -07:00
case TCM_NON_EXISTENT_LUN :
case TCM_UNSUPPORTED_SCSI_OPCODE :
case TCM_INVALID_CDB_FIELD :
case TCM_INVALID_PARAMETER_LIST :
2013-02-08 15:18:39 -08:00
case TCM_PARAMETER_LIST_LENGTH_ERROR :
2011-11-04 02:36:16 -07:00
case TCM_LOGICAL_UNIT_COMMUNICATION_FAILURE :
case TCM_UNKNOWN_MODE_PAGE :
case TCM_WRITE_PROTECTED :
2012-07-16 15:34:21 -07:00
case TCM_ADDRESS_OUT_OF_RANGE :
2011-11-04 02:36:16 -07:00
case TCM_CHECK_CONDITION_ABORT_CMD :
case TCM_CHECK_CONDITION_UNIT_ATTENTION :
2014-02-23 14:04:09 +00:00
case TCM_LOGICAL_BLOCK_GUARD_CHECK_FAILED :
case TCM_LOGICAL_BLOCK_APP_TAG_CHECK_FAILED :
case TCM_LOGICAL_BLOCK_REF_TAG_CHECK_FAILED :
2016-10-08 17:26:44 -07:00
case TCM_COPY_TARGET_DEVICE_NOT_REACHABLE :
2016-12-23 11:37:53 +01:00
case TCM_TOO_MANY_TARGET_DESCS :
case TCM_UNSUPPORTED_TARGET_DESC_TYPE_CODE :
case TCM_TOO_MANY_SEGMENT_DESCS :
case TCM_UNSUPPORTED_SEGMENT_DESC_TYPE_CODE :
2020-12-03 11:20:35 +03:00
case TCM_INVALID_FIELD_IN_COMMAND_IU :
2021-07-28 13:53:54 +02:00
case TCM_ALUA_TG_PT_STANDBY :
case TCM_ALUA_TG_PT_UNAVAILABLE :
case TCM_ALUA_STATE_TRANSITION :
case TCM_ALUA_OFFLINE :
[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
break ;
2012-11-06 12:24:09 -08:00
case TCM_OUT_OF_RESOURCES :
2017-10-25 11:47:14 -05:00
cmd - > scsi_status = SAM_STAT_TASK_SET_FULL ;
goto queue_status ;
2017-12-19 04:03:55 -06:00
case TCM_LUN_BUSY :
cmd - > scsi_status = SAM_STAT_BUSY ;
goto queue_status ;
2011-11-04 02:36:16 -07:00
case TCM_RESERVATION_CONFLICT :
[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
/*
* No SENSE Data payload for this case , set SCSI Status
* and queue the response to $ FABRIC_MOD .
*
* Uses linux / include / scsi / scsi . h SAM status codes defs
*/
cmd - > scsi_status = SAM_STAT_RESERVATION_CONFLICT ;
/*
* For UA Interlock Code 11 b , a RESERVATION CONFLICT will
* establish a UNIT ATTENTION with PREVIOUS RESERVATION
* CONFLICT STATUS .
*
* See spc4r17 , section 7.4 .6 Control Mode Page , Table 349
*/
2011-07-19 08:55:10 +00:00
if ( cmd - > se_sess & &
2020-02-21 10:44:01 +01:00
cmd - > se_dev - > dev_attrib . emulate_ua_intlck_ctrl
= = TARGET_UA_INTLCK_CTRL_ESTABLISH_UA ) {
2015-06-11 10:01:26 +02:00
target_ua_allocate_lun ( cmd - > se_sess - > se_node_acl ,
cmd - > orig_fe_lun , 0x2C ,
ASCQ_2CH_PREVIOUS_RESERVATION_CONFLICT_STATUS ) ;
}
2017-10-25 11:47:14 -05:00
goto queue_status ;
[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
default :
2011-06-08 10:36:43 -07:00
pr_err ( " Unknown transport error for CDB 0x%02x: %d \n " ,
2012-11-06 12:24:09 -08:00
cmd - > t_task_cdb [ 0 ] , sense_reason ) ;
sense_reason = TCM_UNSUPPORTED_SCSI_OPCODE ;
[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
break ;
}
2012-07-08 15:58:48 -04:00
2012-11-06 12:24:09 -08:00
ret = transport_send_check_condition_and_sense ( cmd , sense_reason , 0 ) ;
2016-10-30 17:28:16 -07:00
if ( ret )
2011-11-04 02:36:16 -07:00
goto queue_full ;
2011-06-13 14:46:09 -07:00
[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
check_stop :
2020-02-09 21:12:02 -08:00
transport_lun_remove_cmd ( cmd ) ;
2015-09-03 16:03:43 -07:00
transport_cmd_check_stop_to_fabric ( cmd ) ;
2011-06-13 14:46:09 -07:00
return ;
2017-10-25 11:47:14 -05:00
queue_status :
trace_target_cmd_complete ( cmd ) ;
ret = cmd - > se_tfo - > queue_status ( cmd ) ;
if ( ! ret )
goto check_stop ;
2011-06-13 14:46:09 -07:00
queue_full :
2016-10-30 17:28:16 -07:00
transport_handle_queue_full ( cmd , cmd - > se_dev , ret , false ) ;
[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
}
2012-02-10 16:18:11 -08:00
EXPORT_SYMBOL ( transport_generic_request_failure ) ;
[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
2016-05-17 22:19:10 -07:00
void __target_execute_cmd ( struct se_cmd * cmd , bool do_checks )
[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
{
2012-11-06 12:24:09 -08:00
sense_reason_t ret ;
2012-05-20 14:34:44 -04:00
2016-05-17 22:19:10 -07:00
if ( ! cmd - > execute_cmd ) {
ret = TCM_LOGICAL_UNIT_COMMUNICATION_FAILURE ;
goto err ;
}
if ( do_checks ) {
/*
* Check for an existing UNIT ATTENTION condition after
* target_handle_task_attr ( ) has done SAM task attr
* checking , and possibly have already defered execution
* out to target_restart_delayed_cmds ( ) context .
*/
ret = target_scsi3_ua_check ( cmd ) ;
if ( ret )
goto err ;
ret = target_alua_state_check ( cmd ) ;
if ( ret )
goto err ;
2012-05-20 14:34:44 -04:00
2016-05-17 22:19:10 -07:00
ret = target_check_reservation ( cmd ) ;
if ( ret ) {
cmd - > scsi_status = SAM_STAT_RESERVATION_CONFLICT ;
goto err ;
2012-11-06 12:24:09 -08:00
}
2012-05-20 14:34:44 -04:00
}
2016-05-17 22:19:10 -07:00
ret = cmd - > execute_cmd ( cmd ) ;
if ( ! ret )
return ;
err :
spin_lock_irq ( & cmd - > t_state_lock ) ;
2017-01-03 10:44:11 +01:00
cmd - > transport_state & = ~ CMD_T_SENT ;
2016-05-17 22:19:10 -07:00
spin_unlock_irq ( & cmd - > t_state_lock ) ;
transport_generic_request_failure ( cmd , ret ) ;
2012-05-20 14:34:44 -04:00
}
2015-02-08 12:39:06 -08:00
static int target_write_prot_action ( struct se_cmd * cmd )
{
2015-02-08 03:06:17 -08:00
u32 sectors ;
2015-02-08 12:39:06 -08:00
/*
* Perform WRITE_INSERT of PI using software emulation when backend
* device has PI enabled , if the transport has not already generated
* PI using hardware WRITE_INSERT offload .
*/
switch ( cmd - > prot_op ) {
case TARGET_PROT_DOUT_INSERT :
if ( ! ( cmd - > se_sess - > sup_prot_ops & TARGET_PROT_DOUT_INSERT ) )
sbc_dif_generate ( cmd ) ;
break ;
2015-02-08 03:06:17 -08:00
case TARGET_PROT_DOUT_STRIP :
if ( cmd - > se_sess - > sup_prot_ops & TARGET_PROT_DOUT_STRIP )
break ;
sectors = cmd - > data_length > > ilog2 ( cmd - > se_dev - > dev_attrib . block_size ) ;
2015-04-19 20:27:19 +03:00
cmd - > pi_err = sbc_dif_verify ( cmd , cmd - > t_task_lba ,
sectors , 0 , cmd - > t_prot_sg , 0 ) ;
2015-02-08 03:06:17 -08:00
if ( unlikely ( cmd - > pi_err ) ) {
spin_lock_irq ( & cmd - > t_state_lock ) ;
2017-01-03 10:44:11 +01:00
cmd - > transport_state & = ~ CMD_T_SENT ;
2015-02-08 03:06:17 -08:00
spin_unlock_irq ( & cmd - > t_state_lock ) ;
transport_generic_request_failure ( cmd , cmd - > pi_err ) ;
return - 1 ;
}
break ;
2015-02-08 12:39:06 -08:00
default :
break ;
}
return 0 ;
}
2012-10-10 17:37:14 -04:00
static bool target_handle_task_attr ( struct se_cmd * cmd )
2012-05-20 14:34:44 -04:00
{
struct se_device * dev = cmd - > se_dev ;
2020-04-27 17:08:22 +02:00
if ( dev - > transport_flags & TRANSPORT_FLAG_PASSTHROUGH )
2012-10-10 17:37:14 -04:00
return false ;
2012-05-20 14:34:44 -04:00
2016-06-13 22:58:09 -07:00
cmd - > se_cmd_flags | = SCF_TASK_ATTR_SET ;
[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-03-30 22:57:33 -03:00
* Check for the existence of HEAD_OF_QUEUE , and if true return 1
[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
* to allow the passed struct se_cmd list of tasks to the front of the list .
*/
2012-05-20 14:34:44 -04:00
switch ( cmd - > sam_task_attr ) {
2014-11-24 07:07:25 -08:00
case TCM_HEAD_TAG :
2021-09-29 21:04:19 -05:00
atomic_inc_mb ( & dev - > non_ordered ) ;
2015-07-21 17:45:32 -07:00
pr_debug ( " Added HEAD_OF_QUEUE for CDB: 0x%02x \n " ,
cmd - > t_task_cdb [ 0 ] ) ;
2012-10-10 17:37:14 -04:00
return false ;
2014-11-24 07:07:25 -08:00
case TCM_ORDERED_TAG :
2021-09-29 21:04:19 -05:00
atomic_inc_mb ( & dev - > delayed_cmd_count ) ;
[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
2015-07-21 17:45:32 -07:00
pr_debug ( " Added ORDERED for CDB: 0x%02x to ordered list \n " ,
cmd - > t_task_cdb [ 0 ] ) ;
2012-05-20 14:34:44 -04:00
break ;
default :
[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
/*
* For SIMPLE and UNTAGGED Task Attribute commands
*/
2021-09-29 21:04:19 -05:00
atomic_inc_mb ( & dev - > non_ordered ) ;
if ( atomic_read ( & dev - > delayed_cmd_count ) = = 0 )
return false ;
2012-05-20 14:34:44 -04:00
break ;
[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
}
2012-05-20 14:34:44 -04:00
2021-09-29 21:04:19 -05:00
if ( cmd - > sam_task_attr ! = TCM_ORDERED_TAG ) {
atomic_inc_mb ( & dev - > delayed_cmd_count ) ;
/*
* We will account for this when we dequeue from the delayed
* list .
*/
atomic_dec_mb ( & dev - > non_ordered ) ;
}
[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
2021-09-29 21:04:18 -05:00
spin_lock_irq ( & cmd - > t_state_lock ) ;
cmd - > transport_state & = ~ CMD_T_SENT ;
spin_unlock_irq ( & cmd - > t_state_lock ) ;
2012-10-10 17:37:14 -04:00
spin_lock ( & dev - > delayed_cmd_lock ) ;
list_add_tail ( & cmd - > se_delayed_node , & dev - > delayed_cmd_list ) ;
spin_unlock ( & dev - > delayed_cmd_lock ) ;
2015-07-21 17:45:32 -07:00
pr_debug ( " Added CDB: 0x%02x Task Attr: 0x%02x to delayed CMD listn " ,
cmd - > t_task_cdb [ 0 ] , cmd - > sam_task_attr ) ;
2021-09-29 21:04:19 -05:00
/*
* We may have no non ordered cmds when this function started or we
* could have raced with the last simple / head cmd completing , so kick
* the delayed handler here .
*/
schedule_work ( & dev - > delayed_cmd_work ) ;
2012-10-10 17:37:14 -04:00
return true ;
}
void target_execute_cmd ( struct se_cmd * cmd )
{
/*
* Determine if frontend context caller is requesting the stopping of
* this command for frontend exceptions .
2016-02-05 14:51:36 -08:00
*
2018-10-15 08:51:34 -07:00
* If the received CDB has already been aborted stop processing it here .
2012-10-10 17:37:14 -04:00
*/
2018-11-27 15:52:03 -08:00
if ( target_cmd_interrupted ( cmd ) )
2012-10-10 17:37:14 -04:00
return ;
2018-11-27 15:52:03 -08:00
spin_lock_irq ( & cmd - > t_state_lock ) ;
2012-10-10 17:37:14 -04:00
cmd - > t_state = TRANSPORT_PROCESSING ;
2017-01-03 10:44:11 +01:00
cmd - > transport_state | = CMD_T_ACTIVE | CMD_T_SENT ;
2012-10-10 17:37:14 -04:00
spin_unlock_irq ( & cmd - > t_state_lock ) ;
2015-02-08 12:39:06 -08:00
if ( target_write_prot_action ( cmd ) )
return ;
2012-10-10 17:37:14 -04:00
2021-09-29 21:04:18 -05:00
if ( target_handle_task_attr ( cmd ) )
2013-06-06 01:40:27 -07:00
return ;
2016-05-17 22:19:10 -07:00
__target_execute_cmd ( cmd , true ) ;
[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
}
2012-07-08 15:58:39 -04:00
EXPORT_SYMBOL ( target_execute_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
2012-05-20 14:34:44 -04:00
/*
* Process all commands up to the last received ORDERED task attribute which
* requires another blocking boundary
*/
2021-09-29 21:04:19 -05:00
void target_do_delayed_work ( struct work_struct * work )
2012-05-20 14:34:44 -04:00
{
2021-09-29 21:04:19 -05:00
struct se_device * dev = container_of ( work , struct se_device ,
delayed_cmd_work ) ;
spin_lock ( & dev - > delayed_cmd_lock ) ;
while ( ! dev - > ordered_sync_in_progress ) {
2012-05-20 14:34:44 -04:00
struct se_cmd * cmd ;
2021-09-29 21:04:19 -05:00
if ( list_empty ( & dev - > delayed_cmd_list ) )
2012-05-20 14:34:44 -04:00
break ;
cmd = list_entry ( dev - > delayed_cmd_list . next ,
struct se_cmd , se_delayed_node ) ;
2021-09-29 21:04:19 -05:00
if ( cmd - > sam_task_attr = = TCM_ORDERED_TAG ) {
/*
* Check if we started with :
* [ ordered ] [ simple ] [ ordered ]
* and we are now at the last ordered so we have to wait
* for the simple cmd .
*/
if ( atomic_read ( & dev - > non_ordered ) > 0 )
break ;
dev - > ordered_sync_in_progress = true ;
}
2012-05-20 14:34:44 -04:00
list_del ( & cmd - > se_delayed_node ) ;
2021-09-29 21:04:19 -05:00
atomic_dec_mb ( & dev - > delayed_cmd_count ) ;
2012-05-20 14:34:44 -04:00
spin_unlock ( & dev - > delayed_cmd_lock ) ;
2021-09-29 21:04:19 -05:00
if ( cmd - > sam_task_attr ! = TCM_ORDERED_TAG )
atomic_inc_mb ( & dev - > non_ordered ) ;
2017-09-22 16:48:28 -07:00
cmd - > transport_state | = CMD_T_SENT ;
2016-05-17 22:19:10 -07:00
__target_execute_cmd ( cmd , true ) ;
2012-05-20 14:34:44 -04:00
2021-09-29 21:04:19 -05:00
spin_lock ( & dev - > delayed_cmd_lock ) ;
2012-05-20 14:34:44 -04:00
}
2021-09-29 21:04:19 -05:00
spin_unlock ( & dev - > delayed_cmd_lock ) ;
2012-05-20 14:34:44 -04:00
}
[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-10-17 13:56:53 -04:00
* Called from I / O completion to determine which dormant / delayed
[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
* and ordered cmds need to have their tasks added to the execution queue .
*/
static void transport_complete_task_attr ( struct se_cmd * cmd )
{
2011-07-19 10:26:37 +00:00
struct se_device * dev = cmd - > se_dev ;
[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
2020-04-27 17:08:22 +02:00
if ( dev - > transport_flags & TRANSPORT_FLAG_PASSTHROUGH )
2012-10-10 17:37:14 -04:00
return ;
2016-06-13 22:58:09 -07:00
if ( ! ( cmd - > se_cmd_flags & SCF_TASK_ATTR_SET ) )
goto restart ;
2014-11-24 07:07:25 -08:00
if ( cmd - > sam_task_attr = = TCM_SIMPLE_TAG ) {
2021-09-29 21:04:19 -05:00
atomic_dec_mb ( & dev - > non_ordered ) ;
[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
dev - > dev_cur_ordered_id + + ;
2014-11-24 07:07:25 -08:00
} else if ( cmd - > sam_task_attr = = TCM_HEAD_TAG ) {
2021-09-29 21:04:19 -05:00
atomic_dec_mb ( & dev - > non_ordered ) ;
[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
dev - > dev_cur_ordered_id + + ;
2015-07-21 17:45:32 -07:00
pr_debug ( " Incremented dev_cur_ordered_id: %u for HEAD_OF_QUEUE \n " ,
dev - > dev_cur_ordered_id ) ;
2014-11-24 07:07:25 -08:00
} else if ( cmd - > sam_task_attr = = TCM_ORDERED_TAG ) {
2021-09-29 21:04:19 -05:00
spin_lock ( & dev - > delayed_cmd_lock ) ;
dev - > ordered_sync_in_progress = false ;
spin_unlock ( & dev - > delayed_cmd_lock ) ;
[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
dev - > dev_cur_ordered_id + + ;
2015-07-21 17:45:32 -07:00
pr_debug ( " Incremented dev_cur_ordered_id: %u for ORDERED \n " ,
dev - > dev_cur_ordered_id ) ;
[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
}
2017-09-22 16:48:28 -07:00
cmd - > se_cmd_flags & = ~ SCF_TASK_ATTR_SET ;
2016-06-13 22:58:09 -07:00
restart :
2021-09-29 21:04:19 -05:00
if ( atomic_read ( & dev - > delayed_cmd_count ) > 0 )
schedule_work ( & dev - > delayed_cmd_work ) ;
[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-10-17 13:56:41 -04:00
static void transport_complete_qf ( struct se_cmd * cmd )
2011-06-13 14:46:09 -07:00
{
int ret = 0 ;
2012-10-10 17:37:14 -04:00
transport_complete_task_attr ( cmd ) ;
2016-10-30 17:28:16 -07:00
/*
* If a fabric driver - > write_pending ( ) or - > queue_data_in ( ) callback
* has returned neither - ENOMEM or - EAGAIN , assume it ' s fatal and
* the same callbacks should not be retried . Return CHECK_CONDITION
* if a scsi_status is not already set .
*
* If a fabric driver - > queue_status ( ) has returned non zero , always
* keep retrying no matter what . .
*/
if ( cmd - > t_state = = TRANSPORT_COMPLETE_QF_ERR ) {
if ( cmd - > scsi_status )
goto queue_status ;
2011-10-17 13:56:41 -04:00
2016-10-30 17:28:16 -07:00
translate_sense_reason ( cmd , TCM_LOGICAL_UNIT_COMMUNICATION_FAILURE ) ;
goto queue_status ;
2011-10-17 13:56:41 -04:00
}
2011-06-13 14:46:09 -07:00
2018-05-15 18:25:24 -07:00
/*
* Check if we need to send a sense buffer from
* the struct se_cmd in question . We do NOT want
* to take this path of the IO has been marked as
* needing to be treated like a " normal read " . This
* is the case if it ' s a tape read , and either the
* FM , EOM , or ILI bits are set , but there is no
* sense data .
*/
if ( ! ( cmd - > se_cmd_flags & SCF_TREAT_READ_AS_NORMAL ) & &
cmd - > se_cmd_flags & SCF_TRANSPORT_TASK_SENSE )
2016-10-30 17:28:16 -07:00
goto queue_status ;
2011-06-13 14:46:09 -07:00
switch ( cmd - > data_direction ) {
case DMA_FROM_DEVICE :
2018-05-15 18:25:24 -07:00
/* queue status if not treating this as a normal read */
if ( cmd - > scsi_status & &
! ( cmd - > se_cmd_flags & SCF_TREAT_READ_AS_NORMAL ) )
2016-03-04 22:30:52 -08:00
goto queue_status ;
2013-06-26 17:36:17 -07:00
trace_target_cmd_complete ( cmd ) ;
2011-06-13 14:46:09 -07:00
ret = cmd - > se_tfo - > queue_data_in ( cmd ) ;
break ;
case DMA_TO_DEVICE :
2013-08-21 14:39:19 -07:00
if ( cmd - > se_cmd_flags & SCF_BIDI ) {
2011-06-13 14:46:09 -07:00
ret = cmd - > se_tfo - > queue_data_in ( cmd ) ;
2015-05-13 09:17:54 +02:00
break ;
2011-06-13 14:46:09 -07:00
}
2020-08-23 17:36:59 -05:00
fallthrough ;
2011-06-13 14:46:09 -07:00
case DMA_NONE :
2016-03-04 22:30:52 -08:00
queue_status :
2013-06-26 17:36:17 -07:00
trace_target_cmd_complete ( cmd ) ;
2011-06-13 14:46:09 -07:00
ret = cmd - > se_tfo - > queue_status ( cmd ) ;
break ;
default :
break ;
}
2011-10-17 13:56:41 -04:00
if ( ret < 0 ) {
2016-10-30 17:28:16 -07:00
transport_handle_queue_full ( cmd , cmd - > se_dev , ret , false ) ;
2011-10-17 13:56:41 -04:00
return ;
}
2020-02-09 21:12:02 -08:00
transport_lun_remove_cmd ( cmd ) ;
2011-10-17 13:56:41 -04:00
transport_cmd_check_stop_to_fabric ( cmd ) ;
2011-06-13 14:46:09 -07:00
}
2016-10-30 17:28:16 -07:00
static void transport_handle_queue_full ( struct se_cmd * cmd , struct se_device * dev ,
int err , bool write_pending )
2011-06-13 14:46:09 -07:00
{
2016-10-30 17:28:16 -07:00
/*
* - EAGAIN or - ENOMEM signals retry of - > write_pending ( ) and / or
* - > queue_data_in ( ) callbacks from new process context .
*
* Otherwise for other errors , transport_complete_qf ( ) will send
* CHECK_CONDITION via - > queue_status ( ) instead of attempting to
* retry associated fabric driver data - transfer callbacks .
*/
if ( err = = - EAGAIN | | err = = - ENOMEM ) {
cmd - > t_state = ( write_pending ) ? TRANSPORT_COMPLETE_QF_WP :
TRANSPORT_COMPLETE_QF_OK ;
} else {
pr_warn_ratelimited ( " Got unknown fabric queue status: %d \n " , err ) ;
cmd - > t_state = TRANSPORT_COMPLETE_QF_ERR ;
}
2011-06-13 14:46:09 -07:00
spin_lock_irq ( & dev - > qf_cmd_lock ) ;
list_add_tail ( & cmd - > se_qf_node , & cmd - > se_dev - > qf_cmd_list ) ;
2014-09-16 16:23:12 -04:00
atomic_inc_mb ( & dev - > dev_qf_count ) ;
2011-06-13 14:46:09 -07:00
spin_unlock_irq ( & cmd - > se_dev - > qf_cmd_lock ) ;
schedule_work ( & cmd - > se_dev - > qf_work_queue ) ;
}
2015-02-08 02:53:25 -08:00
static bool target_read_prot_action ( struct se_cmd * cmd )
2014-04-02 14:55:33 -07:00
{
2015-02-08 02:53:25 -08:00
switch ( cmd - > prot_op ) {
case TARGET_PROT_DIN_STRIP :
if ( ! ( cmd - > se_sess - > sup_prot_ops & TARGET_PROT_DIN_STRIP ) ) {
2015-04-19 20:27:19 +03:00
u32 sectors = cmd - > data_length > >
ilog2 ( cmd - > se_dev - > dev_attrib . block_size ) ;
cmd - > pi_err = sbc_dif_verify ( cmd , cmd - > t_task_lba ,
sectors , 0 , cmd - > t_prot_sg ,
0 ) ;
if ( cmd - > pi_err )
2015-02-08 02:53:25 -08:00
return true ;
2014-04-02 14:55:33 -07:00
}
2015-02-08 02:53:25 -08:00
break ;
2015-02-08 04:02:08 -08:00
case TARGET_PROT_DIN_INSERT :
if ( cmd - > se_sess - > sup_prot_ops & TARGET_PROT_DIN_INSERT )
break ;
sbc_dif_generate ( cmd ) ;
break ;
2015-02-08 02:53:25 -08:00
default :
break ;
2014-04-02 14:55:33 -07:00
}
return false ;
}
2011-10-17 13:56:53 -04:00
static void target_complete_ok_work ( struct work_struct * work )
[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-10-17 13:56:53 -04:00
struct se_cmd * cmd = container_of ( work , struct se_cmd , work ) ;
2012-09-05 17:09:14 +02:00
int ret ;
2011-10-17 13:56:53 -04:00
[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
/*
* Check if we need to move delayed / dormant tasks from cmds on the
* delayed execution list after a HEAD_OF_QUEUE or ORDERED Task
* Attribute .
*/
2012-10-10 17:37:14 -04:00
transport_complete_task_attr ( cmd ) ;
2011-06-13 14:46:09 -07:00
/*
* Check to schedule QUEUE_FULL work , or execute an existing
* cmd - > transport_qf_callback ( )
*/
if ( atomic_read ( & cmd - > se_dev - > dev_qf_count ) ! = 0 )
schedule_work ( & cmd - > se_dev - > qf_work_queue ) ;
[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
/*
2012-09-05 17:09:15 +02:00
* Check if we need to send a sense buffer from
2018-05-15 18:25:24 -07:00
* the struct se_cmd in question . We do NOT want
* to take this path of the IO has been marked as
* needing to be treated like a " normal read " . This
* is the case if it ' s a tape read , and either the
* FM , EOM , or ILI bits are set , but there is no
* sense data .
[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
*/
2018-05-15 18:25:24 -07:00
if ( ! ( cmd - > se_cmd_flags & SCF_TREAT_READ_AS_NORMAL ) & &
cmd - > se_cmd_flags & SCF_TRANSPORT_TASK_SENSE ) {
2012-09-05 17:09:14 +02:00
WARN_ON ( ! cmd - > scsi_status ) ;
ret = transport_send_check_condition_and_sense (
cmd , 0 , 1 ) ;
2016-10-30 17:28:16 -07:00
if ( ret )
2012-09-05 17:09:14 +02:00
goto queue_full ;
2020-02-09 21:12:02 -08:00
transport_lun_remove_cmd ( cmd ) ;
2012-09-05 17:09:14 +02:00
transport_cmd_check_stop_to_fabric ( cmd ) ;
return ;
[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-03-30 22:57:33 -03:00
* Check for a callback , used by amongst other things
2013-08-19 14:34:17 -07:00
* XDWRITE_READ_10 and COMPARE_AND_WRITE emulation .
[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
*/
2013-08-19 14:34:17 -07:00
if ( cmd - > transport_complete_callback ) {
sense_reason_t rc ;
2015-11-05 23:37:59 -08:00
bool caw = ( cmd - > se_cmd_flags & SCF_COMPARE_AND_WRITE ) ;
bool zero_dl = ! ( cmd - > data_length ) ;
int post_ret = 0 ;
2013-08-19 14:34:17 -07:00
2015-11-05 23:37:59 -08:00
rc = cmd - > transport_complete_callback ( cmd , true , & post_ret ) ;
if ( ! rc & & ! post_ret ) {
if ( caw & & zero_dl )
2015-04-07 21:53:27 +00:00
goto queue_rsp ;
2013-08-19 14:34:17 -07:00
return ;
2013-08-21 18:10:04 -07:00
} else if ( rc ) {
ret = transport_send_check_condition_and_sense ( cmd ,
rc , 0 ) ;
2016-10-30 17:28:16 -07:00
if ( ret )
2013-08-21 18:10:04 -07:00
goto queue_full ;
2013-08-19 14:34:17 -07:00
2020-02-09 21:12:02 -08:00
transport_lun_remove_cmd ( cmd ) ;
2013-08-21 18:10:04 -07:00
transport_cmd_check_stop_to_fabric ( cmd ) ;
return ;
}
2013-08-19 14:34:17 -07:00
}
[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
2015-04-07 21:53:27 +00:00
queue_rsp :
[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
switch ( cmd - > data_direction ) {
case DMA_FROM_DEVICE :
2018-05-15 18:25:24 -07:00
/*
* if this is a READ - type IO , but SCSI status
* is set , then skip returning data and just
* return the status - - unless this IO is marked
* as needing to be treated as a normal read ,
* in which case we want to go ahead and return
* the data . This happens , for example , for tape
* reads with the FM , EOM , or ILI bits set , with
* no sense data .
*/
if ( cmd - > scsi_status & &
! ( cmd - > se_cmd_flags & SCF_TREAT_READ_AS_NORMAL ) )
2016-03-04 22:30:52 -08:00
goto queue_status ;
2015-05-19 00:03:07 -07:00
atomic_long_add ( cmd - > data_length ,
& cmd - > se_lun - > lun_stats . tx_data_octets ) ;
2014-04-02 14:55:33 -07:00
/*
* Perform READ_STRIP of PI using software emulation when
* backend had PI enabled , if the transport will not be
* performing hardware READ_STRIP offload .
*/
2015-02-08 02:53:25 -08:00
if ( target_read_prot_action ( cmd ) ) {
2014-04-02 14:55:33 -07:00
ret = transport_send_check_condition_and_sense ( cmd ,
cmd - > pi_err , 0 ) ;
2016-10-30 17:28:16 -07:00
if ( ret )
2014-04-02 14:55:33 -07:00
goto queue_full ;
2020-02-09 21:12:02 -08:00
transport_lun_remove_cmd ( cmd ) ;
2014-04-02 14:55:33 -07:00
transport_cmd_check_stop_to_fabric ( cmd ) ;
return ;
}
[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
2013-06-26 17:36:17 -07:00
trace_target_cmd_complete ( cmd ) ;
2011-06-13 14:46:09 -07:00
ret = cmd - > se_tfo - > queue_data_in ( cmd ) ;
2016-10-30 17:28:16 -07:00
if ( ret )
2011-06-13 14:46:09 -07:00
goto queue_full ;
[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
break ;
case DMA_TO_DEVICE :
2015-05-19 00:03:07 -07:00
atomic_long_add ( cmd - > data_length ,
& cmd - > se_lun - > lun_stats . rx_data_octets ) ;
[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
/*
* Check if we need to send READ payload for BIDI - COMMAND
*/
2013-08-21 14:39:19 -07:00
if ( cmd - > se_cmd_flags & SCF_BIDI ) {
2015-05-19 00:03:07 -07:00
atomic_long_add ( cmd - > data_length ,
& cmd - > se_lun - > lun_stats . tx_data_octets ) ;
2011-06-13 14:46:09 -07:00
ret = cmd - > se_tfo - > queue_data_in ( cmd ) ;
2016-10-30 17:28:16 -07:00
if ( ret )
2011-06-13 14:46:09 -07:00
goto queue_full ;
[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
break ;
}
2020-08-23 17:36:59 -05:00
fallthrough ;
[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
case DMA_NONE :
2016-03-04 22:30:52 -08:00
queue_status :
2013-06-26 17:36:17 -07:00
trace_target_cmd_complete ( cmd ) ;
2011-06-13 14:46:09 -07:00
ret = cmd - > se_tfo - > queue_status ( cmd ) ;
2016-10-30 17:28:16 -07:00
if ( ret )
2011-06-13 14:46:09 -07:00
goto queue_full ;
[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
break ;
default :
break ;
}
2020-02-09 21:12:02 -08:00
transport_lun_remove_cmd ( 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
transport_cmd_check_stop_to_fabric ( cmd ) ;
2011-06-13 14:46:09 -07:00
return ;
queue_full :
2011-06-08 10:36:43 -07:00
pr_debug ( " Handling complete_ok QUEUE_FULL: se_cmd: %p, "
2011-06-13 14:46:09 -07:00
" data_direction: %d \n " , cmd , cmd - > data_direction ) ;
2016-10-30 17:28:16 -07:00
transport_handle_queue_full ( cmd , cmd - > se_dev , ret , false ) ;
[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
}
2016-05-03 18:01:10 +02:00
void target_free_sgl ( struct scatterlist * sgl , int nents )
[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
{
2018-01-19 11:00:54 -08:00
sgl_free_n_order ( sgl , nents , 0 ) ;
2011-06-08 10:36:43 -07:00
}
2016-05-03 18:01:10 +02:00
EXPORT_SYMBOL ( target_free_sgl ) ;
[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
2013-08-20 10:45:16 -07:00
static inline void transport_reset_sgl_orig ( struct se_cmd * cmd )
{
/*
* Check for saved t_data_sg that may be used for COMPARE_AND_WRITE
* emulation , and free + reset pointers if necessary . .
*/
if ( ! cmd - > t_data_sg_orig )
return ;
kfree ( cmd - > t_data_sg ) ;
cmd - > t_data_sg = cmd - > t_data_sg_orig ;
cmd - > t_data_sg_orig = NULL ;
cmd - > t_data_nents = cmd - > t_data_nents_orig ;
cmd - > t_data_nents_orig = 0 ;
}
2011-06-08 10:36:43 -07:00
static inline void transport_free_pages ( struct se_cmd * cmd )
{
2015-05-01 15:23:49 +09:00
if ( ! ( cmd - > se_cmd_flags & SCF_PASSTHROUGH_PROT_SG_TO_MEM_NOALLOC ) ) {
2016-05-03 18:01:10 +02:00
target_free_sgl ( cmd - > t_prot_sg , cmd - > t_prot_nents ) ;
2015-05-01 15:23:49 +09:00
cmd - > t_prot_sg = NULL ;
cmd - > t_prot_nents = 0 ;
}
2013-08-20 10:45:16 -07:00
if ( cmd - > se_cmd_flags & SCF_PASSTHROUGH_SG_TO_MEM_NOALLOC ) {
2015-04-07 21:53:27 +00:00
/*
* Release special case READ buffer payload required for
* SG_TO_MEM_NOALLOC to function with COMPARE_AND_WRITE
*/
if ( cmd - > se_cmd_flags & SCF_COMPARE_AND_WRITE ) {
2016-05-03 18:01:10 +02:00
target_free_sgl ( cmd - > t_bidi_data_sg ,
2015-04-07 21:53:27 +00:00
cmd - > t_bidi_data_nents ) ;
cmd - > t_bidi_data_sg = NULL ;
cmd - > t_bidi_data_nents = 0 ;
}
2013-08-20 10:45:16 -07:00
transport_reset_sgl_orig ( cmd ) ;
2011-06-08 10:36:43 -07:00
return ;
2013-08-20 10:45:16 -07:00
}
transport_reset_sgl_orig ( cmd ) ;
2011-06-08 10:36:43 -07:00
2016-05-03 18:01:10 +02:00
target_free_sgl ( cmd - > t_data_sg , cmd - > t_data_nents ) ;
2011-07-20 19:28:46 +00:00
cmd - > t_data_sg = NULL ;
cmd - > t_data_nents = 0 ;
[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
2016-05-03 18:01:10 +02:00
target_free_sgl ( cmd - > t_bidi_data_sg , cmd - > t_bidi_data_nents ) ;
2011-07-20 19:28:46 +00:00
cmd - > t_bidi_data_sg = NULL ;
cmd - > t_bidi_data_nents = 0 ;
[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
}
2012-01-16 16:57:08 -08:00
void * transport_kmap_data_sg ( struct se_cmd * cmd )
2011-07-20 19:13:28 +00:00
{
2011-07-20 19:28:46 +00:00
struct scatterlist * sg = cmd - > t_data_sg ;
2012-01-16 16:57:08 -08:00
struct page * * pages ;
int i ;
2011-07-20 19:13:28 +00:00
/*
2011-07-20 19:28:46 +00:00
* We need to take into account a possible offset here for fabrics like
* tcm_loop who may be using a contig buffer from the SCSI midlayer for
* control CDBs passed as SGLs via transport_generic_map_mem_to_cmd ( )
2011-07-20 19:13:28 +00:00
*/
2012-01-16 16:57:08 -08:00
if ( ! cmd - > t_data_nents )
return NULL ;
2012-09-07 17:30:35 +02:00
BUG_ON ( ! sg ) ;
if ( cmd - > t_data_nents = = 1 )
2012-01-16 16:57:08 -08:00
return kmap ( sg_page ( sg ) ) + sg - > offset ;
/* >1 page. use vmap */
2017-04-09 21:07:14 +02:00
pages = kmalloc_array ( cmd - > t_data_nents , sizeof ( * pages ) , GFP_KERNEL ) ;
2012-11-06 12:24:09 -08:00
if ( ! pages )
2012-01-16 16:57:08 -08:00
return NULL ;
/* convert sg[] to pages[] */
for_each_sg ( cmd - > t_data_sg , sg , cmd - > t_data_nents , i ) {
pages [ i ] = sg_page ( sg ) ;
}
cmd - > t_data_vmap = vmap ( pages , cmd - > t_data_nents , VM_MAP , PAGE_KERNEL ) ;
kfree ( pages ) ;
2012-11-06 12:24:09 -08:00
if ( ! cmd - > t_data_vmap )
2012-01-16 16:57:08 -08:00
return NULL ;
return cmd - > t_data_vmap + cmd - > t_data_sg [ 0 ] . offset ;
2011-07-20 19:13:28 +00:00
}
2012-01-16 16:57:08 -08:00
EXPORT_SYMBOL ( transport_kmap_data_sg ) ;
2011-07-20 19:13:28 +00:00
2012-01-16 16:57:08 -08:00
void transport_kunmap_data_sg ( struct se_cmd * cmd )
2011-07-20 19:13:28 +00:00
{
2012-02-09 12:18:06 -08:00
if ( ! cmd - > t_data_nents ) {
2012-01-16 16:57:08 -08:00
return ;
2012-02-09 12:18:06 -08:00
} else if ( cmd - > t_data_nents = = 1 ) {
2012-01-16 16:57:08 -08:00
kunmap ( sg_page ( cmd - > t_data_sg ) ) ;
2012-02-09 12:18:06 -08:00
return ;
}
2012-01-16 16:57:08 -08:00
vunmap ( cmd - > t_data_vmap ) ;
cmd - > t_data_vmap = NULL ;
2011-07-20 19:13:28 +00:00
}
2012-01-16 16:57:08 -08:00
EXPORT_SYMBOL ( transport_kunmap_data_sg ) ;
2011-07-20 19:13:28 +00:00
2013-08-22 11:58:43 -07:00
int
2013-08-25 15:44:03 -07:00
target_alloc_sgl ( struct scatterlist * * sgl , unsigned int * nents , u32 length ,
2016-05-03 18:01:10 +02:00
bool zero_page , bool chainable )
[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
{
2018-01-05 08:26:50 -08:00
gfp_t gfp = GFP_KERNEL | ( zero_page ? __GFP_ZERO : 0 ) ;
[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
2018-01-05 08:26:50 -08:00
* sgl = sgl_alloc_order ( length , 0 , chainable , gfp , nents ) ;
return * sgl ? 0 : - ENOMEM ;
[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
}
2016-05-03 18:01:10 +02:00
EXPORT_SYMBOL ( target_alloc_sgl ) ;
[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-10-18 06:57:01 -04:00
/*
2012-04-03 15:51:21 -07:00
* Allocate any required resources to execute the command . For writes we
* might not have the payload yet , so notify the fabric via a call to
* - > write_pending instead . Otherwise place it on the execution queue .
[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
*/
2012-11-06 12:24:09 -08:00
sense_reason_t
transport_generic_new_cmd ( struct se_cmd * 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
{
2017-02-01 16:58:35 -08:00
unsigned long flags ;
[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
int ret = 0 ;
2015-04-07 21:53:27 +00:00
bool zero_flag = ! ( cmd - > se_cmd_flags & SCF_SCSI_DATA_CDB ) ;
[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
2015-05-01 15:23:49 +09:00
if ( cmd - > prot_op ! = TARGET_PROT_NORMAL & &
! ( cmd - > se_cmd_flags & SCF_PASSTHROUGH_PROT_SG_TO_MEM_NOALLOC ) ) {
ret = target_alloc_sgl ( & cmd - > t_prot_sg , & cmd - > t_prot_nents ,
2016-05-03 18:01:10 +02:00
cmd - > prot_length , true , false ) ;
2015-05-01 15:23:49 +09:00
if ( ret < 0 )
return TCM_LOGICAL_UNIT_COMMUNICATION_FAILURE ;
}
[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
/*
2018-10-15 08:51:34 -07:00
* Determine if the TCM fabric module has already allocated physical
[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
* memory , and is directly calling transport_generic_map_mem_to_cmd ( )
2011-07-20 19:28:46 +00:00
* beforehand .
[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-07-20 19:28:46 +00:00
if ( ! ( cmd - > se_cmd_flags & SCF_PASSTHROUGH_SG_TO_MEM_NOALLOC ) & &
cmd - > data_length ) {
2013-08-25 15:44:03 -07:00
2013-08-25 16:10:57 -07:00
if ( ( cmd - > se_cmd_flags & SCF_BIDI ) | |
( cmd - > se_cmd_flags & SCF_COMPARE_AND_WRITE ) ) {
u32 bidi_length ;
if ( cmd - > se_cmd_flags & SCF_COMPARE_AND_WRITE )
bidi_length = cmd - > t_task_nolb *
cmd - > se_dev - > dev_attrib . block_size ;
else
bidi_length = cmd - > data_length ;
ret = target_alloc_sgl ( & cmd - > t_bidi_data_sg ,
& cmd - > t_bidi_data_nents ,
2016-05-03 18:01:10 +02:00
bidi_length , zero_flag , false ) ;
2013-08-25 16:10:57 -07:00
if ( ret < 0 )
return TCM_LOGICAL_UNIT_COMMUNICATION_FAILURE ;
}
2013-08-25 15:44:03 -07:00
ret = target_alloc_sgl ( & cmd - > t_data_sg , & cmd - > t_data_nents ,
2016-05-03 18:01:10 +02:00
cmd - > data_length , zero_flag , false ) ;
[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
if ( ret < 0 )
2012-11-06 12:24:09 -08:00
return TCM_LOGICAL_UNIT_COMMUNICATION_FAILURE ;
2015-04-07 21:53:27 +00:00
} else if ( ( cmd - > se_cmd_flags & SCF_COMPARE_AND_WRITE ) & &
cmd - > data_length ) {
/*
* Special case for COMPARE_AND_WRITE with fabrics
* using SCF_PASSTHROUGH_SG_TO_MEM_NOALLOC .
*/
u32 caw_length = cmd - > t_task_nolb *
cmd - > se_dev - > dev_attrib . block_size ;
ret = target_alloc_sgl ( & cmd - > t_bidi_data_sg ,
& cmd - > t_bidi_data_nents ,
2016-05-03 18:01:10 +02:00
caw_length , zero_flag , false ) ;
2015-04-07 21:53:27 +00:00
if ( ret < 0 )
return TCM_LOGICAL_UNIT_COMMUNICATION_FAILURE ;
[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
}
/*
2012-07-08 15:58:41 -04:00
* If this command is not a write we can execute it right here ,
* for write buffers we need to notify the fabric driver first
* and let it call back once the write buffers are ready .
[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
*/
2012-05-20 14:34:44 -04:00
target_add_to_state_list ( cmd ) ;
2014-10-14 14:16:24 -07:00
if ( cmd - > data_direction ! = DMA_TO_DEVICE | | cmd - > data_length = = 0 ) {
2012-07-08 15:58:41 -04:00
target_execute_cmd ( cmd ) ;
return 0 ;
}
2017-02-01 16:58:35 -08:00
spin_lock_irqsave ( & cmd - > t_state_lock , flags ) ;
cmd - > t_state = TRANSPORT_WRITE_PENDING ;
/*
* Determine if frontend context caller is requesting the stopping of
* this command for frontend exceptions .
*/
2018-11-27 15:52:01 -08:00
if ( cmd - > transport_state & CMD_T_STOP & &
! cmd - > se_tfo - > write_pending_must_be_called ) {
2017-02-01 16:58:35 -08:00
pr_debug ( " %s:%d CMD_T_STOP for ITT: 0x%08llx \n " ,
__func__ , __LINE__ , cmd - > tag ) ;
spin_unlock_irqrestore ( & cmd - > t_state_lock , flags ) ;
complete_all ( & cmd - > t_transport_stop_comp ) ;
2017-01-09 10:14:54 -08:00
return 0 ;
2017-02-01 16:58:35 -08:00
}
cmd - > transport_state & = ~ CMD_T_ACTIVE ;
spin_unlock_irqrestore ( & cmd - > t_state_lock , flags ) ;
2012-07-08 15:58:41 -04:00
ret = cmd - > se_tfo - > write_pending ( cmd ) ;
2016-10-30 17:28:16 -07:00
if ( ret )
2012-07-08 15:58:41 -04:00
goto queue_full ;
2016-10-30 17:28:16 -07:00
return 0 ;
2011-10-18 06:57:01 -04:00
2012-07-08 15:58:41 -04:00
queue_full :
pr_debug ( " Handling write_pending QUEUE__FULL: se_cmd: %p \n " , cmd ) ;
2016-10-30 17:28:16 -07:00
transport_handle_queue_full ( cmd , cmd - > se_dev , ret , true ) ;
2012-07-08 15:58:41 -04:00
return 0 ;
[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-05-02 17:12:10 -07:00
EXPORT_SYMBOL ( transport_generic_new_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
2011-10-17 13:56:41 -04:00
static void transport_write_pending_qf ( struct se_cmd * cmd )
2011-06-13 14:46:09 -07:00
{
2017-09-29 16:43:11 -07:00
unsigned long flags ;
2011-10-25 23:57:41 -07:00
int ret ;
2017-09-29 16:43:11 -07:00
bool stop ;
spin_lock_irqsave ( & cmd - > t_state_lock , flags ) ;
stop = ( cmd - > transport_state & ( CMD_T_STOP | CMD_T_ABORTED ) ) ;
spin_unlock_irqrestore ( & cmd - > t_state_lock , flags ) ;
if ( stop ) {
pr_debug ( " %s:%d CMD_T_STOP|CMD_T_ABORTED for ITT: 0x%08llx \n " ,
__func__ , __LINE__ , cmd - > tag ) ;
complete_all ( & cmd - > t_transport_stop_comp ) ;
return ;
}
2011-10-25 23:57:41 -07:00
ret = cmd - > se_tfo - > write_pending ( cmd ) ;
2016-10-30 17:28:16 -07:00
if ( ret ) {
2011-10-17 13:56:41 -04:00
pr_debug ( " Handling write_pending QUEUE__FULL: se_cmd: %p \n " ,
cmd ) ;
2016-10-30 17:28:16 -07:00
transport_handle_queue_full ( cmd , cmd - > se_dev , ret , true ) ;
2011-10-17 13:56:41 -04:00
}
2011-06-13 14:46:09 -07:00
}
2016-01-19 15:23:02 -08:00
static bool
__transport_wait_for_tasks ( struct se_cmd * , bool , bool * , bool * ,
unsigned long * flags ) ;
static void target_wait_free_cmd ( struct se_cmd * cmd , bool * aborted , bool * tas )
{
unsigned long flags ;
spin_lock_irqsave ( & cmd - > t_state_lock , flags ) ;
__transport_wait_for_tasks ( cmd , true , aborted , tas , & flags ) ;
spin_unlock_irqrestore ( & cmd - > t_state_lock , flags ) ;
}
2018-11-27 15:52:03 -08:00
/*
* Call target_put_sess_cmd ( ) and wait until target_release_cmd_kref ( @ cmd ) has
* finished .
*/
void target_put_cmd_and_wait ( struct se_cmd * cmd )
{
DECLARE_COMPLETION_ONSTACK ( compl ) ;
WARN_ON_ONCE ( cmd - > abrt_compl ) ;
cmd - > abrt_compl = & compl ;
target_put_sess_cmd ( cmd ) ;
wait_for_completion ( & compl ) ;
}
2018-06-22 14:52:54 -07:00
/*
* This function is called by frontend drivers after processing of a command
* has finished .
*
2018-11-27 15:52:03 -08:00
* The protocol for ensuring that either the regular frontend command
* processing flow or target_handle_abort ( ) code drops one reference is as
* follows :
2018-06-22 14:52:54 -07:00
* - Calling . queue_data_in ( ) , . queue_status ( ) or queue_tm_rsp ( ) will cause
2018-11-27 15:52:03 -08:00
* the frontend driver to call this function synchronously or asynchronously .
* That will cause one reference to be dropped .
2018-06-22 14:52:54 -07:00
* - During regular command processing the target core sets CMD_T_COMPLETE
* before invoking one of the . queue_ * ( ) functions .
* - The code that aborts commands skips commands and TMFs for which
* CMD_T_COMPLETE has been set .
* - CMD_T_ABORTED is set atomically after the CMD_T_COMPLETE check for
* commands that will be aborted .
* - If the CMD_T_ABORTED flag is set but CMD_T_TAS has not been set
* transport_generic_free_cmd ( ) skips its call to target_put_sess_cmd ( ) .
* - For aborted commands for which CMD_T_TAS has been set . queue_status ( ) will
* be called and will drop a reference .
* - For aborted commands for which CMD_T_TAS has not been set . aborted_task ( )
2018-11-27 15:52:03 -08:00
* will be called . target_handle_abort ( ) will drop the final reference .
2018-06-22 14:52:54 -07:00
*/
2013-05-31 00:46:11 -07:00
int transport_generic_free_cmd ( struct se_cmd * cmd , int wait_for_tasks )
[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
{
2018-06-22 14:52:59 -07:00
DECLARE_COMPLETION_ONSTACK ( compl ) ;
2013-05-31 00:46:11 -07:00
int ret = 0 ;
2016-01-19 15:23:02 -08:00
bool aborted = false , tas = false ;
2013-05-31 00:46:11 -07:00
2018-06-22 14:52:58 -07:00
if ( wait_for_tasks )
target_wait_free_cmd ( cmd , & aborted , & tas ) ;
if ( cmd - > se_cmd_flags & SCF_SE_LUN_CMD ) {
2013-08-31 15:12:01 -07:00
/*
* Handle WRITE failure case where transport_generic_new_cmd ( )
* has already added se_cmd to state_list , but fabric has
* failed command before I / O submission .
*/
2016-01-11 21:31:09 -08:00
if ( cmd - > state_active )
2013-08-31 15:12:01 -07:00
target_remove_from_state_list ( cmd ) ;
2020-02-09 21:12:02 -08:00
if ( cmd - > se_lun )
transport_lun_remove_cmd ( cmd ) ;
2016-01-19 15:23:02 -08:00
}
2018-06-22 14:52:59 -07:00
if ( aborted )
2018-11-27 15:52:00 -08:00
cmd - > free_compl = & compl ;
2018-11-27 15:52:03 -08:00
ret = target_put_sess_cmd ( cmd ) ;
2016-01-19 15:23:02 -08:00
if ( aborted ) {
pr_debug ( " Detected CMD_T_ABORTED for ITT: %llu \n " , cmd - > tag ) ;
2018-06-22 14:52:59 -07:00
wait_for_completion ( & compl ) ;
2016-01-19 15:23:02 -08:00
ret = 1 ;
[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
}
2013-05-31 00:46:11 -07:00
return ret ;
[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
}
EXPORT_SYMBOL ( transport_generic_free_cmd ) ;
2018-04-14 10:51:04 -07:00
/**
2020-11-01 12:59:32 -06:00
* target_get_sess_cmd - Verify the session is accepting cmds and take ref
2011-11-02 21:52:08 -07:00
* @ se_cmd : command descriptor to add
2011-11-18 20:36:22 -08:00
* @ ack_kref : Signal that fabric will perform an ack target_put_sess_cmd ( )
2011-11-02 21:52:08 -07:00
*/
2015-04-27 13:52:36 +02:00
int target_get_sess_cmd ( struct se_cmd * se_cmd , bool ack_kref )
2011-11-02 21:52:08 -07:00
{
2015-04-27 13:52:36 +02:00
struct se_session * se_sess = se_cmd - > se_sess ;
target: Check sess_tearing_down in target_get_sess_cmd()
Target core code assumes that target_splice_sess_cmd_list() has set
sess_tearing_down and moved the list of pending commands to
sess_wait_list, no more commands will be added to the session; if any
are added, nothing keeps the se_session from being freed while the
command is still in flight, which e.g. leads to use-after-free of
se_cmd->se_sess in target_release_cmd_kref().
To enforce this invariant, put a check of sess_tearing_down inside of
sess_cmd_lock in target_get_sess_cmd(); any checks before this are
racy and can lead to the use-after-free described above. For example,
the qla_target check in qlt_do_work() checks sess_tearing_down from
work thread context but then drops all locks before calling
target_submit_cmd() (as it must, since that is a sleeping function).
However, since no locks are held, anything can happen with respect to
the session it has looked up -- although it does correctly get
sess_kref within its lock, so the memory won't be freed while
target_submit_cmd() is actually running, nothing stops eg an ACL from
being dropped and calling ->shutdown_session() (which calls into
target_splice_sess_cmd_list()) before we get to target_get_sess_cmd().
Once this happens, the se_session memory can be freed as soon as
target_submit_cmd() returns and qlt_do_work() drops its reference,
even though we've just added a command to sess_cmd_list.
To prevent this use-after-free, check sess_tearing_down inside of
sess_cmd_lock right before target_get_sess_cmd() adds a command to
sess_cmd_list; this is synchronized with target_splice_sess_cmd_list()
so that every command is either waited for or not added to the queue.
(nab: Keep target_submit_cmd() returning void for now..)
Signed-off-by: Roland Dreier <roland@purestorage.com>
Signed-off-by: Nicholas Bellinger <nab@linux-iscsi.org>
2012-07-16 11:04:40 -07:00
int ret = 0 ;
2011-11-02 21:52:08 -07:00
2011-11-18 20:36:22 -08:00
/*
* Add a second kref if the fabric caller is expecting to handle
* fabric acknowledgement that requires two target_put_sess_cmd ( )
* invocations before se_cmd descriptor release .
*/
2016-10-04 16:37:05 -07:00
if ( ack_kref ) {
2021-02-27 10:59:43 -06:00
kref_get ( & se_cmd - > cmd_kref ) ;
2016-10-04 16:37:05 -07:00
se_cmd - > se_cmd_flags | = SCF_ACK_KREF ;
}
2011-11-12 00:32:17 -08:00
2020-11-01 12:59:32 -06:00
if ( ! percpu_ref_tryget_live ( & se_sess - > cmd_count ) )
target: Check sess_tearing_down in target_get_sess_cmd()
Target core code assumes that target_splice_sess_cmd_list() has set
sess_tearing_down and moved the list of pending commands to
sess_wait_list, no more commands will be added to the session; if any
are added, nothing keeps the se_session from being freed while the
command is still in flight, which e.g. leads to use-after-free of
se_cmd->se_sess in target_release_cmd_kref().
To enforce this invariant, put a check of sess_tearing_down inside of
sess_cmd_lock in target_get_sess_cmd(); any checks before this are
racy and can lead to the use-after-free described above. For example,
the qla_target check in qlt_do_work() checks sess_tearing_down from
work thread context but then drops all locks before calling
target_submit_cmd() (as it must, since that is a sleeping function).
However, since no locks are held, anything can happen with respect to
the session it has looked up -- although it does correctly get
sess_kref within its lock, so the memory won't be freed while
target_submit_cmd() is actually running, nothing stops eg an ACL from
being dropped and calling ->shutdown_session() (which calls into
target_splice_sess_cmd_list()) before we get to target_get_sess_cmd().
Once this happens, the se_session memory can be freed as soon as
target_submit_cmd() returns and qlt_do_work() drops its reference,
even though we've just added a command to sess_cmd_list.
To prevent this use-after-free, check sess_tearing_down inside of
sess_cmd_lock right before target_get_sess_cmd() adds a command to
sess_cmd_list; this is synchronized with target_splice_sess_cmd_list()
so that every command is either waited for or not added to the queue.
(nab: Keep target_submit_cmd() returning void for now..)
Signed-off-by: Roland Dreier <roland@purestorage.com>
Signed-off-by: Nicholas Bellinger <nab@linux-iscsi.org>
2012-07-16 11:04:40 -07:00
ret = - ESHUTDOWN ;
2015-02-18 15:33:58 +01:00
if ( ret & & ack_kref )
2015-04-27 13:52:36 +02:00
target_put_sess_cmd ( se_cmd ) ;
2015-02-18 15:33:58 +01:00
target: Check sess_tearing_down in target_get_sess_cmd()
Target core code assumes that target_splice_sess_cmd_list() has set
sess_tearing_down and moved the list of pending commands to
sess_wait_list, no more commands will be added to the session; if any
are added, nothing keeps the se_session from being freed while the
command is still in flight, which e.g. leads to use-after-free of
se_cmd->se_sess in target_release_cmd_kref().
To enforce this invariant, put a check of sess_tearing_down inside of
sess_cmd_lock in target_get_sess_cmd(); any checks before this are
racy and can lead to the use-after-free described above. For example,
the qla_target check in qlt_do_work() checks sess_tearing_down from
work thread context but then drops all locks before calling
target_submit_cmd() (as it must, since that is a sleeping function).
However, since no locks are held, anything can happen with respect to
the session it has looked up -- although it does correctly get
sess_kref within its lock, so the memory won't be freed while
target_submit_cmd() is actually running, nothing stops eg an ACL from
being dropped and calling ->shutdown_session() (which calls into
target_splice_sess_cmd_list()) before we get to target_get_sess_cmd().
Once this happens, the se_session memory can be freed as soon as
target_submit_cmd() returns and qlt_do_work() drops its reference,
even though we've just added a command to sess_cmd_list.
To prevent this use-after-free, check sess_tearing_down inside of
sess_cmd_lock right before target_get_sess_cmd() adds a command to
sess_cmd_list; this is synchronized with target_splice_sess_cmd_list()
so that every command is either waited for or not added to the queue.
(nab: Keep target_submit_cmd() returning void for now..)
Signed-off-by: Roland Dreier <roland@purestorage.com>
Signed-off-by: Nicholas Bellinger <nab@linux-iscsi.org>
2012-07-16 11:04:40 -07:00
return ret ;
2011-11-02 21:52:08 -07:00
}
2013-03-21 22:54:28 -07:00
EXPORT_SYMBOL ( target_get_sess_cmd ) ;
2011-11-02 21:52:08 -07:00
2016-01-11 21:31:09 -08:00
static void target_free_cmd_mem ( struct se_cmd * cmd )
{
transport_free_pages ( cmd ) ;
if ( cmd - > se_cmd_flags & SCF_SCSI_TMR_CDB )
core_tmr_release_req ( cmd - > se_tmr_req ) ;
if ( cmd - > t_task_cdb ! = cmd - > __t_task_cdb )
kfree ( cmd - > t_task_cdb ) ;
}
2011-11-12 00:32:17 -08:00
static void target_release_cmd_kref ( struct kref * kref )
2011-11-02 21:52:08 -07:00
{
2011-11-12 00:32:17 -08:00
struct se_cmd * se_cmd = container_of ( kref , struct se_cmd , cmd_kref ) ;
struct se_session * se_sess = se_cmd - > se_sess ;
2018-11-27 15:52:00 -08:00
struct completion * free_compl = se_cmd - > free_compl ;
struct completion * abrt_compl = se_cmd - > abrt_compl ;
2011-11-02 21:52:08 -07:00
2016-01-11 21:31:09 -08:00
target_free_cmd_mem ( se_cmd ) ;
2011-11-12 00:32:17 -08:00
se_cmd - > se_tfo - > release_cmd ( se_cmd ) ;
2018-11-27 15:52:00 -08:00
if ( free_compl )
complete ( free_compl ) ;
if ( abrt_compl )
complete ( abrt_compl ) ;
2018-11-27 15:51:58 -08:00
percpu_ref_put ( & se_sess - > cmd_count ) ;
2011-11-12 00:32:17 -08:00
}
2017-02-07 12:19:16 -08:00
/**
* target_put_sess_cmd - decrease the command reference count
* @ se_cmd : command to drop a reference from
*
* Returns 1 if and only if this target_put_sess_cmd ( ) call caused the
* refcount to drop to zero . Returns zero otherwise .
2011-11-12 00:32:17 -08:00
*/
2015-04-27 13:52:36 +02:00
int target_put_sess_cmd ( struct se_cmd * se_cmd )
2011-11-12 00:32:17 -08:00
{
2015-10-22 15:57:04 -07:00
return kref_put ( & se_cmd - > cmd_kref , target_release_cmd_kref ) ;
2011-11-02 21:52:08 -07:00
}
EXPORT_SYMBOL ( target_put_sess_cmd ) ;
2017-05-23 16:48:28 -07:00
static const char * data_dir_name ( enum dma_data_direction d )
{
switch ( d ) {
case DMA_BIDIRECTIONAL : return " BIDI " ;
case DMA_TO_DEVICE : return " WRITE " ;
case DMA_FROM_DEVICE : return " READ " ;
case DMA_NONE : return " NONE " ;
}
return " (?) " ;
}
static const char * cmd_state_name ( enum transport_state_table t )
{
switch ( t ) {
case TRANSPORT_NO_STATE : return " NO_STATE " ;
case TRANSPORT_NEW_CMD : return " NEW_CMD " ;
case TRANSPORT_WRITE_PENDING : return " WRITE_PENDING " ;
case TRANSPORT_PROCESSING : return " PROCESSING " ;
case TRANSPORT_COMPLETE : return " COMPLETE " ;
case TRANSPORT_ISTATE_PROCESSING :
return " ISTATE_PROCESSING " ;
case TRANSPORT_COMPLETE_QF_WP : return " COMPLETE_QF_WP " ;
case TRANSPORT_COMPLETE_QF_OK : return " COMPLETE_QF_OK " ;
case TRANSPORT_COMPLETE_QF_ERR : return " COMPLETE_QF_ERR " ;
}
return " (?) " ;
}
static void target_append_str ( char * * str , const char * txt )
{
char * prev = * str ;
* str = * str ? kasprintf ( GFP_ATOMIC , " %s,%s " , * str , txt ) :
kstrdup ( txt , GFP_ATOMIC ) ;
kfree ( prev ) ;
}
/*
* Convert a transport state bitmask into a string . The caller is
* responsible for freeing the returned pointer .
*/
static char * target_ts_to_str ( u32 ts )
{
char * str = NULL ;
if ( ts & CMD_T_ABORTED )
target_append_str ( & str , " aborted " ) ;
if ( ts & CMD_T_ACTIVE )
target_append_str ( & str , " active " ) ;
if ( ts & CMD_T_COMPLETE )
target_append_str ( & str , " complete " ) ;
if ( ts & CMD_T_SENT )
target_append_str ( & str , " sent " ) ;
if ( ts & CMD_T_STOP )
target_append_str ( & str , " stop " ) ;
if ( ts & CMD_T_FABRIC_STOP )
target_append_str ( & str , " fabric_stop " ) ;
return str ;
}
static const char * target_tmf_name ( enum tcm_tmreq_table tmf )
{
switch ( tmf ) {
case TMR_ABORT_TASK : return " ABORT_TASK " ;
case TMR_ABORT_TASK_SET : return " ABORT_TASK_SET " ;
case TMR_CLEAR_ACA : return " CLEAR_ACA " ;
case TMR_CLEAR_TASK_SET : return " CLEAR_TASK_SET " ;
case TMR_LUN_RESET : return " LUN_RESET " ;
case TMR_TARGET_WARM_RESET : return " TARGET_WARM_RESET " ;
case TMR_TARGET_COLD_RESET : return " TARGET_COLD_RESET " ;
2020-07-26 17:35:04 +02:00
case TMR_LUN_RESET_PRO : return " LUN_RESET_PRO " ;
2017-05-23 16:48:28 -07:00
case TMR_UNKNOWN : break ;
}
return " (?) " ;
}
void target_show_cmd ( const char * pfx , struct se_cmd * cmd )
{
char * ts_str = target_ts_to_str ( cmd - > transport_state ) ;
const u8 * cdb = cmd - > t_task_cdb ;
struct se_tmr_req * tmf = cmd - > se_tmr_req ;
if ( ! ( cmd - > se_cmd_flags & SCF_SCSI_TMR_CDB ) ) {
pr_debug ( " %scmd %#02x:%#02x with tag %#llx dir %s i_state %d t_state %s len %d refcnt %d transport_state %s \n " ,
pfx , cdb [ 0 ] , cdb [ 1 ] , cmd - > tag ,
data_dir_name ( cmd - > data_direction ) ,
cmd - > se_tfo - > get_cmd_state ( cmd ) ,
cmd_state_name ( cmd - > t_state ) , cmd - > data_length ,
kref_read ( & cmd - > cmd_kref ) , ts_str ) ;
} else {
pr_debug ( " %stmf %s with tag %#llx ref_task_tag %#llx i_state %d t_state %s refcnt %d transport_state %s \n " ,
pfx , target_tmf_name ( tmf - > function ) , cmd - > tag ,
tmf - > ref_task_tag , cmd - > se_tfo - > get_cmd_state ( cmd ) ,
cmd_state_name ( cmd - > t_state ) ,
kref_read ( & cmd - > cmd_kref ) , ts_str ) ;
}
kfree ( ts_str ) ;
}
EXPORT_SYMBOL ( target_show_cmd ) ;
2020-11-01 12:59:32 -06:00
static void target_stop_session_confirm ( struct percpu_ref * ref )
{
struct se_session * se_sess = container_of ( ref , struct se_session ,
cmd_count ) ;
complete_all ( & se_sess - > stop_done ) ;
}
2018-04-14 10:51:04 -07:00
/**
2020-11-01 12:59:32 -06:00
* target_stop_session - Stop new IO from being queued on the session .
* @ se_sess : session to stop
2011-11-02 21:52:08 -07:00
*/
2020-11-01 12:59:32 -06:00
void target_stop_session ( struct se_session * se_sess )
2011-11-02 21:52:08 -07:00
{
2020-11-01 12:59:32 -06:00
pr_debug ( " Stopping session queue. \n " ) ;
if ( atomic_cmpxchg ( & se_sess - > stopped , 0 , 1 ) = = 0 )
percpu_ref_kill_and_confirm ( & se_sess - > cmd_count ,
target_stop_session_confirm ) ;
2011-11-02 21:52:08 -07:00
}
2020-11-01 12:59:32 -06:00
EXPORT_SYMBOL ( target_stop_session ) ;
2011-11-02 21:52:08 -07:00
2018-04-14 10:51:04 -07:00
/**
2018-06-22 14:52:53 -07:00
* target_wait_for_sess_cmds - Wait for outstanding commands
2011-11-02 21:52:08 -07:00
* @ se_sess : session to wait for active I / O
*/
2013-05-15 00:44:07 -07:00
void target_wait_for_sess_cmds ( struct se_session * se_sess )
2011-11-02 21:52:08 -07:00
{
2018-06-22 14:52:53 -07:00
int ret ;
2013-05-15 00:52:44 -07:00
2020-11-01 12:59:32 -06:00
WARN_ON_ONCE ( ! atomic_read ( & se_sess - > stopped ) ) ;
2018-06-22 14:52:53 -07:00
do {
2020-11-01 12:59:32 -06:00
pr_debug ( " Waiting for running cmds to complete. \n " ) ;
ret = wait_event_timeout ( se_sess - > cmd_count_wq ,
2018-11-27 15:51:58 -08:00
percpu_ref_is_zero ( & se_sess - > cmd_count ) ,
180 * HZ ) ;
2018-06-22 14:52:53 -07:00
} while ( ret < = 0 ) ;
2020-11-01 12:59:32 -06:00
wait_for_completion ( & se_sess - > stop_done ) ;
pr_debug ( " Waiting for cmds done. \n " ) ;
2011-11-02 21:52:08 -07:00
}
EXPORT_SYMBOL ( target_wait_for_sess_cmds ) ;
2018-11-27 15:51:57 -08:00
/*
* Prevent that new percpu_ref_tryget_live ( ) calls succeed and wait until
* all references to the LUN have been released . Called during LUN shutdown .
*/
2015-05-19 16:16:01 +02:00
void transport_clear_lun_ref ( struct se_lun * lun )
[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
{
2018-11-27 15:51:57 -08:00
percpu_ref_kill ( & lun - > lun_ref ) ;
target: Fix NULL dereference during LUN lookup + active I/O shutdown
When transport_clear_lun_ref() is shutting down a se_lun via
configfs with new I/O in-flight, it's possible to trigger a
NULL pointer dereference in transport_lookup_cmd_lun() due
to the fact percpu_ref_get() doesn't do any __PERCPU_REF_DEAD
checking before incrementing lun->lun_ref.count after
lun->lun_ref has switched to atomic_t mode.
This results in a NULL pointer dereference as LUN shutdown
code in core_tpg_remove_lun() continues running after the
existing ->release() -> core_tpg_lun_ref_release() callback
completes, and clears the RCU protected se_lun->lun_se_dev
pointer.
During the OOPs, the state of lun->lun_ref in the process
which triggered the NULL pointer dereference looks like
the following on v4.1.y stable code:
struct se_lun {
lun_link_magic = 4294932337,
lun_status = TRANSPORT_LUN_STATUS_FREE,
.....
lun_se_dev = 0x0,
lun_sep = 0x0,
.....
lun_ref = {
count = {
counter = 1
},
percpu_count_ptr = 3,
release = 0xffffffffa02fa1e0 <core_tpg_lun_ref_release>,
confirm_switch = 0x0,
force_atomic = false,
rcu = {
next = 0xffff88154fa1a5d0,
func = 0xffffffff8137c4c0 <percpu_ref_switch_to_atomic_rcu>
}
}
}
To address this bug, use percpu_ref_tryget_live() to ensure
once __PERCPU_REF_DEAD is visable on all CPUs and ->lun_ref
has switched to atomic_t, all new I/Os will fail to obtain
a new lun->lun_ref reference.
Also use an explicit percpu_ref_kill_and_confirm() callback
to block on ->lun_ref_comp to allow the first stage and
associated RCU grace period to complete, and then block on
->lun_ref_shutdown waiting for the final percpu_ref_put()
to drop the last reference via transport_lun_remove_cmd()
before continuing with core_tpg_remove_lun() shutdown.
Reported-by: Rob Millner <rlm@daterainc.com>
Tested-by: Rob Millner <rlm@daterainc.com>
Cc: Rob Millner <rlm@daterainc.com>
Tested-by: Vaibhav Tandon <vst@datera.io>
Cc: Vaibhav Tandon <vst@datera.io>
Tested-by: Bryant G. Ly <bryantly@linux.vnet.ibm.com>
Cc: <stable@vger.kernel.org> # v3.14+
Signed-off-by: Nicholas Bellinger <nab@linux-iscsi.org>
2017-02-22 22:06:32 -08:00
wait_for_completion ( & lun - > lun_shutdown_comp ) ;
[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
}
2016-01-19 15:23:02 -08:00
static bool
__transport_wait_for_tasks ( struct se_cmd * cmd , bool fabric_stop ,
bool * aborted , bool * tas , unsigned long * flags )
__releases ( & cmd - > t_state_lock )
__acquires ( & cmd - > t_state_lock )
[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
{
2021-05-31 14:13:26 +02:00
lockdep_assert_held ( & cmd - > t_state_lock ) ;
2016-01-19 15:23:02 -08:00
if ( fabric_stop )
cmd - > transport_state | = CMD_T_FABRIC_STOP ;
if ( cmd - > transport_state & CMD_T_ABORTED )
* aborted = true ;
if ( cmd - > transport_state & CMD_T_TAS )
* tas = true ;
2012-01-19 13:39:17 -08:00
if ( ! ( cmd - > se_cmd_flags & SCF_SE_LUN_CMD ) & &
2016-01-19 15:23:02 -08:00
! ( cmd - > se_cmd_flags & SCF_SCSI_TMR_CDB ) )
2011-11-02 21:52:08 -07:00
return false ;
2012-05-20 11:59:10 -04:00
2012-01-19 13:39:17 -08:00
if ( ! ( cmd - > se_cmd_flags & SCF_SUPPORTED_SAM_OPCODE ) & &
2016-01-19 15:23:02 -08:00
! ( cmd - > se_cmd_flags & SCF_SCSI_TMR_CDB ) )
2011-11-02 21:52:08 -07:00
return false ;
2011-12-21 14:13:47 -05:00
2016-01-19 15:23:02 -08:00
if ( ! ( cmd - > transport_state & CMD_T_ACTIVE ) )
return false ;
if ( fabric_stop & & * aborted )
2011-11-02 21:52:08 -07:00
return false ;
[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-12-21 14:13:47 -05:00
cmd - > transport_state | = CMD_T_STOP ;
[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
2017-05-23 16:48:28 -07:00
target_show_cmd ( " wait_for_tasks: Stopping " , 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
2016-01-19 15:23:02 -08:00
spin_unlock_irqrestore ( & cmd - > t_state_lock , * flags ) ;
[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
2017-05-23 16:48:28 -07:00
while ( ! wait_for_completion_timeout ( & cmd - > t_transport_stop_comp ,
180 * HZ ) )
target_show_cmd ( " wait for tasks: " , 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
2016-01-19 15:23:02 -08:00
spin_lock_irqsave ( & cmd - > t_state_lock , * flags ) ;
2011-12-21 14:13:47 -05:00
cmd - > transport_state & = ~ ( CMD_T_ACTIVE | CMD_T_STOP ) ;
[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
2016-01-19 15:23:02 -08:00
pr_debug ( " wait_for_tasks: Stopped wait_for_completion(&cmd-> "
" t_transport_stop_comp) for ITT: 0x%08llx \n " , cmd - > tag ) ;
[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
2016-01-19 15:23:02 -08:00
return true ;
}
/**
2017-01-10 10:03:28 -08:00
* transport_wait_for_tasks - set CMD_T_STOP and wait for t_transport_stop_comp
* @ cmd : command to wait on
2016-01-19 15:23:02 -08:00
*/
bool transport_wait_for_tasks ( struct se_cmd * cmd )
{
unsigned long flags ;
bool ret , aborted = false , tas = false ;
spin_lock_irqsave ( & cmd - > t_state_lock , flags ) ;
ret = __transport_wait_for_tasks ( cmd , false , & aborted , & tas , & flags ) ;
2011-10-09 01:00:58 -07:00
spin_unlock_irqrestore ( & cmd - > t_state_lock , flags ) ;
2011-11-02 21:52:08 -07:00
2016-01-19 15:23:02 -08:00
return ret ;
[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-10-09 01:00:58 -07:00
EXPORT_SYMBOL ( transport_wait_for_tasks ) ;
[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
2020-11-01 00:32:08 +01:00
struct sense_detail {
2015-07-08 17:58:51 +03:00
u8 key ;
u8 asc ;
u8 ascq ;
2020-11-01 00:32:09 +01:00
bool add_sense_info ;
2015-07-08 17:58:51 +03:00
} ;
2020-11-01 00:32:08 +01:00
static const struct sense_detail sense_detail_table [ ] = {
2015-07-08 17:58:51 +03:00
[ TCM_NO_SENSE ] = {
. key = NOT_READY
} ,
[ TCM_NON_EXISTENT_LUN ] = {
. key = ILLEGAL_REQUEST ,
. asc = 0x25 /* LOGICAL UNIT NOT SUPPORTED */
} ,
[ TCM_UNSUPPORTED_SCSI_OPCODE ] = {
. key = ILLEGAL_REQUEST ,
. asc = 0x20 , /* INVALID COMMAND OPERATION CODE */
} ,
[ TCM_SECTOR_COUNT_TOO_MANY ] = {
. key = ILLEGAL_REQUEST ,
. asc = 0x20 , /* INVALID COMMAND OPERATION CODE */
} ,
[ TCM_UNKNOWN_MODE_PAGE ] = {
. key = ILLEGAL_REQUEST ,
. asc = 0x24 , /* INVALID FIELD IN CDB */
} ,
[ TCM_CHECK_CONDITION_ABORT_CMD ] = {
. key = ABORTED_COMMAND ,
. asc = 0x29 , /* BUS DEVICE RESET FUNCTION OCCURRED */
. ascq = 0x03 ,
} ,
[ TCM_INCORRECT_AMOUNT_OF_DATA ] = {
. key = ABORTED_COMMAND ,
. asc = 0x0c , /* WRITE ERROR */
. ascq = 0x0d , /* NOT ENOUGH UNSOLICITED DATA */
} ,
[ TCM_INVALID_CDB_FIELD ] = {
. key = ILLEGAL_REQUEST ,
. asc = 0x24 , /* INVALID FIELD IN CDB */
} ,
[ TCM_INVALID_PARAMETER_LIST ] = {
. key = ILLEGAL_REQUEST ,
. asc = 0x26 , /* INVALID FIELD IN PARAMETER LIST */
} ,
2016-12-23 11:37:53 +01:00
[ TCM_TOO_MANY_TARGET_DESCS ] = {
. key = ILLEGAL_REQUEST ,
. asc = 0x26 ,
. ascq = 0x06 , /* TOO MANY TARGET DESCRIPTORS */
} ,
[ TCM_UNSUPPORTED_TARGET_DESC_TYPE_CODE ] = {
. key = ILLEGAL_REQUEST ,
. asc = 0x26 ,
. ascq = 0x07 , /* UNSUPPORTED TARGET DESCRIPTOR TYPE CODE */
} ,
[ TCM_TOO_MANY_SEGMENT_DESCS ] = {
. key = ILLEGAL_REQUEST ,
. asc = 0x26 ,
. ascq = 0x08 , /* TOO MANY SEGMENT DESCRIPTORS */
} ,
[ TCM_UNSUPPORTED_SEGMENT_DESC_TYPE_CODE ] = {
. key = ILLEGAL_REQUEST ,
. asc = 0x26 ,
. ascq = 0x09 , /* UNSUPPORTED SEGMENT DESCRIPTOR TYPE CODE */
} ,
2015-07-08 17:58:51 +03:00
[ TCM_PARAMETER_LIST_LENGTH_ERROR ] = {
. key = ILLEGAL_REQUEST ,
. asc = 0x1a , /* PARAMETER LIST LENGTH ERROR */
} ,
[ TCM_UNEXPECTED_UNSOLICITED_DATA ] = {
. key = ILLEGAL_REQUEST ,
. asc = 0x0c , /* WRITE ERROR */
. ascq = 0x0c , /* UNEXPECTED_UNSOLICITED_DATA */
} ,
[ TCM_SERVICE_CRC_ERROR ] = {
. key = ABORTED_COMMAND ,
. asc = 0x47 , /* PROTOCOL SERVICE CRC ERROR */
. ascq = 0x05 , /* N/A */
} ,
[ TCM_SNACK_REJECTED ] = {
. key = ABORTED_COMMAND ,
. asc = 0x11 , /* READ ERROR */
. ascq = 0x13 , /* FAILED RETRANSMISSION REQUEST */
} ,
[ TCM_WRITE_PROTECTED ] = {
. key = DATA_PROTECT ,
. asc = 0x27 , /* WRITE PROTECTED */
} ,
[ TCM_ADDRESS_OUT_OF_RANGE ] = {
. key = ILLEGAL_REQUEST ,
. asc = 0x21 , /* LOGICAL BLOCK ADDRESS OUT OF RANGE */
} ,
[ TCM_CHECK_CONDITION_UNIT_ATTENTION ] = {
. key = UNIT_ATTENTION ,
} ,
[ TCM_MISCOMPARE_VERIFY ] = {
. key = MISCOMPARE ,
. asc = 0x1d , /* MISCOMPARE DURING VERIFY OPERATION */
. ascq = 0x00 ,
2020-11-01 00:32:11 +01:00
. add_sense_info = true ,
2015-07-08 17:58:51 +03:00
} ,
[ TCM_LOGICAL_BLOCK_GUARD_CHECK_FAILED ] = {
2015-07-08 17:58:54 +03:00
. key = ABORTED_COMMAND ,
2015-07-08 17:58:51 +03:00
. asc = 0x10 ,
. ascq = 0x01 , /* LOGICAL BLOCK GUARD CHECK FAILED */
2020-11-01 00:32:09 +01:00
. add_sense_info = true ,
2015-07-08 17:58:51 +03:00
} ,
[ TCM_LOGICAL_BLOCK_APP_TAG_CHECK_FAILED ] = {
2015-07-08 17:58:54 +03:00
. key = ABORTED_COMMAND ,
2015-07-08 17:58:51 +03:00
. asc = 0x10 ,
. ascq = 0x02 , /* LOGICAL BLOCK APPLICATION TAG CHECK FAILED */
2020-11-01 00:32:09 +01:00
. add_sense_info = true ,
2015-07-08 17:58:51 +03:00
} ,
[ TCM_LOGICAL_BLOCK_REF_TAG_CHECK_FAILED ] = {
2015-07-08 17:58:54 +03:00
. key = ABORTED_COMMAND ,
2015-07-08 17:58:51 +03:00
. asc = 0x10 ,
. ascq = 0x03 , /* LOGICAL BLOCK REFERENCE TAG CHECK FAILED */
2020-11-01 00:32:09 +01:00
. add_sense_info = true ,
2015-07-08 17:58:51 +03:00
} ,
2016-10-08 17:26:44 -07:00
[ TCM_COPY_TARGET_DEVICE_NOT_REACHABLE ] = {
. key = COPY_ABORTED ,
. asc = 0x0d ,
. ascq = 0x02 , /* COPY TARGET DEVICE NOT REACHABLE */
} ,
2015-07-08 17:58:51 +03:00
[ TCM_LOGICAL_UNIT_COMMUNICATION_FAILURE ] = {
/*
* Returning ILLEGAL REQUEST would cause immediate IO errors on
* Solaris initiators . Returning NOT READY instead means the
* operations will be retried a finite number of times and we
* can survive intermittent errors .
*/
. key = NOT_READY ,
. asc = 0x08 , /* LOGICAL UNIT COMMUNICATION FAILURE */
} ,
2017-08-21 20:55:41 +08:00
[ TCM_INSUFFICIENT_REGISTRATION_RESOURCES ] = {
/*
* From spc4r22 section5 .7 .7 , 5.7 .8
* If a PERSISTENT RESERVE OUT command with a REGISTER service action
* or a REGISTER AND IGNORE EXISTING KEY service action or
* REGISTER AND MOVE service actionis attempted ,
* but there are insufficient device server resources to complete the
* operation , then the command shall be terminated with CHECK CONDITION
* status , with the sense key set to ILLEGAL REQUEST , and the additonal
* sense code set to INSUFFICIENT REGISTRATION RESOURCES .
*/
. key = ILLEGAL_REQUEST ,
. asc = 0x55 ,
. ascq = 0x04 , /* INSUFFICIENT REGISTRATION RESOURCES */
} ,
2020-12-03 11:20:35 +03:00
[ TCM_INVALID_FIELD_IN_COMMAND_IU ] = {
. key = ILLEGAL_REQUEST ,
. asc = 0x0e ,
. ascq = 0x03 , /* INVALID FIELD IN COMMAND INFORMATION UNIT */
} ,
2021-07-28 13:53:54 +02:00
[ TCM_ALUA_TG_PT_STANDBY ] = {
. key = NOT_READY ,
. asc = 0x04 ,
. ascq = ASCQ_04H_ALUA_TG_PT_STANDBY ,
} ,
[ TCM_ALUA_TG_PT_UNAVAILABLE ] = {
. key = NOT_READY ,
. asc = 0x04 ,
. ascq = ASCQ_04H_ALUA_TG_PT_UNAVAILABLE ,
} ,
[ TCM_ALUA_STATE_TRANSITION ] = {
. key = NOT_READY ,
. asc = 0x04 ,
. ascq = ASCQ_04H_ALUA_STATE_TRANSITION ,
} ,
[ TCM_ALUA_OFFLINE ] = {
. key = NOT_READY ,
. asc = 0x04 ,
. ascq = ASCQ_04H_ALUA_OFFLINE ,
} ,
2015-07-08 17:58:51 +03:00
} ;
2018-06-22 14:53:06 -07:00
/**
* translate_sense_reason - translate a sense reason into T10 key , asc and ascq
* @ cmd : SCSI command in which the resulting sense buffer or SCSI status will
* be stored .
* @ reason : LIO sense reason code . If this argument has the value
* TCM_CHECK_CONDITION_UNIT_ATTENTION , try to dequeue a unit attention . If
* dequeuing a unit attention fails due to multiple commands being processed
* concurrently , set the command status to BUSY .
*
* Return : 0 upon success or - EINVAL if the sense buffer is too small .
*/
2018-06-22 14:53:05 -07:00
static void translate_sense_reason ( struct se_cmd * cmd , sense_reason_t reason )
2015-07-08 17:58:51 +03:00
{
2020-11-01 00:32:08 +01:00
const struct sense_detail * sd ;
2015-07-08 17:58:51 +03:00
u8 * buffer = cmd - > sense_buffer ;
int r = ( __force int ) reason ;
2018-06-22 14:53:06 -07:00
u8 key , asc , ascq ;
2015-07-16 10:28:05 +03:00
bool desc_format = target_sense_desc_format ( cmd - > se_dev ) ;
2015-07-08 17:58:51 +03:00
2020-11-01 00:32:08 +01:00
if ( r < ARRAY_SIZE ( sense_detail_table ) & & sense_detail_table [ r ] . key )
sd = & sense_detail_table [ r ] ;
2015-07-08 17:58:51 +03:00
else
2020-11-01 00:32:08 +01:00
sd = & sense_detail_table [ ( __force int )
2015-07-08 17:58:51 +03:00
TCM_LOGICAL_UNIT_COMMUNICATION_FAILURE ] ;
2020-11-01 00:32:08 +01:00
key = sd - > key ;
2015-07-08 17:58:51 +03:00
if ( reason = = TCM_CHECK_CONDITION_UNIT_ATTENTION ) {
2018-06-22 14:53:06 -07:00
if ( ! core_scsi3_ua_for_check_condition ( cmd , & key , & asc ,
& ascq ) ) {
cmd - > scsi_status = SAM_STAT_BUSY ;
return ;
}
2015-07-08 17:58:51 +03:00
} else {
2021-07-28 13:53:54 +02:00
WARN_ON_ONCE ( sd - > asc = = 0 ) ;
2020-11-01 00:32:08 +01:00
asc = sd - > asc ;
ascq = sd - > ascq ;
2015-07-08 17:58:51 +03:00
}
2015-07-08 17:58:53 +03:00
2018-06-22 14:53:04 -07:00
cmd - > se_cmd_flags | = SCF_EMULATED_TASK_SENSE ;
cmd - > scsi_status = SAM_STAT_CHECK_CONDITION ;
cmd - > scsi_sense_length = TRANSPORT_SENSE_BUFFER ;
2018-06-22 14:53:06 -07:00
scsi_build_sense_buffer ( desc_format , buffer , key , asc , ascq ) ;
2020-11-01 00:32:09 +01:00
if ( sd - > add_sense_info )
2018-06-22 14:53:05 -07:00
WARN_ON_ONCE ( scsi_set_sense_information ( buffer ,
cmd - > scsi_sense_length ,
2020-11-01 00:32:09 +01:00
cmd - > sense_info ) < 0 ) ;
2015-07-08 17:58:51 +03:00
}
2012-11-06 12:24:09 -08:00
int
transport_send_check_condition_and_sense ( struct se_cmd * cmd ,
sense_reason_t reason , int from_transport )
[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
{
unsigned long flags ;
2018-11-27 15:52:03 -08:00
WARN_ON_ONCE ( cmd - > se_cmd_flags & SCF_SCSI_TMR_CDB ) ;
2011-05-02 17:12:10 -07:00
spin_lock_irqsave ( & cmd - > t_state_lock , flags ) ;
[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
if ( cmd - > se_cmd_flags & SCF_SENT_CHECK_CONDITION ) {
2011-05-02 17:12:10 -07:00
spin_unlock_irqrestore ( & cmd - > t_state_lock , flags ) ;
[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
return 0 ;
}
cmd - > se_cmd_flags | = SCF_SENT_CHECK_CONDITION ;
2011-05-02 17:12:10 -07:00
spin_unlock_irqrestore ( & cmd - > t_state_lock , flags ) ;
[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
2018-06-22 14:53:05 -07:00
if ( ! from_transport )
translate_sense_reason ( cmd , reason ) ;
[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
2013-06-26 17:36:17 -07:00
trace_target_cmd_complete ( cmd ) ;
2011-06-13 14:46:09 -07:00
return cmd - > se_tfo - > queue_status ( 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
}
EXPORT_SYMBOL ( transport_send_check_condition_and_sense ) ;
2019-01-25 10:34:47 -08:00
/**
* target_send_busy - Send SCSI BUSY status back to the initiator
* @ cmd : SCSI command for which to send a BUSY reply .
*
* Note : Only call this function if target_submit_cmd * ( ) failed .
*/
int target_send_busy ( struct se_cmd * cmd )
{
WARN_ON_ONCE ( cmd - > se_cmd_flags & SCF_SCSI_TMR_CDB ) ;
cmd - > scsi_status = SAM_STAT_BUSY ;
trace_target_cmd_complete ( cmd ) ;
return cmd - > se_tfo - > queue_status ( cmd ) ;
}
EXPORT_SYMBOL ( target_send_busy ) ;
2012-07-08 15:58:49 -04:00
static void target_tmr_work ( struct work_struct * work )
[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
{
2012-07-08 15:58:49 -04:00
struct se_cmd * cmd = container_of ( work , struct se_cmd , work ) ;
2011-07-19 10:26:37 +00:00
struct se_device * dev = cmd - > se_dev ;
[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_tmr_req * tmr = cmd - > se_tmr_req ;
int ret ;
2018-11-27 15:52:03 -08:00
if ( cmd - > transport_state & CMD_T_ABORTED )
goto aborted ;
2016-01-11 21:53:05 -08:00
[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
switch ( tmr - > function ) {
2011-03-14 04:06:04 -07:00
case TMR_ABORT_TASK :
2012-02-13 02:38:14 -08:00
core_tmr_abort_task ( dev , tmr , cmd - > se_sess ) ;
[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
break ;
2011-03-14 04:06:04 -07:00
case TMR_ABORT_TASK_SET :
case TMR_CLEAR_ACA :
case TMR_CLEAR_TASK_SET :
[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
tmr - > response = TMR_TASK_MGMT_FUNCTION_NOT_SUPPORTED ;
break ;
2011-03-14 04:06:04 -07:00
case TMR_LUN_RESET :
[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
ret = core_tmr_lun_reset ( dev , tmr , NULL , NULL ) ;
tmr - > response = ( ! ret ) ? TMR_FUNCTION_COMPLETE :
TMR_FUNCTION_REJECTED ;
2015-06-11 10:01:28 +02:00
if ( tmr - > response = = TMR_FUNCTION_COMPLETE ) {
target_ua_allocate_lun ( cmd - > se_sess - > se_node_acl ,
cmd - > orig_fe_lun , 0x29 ,
ASCQ_29H_BUS_DEVICE_RESET_FUNCTION_OCCURRED ) ;
}
[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
break ;
2011-03-14 04:06:04 -07:00
case TMR_TARGET_WARM_RESET :
[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
tmr - > response = TMR_FUNCTION_REJECTED ;
break ;
2011-03-14 04:06:04 -07:00
case TMR_TARGET_COLD_RESET :
[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
tmr - > response = TMR_FUNCTION_REJECTED ;
break ;
default :
2018-05-26 16:02:29 +01:00
pr_err ( " Unknown TMR function: 0x%02x. \n " ,
[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
tmr - > function ) ;
tmr - > response = TMR_FUNCTION_REJECTED ;
break ;
}
2018-11-27 15:52:03 -08:00
if ( cmd - > transport_state & CMD_T_ABORTED )
goto aborted ;
2016-01-11 21:53:05 -08:00
2011-07-19 08:55:10 +00:00
cmd - > se_tfo - > queue_tm_rsp ( 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
2020-05-13 17:34:43 +02:00
transport_lun_remove_cmd ( cmd ) ;
2011-10-17 13:56:44 -04:00
transport_cmd_check_stop_to_fabric ( cmd ) ;
2018-11-27 15:52:03 -08:00
return ;
aborted :
target_handle_abort ( 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
}
2012-07-08 15:58:49 -04:00
int transport_generic_handle_tmr (
struct se_cmd * 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
{
2014-06-09 23:13:20 +00:00
unsigned long flags ;
2016-12-06 22:45:46 -08:00
bool aborted = false ;
2014-06-09 23:13:20 +00:00
spin_lock_irqsave ( & cmd - > t_state_lock , flags ) ;
2016-12-06 22:45:46 -08:00
if ( cmd - > transport_state & CMD_T_ABORTED ) {
aborted = true ;
} else {
cmd - > t_state = TRANSPORT_ISTATE_PROCESSING ;
cmd - > transport_state | = CMD_T_ACTIVE ;
}
2014-06-09 23:13:20 +00:00
spin_unlock_irqrestore ( & cmd - > t_state_lock , flags ) ;
2016-12-06 22:45:46 -08:00
if ( aborted ) {
2018-11-27 15:52:03 -08:00
pr_warn_ratelimited ( " handle_tmr caught CMD_T_ABORTED TMR %d ref_tag: %llu tag: %llu \n " ,
cmd - > se_tmr_req - > function ,
cmd - > se_tmr_req - > ref_task_tag , cmd - > tag ) ;
target_handle_abort ( cmd ) ;
2016-12-06 22:45:46 -08:00
return 0 ;
}
2012-07-08 15:58:49 -04:00
INIT_WORK ( & cmd - > work , target_tmr_work ) ;
2018-11-27 15:51:59 -08:00
schedule_work ( & cmd - > work ) ;
[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
return 0 ;
}
2012-07-08 15:58:49 -04:00
EXPORT_SYMBOL ( transport_generic_handle_tmr ) ;
2015-04-20 15:00:30 +02:00
bool
target_check_wce ( struct se_device * dev )
{
bool wce = false ;
if ( dev - > transport - > get_write_cache )
wce = dev - > transport - > get_write_cache ( dev ) ;
else if ( dev - > dev_attrib . emulate_write_cache > 0 )
wce = true ;
return wce ;
}
bool
target_check_fua ( struct se_device * dev )
{
return target_check_wce ( dev ) & & dev - > dev_attrib . emulate_fua_write > 0 ;
}