2019-05-27 09:55:05 +03: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 22:11:26 +03:00
/*******************************************************************************
* Filename : target_core_transport . c
*
* This file contains the Generic Target Engine Core .
*
2013-09-06 02:29:12 +04: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 22:11:26 +03: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 22:20:44 +04:00
# include <linux/module.h>
2012-02-14 04:18:17 +04:00
# include <linux/ratelimit.h>
2015-05-28 21:35:41 +03: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 22:11:26 +03:00
# include <asm/unaligned.h>
# include <net/sock.h>
# include <net/tcp.h>
2015-05-08 11:11:12 +03: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 22:11:26 +03:00
# include <target/target_core_base.h>
2011-11-16 18:46:48 +04: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 22:11:26 +03:00
2011-11-14 21:30:30 +04: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 22:11:26 +03:00
# include "target_core_alua.h"
# include "target_core_pr.h"
# include "target_core_ua.h"
2013-06-27 04:36:17 +04:00
# define CREATE_TRACE_POINTS
# include <trace/events/target.h>
2011-10-17 21:56:53 +04:00
static struct workqueue_struct * 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 22:11:26 +03: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 12:18:50 +04: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 22:11:26 +03:00
static void transport_complete_task_attr ( struct se_cmd * cmd ) ;
2018-06-23 00:53:05 +03:00
static void translate_sense_reason ( struct se_cmd * cmd , sense_reason_t reason ) ;
2011-06-14 01:46:09 +04:00
static void transport_handle_queue_full ( struct se_cmd * cmd ,
2016-10-31 03:28:16 +03:00
struct se_device * dev , int err , bool write_pending ) ;
2011-10-17 21: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 22:11:26 +03:00
2011-07-19 12:55:10 +04: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 22:11:26 +03:00
{
se_sess_cache = kmem_cache_create ( " se_sess_cache " ,
sizeof ( struct se_session ) , __alignof__ ( struct se_session ) ,
0 , NULL ) ;
2011-06-08 21:36:43 +04: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 22:11:26 +03:00
" failed \n " ) ;
2012-01-20 01:39:17 +04: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 22:11:26 +03:00
}
se_ua_cache = kmem_cache_create ( " se_ua_cache " ,
sizeof ( struct se_ua ) , __alignof__ ( struct se_ua ) ,
0 , NULL ) ;
2011-06-08 21:36:43 +04:00
if ( ! se_ua_cache ) {
pr_err ( " kmem_cache_create() for struct se_ua failed \n " ) ;
2011-10-17 21: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 22:11:26 +03: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 21:36:43 +04: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 22:11:26 +03:00
" failed \n " ) ;
2011-10-17 21: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 22:11:26 +03: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 21:36:43 +04: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 22:11:26 +03:00
" failed \n " ) ;
2011-10-17 21: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 22:11:26 +03: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 21:36:43 +04: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 22:11:26 +03:00
" cache failed \n " ) ;
2011-10-17 21: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 22:11:26 +03: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 21:36:43 +04: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 22:11:26 +03:00
" cache failed \n " ) ;
2011-10-17 21: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 22:11:26 +03:00
}
2013-12-17 12:18:50 +04: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-26 07:33:08 +03:00
goto out_free_tg_pt_gp_cache ;
2013-12-17 12:18:50 +04: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 22:11:26 +03:00
2011-10-17 21:56:53 +04:00
target_completion_wq = alloc_workqueue ( " target_completion " ,
WQ_MEM_RECLAIM , 0 ) ;
if ( ! target_completion_wq )
2013-12-17 12:18:50 +04:00
goto out_free_lba_map_mem_cache ;
2011-10-17 21: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 22:11:26 +03:00
return 0 ;
2011-10-17 21:56:53 +04:00
2013-12-17 12:18:50 +04: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 21: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 22:11:26 +03:00
out :
2011-07-19 12:55:10 +04: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 22:11:26 +03:00
}
2011-07-19 12:55:10 +04: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 22:11:26 +03:00
{
2011-10-17 21: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 22:11:26 +03: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 12:18:50 +04: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 22:11:26 +03:00
}
2011-07-19 12:55:10 +04: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-10 02:35:03 +03: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 12:55:10 +04:00
BUG_ON ( ( type < 0 ) | | ( type > = SCSI_INDEX_TYPE_MAX ) ) ;
2011-02-10 02:35:03 +03:00
2011-07-19 12:55:10 +04:00
spin_lock ( & scsi_mib_index_lock ) ;
new_index = + + scsi_mib_index [ type ] ;
spin_unlock ( & scsi_mib_index_lock ) ;
2011-02-10 02:35:03 +03:00
return new_index ;
}
2011-10-22 12:03:54 +04: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 22:11:26 +03:00
{
int ret ;
2012-07-31 02:54:17 +04: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 22:11:26 +03:00
2011-10-22 12:03:54 +04:00
if ( sub_api_initialized )
return ;
2018-10-20 19:45:16 +03: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 22:11:26 +03:00
if ( ret ! = 0 )
2011-06-08 21:36:43 +04: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 22:11:26 +03:00
2018-10-20 19:45:16 +03: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 22:11:26 +03:00
if ( ret ! = 0 )
2011-06-08 21:36:43 +04: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 22:11:26 +03:00
2018-10-20 19:45:16 +03: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 22:11:26 +03:00
if ( ret ! = 0 )
2011-06-08 21:36:43 +04: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 22:11:26 +03:00
2018-10-20 19:45:16 +03:00
ret = IS_ENABLED ( CONFIG_TCM_USER2 ) & & request_module ( " target_core_user " ) ;
2014-10-02 03:07:05 +04:00
if ( ret ! = 0 )
pr_err ( " Unable to load target_core_user \n " ) ;
2011-07-19 12:55:10 +04: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 22:11:26 +03:00
}
2018-11-28 02:51:58 +03:00
static void target_release_sess_cmd_refcnt ( struct percpu_ref * ref )
{
struct se_session * sess = container_of ( ref , typeof ( * sess ) , cmd_count ) ;
wake_up ( & sess - > cmd_list_wq ) ;
}
2018-06-23 00:52:52 +03: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-28 02:51:58 +03:00
int transport_init_session ( struct se_session * se_sess )
2018-06-23 00:52:52 +03:00
{
INIT_LIST_HEAD ( & se_sess - > sess_list ) ;
INIT_LIST_HEAD ( & se_sess - > sess_acl_list ) ;
INIT_LIST_HEAD ( & se_sess - > sess_cmd_list ) ;
spin_lock_init ( & se_sess - > sess_cmd_lock ) ;
2018-06-23 00:52:53 +03:00
init_waitqueue_head ( & se_sess - > cmd_list_wq ) ;
2018-11-28 02:51:58 +03:00
return percpu_ref_init ( & se_sess - > cmd_count ,
target_release_sess_cmd_refcnt , 0 , GFP_KERNEL ) ;
2018-06-23 00:52:52 +03:00
}
EXPORT_SYMBOL ( transport_init_session ) ;
2018-06-23 00:52:51 +03: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 22:11:26 +03:00
{
struct se_session * se_sess ;
2018-11-28 02:51:58 +03: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 22:11:26 +03:00
se_sess = kmem_cache_zalloc ( se_sess_cache , GFP_KERNEL ) ;
2011-06-08 21:36:43 +04: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 22:11:26 +03:00
" se_sess_cache \n " ) ;
return ERR_PTR ( - ENOMEM ) ;
}
2018-11-28 02:51:58 +03:00
ret = transport_init_session ( se_sess ) ;
if ( ret < 0 ) {
2018-12-17 15:19:53 +03:00
kmem_cache_free ( se_sess_cache , se_sess ) ;
2018-11-28 02:51:58 +03:00
return ERR_PTR ( ret ) ;
}
2014-04-02 23:52:38 +04: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 22:11:26 +03:00
return se_sess ;
}
2018-06-23 00:52:51 +03: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-08 04:38:58 +04:00
int transport_alloc_session_tags ( struct se_session * se_sess ,
unsigned int tag_num , unsigned int tag_size )
{
int rc ;
2018-11-28 02:51:56 +03:00
se_sess - > sess_cmd_map = kvcalloc ( tag_size , tag_num ,
GFP_KERNEL | __GFP_RETRY_MAYFAIL ) ;
2013-06-08 04:38:58 +04:00
if ( ! se_sess - > sess_cmd_map ) {
2018-11-28 02:51:56 +03:00
pr_err ( " Unable to allocate se_sess->sess_cmd_map \n " ) ;
return - ENOMEM ;
2013-06-08 04:38:58 +04:00
}
2018-06-12 22:05:44 +03:00
rc = sbitmap_queue_init_node ( & se_sess - > sess_tag_pool , tag_num , - 1 ,
false , GFP_KERNEL , NUMA_NO_NODE ) ;
2013-06-08 04:38:58 +04:00
if ( rc < 0 ) {
pr_err ( " Unable to init se_sess->sess_tag_pool, "
" tag_num: %u \n " , tag_num ) ;
2015-07-01 00:59:24 +03:00
kvfree ( se_sess - > sess_cmd_map ) ;
2013-06-08 04:38:58 +04:00
se_sess - > sess_cmd_map = NULL ;
return - ENOMEM ;
}
return 0 ;
}
EXPORT_SYMBOL ( transport_alloc_session_tags ) ;
2018-06-23 00:52:51 +03: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 20:12:22 +03: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-08 04:38:58 +04:00
{
struct se_session * se_sess ;
int rc ;
2016-01-09 16:29:24 +03: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-23 00:52:51 +03:00
se_sess = transport_alloc_session ( sup_prot_ops ) ;
2013-06-08 04:38:58 +04: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 22:11:26 +03:00
/*
2011-08-31 23:34:39 +04: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 22:11:26 +03: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 21:01:35 +03: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 22:11:26 +03:00
unsigned char buf [ PR_REG_ISID_LEN ] ;
2018-08-02 20:12:20 +03: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 22:11:26 +03: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 21:52:22 +03: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 22:11:26 +03: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 12:55:10 +04: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 22:11:26 +03:00
memset ( & buf [ 0 ] , 0 , PR_REG_ISID_LEN ) ;
2011-07-19 12:55:10 +04: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 22:11:26 +03:00
& buf [ 0 ] , PR_REG_ISID_LEN ) ;
se_sess - > sess_bin_isid = get_unaligned_be64 ( & buf [ 0 ] ) ;
}
2012-03-09 11:45:02 +04:00
2018-08-02 20:12:20 +03: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 22:11:26 +03: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 20:12:20 +03: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 22:11:26 +03:00
}
list_add_tail ( & se_sess - > sess_list , & se_tpg - > tpg_sess_list ) ;
2011-06-08 21:36:43 +04:00
pr_debug ( " TARGET_CORE[%s]: Registered fabric_sess_ptr: %p \n " ,
2018-11-23 20:36:12 +03: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 22:11:26 +03: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 23:34:39 +04: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 22:11:26 +03:00
__transport_register_session ( se_tpg , se_nacl , se_sess , fabric_sess_ptr ) ;
2011-08-31 23:34:39 +04: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 22:11:26 +03:00
}
EXPORT_SYMBOL ( transport_register_session ) ;
2016-01-09 16:29:24 +03:00
struct se_session *
2018-08-02 20:12:23 +03:00
target_setup_session ( struct se_portal_group * tpg ,
2016-01-09 16:29:24 +03: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-23 00:52:51 +03:00
sess = transport_alloc_session ( prot_op ) ;
2016-01-09 16:29:24 +03: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 20:12:23 +03:00
EXPORT_SYMBOL ( target_setup_session ) ;
2016-01-09 16:29:24 +03:00
2015-03-07 07:34:32 +03: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-09 11:45:02 +04: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 23:55:54 +03:00
struct se_portal_group * se_tpg = nacl - > se_tpg ;
2012-03-09 11:45:02 +04:00
2016-12-07 23:55:54 +03:00
if ( ! nacl - > dynamic_stop ) {
complete ( & nacl - > acl_free_comp ) ;
return ;
}
mutex_lock ( & se_tpg - > acl_node_mutex ) ;
2017-08-07 02:10:03 +03:00
list_del_init ( & nacl - > acl_list ) ;
2016-12-07 23:55:54 +03: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-09 11:45:02 +04:00
}
void target_put_nacl ( struct se_node_acl * nacl )
{
kref_put ( & nacl - > acl_kref , target_complete_nacl ) ;
}
2016-01-08 09:09:27 +03:00
EXPORT_SYMBOL ( target_put_nacl ) ;
2012-03-09 11:45:02 +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 22:11:26 +03:00
void transport_deregister_session_configfs ( struct se_session * se_sess )
{
struct se_node_acl * se_nacl ;
2011-06-22 12:02:21 +04: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 22:11:26 +03: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 21:36:43 +04:00
if ( se_nacl ) {
2011-06-22 12:02:21 +04:00
spin_lock_irqsave ( & se_nacl - > nacl_sess_lock , flags ) ;
2016-05-02 16:45:20 +03: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 22:11:26 +03: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 12:02:21 +04: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 22:11:26 +03:00
}
}
EXPORT_SYMBOL ( transport_deregister_session_configfs ) ;
void transport_free_session ( struct se_session * se_sess )
{
2016-01-08 09:09:27 +03:00
struct se_node_acl * se_nacl = se_sess - > se_node_acl ;
2016-12-07 23:55:54 +03:00
2016-01-08 09:09:27 +03:00
/*
* Drop the se_node_acl - > nacl_kref obtained from within
* core_tpg_get_initiator_node_acl ( ) .
*/
if ( se_nacl ) {
2016-12-07 23:55:54 +03: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-08 09:09:27 +03:00
se_sess - > se_node_acl = NULL ;
2016-12-07 23:55:54 +03: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-07 02:10:03 +03:00
list_del_init ( & se_nacl - > acl_list ) ;
2016-12-07 23:55:54 +03:00
}
mutex_unlock ( & se_tpg - > acl_node_mutex ) ;
if ( se_nacl - > dynamic_stop )
target_put_nacl ( se_nacl ) ;
2016-01-08 09:09:27 +03:00
target_put_nacl ( se_nacl ) ;
}
2013-06-08 04:38:58 +04:00
if ( se_sess - > sess_cmd_map ) {
2018-06-12 22:05:44 +03:00
sbitmap_queue_free ( & se_sess - > sess_tag_pool ) ;
2015-07-01 00:59:24 +03:00
kvfree ( se_sess - > sess_cmd_map ) ;
2013-06-08 04:38:58 +04:00
}
2018-11-28 02:51:58 +03:00
percpu_ref_exit ( & se_sess - > 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 22:11:26 +03:00
kmem_cache_free ( se_sess_cache , se_sess ) ;
}
EXPORT_SYMBOL ( transport_free_session ) ;
void transport_deregister_session ( struct se_session * se_sess )
{
struct se_portal_group * se_tpg = se_sess - > se_tpg ;
2011-08-13 03:01:02 +04: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 22:11:26 +03:00
2011-06-08 21:36:43 +04: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 22:11:26 +03:00
transport_free_session ( se_sess ) ;
return ;
}
2011-08-13 03:01:02 +04: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 22:11:26 +03:00
list_del ( & se_sess - > sess_list ) ;
se_sess - > se_tpg = NULL ;
se_sess - > fabric_sess_ptr = NULL ;
2011-08-13 03:01:02 +04: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 22:11:26 +03:00
2011-06-08 21:36:43 +04:00
pr_debug ( " TARGET_CORE[%s]: Deregistered fabric_sess \n " ,
2018-11-23 20:36:12 +03:00
se_tpg - > se_tpg_tfo - > fabric_name ) ;
2012-03-11 02:32:52 +04:00
/*
2013-11-19 12:07:46 +04:00
* If last kref is dropping now for an explicit NodeACL , awake sleeping
2012-03-09 11:45:02 +04:00
* - > acl_free_comp caller to wakeup configfs se_node_acl - > acl_group
2016-01-08 09:09:27 +03:00
* removal context from within transport_free_session ( ) code .
2016-12-07 23:55:54 +03:00
*
* For dynamic ACL , target_put_nacl ( ) uses target_complete_nacl ( )
* to release all remaining generate_node_acl = 1 created ACL resources .
2012-03-11 02:32:52 +04:00
*/
2012-03-09 11:45:02 +04: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 22:11:26 +03:00
}
EXPORT_SYMBOL ( transport_deregister_session ) ;
2018-08-02 20:12:24 +03: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 08: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 22:11:26 +03:00
{
2011-10-12 19: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 22:11:26 +03:00
unsigned long flags ;
2011-10-12 19: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 22:11:26 +03:00
2012-04-24 08:25:05 +04:00
spin_lock_irqsave ( & dev - > execute_task_lock , flags ) ;
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 22:11:26 +03:00
}
2012-04-24 08:25:05 +04:00
spin_unlock_irqrestore ( & dev - > execute_task_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 22:11:26 +03:00
}
2018-06-23 00:52:54 +03: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-02 03:58:35 +03: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 22:11:26 +03:00
{
unsigned long flags ;
2017-02-02 03:58:35 +03:00
target_remove_from_state_list ( cmd ) ;
2012-07-08 23:58:38 +04:00
2016-01-12 08:31:09 +03: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 22:11:26 +03:00
/*
* Determine if frontend context caller is requesting the stopping of
2011-07-19 12:55:10 +04: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 22:11:26 +03:00
*/
2011-12-21 23:13:47 +04:00
if ( cmd - > transport_state & CMD_T_STOP ) {
2015-04-14 14:26:44 +03: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 22:11:26 +03:00
2011-05-03 04:12:10 +04: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 22:11:26 +03:00
2014-06-10 03:36:51 +04: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 22:11:26 +03:00
return 1 ;
}
2012-07-08 23:58:38 +04:00
cmd - > transport_state & = ~ CMD_T_ACTIVE ;
2011-05-03 04:12:10 +04: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 22:11:26 +03:00
2017-02-02 03:58:35 +03: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 11:09:59 +03: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 22:11:26 +03:00
}
2011-10-17 21: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 ) ;
2012-11-07 00:24:09 +04:00
transport_generic_request_failure ( cmd ,
TCM_LOGICAL_UNIT_COMMUNICATION_FAILURE ) ;
2011-10-17 21:56:53 +04:00
}
2012-09-05 19:09:13 +04:00
/*
2012-09-05 19:09:15 +04:00
* Used when asking transport to copy Sense Data from the underlying
* Linux / SCSI struct scsi_cmnd
2012-09-05 19:09:13 +04:00
*/
2012-09-05 19:09:15 +04:00
static unsigned char * transport_get_sense_buffer ( struct se_cmd * cmd )
2012-09-05 19:09:13 +04:00
{
struct se_device * dev = cmd - > se_dev ;
WARN_ON ( ! cmd - > se_lun ) ;
if ( ! dev )
2012-09-05 19:09:15 +04:00
return NULL ;
2012-09-05 19:09:13 +04:00
2012-09-05 19:09:15 +04:00
if ( cmd - > se_cmd_flags & SCF_SENT_CHECK_CONDITION )
return NULL ;
2012-09-05 19:09:13 +04:00
2012-08-16 01:35:25 +04:00
cmd - > scsi_sense_length = TRANSPORT_SENSE_BUFFER ;
2012-09-05 19:09:13 +04:00
2012-09-05 19:09:15 +04:00
pr_debug ( " HBA_[%u]_PLUG[%s]: Requesting sense for SAM STATUS: 0x%02x \n " ,
2012-09-05 19:09:13 +04:00
dev - > se_hba - > hba_id , dev - > transport - > name , cmd - > scsi_status ) ;
2012-08-16 01:35:25 +04:00
return cmd - > sense_buffer ;
2012-09-05 19:09:13 +04:00
}
2017-05-31 23:52:39 +03: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-28 02:52:03 +03: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 ) ;
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. */
2012-04-24 08:25:06 +04:00
void target_complete_cmd ( struct se_cmd * cmd , u8 scsi_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 22:11:26 +03:00
{
2017-05-31 23:52:43 +03:00
int success ;
[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 22:11:26 +03:00
unsigned long flags ;
2018-11-28 02:52:03 +03:00
if ( target_cmd_interrupted ( cmd ) )
return ;
2012-04-24 08:25:06 +04:00
cmd - > scsi_status = scsi_status ;
2011-05-03 04:12:10 +04:00
spin_lock_irqsave ( & cmd - > t_state_lock , flags ) ;
2017-05-31 23:52:43 +03:00
switch ( cmd - > scsi_status ) {
case SAM_STAT_CHECK_CONDITION :
2012-09-05 19:09:15 +04: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 22:11:26 +03:00
success = 1 ;
2017-05-31 23:52:43 +03:00
else
success = 0 ;
break ;
default :
2017-05-31 23:52:38 +03:00
success = 1 ;
2017-05-31 23:52:43 +03: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 22:11:26 +03:00
}
2011-10-17 21:56:53 +04:00
cmd - > t_state = TRANSPORT_COMPLETE ;
2012-02-13 14:38:14 +04:00
cmd - > transport_state | = ( CMD_T_COMPLETE | CMD_T_ACTIVE ) ;
2011-05-03 04:12:10 +04: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 22:11:26 +03:00
2018-11-28 02:52:04 +03:00
INIT_WORK ( & cmd - > work , success ? target_complete_ok_work :
target_complete_failure_work ) ;
2016-02-11 02:59:13 +03:00
if ( cmd - > se_cmd_flags & SCF_USE_CPUID )
2015-12-17 22:57:06 +03:00
queue_work_on ( cmd - > cpuid , target_completion_wq , & cmd - > work ) ;
2016-02-11 02:59:13 +03:00
else
queue_work ( 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 22:11:26 +03:00
}
2012-04-23 19:35:33 +04:00
EXPORT_SYMBOL ( target_complete_cmd ) ;
2014-06-10 22:07:47 +04:00
void target_complete_cmd_with_length ( struct se_cmd * cmd , u8 scsi_status , int length )
{
2018-05-16 04:25:24 +03:00
if ( ( scsi_status = = SAM_STAT_GOOD | |
cmd - > se_cmd_flags & SCF_TREAT_READ_AS_NORMAL ) & &
length < cmd - > data_length ) {
2014-06-10 22:07:47 +04: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 ;
}
target_complete_cmd ( cmd , scsi_status ) ;
}
EXPORT_SYMBOL ( target_complete_cmd_with_length ) ;
2012-04-24 08: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 22:11:26 +03:00
{
2012-04-24 08: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 22:11:26 +03:00
2012-04-24 08:25:05 +04:00
spin_lock_irqsave ( & dev - > execute_task_lock , flags ) ;
if ( ! cmd - > state_active ) {
list_add_tail ( & cmd - > state_list , & dev - > state_list ) ;
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 22:11:26 +03:00
}
2012-04-24 08:25:05 +04:00
spin_unlock_irqrestore ( & dev - > execute_task_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 22:11:26 +03:00
}
2011-06-14 01:46:09 +04:00
/*
2011-10-26 10:57:41 +04:00
* Handle QUEUE_FULL / - EAGAIN and - ENOMEM status
2011-06-14 01:46:09 +04:00
*/
2012-07-08 23: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-14 01:46:09 +04:00
2012-10-08 08:03:19 +04:00
void target_qf_do_work ( struct work_struct * work )
2011-06-14 01:46:09 +04:00
{
struct se_device * dev = container_of ( work , struct se_device ,
qf_work_queue ) ;
2011-08-28 08:33:16 +04:00
LIST_HEAD ( qf_cmd_list ) ;
2011-06-14 01:46:09 +04:00
struct se_cmd * cmd , * cmd_tmp ;
spin_lock_irq ( & dev - > qf_cmd_lock ) ;
2011-08-28 08:33:16 +04:00
list_splice_init ( & dev - > qf_cmd_list , & qf_cmd_list ) ;
spin_unlock_irq ( & dev - > qf_cmd_lock ) ;
2011-06-14 01:46:09 +04:00
2011-08-28 08:33:16 +04:00
list_for_each_entry_safe ( cmd , cmd_tmp , & qf_cmd_list , se_qf_node ) {
2011-06-14 01:46:09 +04:00
list_del ( & cmd - > se_qf_node ) ;
2014-09-17 00:23:12 +04:00
atomic_dec_mb ( & dev - > dev_qf_count ) ;
2011-06-14 01:46:09 +04:00
2011-06-08 21:36:43 +04:00
pr_debug ( " Processing %s cmd: %p QUEUE_FULL in work queue "
2018-11-23 20:36:12 +03:00
" context: %s \n " , cmd - > se_tfo - > fabric_name , cmd ,
2011-10-17 21:56:41 +04:00
( cmd - > t_state = = TRANSPORT_COMPLETE_QF_OK ) ? " COMPLETE_OK " :
2011-06-14 01:46:09 +04:00
( cmd - > t_state = = TRANSPORT_COMPLETE_QF_WP ) ? " WRITE_PENDING "
: " UNKNOWN " ) ;
2011-10-17 21:56:42 +04:00
2012-07-08 23:58:47 +04:00
if ( cmd - > t_state = = TRANSPORT_COMPLETE_QF_WP )
transport_write_pending_qf ( cmd ) ;
2016-10-31 03:28:16 +03:00
else if ( cmd - > t_state = = TRANSPORT_COMPLETE_QF_OK | |
cmd - > t_state = = TRANSPORT_COMPLETE_QF_ERR )
2012-07-08 23:58:47 +04:00
transport_complete_qf ( cmd ) ;
2011-06-14 01:46:09 +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 22:11:26 +03: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 08: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 22:11:26 +03:00
* bl + = sprintf ( b + * bl , " ACTIVATED " ) ;
2012-10-08 08: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 22:11:26 +03:00
* bl + = sprintf ( b + * bl , " DEACTIVATED " ) ;
2012-05-20 22:34:44 +04:00
* bl + = sprintf ( b + * bl , " Max Queue Depth: %d " , dev - > queue_depth ) ;
2012-05-09 23:42:09 +04:00
* bl + = sprintf ( b + * bl , " SectorSize: %u HwMaxSectors: %u \n " ,
2012-10-08 08: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 22:11:26 +03: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 21:36:43 +04: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 22:11:26 +03: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 12:55:10 +04: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 22:11:26 +03: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 12:55:10 +04: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 22:11:26 +03:00
break ;
}
if ( p_buf )
strncpy ( p_buf , buf , p_buf_len ) ;
else
2011-06-08 21:36:43 +04: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 22:11:26 +03: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 12:55:10 +04: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 22:11:26 +03: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 12:55:10 +04: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 22:11:26 +03:00
break ;
}
2011-07-19 12:55:10 +04: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 22:11:26 +03:00
strncpy ( p_buf , buf , p_buf_len ) ;
2011-07-19 12:55:10 +04:00
} else {
2011-06-08 21:36:43 +04:00
pr_debug ( " %s " , buf ) ;
2011-07-19 12:55:10 +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 22:11:26 +03: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 17:05:12 +04: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 22:11:26 +03:00
& vpd - > device_identifier [ 0 ] ) ;
break ;
case 0x02 : /* ASCII */
2013-01-18 17:05:12 +04: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 22:11:26 +03:00
& vpd - > device_identifier [ 0 ] ) ;
break ;
case 0x03 : /* UTF-8 */
2013-01-18 17:05:12 +04: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 22:11:26 +03: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 12:55:10 +04: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 22:11:26 +03:00
break ;
}
if ( p_buf )
strncpy ( p_buf , buf , p_buf_len ) ;
else
2011-06-08 21:36:43 +04: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 22:11:26 +03: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 17:43:13 +04: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 22:11:26 +03: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-31 04:28:13 +03: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 ;
}
2012-11-07 00:24:09 +04:00
sense_reason_t
target_cmd_size_check ( struct se_cmd * cmd , unsigned int size )
2012-05-20 19: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 11:07:24 +03:00
pr_warn_ratelimited ( " TARGET_CORE[%s]: Expected Transfer Length: "
2012-05-20 19:59:12 +04:00
" %u does not match SCSI CDB Length: %u for SAM Opcode: "
2018-11-23 20:36:12 +03:00
" 0x%02x \n " , cmd - > se_tfo - > fabric_name ,
2012-05-20 19:59:12 +04:00
cmd - > data_length , size , cmd - > t_task_cdb [ 0 ] ) ;
2017-05-11 11:07:24 +03: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 " ) ;
return TCM_INVALID_CDB_FIELD ;
}
/*
* 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 19:59:12 +04:00
}
/*
* Reject READ_ * or WRITE_ * with overflow / underflow for
* type SCF_SCSI_DATA_CDB .
*/
2012-10-08 08:03:19 +04:00
if ( dev - > dev_attrib . block_size ! = 512 ) {
2012-05-20 19:59:12 +04:00
pr_err ( " Failing OVERFLOW/UNDERFLOW for LBA op "
" CDB on non 512-byte sector setup subsystem "
" plugin: %s \n " , dev - > transport - > name ) ;
/* Returns CHECK_CONDITION + INVALID_CDB_FIELD */
2012-11-07 00:24:09 +04:00
return TCM_INVALID_CDB_FIELD ;
2012-05-20 19:59:12 +04:00
}
2012-08-17 02:33:10 +04:00
/*
* 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 .
*/
2012-05-20 19:59:12 +04:00
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 ) ;
2012-08-17 02:33:10 +04:00
cmd - > data_length = size ;
2012-05-20 19:59:12 +04:00
}
}
2015-07-31 04:28:13 +03:00
return target_check_max_data_sg_nents ( cmd , dev , size ) ;
2012-05-20 19: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 22:11:26 +03:00
/*
* Used by fabric modules containing a local struct se_cmd within their
* fabric dependent per I / O descriptor .
2015-04-14 14:26:44 +03: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 22:11:26 +03:00
*/
void transport_init_se_cmd (
struct se_cmd * cmd ,
2015-04-08 21:01:35 +03: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 22:11:26 +03:00
struct se_session * se_sess ,
u32 data_length ,
int data_direction ,
int task_attr ,
unsigned char * sense_buffer )
{
2011-07-19 14:26:37 +04:00
INIT_LIST_HEAD ( & cmd - > se_delayed_node ) ;
2011-06-14 01:46:09 +04:00
INIT_LIST_HEAD ( & cmd - > se_qf_node ) ;
2011-11-03 08:52:08 +04:00
INIT_LIST_HEAD ( & cmd - > se_cmd_list ) ;
2012-04-24 08:25:05 +04:00
INIT_LIST_HEAD ( & cmd - > state_list ) ;
2011-05-03 04:12:10 +04:00
init_completion ( & cmd - > t_transport_stop_comp ) ;
2018-11-28 02:52:00 +03:00
cmd - > free_compl = NULL ;
cmd - > abrt_compl = NULL ;
2011-05-03 04:12:10 +04:00
spin_lock_init ( & cmd - > t_state_lock ) ;
2017-05-24 02:48:24 +03:00
INIT_WORK ( & cmd - > work , NULL ) ;
2014-05-17 14: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 22:11:26 +03: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 ;
2012-04-24 08: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 22:11:26 +03:00
}
EXPORT_SYMBOL ( transport_init_se_cmd ) ;
2012-11-07 00:24:09 +04: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 22:11:26 +03:00
{
2012-10-11 01: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 22:11:26 +03:00
/*
* Check if SAM Task Attribute emulation is enabled for this
* struct se_device storage object
*/
2015-05-20 00:44:41 +03:00
if ( dev - > transport - > 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 22:11:26 +03:00
return 0 ;
2014-11-24 18:07:25 +03:00
if ( cmd - > sam_task_attr = = TCM_ACA_TAG ) {
2011-06-08 21:36:43 +04: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 22:11:26 +03:00
" emulation is not supported \n " ) ;
2012-11-07 00:24:09 +04: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 22:11:26 +03:00
}
2015-07-22 03:45:32 +03: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 22:11:26 +03:00
return 0 ;
}
2012-11-07 00:24:09 +04:00
sense_reason_t
target_setup_cmd_from_cdb ( struct se_cmd * cmd , unsigned char * 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 22:11:26 +03:00
{
2012-10-08 08:03:19 +04:00
struct se_device * dev = cmd - > se_dev ;
2012-11-07 00:24:09 +04: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 22:11:26 +03: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 21:36:43 +04: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 22:11:26 +03:00
" exceeds SCSI_MAX_VARLEN_CDB_SIZE: %d \n " ,
scsi_command_size ( cdb ) , SCSI_MAX_VARLEN_CDB_SIZE ) ;
2012-11-07 00:24:09 +04: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 22:11:26 +03: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-03 04:12:10 +04:00
if ( scsi_command_size ( cdb ) > sizeof ( cmd - > __t_task_cdb ) ) {
cmd - > t_task_cdb = kzalloc ( scsi_command_size ( 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 22:11:26 +03:00
GFP_KERNEL ) ;
2011-06-08 21:36:43 +04:00
if ( ! cmd - > t_task_cdb ) {
pr_err ( " Unable to allocate cmd->t_task_cdb "
2011-05-03 04:12:10 +04: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 22:11:26 +03:00
scsi_command_size ( cdb ) ,
2011-05-03 04:12:10 +04:00
( unsigned long ) sizeof ( cmd - > __t_task_cdb ) ) ;
2012-11-07 00:24:09 +04:00
return TCM_OUT_OF_RESOURCES ;
[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 22:11:26 +03:00
}
} else
2011-05-03 04:12:10 +04: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 22:11:26 +03:00
/*
2011-05-03 04:12:10 +04: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 22:11:26 +03:00
*/
2011-05-03 04:12:10 +04:00
memcpy ( cmd - > t_task_cdb , cdb , scsi_command_size ( cdb ) ) ;
2012-05-20 19:59:10 +04:00
2013-06-27 04:36:17 +04:00
trace_target_sequencer_start ( cmd ) ;
2012-10-08 08:03:19 +04:00
ret = dev - > transport - > parse_cdb ( cmd ) ;
2015-07-23 01:01:36 +03:00
if ( ret = = TCM_UNSUPPORTED_SCSI_OPCODE )
pr_warn_ratelimited ( " %s/%s: Unsupported SCSI Opcode 0x%02x, sending CHECK_CONDITION. \n " ,
2018-11-23 20:36:12 +03:00
cmd - > se_tfo - > fabric_name ,
2015-07-23 01:01:36 +03:00
cmd - > se_sess - > se_node_acl - > initiatorname ,
cmd - > t_task_cdb [ 0 ] ) ;
2012-11-07 00:24:09 +04: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 22:11:26 +03:00
return ret ;
2012-05-20 19:59:10 +04:00
cmd - > se_cmd_flags | = SCF_SUPPORTED_SAM_OPCODE ;
2015-05-19 10:03:07 +03: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 22:11:26 +03:00
return 0 ;
}
2012-04-04 02:51:20 +04:00
EXPORT_SYMBOL ( target_setup_cmd_from_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 22:11:26 +03:00
2011-06-04 07:59:19 +04:00
/*
* Used by fabric module frontends to queue tasks directly .
2015-10-23 01:52:01 +03:00
* May only be used from process context .
2011-06-04 07:59:19 +04:00
*/
int transport_handle_cdb_direct (
struct se_cmd * cmd )
{
2012-11-07 00:24:09 +04:00
sense_reason_t ret ;
2011-07-30 16:03:58 +04:00
2011-06-04 07:59:19 +04:00
if ( ! cmd - > se_lun ) {
dump_stack ( ) ;
2011-06-08 21:36:43 +04:00
pr_err ( " cmd->se_lun is NULL \n " ) ;
2011-06-04 07:59:19 +04:00
return - EINVAL ;
}
if ( in_interrupt ( ) ) {
dump_stack ( ) ;
2011-06-08 21:36:43 +04:00
pr_err ( " transport_generic_handle_cdb cannot be called "
2011-06-04 07:59:19 +04:00
" from interrupt context \n " ) ;
return - EINVAL ;
}
2011-07-30 16:03:58 +04:00
/*
2012-07-08 23: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 16:03:58 +04: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 23:13:47 +04:00
cmd - > transport_state | = CMD_T_ACTIVE ;
2011-07-30 16:03:58 +04: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-07 00:24:09 +04:00
if ( ret )
transport_generic_request_failure ( cmd , ret ) ;
2011-07-30 16:03:58 +04:00
return 0 ;
2011-06-04 07:59:19 +04:00
}
EXPORT_SYMBOL ( transport_handle_cdb_direct ) ;
2013-08-22 22:58:43 +04:00
sense_reason_t
2012-11-07 00:24:09 +04: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-07 00:24:09 +04:00
cmd - > se_cmd_flags | = SCF_PASSTHROUGH_SG_TO_MEM_NOALLOC ;
return 0 ;
}
2018-04-14 20:51:04 +03:00
/**
2012-10-02 04:23:22 +04:00
* target_submit_cmd_map_sgls - lookup unpacked lun and submit uninitialized
* se_cmd + use pre - allocated SGL memory .
2011-11-19 08:36:22 +04: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
2018-04-14 20:51:04 +03:00
* @ task_attr : SAM task attribute
2011-11-19 08:36:22 +04:00
* @ data_dir : DMA data direction
* @ flags : flags for command submission from target_sc_flags_tables
2012-10-02 04:23:22 +04:00
* @ 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
2013-12-24 00:38:30 +04:00
* @ sgl_prot : struct scatterlist memory protection information
* @ sgl_prot_count : scatterlist count for protection information
2011-11-19 08:36:22 +04:00
*
2015-04-14 14:26:44 +03:00
* Task tags are supported if the caller has set @ se_cmd - > tag .
*
2012-07-16 22:04:39 +04:00
* Returns non zero to signal active I / O shutdown failure . All other
* setup exceptions will be returned as a SCSI CHECK_CONDITION response ,
* but still return zero here .
*
2011-11-19 08:36:22 +04:00
* This may only be called from process context , and also currently
* assumes internal allocation of fabric payload buffer by target - core .
2012-10-02 04:23:22 +04:00
*/
int target_submit_cmd_map_sgls ( struct se_cmd * se_cmd , struct se_session * se_sess ,
2015-06-10 09:41:22 +03:00
unsigned char * cdb , unsigned char * sense , u64 unpacked_lun ,
2012-10-02 04:23:22 +04:00
u32 data_length , int task_attr , int data_dir , int flags ,
struct scatterlist * sgl , u32 sgl_count ,
2013-12-24 00:38:30 +04:00
struct scatterlist * sgl_bidi , u32 sgl_bidi_count ,
struct scatterlist * sgl_prot , u32 sgl_prot_count )
2011-11-19 08:36:22 +04:00
{
struct se_portal_group * se_tpg ;
2012-11-07 00:24:09 +04:00
sense_reason_t rc ;
int ret ;
2011-11-19 08:36:22 +04:00
se_tpg = se_sess - > se_tpg ;
BUG_ON ( ! se_tpg ) ;
BUG_ON ( se_cmd - > se_tfo | | se_cmd - > se_sess ) ;
BUG_ON ( in_interrupt ( ) ) ;
/*
* Initialize se_cmd for target operation . From this point
* exceptions are handled by sending exception status via
* target_core_fabric_ops - > queue_status ( ) callback
*/
transport_init_se_cmd ( se_cmd , se_tpg - > se_tpg_tfo , se_sess ,
data_length , data_dir , task_attr , sense ) ;
2016-02-11 02:59:13 +03:00
if ( flags & TARGET_SCF_USE_CPUID )
se_cmd - > se_cmd_flags | = SCF_USE_CPUID ;
else
se_cmd - > cpuid = WORK_CPU_UNBOUND ;
2012-01-10 17:16:59 +04:00
if ( flags & TARGET_SCF_UNKNOWN_SIZE )
se_cmd - > unknown_data_length = 1 ;
2011-11-19 08:36:22 +04:00
/*
* Obtain struct se_cmd - > cmd_kref reference and add new cmd to
* se_sess - > sess_cmd_list . A second kref_get here is necessary
* for fabrics using TARGET_SCF_ACK_KREF that expect a second
* kref_put ( ) to happen during fabric packet acknowledgement .
*/
2015-04-27 14:52:36 +03:00
ret = target_get_sess_cmd ( se_cmd , flags & TARGET_SCF_ACK_KREF ) ;
2012-11-07 00:24:09 +04:00
if ( ret )
return ret ;
2011-11-19 08:36:22 +04:00
/*
* Signal bidirectional data payloads to target - core
*/
if ( flags & TARGET_SCF_BIDI_OP )
se_cmd - > se_cmd_flags | = SCF_BIDI ;
/*
* Locate se_lun pointer and attach it to struct se_cmd
*/
2012-11-07 00:24:09 +04:00
rc = transport_lookup_cmd_lun ( se_cmd , unpacked_lun ) ;
if ( rc ) {
transport_send_check_condition_and_sense ( se_cmd , rc , 0 ) ;
2015-04-27 14:52:36 +03:00
target_put_sess_cmd ( se_cmd ) ;
2012-07-16 22:04:39 +04:00
return 0 ;
2012-01-21 07:02:56 +04:00
}
2014-02-19 19:50:17 +04:00
rc = target_setup_cmd_from_cdb ( se_cmd , cdb ) ;
if ( rc ! = 0 ) {
transport_generic_request_failure ( se_cmd , rc ) ;
return 0 ;
}
2013-12-24 00:38:30 +04: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 09:23:49 +03:00
se_cmd - > se_cmd_flags | = SCF_PASSTHROUGH_PROT_SG_TO_MEM_NOALLOC ;
2013-12-24 00:38:30 +04:00
}
2012-05-20 19:59:14 +04:00
2012-10-02 04:23:22 +04: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 ) ;
2012-10-03 01:00:33 +04: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 ) {
unsigned char * buf = NULL ;
if ( sgl )
buf = kmap ( sg_page ( sgl ) ) + sgl - > offset ;
if ( buf ) {
memset ( buf , 0 , sgl - > length ) ;
kunmap ( sg_page ( sgl ) ) ;
}
}
2012-10-02 04:23:22 +04:00
rc = transport_generic_map_mem_to_cmd ( se_cmd , sgl , sgl_count ,
sgl_bidi , sgl_bidi_count ) ;
if ( rc ! = 0 ) {
2012-11-07 00:24:09 +04:00
transport_generic_request_failure ( se_cmd , rc ) ;
2012-10-02 04:23:22 +04:00
return 0 ;
}
}
2013-12-24 00:38:30 +04:00
2012-04-04 02:51:28 +04: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-19 08:36:22 +04:00
transport_handle_cdb_direct ( se_cmd ) ;
2012-07-16 22:04:39 +04:00
return 0 ;
2011-11-19 08:36:22 +04:00
}
2012-10-02 04:23:22 +04:00
EXPORT_SYMBOL ( target_submit_cmd_map_sgls ) ;
2018-04-14 20:51:04 +03:00
/**
2012-10-02 04:23:22 +04:00
* target_submit_cmd - lookup unpacked lun and submit uninitialized se_cmd
*
* @ 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
2018-04-14 20:51:04 +03:00
* @ task_attr : SAM task attribute
2012-10-02 04:23:22 +04:00
* @ data_dir : DMA data direction
* @ flags : flags for command submission from target_sc_flags_tables
*
2015-04-14 14:26:44 +03:00
* Task tags are supported if the caller has set @ se_cmd - > tag .
*
2012-10-02 04:23:22 +04:00
* Returns non zero to signal active I / O shutdown failure . All other
* setup exceptions will be returned as a SCSI CHECK_CONDITION response ,
* but still return zero here .
*
* This may only be called from process context , and also currently
* assumes internal allocation of fabric payload buffer by target - core .
*
* It also assumes interal target core SGL memory allocation .
*/
int target_submit_cmd ( struct se_cmd * se_cmd , struct se_session * se_sess ,
2015-06-10 09:41:22 +03:00
unsigned char * cdb , unsigned char * sense , u64 unpacked_lun ,
2012-10-02 04:23:22 +04:00
u32 data_length , int task_attr , int data_dir , int flags )
{
return target_submit_cmd_map_sgls ( se_cmd , se_sess , cdb , sense ,
unpacked_lun , data_length , task_attr , data_dir ,
2013-12-24 00:38:30 +04:00
flags , NULL , 0 , NULL , 0 , NULL , 0 ) ;
2012-10-02 04:23:22 +04:00
}
2011-11-19 08:36:22 +04:00
EXPORT_SYMBOL ( target_submit_cmd ) ;
2012-02-25 17:02:48 +04: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-03 00:47:59 +04:00
transport_cmd_check_stop_to_fabric ( se_cmd ) ;
2012-02-25 17:02:48 +04:00
}
2017-06-03 16:55:50 +03:00
static bool target_lookup_lun_from_tag ( struct se_session * se_sess , u64 tag ,
u64 * unpacked_lun )
{
struct se_cmd * se_cmd ;
unsigned long flags ;
bool ret = false ;
spin_lock_irqsave ( & se_sess - > sess_cmd_lock , flags ) ;
list_for_each_entry ( se_cmd , & se_sess - > sess_cmd_list , se_cmd_list ) {
if ( se_cmd - > se_cmd_flags & SCF_SCSI_TMR_CDB )
continue ;
if ( se_cmd - > tag = = tag ) {
* unpacked_lun = se_cmd - > orig_fe_lun ;
ret = true ;
break ;
}
}
spin_unlock_irqrestore ( & se_sess - > sess_cmd_lock , flags ) ;
return ret ;
}
2012-01-20 01:39:21 +04: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 20:51:03 +03:00
* @ fabric_tmr_ptr : fabric context for TMR req
2012-01-20 01:39:21 +04:00
* @ tm_type : Type of TM request
2012-02-25 17:10:04 +04:00
* @ gfp : gfp type for caller
* @ tag : referenced task tag for TMR_ABORT_TASK
2012-02-25 13:40:24 +04:00
* @ flags : submit cmd flags
2012-01-20 01:39:21 +04:00
*
* Callable from all contexts .
* */
2012-02-25 13:40:24 +04:00
int target_submit_tmr ( struct se_cmd * se_cmd , struct se_session * se_sess ,
2015-06-10 09:41:22 +03:00
unsigned char * sense , u64 unpacked_lun ,
2012-02-25 17:10:04 +04:00
void * fabric_tmr_ptr , unsigned char tm_type ,
2016-01-05 16:46:39 +03:00
gfp_t gfp , u64 tag , int flags )
2012-01-20 01:39:21 +04:00
{
struct se_portal_group * se_tpg ;
int ret ;
se_tpg = se_sess - > se_tpg ;
BUG_ON ( ! se_tpg ) ;
transport_init_se_cmd ( se_cmd , se_tpg - > se_tpg_tfo , se_sess ,
2014-11-24 18:07:25 +03:00
0 , DMA_NONE , TCM_SIMPLE_TAG , sense ) ;
2012-02-25 13:40:24 +04:00
/*
* FIXME : Currently expect caller to handle se_cmd - > se_tmr_req
* allocation failure .
*/
2012-02-25 17:10:04 +04:00
ret = core_tmr_alloc_req ( se_cmd , fabric_tmr_ptr , tm_type , gfp ) ;
2012-02-25 13:40:24 +04:00
if ( ret < 0 )
return - ENOMEM ;
2012-01-20 01:39:21 +04:00
2012-02-25 17:10:04 +04:00
if ( tm_type = = TMR_ABORT_TASK )
se_cmd - > se_tmr_req - > ref_task_tag = tag ;
2012-01-20 01:39:21 +04:00
/* See target_submit_cmd for commentary */
2015-04-27 14:52:36 +03: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 22:04:40 +04:00
if ( ret ) {
core_tmr_release_req ( se_cmd - > se_tmr_req ) ;
return ret ;
}
2017-06-03 16:55:50 +03:00
/*
* If this is ABORT_TASK with no explicit fabric provided LUN ,
* go ahead and search active session tags for a match to figure
* out unpacked_lun for the original se_cmd .
*/
if ( tm_type = = TMR_ABORT_TASK & & ( flags & TARGET_SCF_LOOKUP_LUN_FROM_TAG ) ) {
if ( ! target_lookup_lun_from_tag ( se_sess , tag , & unpacked_lun ) )
goto failure ;
}
2012-01-20 01:39:21 +04:00
ret = transport_lookup_tmr_lun ( se_cmd , unpacked_lun ) ;
2017-06-03 16:55:50 +03:00
if ( ret )
goto failure ;
2012-01-20 01:39:21 +04:00
transport_generic_handle_tmr ( se_cmd ) ;
2012-02-25 13:40:24 +04:00
return 0 ;
2017-06-03 16:55:50 +03: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-20 01:39:21 +04: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 22:11:26 +03:00
/*
* Handle SAM - esque emulation for generic transport request failures .
*/
2012-11-07 00:24:09 +04: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 22:11:26 +03:00
{
2018-11-06 03:44:59 +03:00
int ret = 0 , post_ret ;
2011-06-14 01:46:09 +04:00
2017-05-24 02:48:28 +03: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 22:11:26 +03:00
/*
* For SAM Task Attribute emulation for failed struct se_cmd
*/
2012-10-11 01:37:14 +04:00
transport_complete_task_attr ( cmd ) ;
2017-09-30 02:03:24 +03:00
2018-10-15 18:51:39 +03:00
if ( cmd - > transport_complete_callback )
2018-11-06 03:44:59 +03: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 22:11:26 +03:00
2018-11-28 02:52:03 +03:00
if ( cmd - > transport_state & CMD_T_ABORTED ) {
INIT_WORK ( & cmd - > work , target_abort_work ) ;
queue_work ( target_completion_wq , & cmd - > work ) ;
2017-09-30 02:03:24 +03:00
return ;
2018-11-28 02:52:03 +03:00
}
2017-09-30 02:03:24 +03:00
2012-11-07 00:24:09 +04:00
switch ( sense_reason ) {
2011-11-04 13:36:16 +04:00
case TCM_NON_EXISTENT_LUN :
case TCM_UNSUPPORTED_SCSI_OPCODE :
case TCM_INVALID_CDB_FIELD :
case TCM_INVALID_PARAMETER_LIST :
2013-02-09 03:18:39 +04:00
case TCM_PARAMETER_LIST_LENGTH_ERROR :
2011-11-04 13:36:16 +04:00
case TCM_LOGICAL_UNIT_COMMUNICATION_FAILURE :
case TCM_UNKNOWN_MODE_PAGE :
case TCM_WRITE_PROTECTED :
2012-07-17 02:34:21 +04:00
case TCM_ADDRESS_OUT_OF_RANGE :
2011-11-04 13:36:16 +04:00
case TCM_CHECK_CONDITION_ABORT_CMD :
case TCM_CHECK_CONDITION_UNIT_ATTENTION :
case TCM_CHECK_CONDITION_NOT_READY :
2014-02-23 18:04:09 +04: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-09 03:26:44 +03:00
case TCM_COPY_TARGET_DEVICE_NOT_REACHABLE :
2016-12-23 13:37:53 +03: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 :
[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 22:11:26 +03:00
break ;
2012-11-07 00:24:09 +04:00
case TCM_OUT_OF_RESOURCES :
2017-10-25 19:47:14 +03:00
cmd - > scsi_status = SAM_STAT_TASK_SET_FULL ;
goto queue_status ;
2017-12-19 13:03:55 +03:00
case TCM_LUN_BUSY :
cmd - > scsi_status = SAM_STAT_BUSY ;
goto queue_status ;
2011-11-04 13:36:16 +04: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 22:11:26 +03: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 12:55:10 +04:00
if ( cmd - > se_sess & &
2015-06-11 11:01:26 +03:00
cmd - > se_dev - > dev_attrib . emulate_ua_intlck_ctrl = = 2 ) {
target_ua_allocate_lun ( cmd - > se_sess - > se_node_acl ,
cmd - > orig_fe_lun , 0x2C ,
ASCQ_2CH_PREVIOUS_RESERVATION_CONFLICT_STATUS ) ;
}
2017-10-25 19:47:14 +03: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 22:11:26 +03:00
default :
2011-06-08 21:36:43 +04:00
pr_err ( " Unknown transport error for CDB 0x%02x: %d \n " ,
2012-11-07 00:24:09 +04: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 22:11:26 +03:00
break ;
}
2012-07-08 23:58:48 +04:00
2012-11-07 00:24:09 +04:00
ret = transport_send_check_condition_and_sense ( cmd , sense_reason , 0 ) ;
2016-10-31 03:28:16 +03:00
if ( ret )
2011-11-04 13:36:16 +04:00
goto queue_full ;
2011-06-14 01:46:09 +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 22:11:26 +03:00
check_stop :
2015-09-04 02:03:43 +03:00
transport_cmd_check_stop_to_fabric ( cmd ) ;
2011-06-14 01:46:09 +04:00
return ;
2017-10-25 19:47:14 +03:00
queue_status :
trace_target_cmd_complete ( cmd ) ;
ret = cmd - > se_tfo - > queue_status ( cmd ) ;
if ( ! ret )
goto check_stop ;
2011-06-14 01:46:09 +04:00
queue_full :
2016-10-31 03:28:16 +03: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 22:11:26 +03:00
}
2012-02-11 04:18:11 +04: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 22:11:26 +03:00
2016-05-18 08:19:10 +03: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 22:11:26 +03:00
{
2012-11-07 00:24:09 +04:00
sense_reason_t ret ;
2012-05-20 22:34:44 +04:00
2016-05-18 08:19:10 +03: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 22:34:44 +04:00
2016-05-18 08:19:10 +03:00
ret = target_check_reservation ( cmd ) ;
if ( ret ) {
cmd - > scsi_status = SAM_STAT_RESERVATION_CONFLICT ;
goto err ;
2012-11-07 00:24:09 +04:00
}
2012-05-20 22:34:44 +04:00
}
2016-05-18 08:19:10 +03:00
ret = cmd - > execute_cmd ( cmd ) ;
if ( ! ret )
return ;
err :
spin_lock_irq ( & cmd - > t_state_lock ) ;
2017-01-03 12:44:11 +03:00
cmd - > transport_state & = ~ CMD_T_SENT ;
2016-05-18 08:19:10 +03:00
spin_unlock_irq ( & cmd - > t_state_lock ) ;
transport_generic_request_failure ( cmd , ret ) ;
2012-05-20 22:34:44 +04:00
}
2015-02-08 23:39:06 +03:00
static int target_write_prot_action ( struct se_cmd * cmd )
{
2015-02-08 14:06:17 +03:00
u32 sectors ;
2015-02-08 23:39:06 +03: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 14:06:17 +03: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 14:06:17 +03:00
if ( unlikely ( cmd - > pi_err ) ) {
spin_lock_irq ( & cmd - > t_state_lock ) ;
2017-01-03 12:44:11 +03:00
cmd - > transport_state & = ~ CMD_T_SENT ;
2015-02-08 14:06:17 +03:00
spin_unlock_irq ( & cmd - > t_state_lock ) ;
transport_generic_request_failure ( cmd , cmd - > pi_err ) ;
return - 1 ;
}
break ;
2015-02-08 23:39:06 +03:00
default :
break ;
}
return 0 ;
}
2012-10-11 01:37:14 +04:00
static bool target_handle_task_attr ( struct se_cmd * cmd )
2012-05-20 22:34:44 +04:00
{
struct se_device * dev = cmd - > se_dev ;
2015-05-20 00:44:41 +03:00
if ( dev - > transport - > transport_flags & TRANSPORT_FLAG_PASSTHROUGH )
2012-10-11 01:37:14 +04:00
return false ;
2012-05-20 22:34:44 +04:00
2016-06-14 08:58:09 +03: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 22:11:26 +03:00
/*
2011-03-31 05:57:33 +04: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 22:11:26 +03:00
* to allow the passed struct se_cmd list of tasks to the front of the list .
*/
2012-05-20 22:34:44 +04:00
switch ( cmd - > sam_task_attr ) {
2014-11-24 18:07:25 +03:00
case TCM_HEAD_TAG :
2015-07-22 03:45:32 +03:00
pr_debug ( " Added HEAD_OF_QUEUE for CDB: 0x%02x \n " ,
cmd - > t_task_cdb [ 0 ] ) ;
2012-10-11 01:37:14 +04:00
return false ;
2014-11-24 18:07:25 +03:00
case TCM_ORDERED_TAG :
2014-09-17 00:23:12 +04:00
atomic_inc_mb ( & dev - > dev_ordered_sync ) ;
[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 22:11:26 +03:00
2015-07-22 03:45:32 +03:00
pr_debug ( " Added ORDERED for CDB: 0x%02x to ordered list \n " ,
cmd - > t_task_cdb [ 0 ] ) ;
2012-05-20 22: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 22:11:26 +03:00
/*
2012-05-20 22:34:44 +04:00
* Execute an ORDERED command if no other older commands
* exist that need to be completed first .
[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 22:11:26 +03:00
*/
2012-05-20 22:34:44 +04:00
if ( ! atomic_read ( & dev - > simple_cmds ) )
2012-10-11 01:37:14 +04:00
return false ;
2012-05-20 22: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 22:11:26 +03:00
/*
* For SIMPLE and UNTAGGED Task Attribute commands
*/
2014-09-17 00:23:12 +04:00
atomic_inc_mb ( & dev - > simple_cmds ) ;
2012-05-20 22: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 22:11:26 +03:00
}
2012-05-20 22:34:44 +04:00
2012-10-11 01:37:14 +04:00
if ( atomic_read ( & dev - > dev_ordered_sync ) = = 0 )
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 22:11:26 +03:00
2012-10-11 01: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-22 03:45:32 +03:00
pr_debug ( " Added CDB: 0x%02x Task Attr: 0x%02x to delayed CMD listn " ,
cmd - > t_task_cdb [ 0 ] , cmd - > sam_task_attr ) ;
2012-10-11 01: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-06 01:51:36 +03:00
*
2018-10-15 18:51:34 +03:00
* If the received CDB has already been aborted stop processing it here .
2012-10-11 01:37:14 +04:00
*/
2018-11-28 02:52:03 +03:00
if ( target_cmd_interrupted ( cmd ) )
2012-10-11 01:37:14 +04:00
return ;
2018-11-28 02:52:03 +03:00
spin_lock_irq ( & cmd - > t_state_lock ) ;
2012-10-11 01:37:14 +04:00
cmd - > t_state = TRANSPORT_PROCESSING ;
2017-01-03 12:44:11 +03:00
cmd - > transport_state | = CMD_T_ACTIVE | CMD_T_SENT ;
2012-10-11 01:37:14 +04:00
spin_unlock_irq ( & cmd - > t_state_lock ) ;
2015-02-08 23:39:06 +03:00
if ( target_write_prot_action ( cmd ) )
return ;
2012-10-11 01:37:14 +04:00
2013-06-06 12:40:27 +04:00
if ( target_handle_task_attr ( cmd ) ) {
spin_lock_irq ( & cmd - > t_state_lock ) ;
2017-01-03 12:44:11 +03:00
cmd - > transport_state & = ~ CMD_T_SENT ;
2013-06-06 12:40:27 +04:00
spin_unlock_irq ( & cmd - > t_state_lock ) ;
return ;
}
2016-05-18 08:19:10 +03: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 22:11:26 +03:00
}
2012-07-08 23: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 22:11:26 +03:00
2012-05-20 22:34:44 +04:00
/*
* Process all commands up to the last received ORDERED task attribute which
* requires another blocking boundary
*/
static void target_restart_delayed_cmds ( struct se_device * dev )
{
for ( ; ; ) {
struct se_cmd * cmd ;
spin_lock ( & dev - > delayed_cmd_lock ) ;
if ( list_empty ( & dev - > delayed_cmd_list ) ) {
spin_unlock ( & dev - > delayed_cmd_lock ) ;
break ;
}
cmd = list_entry ( dev - > delayed_cmd_list . next ,
struct se_cmd , se_delayed_node ) ;
list_del ( & cmd - > se_delayed_node ) ;
spin_unlock ( & dev - > delayed_cmd_lock ) ;
2017-09-23 02:48:28 +03:00
cmd - > transport_state | = CMD_T_SENT ;
2016-05-18 08:19:10 +03:00
__target_execute_cmd ( cmd , true ) ;
2012-05-20 22:34:44 +04:00
2014-11-24 18:07:25 +03:00
if ( cmd - > sam_task_attr = = TCM_ORDERED_TAG )
2012-05-20 22: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 22:11:26 +03:00
/*
2011-10-17 21: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 22:11:26 +03: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 14:26:37 +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 22:11:26 +03:00
2015-05-20 00:44:41 +03:00
if ( dev - > transport - > transport_flags & TRANSPORT_FLAG_PASSTHROUGH )
2012-10-11 01:37:14 +04:00
return ;
2016-06-14 08:58:09 +03:00
if ( ! ( cmd - > se_cmd_flags & SCF_TASK_ATTR_SET ) )
goto restart ;
2014-11-24 18:07:25 +03:00
if ( cmd - > sam_task_attr = = TCM_SIMPLE_TAG ) {
2014-09-17 00:23:12 +04:00
atomic_dec_mb ( & dev - > simple_cmds ) ;
[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 22:11:26 +03:00
dev - > dev_cur_ordered_id + + ;
2014-11-24 18:07:25 +03:00
} else if ( cmd - > sam_task_attr = = TCM_HEAD_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 22:11:26 +03:00
dev - > dev_cur_ordered_id + + ;
2015-07-22 03:45:32 +03:00
pr_debug ( " Incremented dev_cur_ordered_id: %u for HEAD_OF_QUEUE \n " ,
dev - > dev_cur_ordered_id ) ;
2014-11-24 18:07:25 +03:00
} else if ( cmd - > sam_task_attr = = TCM_ORDERED_TAG ) {
2014-09-17 00:23:12 +04:00
atomic_dec_mb ( & dev - > dev_ordered_sync ) ;
[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 22:11:26 +03:00
dev - > dev_cur_ordered_id + + ;
2015-07-22 03:45:32 +03: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 22:11:26 +03:00
}
2017-09-23 02:48:28 +03:00
cmd - > se_cmd_flags & = ~ SCF_TASK_ATTR_SET ;
2016-06-14 08:58:09 +03:00
restart :
2012-05-20 22:34:44 +04:00
target_restart_delayed_cmds ( 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 22:11:26 +03:00
}
2011-10-17 21:56:41 +04:00
static void transport_complete_qf ( struct se_cmd * cmd )
2011-06-14 01:46:09 +04:00
{
int ret = 0 ;
2012-10-11 01:37:14 +04:00
transport_complete_task_attr ( cmd ) ;
2016-10-31 03:28:16 +03: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 21:56:41 +04:00
2016-10-31 03:28:16 +03:00
translate_sense_reason ( cmd , TCM_LOGICAL_UNIT_COMMUNICATION_FAILURE ) ;
goto queue_status ;
2011-10-17 21:56:41 +04:00
}
2011-06-14 01:46:09 +04:00
2018-05-16 04:25:24 +03: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-31 03:28:16 +03:00
goto queue_status ;
2011-06-14 01:46:09 +04:00
switch ( cmd - > data_direction ) {
case DMA_FROM_DEVICE :
2018-05-16 04:25:24 +03: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-05 09:30:52 +03:00
goto queue_status ;
2013-06-27 04:36:17 +04:00
trace_target_cmd_complete ( cmd ) ;
2011-06-14 01:46:09 +04:00
ret = cmd - > se_tfo - > queue_data_in ( cmd ) ;
break ;
case DMA_TO_DEVICE :
2013-08-22 01:39:19 +04:00
if ( cmd - > se_cmd_flags & SCF_BIDI ) {
2011-06-14 01:46:09 +04:00
ret = cmd - > se_tfo - > queue_data_in ( cmd ) ;
2015-05-13 10:17:54 +03:00
break ;
2011-06-14 01:46:09 +04:00
}
2017-10-31 21:03:10 +03:00
/* fall through */
2011-06-14 01:46:09 +04:00
case DMA_NONE :
2016-03-05 09:30:52 +03:00
queue_status :
2013-06-27 04:36:17 +04:00
trace_target_cmd_complete ( cmd ) ;
2011-06-14 01:46:09 +04:00
ret = cmd - > se_tfo - > queue_status ( cmd ) ;
break ;
default :
break ;
}
2011-10-17 21:56:41 +04:00
if ( ret < 0 ) {
2016-10-31 03:28:16 +03:00
transport_handle_queue_full ( cmd , cmd - > se_dev , ret , false ) ;
2011-10-17 21:56:41 +04:00
return ;
}
transport_cmd_check_stop_to_fabric ( cmd ) ;
2011-06-14 01:46:09 +04:00
}
2016-10-31 03:28:16 +03:00
static void transport_handle_queue_full ( struct se_cmd * cmd , struct se_device * dev ,
int err , bool write_pending )
2011-06-14 01:46:09 +04:00
{
2016-10-31 03:28:16 +03: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-14 01:46:09 +04:00
spin_lock_irq ( & dev - > qf_cmd_lock ) ;
list_add_tail ( & cmd - > se_qf_node , & cmd - > se_dev - > qf_cmd_list ) ;
2014-09-17 00:23:12 +04:00
atomic_inc_mb ( & dev - > dev_qf_count ) ;
2011-06-14 01:46:09 +04:00
spin_unlock_irq ( & cmd - > se_dev - > qf_cmd_lock ) ;
schedule_work ( & cmd - > se_dev - > qf_work_queue ) ;
}
2015-02-08 13:53:25 +03:00
static bool target_read_prot_action ( struct se_cmd * cmd )
2014-04-03 01:55:33 +04:00
{
2015-02-08 13:53:25 +03: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 13:53:25 +03:00
return true ;
2014-04-03 01:55:33 +04:00
}
2015-02-08 13:53:25 +03:00
break ;
2015-02-08 15:02:08 +03: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 13:53:25 +03:00
default :
break ;
2014-04-03 01:55:33 +04:00
}
return false ;
}
2011-10-17 21: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 22:11:26 +03:00
{
2011-10-17 21:56:53 +04:00
struct se_cmd * cmd = container_of ( work , struct se_cmd , work ) ;
2012-09-05 19:09:14 +04:00
int ret ;
2011-10-17 21: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 22:11:26 +03: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-11 01:37:14 +04:00
transport_complete_task_attr ( cmd ) ;
2011-06-14 01:46:09 +04: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 22:11:26 +03:00
/*
2012-09-05 19:09:15 +04:00
* Check if we need to send a sense buffer from
2018-05-16 04:25:24 +03: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 22:11:26 +03:00
*/
2018-05-16 04:25:24 +03:00
if ( ! ( cmd - > se_cmd_flags & SCF_TREAT_READ_AS_NORMAL ) & &
cmd - > se_cmd_flags & SCF_TRANSPORT_TASK_SENSE ) {
2012-09-05 19:09:14 +04:00
WARN_ON ( ! cmd - > scsi_status ) ;
ret = transport_send_check_condition_and_sense (
cmd , 0 , 1 ) ;
2016-10-31 03:28:16 +03:00
if ( ret )
2012-09-05 19:09:14 +04:00
goto queue_full ;
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 22:11:26 +03:00
}
/*
2011-03-31 05:57:33 +04:00
* Check for a callback , used by amongst other things
2013-08-20 01:34:17 +04: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 22:11:26 +03:00
*/
2013-08-20 01:34:17 +04:00
if ( cmd - > transport_complete_callback ) {
sense_reason_t rc ;
2015-11-06 10:37:59 +03:00
bool caw = ( cmd - > se_cmd_flags & SCF_COMPARE_AND_WRITE ) ;
bool zero_dl = ! ( cmd - > data_length ) ;
int post_ret = 0 ;
2013-08-20 01:34:17 +04:00
2015-11-06 10:37:59 +03:00
rc = cmd - > transport_complete_callback ( cmd , true , & post_ret ) ;
if ( ! rc & & ! post_ret ) {
if ( caw & & zero_dl )
2015-04-08 00:53:27 +03:00
goto queue_rsp ;
2013-08-20 01:34:17 +04:00
return ;
2013-08-22 05:10:04 +04:00
} else if ( rc ) {
ret = transport_send_check_condition_and_sense ( cmd ,
rc , 0 ) ;
2016-10-31 03:28:16 +03:00
if ( ret )
2013-08-22 05:10:04 +04:00
goto queue_full ;
2013-08-20 01:34:17 +04:00
2013-08-22 05:10:04 +04:00
transport_cmd_check_stop_to_fabric ( cmd ) ;
return ;
}
2013-08-20 01:34:17 +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 22:11:26 +03:00
2015-04-08 00:53:27 +03: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 22:11:26 +03:00
switch ( cmd - > data_direction ) {
case DMA_FROM_DEVICE :
2018-05-16 04:25:24 +03: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-05 09:30:52 +03:00
goto queue_status ;
2015-05-19 10:03:07 +03:00
atomic_long_add ( cmd - > data_length ,
& cmd - > se_lun - > lun_stats . tx_data_octets ) ;
2014-04-03 01:55:33 +04: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 13:53:25 +03:00
if ( target_read_prot_action ( cmd ) ) {
2014-04-03 01:55:33 +04:00
ret = transport_send_check_condition_and_sense ( cmd ,
cmd - > pi_err , 0 ) ;
2016-10-31 03:28:16 +03:00
if ( ret )
2014-04-03 01:55:33 +04:00
goto queue_full ;
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 22:11:26 +03:00
2013-06-27 04:36:17 +04:00
trace_target_cmd_complete ( cmd ) ;
2011-06-14 01:46:09 +04:00
ret = cmd - > se_tfo - > queue_data_in ( cmd ) ;
2016-10-31 03:28:16 +03:00
if ( ret )
2011-06-14 01:46:09 +04: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 22:11:26 +03:00
break ;
case DMA_TO_DEVICE :
2015-05-19 10:03:07 +03: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 22:11:26 +03:00
/*
* Check if we need to send READ payload for BIDI - COMMAND
*/
2013-08-22 01:39:19 +04:00
if ( cmd - > se_cmd_flags & SCF_BIDI ) {
2015-05-19 10:03:07 +03:00
atomic_long_add ( cmd - > data_length ,
& cmd - > se_lun - > lun_stats . tx_data_octets ) ;
2011-06-14 01:46:09 +04:00
ret = cmd - > se_tfo - > queue_data_in ( cmd ) ;
2016-10-31 03:28:16 +03:00
if ( ret )
2011-06-14 01:46:09 +04: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 22:11:26 +03:00
break ;
}
2017-10-31 21:03:10 +03:00
/* fall through */
[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 22:11:26 +03:00
case DMA_NONE :
2016-03-05 09:30:52 +03:00
queue_status :
2013-06-27 04:36:17 +04:00
trace_target_cmd_complete ( cmd ) ;
2011-06-14 01:46:09 +04:00
ret = cmd - > se_tfo - > queue_status ( cmd ) ;
2016-10-31 03:28:16 +03:00
if ( ret )
2011-06-14 01:46:09 +04: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 22:11:26 +03:00
break ;
default :
break ;
}
transport_cmd_check_stop_to_fabric ( cmd ) ;
2011-06-14 01:46:09 +04:00
return ;
queue_full :
2011-06-08 21:36:43 +04:00
pr_debug ( " Handling complete_ok QUEUE_FULL: se_cmd: %p, "
2011-06-14 01:46:09 +04:00
" data_direction: %d \n " , cmd , cmd - > data_direction ) ;
2016-10-31 03:28:16 +03: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 22:11:26 +03:00
}
2016-05-03 19:01:10 +03: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 22:11:26 +03:00
{
2018-01-19 22:00:54 +03:00
sgl_free_n_order ( sgl , nents , 0 ) ;
2011-06-08 21:36:43 +04:00
}
2016-05-03 19:01:10 +03: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 22:11:26 +03:00
2013-08-20 21:45:16 +04: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 21:36:43 +04:00
static inline void transport_free_pages ( struct se_cmd * cmd )
{
2015-05-01 09:23:49 +03:00
if ( ! ( cmd - > se_cmd_flags & SCF_PASSTHROUGH_PROT_SG_TO_MEM_NOALLOC ) ) {
2016-05-03 19:01:10 +03:00
target_free_sgl ( cmd - > t_prot_sg , cmd - > t_prot_nents ) ;
2015-05-01 09:23:49 +03:00
cmd - > t_prot_sg = NULL ;
cmd - > t_prot_nents = 0 ;
}
2013-08-20 21:45:16 +04:00
if ( cmd - > se_cmd_flags & SCF_PASSTHROUGH_SG_TO_MEM_NOALLOC ) {
2015-04-08 00:53:27 +03: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 19:01:10 +03:00
target_free_sgl ( cmd - > t_bidi_data_sg ,
2015-04-08 00:53:27 +03:00
cmd - > t_bidi_data_nents ) ;
cmd - > t_bidi_data_sg = NULL ;
cmd - > t_bidi_data_nents = 0 ;
}
2013-08-20 21:45:16 +04:00
transport_reset_sgl_orig ( cmd ) ;
2011-06-08 21:36:43 +04:00
return ;
2013-08-20 21:45:16 +04:00
}
transport_reset_sgl_orig ( cmd ) ;
2011-06-08 21:36:43 +04:00
2016-05-03 19:01:10 +03:00
target_free_sgl ( cmd - > t_data_sg , cmd - > t_data_nents ) ;
2011-07-20 23:28:46 +04: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 22:11:26 +03:00
2016-05-03 19:01:10 +03:00
target_free_sgl ( cmd - > t_bidi_data_sg , cmd - > t_bidi_data_nents ) ;
2011-07-20 23:28:46 +04: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 22:11:26 +03:00
}
2012-01-17 04:57:08 +04:00
void * transport_kmap_data_sg ( struct se_cmd * cmd )
2011-07-20 23:13:28 +04:00
{
2011-07-20 23:28:46 +04:00
struct scatterlist * sg = cmd - > t_data_sg ;
2012-01-17 04:57:08 +04:00
struct page * * pages ;
int i ;
2011-07-20 23:13:28 +04:00
/*
2011-07-20 23:28:46 +04: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 23:13:28 +04:00
*/
2012-01-17 04:57:08 +04:00
if ( ! cmd - > t_data_nents )
return NULL ;
2012-09-07 19:30:35 +04:00
BUG_ON ( ! sg ) ;
if ( cmd - > t_data_nents = = 1 )
2012-01-17 04:57:08 +04:00
return kmap ( sg_page ( sg ) ) + sg - > offset ;
/* >1 page. use vmap */
2017-04-09 22:07:14 +03:00
pages = kmalloc_array ( cmd - > t_data_nents , sizeof ( * pages ) , GFP_KERNEL ) ;
2012-11-07 00:24:09 +04:00
if ( ! pages )
2012-01-17 04:57:08 +04: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-07 00:24:09 +04:00
if ( ! cmd - > t_data_vmap )
2012-01-17 04:57:08 +04:00
return NULL ;
return cmd - > t_data_vmap + cmd - > t_data_sg [ 0 ] . offset ;
2011-07-20 23:13:28 +04:00
}
2012-01-17 04:57:08 +04:00
EXPORT_SYMBOL ( transport_kmap_data_sg ) ;
2011-07-20 23:13:28 +04:00
2012-01-17 04:57:08 +04:00
void transport_kunmap_data_sg ( struct se_cmd * cmd )
2011-07-20 23:13:28 +04:00
{
2012-02-10 00:18:06 +04:00
if ( ! cmd - > t_data_nents ) {
2012-01-17 04:57:08 +04:00
return ;
2012-02-10 00:18:06 +04:00
} else if ( cmd - > t_data_nents = = 1 ) {
2012-01-17 04:57:08 +04:00
kunmap ( sg_page ( cmd - > t_data_sg ) ) ;
2012-02-10 00:18:06 +04:00
return ;
}
2012-01-17 04:57:08 +04:00
vunmap ( cmd - > t_data_vmap ) ;
cmd - > t_data_vmap = NULL ;
2011-07-20 23:13:28 +04:00
}
2012-01-17 04:57:08 +04:00
EXPORT_SYMBOL ( transport_kunmap_data_sg ) ;
2011-07-20 23:13:28 +04:00
2013-08-22 22:58:43 +04:00
int
2013-08-26 02:44:03 +04:00
target_alloc_sgl ( struct scatterlist * * sgl , unsigned int * nents , u32 length ,
2016-05-03 19:01:10 +03: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 22:11:26 +03:00
{
2018-01-05 19:26:50 +03: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 22:11:26 +03:00
2018-01-05 19:26:50 +03: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 22:11:26 +03:00
}
2016-05-03 19:01:10 +03: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 22:11:26 +03:00
2011-10-18 14:57:01 +04:00
/*
2012-04-04 02:51:21 +04: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 22:11:26 +03:00
*/
2012-11-07 00:24:09 +04: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 22:11:26 +03:00
{
2017-02-02 03:58:35 +03: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 22:11:26 +03:00
int ret = 0 ;
2015-04-08 00:53:27 +03: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 22:11:26 +03:00
2015-05-01 09:23:49 +03: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 19:01:10 +03:00
cmd - > prot_length , true , false ) ;
2015-05-01 09:23:49 +03: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 22:11:26 +03:00
/*
2018-10-15 18:51:34 +03: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 22:11:26 +03:00
* memory , and is directly calling transport_generic_map_mem_to_cmd ( )
2011-07-20 23:28:46 +04: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 22:11:26 +03:00
*/
2011-07-20 23:28:46 +04:00
if ( ! ( cmd - > se_cmd_flags & SCF_PASSTHROUGH_SG_TO_MEM_NOALLOC ) & &
cmd - > data_length ) {
2013-08-26 02:44:03 +04:00
2013-08-26 03:10:57 +04: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 19:01:10 +03:00
bidi_length , zero_flag , false ) ;
2013-08-26 03:10:57 +04:00
if ( ret < 0 )
return TCM_LOGICAL_UNIT_COMMUNICATION_FAILURE ;
}
2013-08-26 02:44:03 +04:00
ret = target_alloc_sgl ( & cmd - > t_data_sg , & cmd - > t_data_nents ,
2016-05-03 19:01:10 +03: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 22:11:26 +03:00
if ( ret < 0 )
2012-11-07 00:24:09 +04:00
return TCM_LOGICAL_UNIT_COMMUNICATION_FAILURE ;
2015-04-08 00:53:27 +03: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 19:01:10 +03:00
caw_length , zero_flag , false ) ;
2015-04-08 00:53:27 +03: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 22:11:26 +03:00
}
/*
2012-07-08 23: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 22:11:26 +03:00
*/
2012-05-20 22:34:44 +04:00
target_add_to_state_list ( cmd ) ;
2014-10-15 01:16:24 +04:00
if ( cmd - > data_direction ! = DMA_TO_DEVICE | | cmd - > data_length = = 0 ) {
2012-07-08 23:58:41 +04:00
target_execute_cmd ( cmd ) ;
return 0 ;
}
2017-02-02 03:58:35 +03: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-28 02:52:01 +03:00
if ( cmd - > transport_state & CMD_T_STOP & &
! cmd - > se_tfo - > write_pending_must_be_called ) {
2017-02-02 03:58:35 +03: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 21:14:54 +03:00
return 0 ;
2017-02-02 03:58:35 +03:00
}
cmd - > transport_state & = ~ CMD_T_ACTIVE ;
spin_unlock_irqrestore ( & cmd - > t_state_lock , flags ) ;
2012-07-08 23:58:41 +04:00
ret = cmd - > se_tfo - > write_pending ( cmd ) ;
2016-10-31 03:28:16 +03:00
if ( ret )
2012-07-08 23:58:41 +04:00
goto queue_full ;
2016-10-31 03:28:16 +03:00
return 0 ;
2011-10-18 14:57:01 +04:00
2012-07-08 23:58:41 +04:00
queue_full :
pr_debug ( " Handling write_pending QUEUE__FULL: se_cmd: %p \n " , cmd ) ;
2016-10-31 03:28:16 +03:00
transport_handle_queue_full ( cmd , cmd - > se_dev , ret , true ) ;
2012-07-08 23: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 22:11:26 +03:00
}
2011-05-03 04:12:10 +04: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 22:11:26 +03:00
2011-10-17 21:56:41 +04:00
static void transport_write_pending_qf ( struct se_cmd * cmd )
2011-06-14 01:46:09 +04:00
{
2017-09-30 02:43:11 +03:00
unsigned long flags ;
2011-10-26 10:57:41 +04:00
int ret ;
2017-09-30 02:43:11 +03: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-26 10:57:41 +04:00
ret = cmd - > se_tfo - > write_pending ( cmd ) ;
2016-10-31 03:28:16 +03:00
if ( ret ) {
2011-10-17 21:56:41 +04:00
pr_debug ( " Handling write_pending QUEUE__FULL: se_cmd: %p \n " ,
cmd ) ;
2016-10-31 03:28:16 +03:00
transport_handle_queue_full ( cmd , cmd - > se_dev , ret , true ) ;
2011-10-17 21:56:41 +04:00
}
2011-06-14 01:46:09 +04:00
}
2016-01-20 02:23:02 +03: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-28 02:52:03 +03: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-23 00:52:54 +03:00
/*
* This function is called by frontend drivers after processing of a command
* has finished .
*
2018-11-28 02:52:03 +03: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-23 00:52:54 +03:00
* - Calling . queue_data_in ( ) , . queue_status ( ) or queue_tm_rsp ( ) will cause
2018-11-28 02:52:03 +03:00
* the frontend driver to call this function synchronously or asynchronously .
* That will cause one reference to be dropped .
2018-06-23 00:52:54 +03: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-28 02:52:03 +03:00
* will be called . target_handle_abort ( ) will drop the final reference .
2018-06-23 00:52:54 +03:00
*/
2013-05-31 11:46:11 +04: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 22:11:26 +03:00
{
2018-06-23 00:52:59 +03:00
DECLARE_COMPLETION_ONSTACK ( compl ) ;
2013-05-31 11:46:11 +04:00
int ret = 0 ;
2016-01-20 02:23:02 +03:00
bool aborted = false , tas = false ;
2013-05-31 11:46:11 +04:00
2018-06-23 00:52:58 +03:00
if ( wait_for_tasks )
target_wait_free_cmd ( cmd , & aborted , & tas ) ;
if ( cmd - > se_cmd_flags & SCF_SE_LUN_CMD ) {
2013-09-01 02:12:01 +04: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-12 08:31:09 +03:00
if ( cmd - > state_active )
2013-09-01 02:12:01 +04:00
target_remove_from_state_list ( cmd ) ;
2016-01-20 02:23:02 +03:00
}
2018-06-23 00:52:59 +03:00
if ( aborted )
2018-11-28 02:52:00 +03:00
cmd - > free_compl = & compl ;
2018-11-28 02:52:03 +03:00
ret = target_put_sess_cmd ( cmd ) ;
2016-01-20 02:23:02 +03:00
if ( aborted ) {
pr_debug ( " Detected CMD_T_ABORTED for ITT: %llu \n " , cmd - > tag ) ;
2018-06-23 00:52:59 +03:00
wait_for_completion ( & compl ) ;
2016-01-20 02:23:02 +03: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 22:11:26 +03:00
}
2013-05-31 11:46:11 +04: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 22:11:26 +03:00
}
EXPORT_SYMBOL ( transport_generic_free_cmd ) ;
2018-04-14 20:51:04 +03:00
/**
* target_get_sess_cmd - Add command to active - > sess_cmd_list
2011-11-03 08:52:08 +04:00
* @ se_cmd : command descriptor to add
2011-11-19 08:36:22 +04:00
* @ ack_kref : Signal that fabric will perform an ack target_put_sess_cmd ( )
2011-11-03 08:52:08 +04:00
*/
2015-04-27 14:52:36 +03:00
int target_get_sess_cmd ( struct se_cmd * se_cmd , bool ack_kref )
2011-11-03 08:52:08 +04:00
{
2015-04-27 14:52:36 +03:00
struct se_session * se_sess = se_cmd - > se_sess ;
2011-11-03 08:52:08 +04:00
unsigned long flags ;
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 22:04:40 +04:00
int ret = 0 ;
2011-11-03 08:52:08 +04:00
2011-11-19 08:36:22 +04: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-05 02:37:05 +03:00
if ( ack_kref ) {
2016-08-22 11:54:07 +03:00
if ( ! kref_get_unless_zero ( & se_cmd - > cmd_kref ) )
return - EINVAL ;
2016-10-05 02:37:05 +03:00
se_cmd - > se_cmd_flags | = SCF_ACK_KREF ;
}
2011-11-12 12:32:17 +04:00
2011-11-03 08:52:08 +04:00
spin_lock_irqsave ( & se_sess - > sess_cmd_lock , flags ) ;
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 22:04:40 +04:00
if ( se_sess - > sess_tearing_down ) {
ret = - ESHUTDOWN ;
goto out ;
}
2011-11-03 08:52:08 +04:00
list_add_tail ( & se_cmd - > se_cmd_list , & se_sess - > sess_cmd_list ) ;
2018-11-28 02:51:58 +03:00
percpu_ref_get ( & 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 22:04:40 +04:00
out :
2011-11-03 08:52:08 +04:00
spin_unlock_irqrestore ( & se_sess - > sess_cmd_lock , flags ) ;
2015-02-18 17:33:58 +03:00
if ( ret & & ack_kref )
2015-04-27 14:52:36 +03:00
target_put_sess_cmd ( se_cmd ) ;
2015-02-18 17:33:58 +03: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 22:04:40 +04:00
return ret ;
2011-11-03 08:52:08 +04:00
}
2013-03-22 09:54:28 +04:00
EXPORT_SYMBOL ( target_get_sess_cmd ) ;
2011-11-03 08:52:08 +04:00
2016-01-12 08:31:09 +03: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 12:32:17 +04:00
static void target_release_cmd_kref ( struct kref * kref )
2011-11-03 08:52:08 +04:00
{
2011-11-12 12:32:17 +04: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-28 02:52:00 +03:00
struct completion * free_compl = se_cmd - > free_compl ;
struct completion * abrt_compl = se_cmd - > abrt_compl ;
2015-10-23 01:57:04 +03:00
unsigned long flags ;
2011-11-03 08:52:08 +04:00
2019-01-25 21:34:46 +03:00
if ( se_cmd - > lun_ref_active )
percpu_ref_put ( & se_cmd - > se_lun - > lun_ref ) ;
2017-02-07 23:19:16 +03:00
if ( se_sess ) {
spin_lock_irqsave ( & se_sess - > sess_cmd_lock , flags ) ;
2018-06-23 00:52:50 +03:00
list_del_init ( & se_cmd - > se_cmd_list ) ;
2015-10-23 01:57:04 +03:00
spin_unlock_irqrestore ( & se_sess - > sess_cmd_lock , flags ) ;
2011-11-03 08:52:08 +04:00
}
2016-01-12 08:31:09 +03:00
target_free_cmd_mem ( se_cmd ) ;
2011-11-12 12:32:17 +04:00
se_cmd - > se_tfo - > release_cmd ( se_cmd ) ;
2018-11-28 02:52:00 +03:00
if ( free_compl )
complete ( free_compl ) ;
if ( abrt_compl )
complete ( abrt_compl ) ;
2018-11-28 02:51:58 +03:00
percpu_ref_put ( & se_sess - > cmd_count ) ;
2011-11-12 12:32:17 +04:00
}
2017-02-07 23:19:16 +03: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 12:32:17 +04:00
*/
2015-04-27 14:52:36 +03:00
int target_put_sess_cmd ( struct se_cmd * se_cmd )
2011-11-12 12:32:17 +04:00
{
2015-10-23 01:57:04 +03:00
return kref_put ( & se_cmd - > cmd_kref , target_release_cmd_kref ) ;
2011-11-03 08:52:08 +04:00
}
EXPORT_SYMBOL ( target_put_sess_cmd ) ;
2017-05-24 02:48:28 +03: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 " ;
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 ) ;
2018-04-14 20:51:04 +03:00
/**
2018-06-23 00:52:53 +03:00
* target_sess_cmd_list_set_waiting - Set sess_tearing_down so no new commands are queued .
2012-07-16 22:04:42 +04:00
* @ se_sess : session to flag
2011-11-03 08:52:08 +04:00
*/
2012-07-16 22:04:42 +04:00
void target_sess_cmd_list_set_waiting ( struct se_session * se_sess )
2011-11-03 08:52:08 +04:00
{
unsigned long flags ;
spin_lock_irqsave ( & se_sess - > sess_cmd_lock , flags ) ;
2012-07-16 22:04:42 +04:00
se_sess - > sess_tearing_down = 1 ;
2011-11-03 08:52:08 +04:00
spin_unlock_irqrestore ( & se_sess - > sess_cmd_lock , flags ) ;
2018-11-28 02:51:58 +03:00
percpu_ref_kill ( & se_sess - > cmd_count ) ;
2011-11-03 08:52:08 +04:00
}
2012-07-16 22:04:42 +04:00
EXPORT_SYMBOL ( target_sess_cmd_list_set_waiting ) ;
2011-11-03 08:52:08 +04:00
2018-04-14 20:51:04 +03:00
/**
2018-06-23 00:52:53 +03:00
* target_wait_for_sess_cmds - Wait for outstanding commands
2011-11-03 08:52:08 +04:00
* @ se_sess : session to wait for active I / O
*/
2013-05-15 11:44:07 +04:00
void target_wait_for_sess_cmds ( struct se_session * se_sess )
2011-11-03 08:52:08 +04:00
{
2018-06-23 00:52:53 +03:00
struct se_cmd * cmd ;
int ret ;
2013-05-15 11:52:44 +04:00
2018-06-23 00:52:53 +03:00
WARN_ON_ONCE ( ! se_sess - > sess_tearing_down ) ;
do {
2018-11-28 02:51:58 +03:00
ret = wait_event_timeout ( se_sess - > cmd_list_wq ,
percpu_ref_is_zero ( & se_sess - > cmd_count ) ,
180 * HZ ) ;
2018-06-23 00:52:53 +03:00
list_for_each_entry ( cmd , & se_sess - > sess_cmd_list , se_cmd_list )
target_show_cmd ( " session shutdown: still waiting for " ,
cmd ) ;
} while ( ret < = 0 ) ;
2011-11-03 08:52:08 +04:00
}
EXPORT_SYMBOL ( target_wait_for_sess_cmds ) ;
2018-11-28 02:51:57 +03: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 17:16:01 +03: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 22:11:26 +03:00
{
2018-11-28 02:51:57 +03: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-23 09:06:32 +03: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 22:11:26 +03:00
}
2016-01-20 02:23:02 +03: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 22:11:26 +03:00
{
2016-01-20 02:23:02 +03:00
assert_spin_locked ( & cmd - > t_state_lock ) ;
WARN_ON_ONCE ( ! irqs_disabled ( ) ) ;
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-20 01:39:17 +04:00
if ( ! ( cmd - > se_cmd_flags & SCF_SE_LUN_CMD ) & &
2016-01-20 02:23:02 +03:00
! ( cmd - > se_cmd_flags & SCF_SCSI_TMR_CDB ) )
2011-11-03 08:52:08 +04:00
return false ;
2012-05-20 19:59:10 +04:00
2012-01-20 01:39:17 +04:00
if ( ! ( cmd - > se_cmd_flags & SCF_SUPPORTED_SAM_OPCODE ) & &
2016-01-20 02:23:02 +03:00
! ( cmd - > se_cmd_flags & SCF_SCSI_TMR_CDB ) )
2011-11-03 08:52:08 +04:00
return false ;
2011-12-21 23:13:47 +04:00
2016-01-20 02:23:02 +03:00
if ( ! ( cmd - > transport_state & CMD_T_ACTIVE ) )
return false ;
if ( fabric_stop & & * aborted )
2011-11-03 08:52:08 +04: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 22:11:26 +03:00
2011-12-21 23:13:47 +04: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 22:11:26 +03:00
2017-05-24 02:48:28 +03: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 22:11:26 +03:00
2016-01-20 02:23:02 +03: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 22:11:26 +03:00
2017-05-24 02:48:28 +03: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 22:11:26 +03:00
2016-01-20 02:23:02 +03:00
spin_lock_irqsave ( & cmd - > t_state_lock , * flags ) ;
2011-12-21 23:13:47 +04: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 22:11:26 +03:00
2016-01-20 02:23:02 +03: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 22:11:26 +03:00
2016-01-20 02:23:02 +03:00
return true ;
}
/**
2017-01-10 21:03:28 +03:00
* transport_wait_for_tasks - set CMD_T_STOP and wait for t_transport_stop_comp
* @ cmd : command to wait on
2016-01-20 02:23:02 +03: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 12:00:58 +04:00
spin_unlock_irqrestore ( & cmd - > t_state_lock , flags ) ;
2011-11-03 08:52:08 +04:00
2016-01-20 02:23:02 +03: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 22:11:26 +03:00
}
2011-10-09 12:00:58 +04: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 22:11:26 +03:00
2015-07-08 17:58:51 +03:00
struct sense_info {
u8 key ;
u8 asc ;
u8 ascq ;
bool add_sector_info ;
} ;
static const struct sense_info sense_info_table [ ] = {
[ 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 13:37:53 +03: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_CHECK_CONDITION_NOT_READY ] = {
. key = NOT_READY ,
} ,
[ TCM_MISCOMPARE_VERIFY ] = {
. key = MISCOMPARE ,
. asc = 0x1d , /* MISCOMPARE DURING VERIFY OPERATION */
. ascq = 0x00 ,
} ,
[ 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 */
. add_sector_info = true ,
} ,
[ 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 */
. add_sector_info = true ,
} ,
[ 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 */
. add_sector_info = true ,
} ,
2016-10-09 03:26:44 +03: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 15:55:41 +03: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 */
} ,
2015-07-08 17:58:51 +03:00
} ;
2018-06-23 00:53:06 +03: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-23 00:53:05 +03:00
static void translate_sense_reason ( struct se_cmd * cmd , sense_reason_t reason )
2015-07-08 17:58:51 +03:00
{
const struct sense_info * si ;
u8 * buffer = cmd - > sense_buffer ;
int r = ( __force int ) reason ;
2018-06-23 00:53:06 +03: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
if ( r < ARRAY_SIZE ( sense_info_table ) & & sense_info_table [ r ] . key )
si = & sense_info_table [ r ] ;
else
si = & sense_info_table [ ( __force int )
TCM_LOGICAL_UNIT_COMMUNICATION_FAILURE ] ;
2018-06-23 00:53:06 +03:00
key = si - > key ;
2015-07-08 17:58:51 +03:00
if ( reason = = TCM_CHECK_CONDITION_UNIT_ATTENTION ) {
2018-06-23 00:53:06 +03: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 if ( si - > asc = = 0 ) {
WARN_ON_ONCE ( cmd - > scsi_asc = = 0 ) ;
asc = cmd - > scsi_asc ;
ascq = cmd - > scsi_ascq ;
} else {
asc = si - > asc ;
ascq = si - > ascq ;
}
2015-07-08 17:58:53 +03:00
2018-06-23 00:53:04 +03: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-23 00:53:06 +03:00
scsi_build_sense_buffer ( desc_format , buffer , key , asc , ascq ) ;
2015-07-08 17:58:51 +03:00
if ( si - > add_sector_info )
2018-06-23 00:53:05 +03:00
WARN_ON_ONCE ( scsi_set_sense_information ( buffer ,
cmd - > scsi_sense_length ,
cmd - > bad_sector ) < 0 ) ;
2015-07-08 17:58:51 +03:00
}
2012-11-07 00:24:09 +04: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 22:11:26 +03:00
{
unsigned long flags ;
2018-11-28 02:52:03 +03:00
WARN_ON_ONCE ( cmd - > se_cmd_flags & SCF_SCSI_TMR_CDB ) ;
2011-05-03 04:12:10 +04: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 22:11:26 +03:00
if ( cmd - > se_cmd_flags & SCF_SENT_CHECK_CONDITION ) {
2011-05-03 04:12:10 +04: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 22:11:26 +03:00
return 0 ;
}
cmd - > se_cmd_flags | = SCF_SENT_CHECK_CONDITION ;
2011-05-03 04:12:10 +04: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 22:11:26 +03:00
2018-06-23 00:53:05 +03: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 22:11:26 +03:00
2013-06-27 04:36:17 +04:00
trace_target_cmd_complete ( cmd ) ;
2011-06-14 01:46:09 +04: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 22:11:26 +03:00
}
EXPORT_SYMBOL ( transport_send_check_condition_and_sense ) ;
2019-01-25 21:34:47 +03: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 23: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 22:11:26 +03:00
{
2012-07-08 23:58:49 +04:00
struct se_cmd * cmd = container_of ( work , struct se_cmd , work ) ;
2011-07-19 14:26:37 +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 22:11:26 +03:00
struct se_tmr_req * tmr = cmd - > se_tmr_req ;
int ret ;
2018-11-28 02:52:03 +03:00
if ( cmd - > transport_state & CMD_T_ABORTED )
goto aborted ;
2016-01-12 08:53:05 +03: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 22:11:26 +03:00
switch ( tmr - > function ) {
2011-03-14 14:06:04 +03:00
case TMR_ABORT_TASK :
2012-02-13 14:38:14 +04: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 22:11:26 +03:00
break ;
2011-03-14 14:06:04 +03: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 22:11:26 +03:00
tmr - > response = TMR_TASK_MGMT_FUNCTION_NOT_SUPPORTED ;
break ;
2011-03-14 14:06:04 +03: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 22:11:26 +03:00
ret = core_tmr_lun_reset ( dev , tmr , NULL , NULL ) ;
tmr - > response = ( ! ret ) ? TMR_FUNCTION_COMPLETE :
TMR_FUNCTION_REJECTED ;
2015-06-11 11:01:28 +03: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 22:11:26 +03:00
break ;
2011-03-14 14:06:04 +03: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 22:11:26 +03:00
tmr - > response = TMR_FUNCTION_REJECTED ;
break ;
2011-03-14 14:06:04 +03: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 22:11:26 +03:00
tmr - > response = TMR_FUNCTION_REJECTED ;
break ;
default :
2018-05-26 18:02:29 +03: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 22:11:26 +03:00
tmr - > function ) ;
tmr - > response = TMR_FUNCTION_REJECTED ;
break ;
}
2018-11-28 02:52:03 +03:00
if ( cmd - > transport_state & CMD_T_ABORTED )
goto aborted ;
2016-01-12 08:53:05 +03:00
2011-07-19 12:55:10 +04: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 22:11:26 +03:00
2011-10-17 21:56:44 +04:00
transport_cmd_check_stop_to_fabric ( cmd ) ;
2018-11-28 02:52:03 +03: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 22:11:26 +03:00
}
2012-07-08 23: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 22:11:26 +03:00
{
2014-06-10 03:13:20 +04:00
unsigned long flags ;
2016-12-07 09:45:46 +03:00
bool aborted = false ;
2014-06-10 03:13:20 +04:00
spin_lock_irqsave ( & cmd - > t_state_lock , flags ) ;
2016-12-07 09:45:46 +03: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-10 03:13:20 +04:00
spin_unlock_irqrestore ( & cmd - > t_state_lock , flags ) ;
2016-12-07 09:45:46 +03:00
if ( aborted ) {
2018-11-28 02:52:03 +03: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-07 09:45:46 +03:00
return 0 ;
}
2012-07-08 23:58:49 +04:00
INIT_WORK ( & cmd - > work , target_tmr_work ) ;
2018-11-28 02:51:59 +03: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 22:11:26 +03:00
return 0 ;
}
2012-07-08 23:58:49 +04:00
EXPORT_SYMBOL ( transport_generic_handle_tmr ) ;
2015-04-20 16:00:30 +03: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 ;
}