]>
www.infradead.org Git - users/dwmw2/linux.git/log 
Mike Christie [Thu, 30 Sep 2021 02:04:21 +0000  (21:04 -0500)] 
 
scsi: target: Replace lun_tg_pt_gp_lock with rcu in I/O path
We are only holding the lun_tg_pt_gp_lock in target_alua_state_check() to
make sure tg_pt_gp is not freed from under us while we copy the state,
delay, ID values. We can instead use RCU here to access the tg_pt_gp.
With this patch IOPs can increase up to 10% for jobs like:
  fio  --filename=/dev/sdX  --direct=1 --rw=randrw --bs=4k \
    --ioengine=libaio --iodepth=64  --numjobs=N
when there are multiple sessions (running that fio command to each /dev/sdX
or using multipath and there are over 8 paths), or more than 8 queues for
the loop or vhost with multiple threads case and numjobs > 8.
Link: https://lore.kernel.org/r/20210930020422.92578-5-michael.christie@oracle.com  
Signed-off-by: Mike Christie <michael.christie@oracle.com> 
Signed-off-by: Martin K. Petersen <martin.petersen@oracle.com> 
Mike Christie [Thu, 30 Sep 2021 02:04:20 +0000  (21:04 -0500)] 
 
scsi: target: Fix alua_tg_pt_gps_count tracking
We can't free the tg_pt_gp in core_alua_set_tg_pt_gp_id() because it's
still accessed via configfs. Its release must go through the normal
configfs/refcount process.
The max alua_tg_pt_gps_count check should probably have been done in
core_alua_allocate_tg_pt_gp(), but with the current code userspace could
have created 0x0000ffff + 1 groups, but only set the id for 0x0000ffff.
Then it could have deleted a group with an ID set, and then set the ID for
that extra group and it would work ok.
It's unlikely, but just in case this patch continues to allow that type of
behavior, and just fixes the kfree() while in use bug.
Link: https://lore.kernel.org/r/20210930020422.92578-4-michael.christie@oracle.com  
Signed-off-by: Mike Christie <michael.christie@oracle.com> 
Signed-off-by: Martin K. Petersen <martin.petersen@oracle.com> 
Mike Christie [Thu, 30 Sep 2021 02:04:19 +0000  (21:04 -0500)] 
 
scsi: target: Fix ordered tag handling
This patch fixes the following bugs:
1. If there are multiple ordered cmds queued and multiple simple cmds
   completing, target_restart_delayed_cmds() could be called on different
   CPUs and each instance could start a ordered cmd. They could then run in
   different orders than they were queued.
2. target_restart_delayed_cmds() and target_handle_task_attr() can race
   where:
   1. target_handle_task_attr() has passed the simple_cmds == 0 check.
   2. transport_complete_task_attr() then decrements simple_cmds to 0.
   3. transport_complete_task_attr() runs target_restart_delayed_cmds() and
      it does not see any cmds on the delayed_cmd_list.
   4. target_handle_task_attr() adds the cmd to the delayed_cmd_list.
   The cmd will then end up timing out.
3. If we are sent > 1 ordered cmds and simple_cmds == 0, we can execute
   them out of order, because target_handle_task_attr() will hit that
   simple_cmds check first and return false for all ordered cmds sent.
4. We run target_restart_delayed_cmds() after every cmd completion, so if
   there is more than 1 simple cmd running, we start executing ordered cmds
   after that first cmd instead of waiting for all of them to complete.
5. Ordered cmds are not supposed to start until HEAD OF QUEUE and all older
   cmds have completed, and not just simple.
6. It's not a bug but it doesn't make sense to take the delayed_cmd_lock
   for every cmd completion when ordered cmds are almost never used. Just
   replacing that lock with an atomic increases IOPs by up to 10% when
   completions are spread over multiple CPUs and there are multiple
   sessions/ mqs/thread accessing the same device.
This patch moves the queued delayed handling to a per device work to
serialze the cmd executions for each device and adds a new counter to track
HEAD_OF_QUEUE and SIMPLE cmds. We can then check the new counter to
determine when to run the work on the completion path.
Link: https://lore.kernel.org/r/20210930020422.92578-3-michael.christie@oracle.com  
Signed-off-by: Mike Christie <michael.christie@oracle.com> 
Signed-off-by: Martin K. Petersen <martin.petersen@oracle.com> 
Mike Christie [Thu, 30 Sep 2021 02:04:18 +0000  (21:04 -0500)] 
 
scsi: target: Fix ordered CMD_T_SENT handling
We can race where target_handle_task_attr() has put the cmd on the
delayed_cmd_list. Then target_restart_delayed_cmds() has removed it and set
CMD_T_SENT, but then target_execute_cmd() now clears that bit.
This patch moves the clearing to before we've put the cmd on the list.
Link: https://lore.kernel.org/r/20210930020422.92578-2-michael.christie@oracle.com  
Reviewed-by: Lee Duncan <lduncan@suse.com> 
Signed-off-by: Mike Christie <michael.christie@oracle.com> 
Signed-off-by: Martin K. Petersen <martin.petersen@oracle.com> 
Peter Wang [Sat, 16 Oct 2021 00:58:02 +0000  (08:58 +0800)] 
 
scsi: ufs: ufs-mediatek: Fix wrong location for ref-clk delay
Fix the location of delay for ref-clk gating and ungating in
ufs_mtk_setup_ref_clk().
Link: https://lore.kernel.org/r/20211016005802.7729-4-stanley.chu@mediatek.com  
Reviewed-by: Stanley Chu <stanley.chu@mediatek.com> 
Signed-off-by: Peter Wang <peter.wang@mediatek.com> 
Signed-off-by: Stanley Chu <stanley.chu@mediatek.com> 
Signed-off-by: Martin K. Petersen <martin.petersen@oracle.com> 
Stanley Chu [Sat, 16 Oct 2021 00:58:01 +0000  (08:58 +0800)] 
 
scsi: ufs: ufs-mediatek: Fix build error caused by use of sched_clock()
Add proper header for using sched_clock().
Link: https://lore.kernel.org/r/20211016005802.7729-3-stanley.chu@mediatek.com  
Signed-off-by: Stanley Chu <stanley.chu@mediatek.com> 
Signed-off-by: Martin K. Petersen <martin.petersen@oracle.com> 
Stanley Chu [Sat, 16 Oct 2021 00:58:00 +0000  (08:58 +0800)] 
 
scsi: ufs: ufs-mediatek: Introduce default delay for reference clock
Introduce default delay time for gating or ungating reference clock instead
of ambiguous magic numbers.
The defined value is suitable for all current MediaTek UFS platforms.
Link: https://lore.kernel.org/r/20211016005802.7729-2-stanley.chu@mediatek.com  
Signed-off-by: Stanley Chu <stanley.chu@mediatek.com> 
Signed-off-by: Martin K. Petersen <martin.petersen@oracle.com> 
Bodo Stroesser [Wed, 13 Oct 2021 17:16:06 +0000  (19:16 +0200)] 
 
scsi: target: tcmu: Allocate zeroed pages for data area
Tcmu populates the data area (used for communication with userspace) with
pages that are allocated by calling alloc_page(GFP_NOIO).  Therefore
previous content of the allocated pages is exposed to user space. Avoid
this by adding __GFP_ZERO flag.
Zeroing the pages does (nearly) not affect tcmu throughput, because
allocated pages are re-used for the data transfers of later SCSI cmds.
Link: https://lore.kernel.org/r/20211013171606.25197-1-bostroesser@gmail.com  
Signed-off-by: Bodo Stroesser <bostroesser@gmail.com> 
Signed-off-by: Martin K. Petersen <martin.petersen@oracle.com> 
Varun Prakash [Wed, 13 Oct 2021 14:25:09 +0000  (19:55 +0530)] 
 
scsi: target: cxgbit: Enable Delayed ACK
Enable Delayed ACK to reduce the number of TCP ACKs.
Link: https://lore.kernel.org/r/1634135109-5044-1-git-send-email-varun@chelsio.com  
Signed-off-by: Varun Prakash <varun@chelsio.com> 
Signed-off-by: Martin K. Petersen <martin.petersen@oracle.com> 
Varun Prakash [Wed, 13 Oct 2021 14:24:47 +0000  (19:54 +0530)] 
 
scsi: target: cxgbit: Increase max DataSegmentLength
Current value of max DataSegmentLength is 8K. T5/T6 adapters support
DataSegmentLength upto 16K. Increase max DataSegmentLength.
Link: https://lore.kernel.org/r/1634135087-4996-1-git-send-email-varun@chelsio.com  
Signed-off-by: Varun Prakash <varun@chelsio.com> 
Signed-off-by: Martin K. Petersen <martin.petersen@oracle.com> 
Ye Bin [Wed, 13 Oct 2021 03:39:13 +0000  (11:39 +0800)] 
 
scsi: scsi_debug: Fix out-of-bound read in resp_report_tgtpgs()
The following issue was observed running syzkaller:
BUG: KASAN: slab-out-of-bounds in memcpy include/linux/string.h:377 [inline]
BUG: KASAN: slab-out-of-bounds in sg_copy_buffer+0x150/0x1c0 lib/scatterlist.c:831
Read of size 2132 at addr 
ffff8880aea95dc8  by task syz-executor.0/9815
CPU: 0 PID: 9815 Comm: syz-executor.0 Not tainted 
4.19.202-00874-gfc0fe04215a9  #2
Hardware name: QEMU Standard PC (i440FX + PIIX, 1996), BIOS 1.10.2-1ubuntu1 04/01/2014
Call Trace:
 __dump_stack lib/dump_stack.c:77 [inline]
 dump_stack+0xe4/0x14a lib/dump_stack.c:118
 print_address_description+0x73/0x280 mm/kasan/report.c:253
 kasan_report_error mm/kasan/report.c:352 [inline]
 kasan_report+0x272/0x370 mm/kasan/report.c:410
 memcpy+0x1f/0x50 mm/kasan/kasan.c:302
 memcpy include/linux/string.h:377 [inline]
 sg_copy_buffer+0x150/0x1c0 lib/scatterlist.c:831
 fill_from_dev_buffer+0x14f/0x340 drivers/scsi/scsi_debug.c:1021
 resp_report_tgtpgs+0x5aa/0x770 drivers/scsi/scsi_debug.c:1772
 schedule_resp+0x464/0x12f0 drivers/scsi/scsi_debug.c:4429
 scsi_debug_queuecommand+0x467/0x1390 drivers/scsi/scsi_debug.c:5835
 scsi_dispatch_cmd+0x3fc/0x9b0 drivers/scsi/scsi_lib.c:1896
 scsi_request_fn+0x1042/0x1810 drivers/scsi/scsi_lib.c:2034
 __blk_run_queue_uncond block/blk-core.c:464 [inline]
 __blk_run_queue+0x1a4/0x380 block/blk-core.c:484
 blk_execute_rq_nowait+0x1c2/0x2d0 block/blk-exec.c:78
 sg_common_write.isra.19+0xd74/0x1dc0 drivers/scsi/sg.c:847
 sg_write.part.23+0x6e0/0xd00 drivers/scsi/sg.c:716
 sg_write+0x64/0xa0 drivers/scsi/sg.c:622
 __vfs_write+0xed/0x690 fs/read_write.c:485
kill_bdev:block_device:
00000000e138492c 
 vfs_write+0x184/0x4c0 fs/read_write.c:549
 ksys_write+0x107/0x240 fs/read_write.c:599
 do_syscall_64+0xc2/0x560 arch/x86/entry/common.c:293
 entry_SYSCALL_64_after_hwframe+0x49/0xbe
We get 'alen' from command its type is int. If userspace passes a large
length we will get a negative 'alen'.
Switch n, alen, and rlen to u32.
Link: https://lore.kernel.org/r/20211013033913.2551004-3-yebin10@huawei.com  
Acked-by: Douglas Gilbert <dgilbert@interlog.com> 
Signed-off-by: Ye Bin <yebin10@huawei.com> 
Signed-off-by: Martin K. Petersen <martin.petersen@oracle.com> 
Ye Bin [Wed, 13 Oct 2021 03:39:12 +0000  (11:39 +0800)] 
 
scsi: scsi_debug: Fix out-of-bound read in resp_readcap16()
The following warning was observed running syzkaller:
[ 3813.830724] sg_write: data in/out 65466/242 bytes for SCSI command 0x9e-- guessing data in;
[ 3813.830724]    program syz-executor not setting count and/or reply_len properly
[ 3813.836956] ==================================================================
[ 3813.839465] BUG: KASAN: stack-out-of-bounds in sg_copy_buffer+0x157/0x1e0
[ 3813.841773] Read of size 4096 at addr 
ffff8883cf80f540  by task syz-executor/1549
[ 3813.846612] Call Trace:
[ 3813.846995]  dump_stack+0x108/0x15f
[ 3813.847524]  print_address_description+0xa5/0x372
[ 3813.848243]  kasan_report.cold+0x236/0x2a8
[ 3813.849439]  check_memory_region+0x240/0x270
[ 3813.850094]  memcpy+0x30/0x80
[ 3813.850553]  sg_copy_buffer+0x157/0x1e0
[ 3813.853032]  sg_copy_from_buffer+0x13/0x20
[ 3813.853660]  fill_from_dev_buffer+0x135/0x370
[ 3813.854329]  resp_readcap16+0x1ac/0x280
[ 3813.856917]  schedule_resp+0x41f/0x1630
[ 3813.858203]  scsi_debug_queuecommand+0xb32/0x17e0
[ 3813.862699]  scsi_dispatch_cmd+0x330/0x950
[ 3813.863329]  scsi_request_fn+0xd8e/0x1710
[ 3813.863946]  __blk_run_queue+0x10b/0x230
[ 3813.864544]  blk_execute_rq_nowait+0x1d8/0x400
[ 3813.865220]  sg_common_write.isra.0+0xe61/0x2420
[ 3813.871637]  sg_write+0x6c8/0xef0
[ 3813.878853]  __vfs_write+0xe4/0x800
[ 3813.883487]  vfs_write+0x17b/0x530
[ 3813.884008]  ksys_write+0x103/0x270
[ 3813.886268]  __x64_sys_write+0x77/0xc0
[ 3813.886841]  do_syscall_64+0x106/0x360
[ 3813.887415]  entry_SYSCALL_64_after_hwframe+0x44/0xa9
This issue can be reproduced with the following syzkaller log:
r0 = openat(0xffffffffffffff9c, &(0x7f0000000040)='./file0\x00', 0x26e1, 0x0)
r1 = syz_open_procfs(0xffffffffffffffff, &(0x7f0000000000)='fd/3\x00')
open_by_handle_at(r1, &(0x7f00000003c0)=ANY=[@ANYRESHEX], 0x602000)
r2 = syz_open_dev$sg(&(0x7f0000000000), 0x0, 0x40782)
write$binfmt_aout(r2, &(0x7f0000000340)=ANY=[@ANYBLOB="00000000deff000000000000000000000000000000000000000000000000000047f007af9e107a41ec395f1bded7be24277a1501ff6196a83366f4e6362bc0ff2b247f68a972989b094b2da4fb3607fcf611a22dd04310d28c75039d"], 0x126)
In resp_readcap16() we get "int alloc_len" value -
1104926854 , and then pass
the huge arr_len to fill_from_dev_buffer(), but arr is only 32 bytes. This
leads to OOB in sg_copy_buffer().
To solve this issue, define alloc_len as u32.
Link: https://lore.kernel.org/r/20211013033913.2551004-2-yebin10@huawei.com  
Acked-by: Douglas Gilbert <dgilbert@interlog.com> 
Signed-off-by: Ye Bin <yebin10@huawei.com> 
Signed-off-by: Martin K. Petersen <martin.petersen@oracle.com> 
Colin Ian King [Wed, 13 Oct 2021 18:28:34 +0000  (19:28 +0100)] 
 
scsi: 3w-xxx: Remove redundant initialization of variable retval
The variable retval is being initialized with a value that is never read,
it is being updated immediately afterwards. The assignment is redundant and
can be removed.
Link: https://lore.kernel.org/r/20211013182834.137410-1-colin.king@canonical.com  
Signed-off-by: Colin Ian King <colin.king@canonical.com> 
Signed-off-by: Martin K. Petersen <martin.petersen@oracle.com> 
Addresses-Coverity: ("Unused value")
MichelleJin [Fri, 15 Oct 2021 14:20:06 +0000  (14:20 +0000)] 
 
scsi: fcoe: Use netif_is_bond_master() instead of open code
'netdev->priv_flags & IFF_BONDING && netdev->flags & IFF_MASTER' is defined
as netif_is_bond_master() in netdevice.h. Replace it to clean up code.
Link: https://lore.kernel.org/r/20211015142006.540773-1-shjy180909@gmail.com  
Reviewed-by: Lee Duncan <lduncan@suse.com> 
Signed-off-by: MichelleJin <shjy180909@gmail.com> 
Signed-off-by: Martin K. Petersen <martin.petersen@oracle.com> 
Tyrel Datwyler [Thu, 10 Jan 2019 02:59:09 +0000  (18:59 -0800)] 
 
scsi: ibmvscsi: Use GFP_KERNEL with dma_alloc_coherent() in initialize_event_pool()
During driver probe we allocate a dma region for our event pool.
Currently, zero is passed for the gfp_flags parameter. Driver probe
callbacks are run in process context and we hold no locks so we can sleep
here if necessary.
Fix by passing GFP_KERNEL explicitly to dma_alloc_coherent().
Link: https://lore.kernel.org/r/1547089149-20577-1-git-send-email-tyreld@linux.vnet.ibm.com  
Reviewed-by: Brian King <brking@linux.vnet.ibm.com> 
Signed-off-by: Tyrel Datwyler <tyreld@linux.vnet.ibm.com> 
Signed-off-by: Martin K. Petersen <martin.petersen@oracle.com> 
Dan Carpenter [Wed, 13 Oct 2021 08:30:05 +0000  (11:30 +0300)] 
 
scsi: mpi3mr: Use scnprintf() instead of snprintf()
I intended to move from snprintf() to scnprintf() in the previous patch but
I messed up and did not do that.  The result of my bug is that it this
function could trigger a WARN() if the buffer is too large.
Link: https://lore.kernel.org/r/20211013083005.GA8592@kili  
Fixes: 76a4f7cc5973 ("scsi: mpi3mr: Clean up mpi3mr_print_ioc_info()") 
Signed-off-by: Dan Carpenter <dan.carpenter@oracle.com> 
Signed-off-by: Martin K. Petersen <martin.petersen@oracle.com> 
Martin Kepplinger [Wed, 13 Oct 2021 07:50:50 +0000  (09:50 +0200)] 
 
scsi: sd: Print write through due to no caching mode page as warning
For SD cardreaders it is extremely common not to have a cache.
Consequently, the following messages do not point to a real error one could
try to fix but rather describe how the disk works:
  sd 0:0:0:0: [sda] No Caching mode page found
  sd 0:0:0:0: [sda] Assuming drive cache: write through
Print these messages as warnings instead of errors.
Link: https://lore.kernel.org/r/20211013075050.3870354-1-martin.kepplinger@puri.sm  
Reviewed-by: Bart Van Assche <bvanassche@acm.org> 
Signed-off-by: Martin Kepplinger <martin.kepplinger@puri.sm> 
Signed-off-by: Martin K. Petersen <martin.petersen@oracle.com> 
Bart Van Assche [Tue, 12 Oct 2021 23:35:58 +0000  (16:35 -0700)] 
 
scsi: core: Remove two host template members that are no longer used
All SCSI drivers have been converted to use shost_groups and sdev_groups
instead of shost_attrs or sdev_attrs. Hence remove shost_attrs and
sdev_attrs. Additionally, remove the 'lld_attr_group' members and also
the scsi_convert_dev_attrs() function.
Link: https://lore.kernel.org/r/20211012233558.4066756-47-bvanassche@acm.org  
Cc: Greg Kroah-Hartman <gregkh@linuxfoundation.org> 
Reviewed-by: Benjamin Block <bblock@linux.ibm.com> 
Signed-off-by: Bart Van Assche <bvanassche@acm.org> 
Signed-off-by: Martin K. Petersen <martin.petersen@oracle.com> 
Bart Van Assche [Tue, 12 Oct 2021 23:35:57 +0000  (16:35 -0700)] 
 
scsi: usb: Switch to attribute groups
struct device supports attribute groups directly but does not support
struct device_attribute directly. Hence switch to attribute groups.
Link: https://lore.kernel.org/r/20211012233558.4066756-46-bvanassche@acm.org  
Acked-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org> 
Signed-off-by: Bart Van Assche <bvanassche@acm.org> 
Signed-off-by: Martin K. Petersen <martin.petersen@oracle.com> 
Bart Van Assche [Tue, 12 Oct 2021 23:35:56 +0000  (16:35 -0700)] 
 
scsi: staging: unisys: Remove the shost_attrs member
This patch prepares for removal of the shost_attrs member from struct
scsi_host_template.
Link: https://lore.kernel.org/r/20211012233558.4066756-45-bvanassche@acm.org  
Acked-by: David Kershner <david.kershner@unisys.com> 
Acked-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org> 
Signed-off-by: Bart Van Assche <bvanassche@acm.org> 
Signed-off-by: Martin K. Petersen <martin.petersen@oracle.com> 
Bart Van Assche [Tue, 12 Oct 2021 23:35:55 +0000  (16:35 -0700)] 
 
scsi: snic: Switch to attribute groups
struct device supports attribute groups directly but does not support
struct device_attribute directly. Hence switch to attribute groups.
Link: https://lore.kernel.org/r/20211012233558.4066756-44-bvanassche@acm.org  
Signed-off-by: Bart Van Assche <bvanassche@acm.org> 
Signed-off-by: Martin K. Petersen <martin.petersen@oracle.com> 
Bart Van Assche [Tue, 12 Oct 2021 23:35:54 +0000  (16:35 -0700)] 
 
scsi: smartpqi: Switch to attribute groups
struct device supports attribute groups directly but does not support
struct device_attribute directly. Hence switch to attribute groups.
Link: https://lore.kernel.org/r/20211012233558.4066756-43-bvanassche@acm.org  
Signed-off-by: Bart Van Assche <bvanassche@acm.org> 
Signed-off-by: Martin K. Petersen <martin.petersen@oracle.com> 
Bart Van Assche [Tue, 12 Oct 2021 23:35:53 +0000  (16:35 -0700)] 
 
scsi: qla4xxx: Switch to attribute groups
struct device supports attribute groups directly but does not support
struct device_attribute directly. Hence switch to attribute groups.
Link: https://lore.kernel.org/r/20211012233558.4066756-42-bvanassche@acm.org  
Signed-off-by: Bart Van Assche <bvanassche@acm.org> 
Signed-off-by: Martin K. Petersen <martin.petersen@oracle.com> 
Bart Van Assche [Tue, 12 Oct 2021 23:35:52 +0000  (16:35 -0700)] 
 
scsi: qla2xxx: Switch to attribute groups
struct device supports attribute groups directly but does not support
struct device_attribute directly. Hence switch to attribute groups.
Additionally, remove qla_insert_tgt_attrs() and replace it with
qla_host_attr_is_visible().
Link: https://lore.kernel.org/r/20211012233558.4066756-41-bvanassche@acm.org  
Signed-off-by: Bart Van Assche <bvanassche@acm.org> 
Signed-off-by: Martin K. Petersen <martin.petersen@oracle.com> 
Bart Van Assche [Tue, 12 Oct 2021 23:35:51 +0000  (16:35 -0700)] 
 
scsi: qla2xxx: Remove a declaration
Since there is no definition for the qla2x00_host_attrs_dm array, remove
its declaration.
Link: https://lore.kernel.org/r/20211012233558.4066756-40-bvanassche@acm.org  
Signed-off-by: Bart Van Assche <bvanassche@acm.org> 
Signed-off-by: Martin K. Petersen <martin.petersen@oracle.com> 
Bart Van Assche [Tue, 12 Oct 2021 23:35:50 +0000  (16:35 -0700)] 
 
scsi: qedi: Switch to attribute groups
struct device supports attribute groups directly but does not support
struct device_attribute directly. Hence switch to attribute groups.
Link: https://lore.kernel.org/r/20211012233558.4066756-39-bvanassche@acm.org  
Signed-off-by: Bart Van Assche <bvanassche@acm.org> 
Signed-off-by: Martin K. Petersen <martin.petersen@oracle.com> 
Bart Van Assche [Tue, 12 Oct 2021 23:35:49 +0000  (16:35 -0700)] 
 
scsi: qedf: Switch to attribute groups
struct device supports attribute groups directly but does not support
struct device_attribute directly. Hence switch to attribute groups.
Link: https://lore.kernel.org/r/20211012233558.4066756-38-bvanassche@acm.org  
Signed-off-by: Bart Van Assche <bvanassche@acm.org> 
Signed-off-by: Martin K. Petersen <martin.petersen@oracle.com> 
Bart Van Assche [Tue, 12 Oct 2021 23:35:48 +0000  (16:35 -0700)] 
 
scsi: pmcraid: Switch to attribute groups
struct device supports attribute groups directly but does not support
struct device_attribute directly. Hence switch to attribute groups.
Link: https://lore.kernel.org/r/20211012233558.4066756-37-bvanassche@acm.org  
Signed-off-by: Bart Van Assche <bvanassche@acm.org> 
Signed-off-by: Martin K. Petersen <martin.petersen@oracle.com> 
Bart Van Assche [Tue, 12 Oct 2021 23:35:47 +0000  (16:35 -0700)] 
 
scsi: pm8001: Switch to attribute groups
struct device supports attribute groups directly but does not support
struct device_attribute directly. Hence switch to attribute groups.
Link: https://lore.kernel.org/r/20211012233558.4066756-36-bvanassche@acm.org  
Acked-by: Jack Wang <jinpu.wang@ionos.com> 
Signed-off-by: Bart Van Assche <bvanassche@acm.org> 
Signed-off-by: Martin K. Petersen <martin.petersen@oracle.com> 
Bart Van Assche [Tue, 12 Oct 2021 23:35:46 +0000  (16:35 -0700)] 
 
scsi: sym53c500_cs: Switch to attribute groups
struct device supports attribute groups directly but does not support
struct device_attribute directly. Hence switch to attribute groups.
Link: https://lore.kernel.org/r/20211012233558.4066756-35-bvanassche@acm.org  
Signed-off-by: Bart Van Assche <bvanassche@acm.org> 
Signed-off-by: Martin K. Petersen <martin.petersen@oracle.com> 
Bart Van Assche [Tue, 12 Oct 2021 23:35:45 +0000  (16:35 -0700)] 
 
scsi: ncr53c8xx: Switch to attribute groups
struct device supports attribute groups directly but does not support
struct device_attribute directly. Hence switch to attribute groups.
Link: https://lore.kernel.org/r/20211012233558.4066756-34-bvanassche@acm.org  
Signed-off-by: Bart Van Assche <bvanassche@acm.org> 
Signed-off-by: Martin K. Petersen <martin.petersen@oracle.com> 
Bart Van Assche [Tue, 12 Oct 2021 23:35:44 +0000  (16:35 -0700)] 
 
scsi: myrs: Switch to attribute groups
struct device supports attribute groups directly but does not support
struct device_attribute directly. Hence switch to attribute groups.
Link: https://lore.kernel.org/r/20211012233558.4066756-33-bvanassche@acm.org  
Signed-off-by: Bart Van Assche <bvanassche@acm.org> 
Signed-off-by: Martin K. Petersen <martin.petersen@oracle.com> 
Bart Van Assche [Tue, 12 Oct 2021 23:35:43 +0000  (16:35 -0700)] 
 
scsi: myrb: Switch to attribute groups
struct device supports attribute groups directly but does not support
struct device_attribute directly. Hence switch to attribute groups.
Link: https://lore.kernel.org/r/20211012233558.4066756-32-bvanassche@acm.org  
Signed-off-by: Bart Van Assche <bvanassche@acm.org> 
Signed-off-by: Martin K. Petersen <martin.petersen@oracle.com> 
Bart Van Assche [Tue, 12 Oct 2021 23:35:42 +0000  (16:35 -0700)] 
 
scsi: mvsas: Switch to attribute groups
struct device supports attribute groups directly but does not support
struct device_attribute directly. Hence switch to attribute groups.
Link: https://lore.kernel.org/r/20211012233558.4066756-31-bvanassche@acm.org  
Signed-off-by: Bart Van Assche <bvanassche@acm.org> 
Signed-off-by: Martin K. Petersen <martin.petersen@oracle.com> 
Bart Van Assche [Tue, 12 Oct 2021 23:35:41 +0000  (16:35 -0700)] 
 
scsi: mpt3sas: Switch to attribute groups
struct device supports attribute groups directly but does not support
struct device_attribute directly. Hence switch to attribute groups.
Link: https://lore.kernel.org/r/20211012233558.4066756-30-bvanassche@acm.org  
Signed-off-by: Bart Van Assche <bvanassche@acm.org> 
Signed-off-by: Martin K. Petersen <martin.petersen@oracle.com> 
Bart Van Assche [Tue, 12 Oct 2021 23:35:40 +0000  (16:35 -0700)] 
 
scsi: megaraid_sas: Switch to attribute groups
struct device supports attribute groups directly but does not support
struct device_attribute directly. Hence switch to attribute groups.
Link: https://lore.kernel.org/r/20211012233558.4066756-29-bvanassche@acm.org  
Signed-off-by: Bart Van Assche <bvanassche@acm.org> 
Signed-off-by: Martin K. Petersen <martin.petersen@oracle.com> 
Bart Van Assche [Tue, 12 Oct 2021 23:35:40 +0000  (16:35 -0700)] 
 
scsi: megaraid_mbox: Switch to attribute groups
struct device supports attribute groups directly but does not support
struct device_attribute directly. Hence switch to attribute groups.
Link: https://lore.kernel.org/r/20211012233558.4066756-29-bvanassche@acm.org  
Signed-off-by: Bart Van Assche <bvanassche@acm.org> 
Signed-off-by: Martin K. Petersen <martin.petersen@oracle.com> 
Bart Van Assche [Tue, 12 Oct 2021 23:35:39 +0000  (16:35 -0700)] 
 
scsi: lpfc: Switch to attribute groups
struct device supports attribute groups directly but does not support
struct device_attribute directly. Hence switch to attribute groups.
Link: https://lore.kernel.org/r/20211012233558.4066756-28-bvanassche@acm.org  
Signed-off-by: Bart Van Assche <bvanassche@acm.org> 
Signed-off-by: Martin K. Petersen <martin.petersen@oracle.com> 
Bart Van Assche [Tue, 12 Oct 2021 23:35:38 +0000  (16:35 -0700)] 
 
scsi: isci: Switch to attribute groups
struct device supports attribute groups directly but does not support
struct device_attribute directly. Hence switch to attribute groups.
Link: https://lore.kernel.org/r/20211012233558.4066756-27-bvanassche@acm.org  
Signed-off-by: Bart Van Assche <bvanassche@acm.org> 
Signed-off-by: Martin K. Petersen <martin.petersen@oracle.com> 
Bart Van Assche [Tue, 12 Oct 2021 23:35:37 +0000  (16:35 -0700)] 
 
scsi: ipr: Switch to attribute groups
struct device supports attribute groups directly but does not support
struct device_attribute directly. Hence switch to attribute groups.
Link: https://lore.kernel.org/r/20211012233558.4066756-26-bvanassche@acm.org  
Signed-off-by: Bart Van Assche <bvanassche@acm.org> 
Signed-off-by: Martin K. Petersen <martin.petersen@oracle.com> 
Bart Van Assche [Tue, 12 Oct 2021 23:35:36 +0000  (16:35 -0700)] 
 
scsi: ibmvfc: Switch to attribute groups
struct device supports attribute groups directly but does not support
struct device_attribute directly. Hence switch to attribute groups.
Link: https://lore.kernel.org/r/20211012233558.4066756-25-bvanassche@acm.org  
Acked-by: Tyrel Datwyler <tyreld@linux.ibm.com> 
Signed-off-by: Bart Van Assche <bvanassche@acm.org> 
Signed-off-by: Martin K. Petersen <martin.petersen@oracle.com> 
Bart Van Assche [Tue, 12 Oct 2021 23:35:35 +0000  (16:35 -0700)] 
 
scsi: ibmvscsi: Switch to attribute groups
struct device supports attribute groups directly but does not support
struct device_attribute directly. Hence switch to attribute groups.
Link: https://lore.kernel.org/r/20211012233558.4066756-24-bvanassche@acm.org  
Acked-by: Tyrel Datwyler <tyreld@linux.ibm.com> 
Signed-off-by: Bart Van Assche <bvanassche@acm.org> 
Signed-off-by: Martin K. Petersen <martin.petersen@oracle.com> 
Bart Van Assche [Tue, 12 Oct 2021 23:35:34 +0000  (16:35 -0700)] 
 
scsi: hptiop: Switch to attribute groups
struct device supports attribute groups directly but does not support
struct device_attribute directly. Hence switch to attribute groups.
Link: https://lore.kernel.org/r/20211012233558.4066756-23-bvanassche@acm.org  
Signed-off-by: Bart Van Assche <bvanassche@acm.org> 
Signed-off-by: Martin K. Petersen <martin.petersen@oracle.com> 
Bart Van Assche [Tue, 12 Oct 2021 23:35:33 +0000  (16:35 -0700)] 
 
scsi: hpsa: Switch to attribute groups
struct device supports attribute groups directly but does not support
struct device_attribute directly. Hence switch to attribute groups.
Link: https://lore.kernel.org/r/20211012233558.4066756-22-bvanassche@acm.org  
Signed-off-by: Bart Van Assche <bvanassche@acm.org> 
Signed-off-by: Martin K. Petersen <martin.petersen@oracle.com> 
Bart Van Assche [Tue, 12 Oct 2021 23:35:32 +0000  (16:35 -0700)] 
 
scsi: hisi_sas: Switch to attribute groups
struct device supports attribute groups directly but does not support
struct device_attribute directly. Hence switch to attribute groups.
Link: https://lore.kernel.org/r/20211012233558.4066756-21-bvanassche@acm.org  
Acked-by: John Garry <john.garry@huawei.com> 
Signed-off-by: Bart Van Assche <bvanassche@acm.org> 
Signed-off-by: Martin K. Petersen <martin.petersen@oracle.com> 
Bart Van Assche [Tue, 12 Oct 2021 23:35:31 +0000  (16:35 -0700)] 
 
scsi: fnic: Switch to attribute groups
struct device supports attribute groups directly but does not support
struct device_attribute directly. Hence switch to attribute groups.
Link: https://lore.kernel.org/r/20211012233558.4066756-20-bvanassche@acm.org  
Signed-off-by: Bart Van Assche <bvanassche@acm.org> 
Signed-off-by: Martin K. Petersen <martin.petersen@oracle.com> 
Bart Van Assche [Tue, 12 Oct 2021 23:35:30 +0000  (16:35 -0700)] 
 
scsi: cxlflash: Switch to attribute groups
struct device supports attribute groups directly but does not support
struct device_attribute directly. Hence switch to attribute groups.
Link: https://lore.kernel.org/r/20211012233558.4066756-19-bvanassche@acm.org  
Signed-off-by: Bart Van Assche <bvanassche@acm.org> 
Signed-off-by: Martin K. Petersen <martin.petersen@oracle.com> 
Bart Van Assche [Tue, 12 Oct 2021 23:35:29 +0000  (16:35 -0700)] 
 
scsi: csiostor: Switch to attribute groups
struct device supports attribute groups directly but does not support
struct device_attribute directly. Hence switch to attribute groups.
Link: https://lore.kernel.org/r/20211012233558.4066756-18-bvanassche@acm.org  
Signed-off-by: Bart Van Assche <bvanassche@acm.org> 
Signed-off-by: Martin K. Petersen <martin.petersen@oracle.com> 
Bart Van Assche [Tue, 12 Oct 2021 23:35:28 +0000  (16:35 -0700)] 
 
scsi: bnx2i: Switch to attribute groups
struct device supports attribute groups directly but does not support
struct device_attribute directly. Hence switch to attribute groups.
Link: https://lore.kernel.org/r/20211012233558.4066756-17-bvanassche@acm.org  
Signed-off-by: Bart Van Assche <bvanassche@acm.org> 
Signed-off-by: Martin K. Petersen <martin.petersen@oracle.com> 
Bart Van Assche [Tue, 12 Oct 2021 23:35:27 +0000  (16:35 -0700)] 
 
scsi: bnx2fc: Switch to attribute groups
struct device supports attribute groups directly but does not support
struct device_attribute directly. Hence switch to attribute groups.
Link: https://lore.kernel.org/r/20211012233558.4066756-16-bvanassche@acm.org  
Signed-off-by: Bart Van Assche <bvanassche@acm.org> 
Signed-off-by: Martin K. Petersen <martin.petersen@oracle.com> 
Bart Van Assche [Tue, 12 Oct 2021 23:35:26 +0000  (16:35 -0700)] 
 
scsi: bfa: Switch to attribute groups
struct device supports attribute groups directly but does not support
struct device_attribute directly. Hence switch to attribute groups.
Link: https://lore.kernel.org/r/20211012233558.4066756-15-bvanassche@acm.org  
Signed-off-by: Bart Van Assche <bvanassche@acm.org> 
Signed-off-by: Martin K. Petersen <martin.petersen@oracle.com> 
Bart Van Assche [Tue, 12 Oct 2021 23:35:25 +0000  (16:35 -0700)] 
 
scsi: be2iscsi: Switch to attribute groups
struct device supports attribute groups directly but does not support
struct device_attribute directly. Hence switch to attribute groups.
Link: https://lore.kernel.org/r/20211012233558.4066756-14-bvanassche@acm.org  
Signed-off-by: Bart Van Assche <bvanassche@acm.org> 
Signed-off-by: Martin K. Petersen <martin.petersen@oracle.com> 
Bart Van Assche [Tue, 12 Oct 2021 23:35:24 +0000  (16:35 -0700)] 
 
scsi: arcmsr: Switch to attribute groups
struct device supports attribute groups directly but does not support
struct device_attribute directly. Hence switch to attribute groups.
Link: https://lore.kernel.org/r/20211012233558.4066756-13-bvanassche@acm.org  
Signed-off-by: Bart Van Assche <bvanassche@acm.org> 
Signed-off-by: Martin K. Petersen <martin.petersen@oracle.com> 
Bart Van Assche [Tue, 12 Oct 2021 23:35:23 +0000  (16:35 -0700)] 
 
scsi: aacraid: Switch to attribute groups
struct device supports attribute groups directly but does not support
struct device_attribute directly. Hence switch to attribute groups.
Link: https://lore.kernel.org/r/20211012233558.4066756-12-bvanassche@acm.org  
Signed-off-by: Bart Van Assche <bvanassche@acm.org> 
Signed-off-by: Martin K. Petersen <martin.petersen@oracle.com> 
Bart Van Assche [Tue, 12 Oct 2021 23:35:22 +0000  (16:35 -0700)] 
 
scsi: 53c700: Switch to attribute groups
struct device supports attribute groups directly but does not support
struct device_attribute directly. Hence switch to attribute groups.
Link: https://lore.kernel.org/r/20211012233558.4066756-11-bvanassche@acm.org  
Signed-off-by: Bart Van Assche <bvanassche@acm.org> 
Signed-off-by: Martin K. Petersen <martin.petersen@oracle.com> 
Bart Van Assche [Tue, 12 Oct 2021 23:35:21 +0000  (16:35 -0700)] 
 
scsi: 3w-xxxx: Switch to attribute groups
struct device supports attribute groups directly but does not support
struct device_attribute directly. Hence switch to attribute groups.
Link: https://lore.kernel.org/r/20211012233558.4066756-10-bvanassche@acm.org  
Signed-off-by: Bart Van Assche <bvanassche@acm.org> 
Signed-off-by: Martin K. Petersen <martin.petersen@oracle.com> 
Bart Van Assche [Tue, 12 Oct 2021 23:35:20 +0000  (16:35 -0700)] 
 
scsi: 3w-sas: Switch to attribute groups
struct device supports attribute groups directly but does not support
struct device_attribute directly. Hence switch to attribute groups.
Link: https://lore.kernel.org/r/20211012233558.4066756-9-bvanassche@acm.org  
Signed-off-by: Bart Van Assche <bvanassche@acm.org> 
Signed-off-by: Martin K. Petersen <martin.petersen@oracle.com> 
Bart Van Assche [Tue, 12 Oct 2021 23:35:19 +0000  (16:35 -0700)] 
 
scsi: 3w-9xxx: Switch to attribute groups
struct device supports attribute groups directly but does not support
struct device_attribute directly. Hence switch to attribute groups.
Link: https://lore.kernel.org/r/20211012233558.4066756-8-bvanassche@acm.org  
Signed-off-by: Bart Van Assche <bvanassche@acm.org> 
Signed-off-by: Martin K. Petersen <martin.petersen@oracle.com> 
Bart Van Assche [Tue, 12 Oct 2021 23:35:18 +0000  (16:35 -0700)] 
 
scsi: zfcp: Switch to attribute groups
struct device supports attribute groups directly but does not support
struct device_attribute directly. Hence switch to attribute groups.
Link: https://lore.kernel.org/r/20211012233558.4066756-7-bvanassche@acm.org  
Acked-by: Benjamin Block <bblock@linux.ibm.com> 
Signed-off-by: Bart Van Assche <bvanassche@acm.org> 
Signed-off-by: Martin K. Petersen <martin.petersen@oracle.com> 
Bart Van Assche [Tue, 12 Oct 2021 23:35:17 +0000  (16:35 -0700)] 
 
scsi: message: fusion: Switch to attribute groups
struct device supports attribute groups directly but does not support
struct device_attribute directly. Hence switch to attribute groups.
Link: https://lore.kernel.org/r/20211012233558.4066756-6-bvanassche@acm.org  
Signed-off-by: Bart Van Assche <bvanassche@acm.org> 
Signed-off-by: Martin K. Petersen <martin.petersen@oracle.com> 
Bart Van Assche [Tue, 12 Oct 2021 23:35:16 +0000  (16:35 -0700)] 
 
scsi: RDMA/srp: Switch to attribute groups
struct device supports attribute groups directly but does not support
struct device_attribute directly. Hence switch to attribute groups.
Link: https://lore.kernel.org/r/20211012233558.4066756-5-bvanassche@acm.org  
Signed-off-by: Bart Van Assche <bvanassche@acm.org> 
Signed-off-by: Martin K. Petersen <martin.petersen@oracle.com> 
Bart Van Assche [Tue, 12 Oct 2021 23:35:15 +0000  (16:35 -0700)] 
 
scsi: firewire: sbp2: Switch to attribute groups
struct device supports attribute groups directly but does not support
struct device_attribute directly. Hence switch to attribute groups.
Link: https://lore.kernel.org/r/20211012233558.4066756-4-bvanassche@acm.org  
Signed-off-by: Bart Van Assche <bvanassche@acm.org> 
Signed-off-by: Martin K. Petersen <martin.petersen@oracle.com> 
Bart Van Assche [Tue, 12 Oct 2021 23:35:14 +0000  (16:35 -0700)] 
 
scsi: ata: Switch to attribute groups
struct device supports attribute groups directly but does not support
struct device_attribute directly. Hence switch to attribute groups.
Link: https://lore.kernel.org/r/20211012233558.4066756-3-bvanassche@acm.org  
Acked-by: Damien Le Moal <damien.lemoal@opensource.wdc.com> 
Signed-off-by: Bart Van Assche <bvanassche@acm.org> 
Signed-off-by: Martin K. Petersen <martin.petersen@oracle.com> 
Bart Van Assche [Tue, 12 Oct 2021 23:35:13 +0000  (16:35 -0700)] 
 
scsi: core: Register sysfs attributes earlier
A quote from Documentation/driver-api/driver-model/device.rst:
"Word of warning:  While the kernel allows device_create_file() and
device_remove_file() to be called on a device at any time, userspace has
strict expectations on when attributes get created.  When a new device is
registered in the kernel, a uevent is generated to notify userspace (like
udev) that a new device is available.  If attributes are added after the
device is registered, then userspace won't get notified and userspace will
not know about the new attributes."
Hence register SCSI host sysfs attributes before the SCSI host shost_dev
uevent is emitted instead of after that event has been emitted.
Link: https://lore.kernel.org/r/20211012233558.4066756-2-bvanassche@acm.org  
Cc: Greg Kroah-Hartman <gregkh@linuxfoundation.org> 
Reviewed-by: Benjamin Block <bblock@linux.ibm.com> 
Signed-off-by: Bart Van Assche <bvanassche@acm.org> 
Signed-off-by: Martin K. Petersen <martin.petersen@oracle.com> 
Bart Van Assche [Thu, 7 Oct 2021 20:46:14 +0000  (13:46 -0700)] 
 
scsi: core: Remove the 'done' argument from SCSI queuecommand_lck functions
The DEF_SCSI_QCMD() macro passes the addresses of the SCSI host lock and
also that of the scsi_done function to the queuecommand_lck() function
implementations. Remove the 'scsi_done' argument since its address is
now a constant and instead call 'scsi_done' directly from inside the
queuecommand_lck() functions.
Link: https://lore.kernel.org/r/20211007204618.2196847-14-bvanassche@acm.org  
Signed-off-by: Bart Van Assche <bvanassche@acm.org> 
Signed-off-by: Martin K. Petersen <martin.petersen@oracle.com> 
Bart Van Assche [Thu, 7 Oct 2021 20:46:13 +0000  (13:46 -0700)] 
 
scsi: fas216: Introduce the function fas216_queue_command_internal()
This patch does not change any functionality but prepares for removal of
the second argument of the fas216_queue_command_lck() function.
Link: https://lore.kernel.org/r/20211007204618.2196847-13-bvanassche@acm.org  
Signed-off-by: Bart Van Assche <bvanassche@acm.org> 
Signed-off-by: Martin K. Petersen <martin.petersen@oracle.com> 
Bart Van Assche [Thu, 7 Oct 2021 20:46:12 +0000  (13:46 -0700)] 
 
scsi: isci: Remove a declaration
There is no function with the name isci_queuecommand(). Hence remove the
declaration for isci_queuecommand().
Link: https://lore.kernel.org/r/20211007204618.2196847-12-bvanassche@acm.org  
Signed-off-by: Bart Van Assche <bvanassche@acm.org> 
Signed-off-by: Martin K. Petersen <martin.petersen@oracle.com> 
Bart Van Assche [Thu, 7 Oct 2021 20:46:11 +0000  (13:46 -0700)] 
 
scsi: core: Call scsi_done directly
Conditional statements are faster than indirect calls. Hence call
scsi_done() directly. Since this patch removes the last user of the
scsi_done member, also remove that data structure member.
Link: https://lore.kernel.org/r/20211007204618.2196847-11-bvanassche@acm.org  
Reviewed-by: Benjamin Block <bblock@linux.ibm.com> 
Reviewed-by: Bean Huo <beanhuo@micron.com> 
Signed-off-by: Bart Van Assche <bvanassche@acm.org> 
Signed-off-by: Martin K. Petersen <martin.petersen@oracle.com> 
Bart Van Assche [Thu, 7 Oct 2021 20:46:10 +0000  (13:46 -0700)] 
 
scsi: usb: Call scsi_done() directly
Conditional statements are faster than indirect calls. Hence call
scsi_done() directly.
Link: https://lore.kernel.org/r/20211007204618.2196847-10-bvanassche@acm.org  
Signed-off-by: Bart Van Assche <bvanassche@acm.org> 
Signed-off-by: Martin K. Petersen <martin.petersen@oracle.com> 
Bart Van Assche [Thu, 7 Oct 2021 20:46:09 +0000  (13:46 -0700)] 
 
scsi: target: tcm_loop: Call scsi_done() directly
Conditional statements are faster than indirect calls. Hence call
scsi_done() directly.
Link: https://lore.kernel.org/r/20211007204618.2196847-9-bvanassche@acm.org  
Signed-off-by: Bart Van Assche <bvanassche@acm.org> 
Signed-off-by: Martin K. Petersen <martin.petersen@oracle.com> 
Bart Van Assche [Thu, 7 Oct 2021 20:46:08 +0000  (13:46 -0700)] 
 
scsi: staging: unisys: visorhba: Call scsi_done() directly
Conditional statements are faster than indirect calls. Hence call
scsi_done() directly.
Link: https://lore.kernel.org/r/20211007204618.2196847-8-bvanassche@acm.org  
Acked-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org> 
Signed-off-by: Bart Van Assche <bvanassche@acm.org> 
Signed-off-by: Martin K. Petersen <martin.petersen@oracle.com> 
Bart Van Assche [Thu, 7 Oct 2021 20:46:07 +0000  (13:46 -0700)] 
 
scsi: staging: rts5208: Call scsi_done() directly
Conditional statements are faster than indirect calls. Hence call
scsi_done() directly.
Link: https://lore.kernel.org/r/20211007204618.2196847-7-bvanassche@acm.org  
Acked-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org> 
Signed-off-by: Bart Van Assche <bvanassche@acm.org> 
Signed-off-by: Martin K. Petersen <martin.petersen@oracle.com> 
Bart Van Assche [Thu, 7 Oct 2021 20:46:06 +0000  (13:46 -0700)] 
 
scsi: xen-scsifront: Call scsi_done() directly
Conditional statements are faster than indirect calls. Hence call
scsi_done() directly.
Link: https://lore.kernel.org/r/20211007204618.2196847-6-bvanassche@acm.org  
Reviewed-by: Juergen Gross <jgross@suse.com> 
Signed-off-by: Bart Van Assche <bvanassche@acm.org> 
Signed-off-by: Martin K. Petersen <martin.petersen@oracle.com> 
Bart Van Assche [Thu, 7 Oct 2021 20:46:05 +0000  (13:46 -0700)] 
 
scsi: wd719x: Call scsi_done() directly
Conditional statements are faster than indirect calls. Hence call
scsi_done() directly.
Link: https://lore.kernel.org/r/20211007204618.2196847-5-bvanassche@acm.org  
Signed-off-by: Bart Van Assche <bvanassche@acm.org> 
Signed-off-by: Martin K. Petersen <martin.petersen@oracle.com> 
Bart Van Assche [Thu, 7 Oct 2021 20:46:04 +0000  (13:46 -0700)] 
 
scsi: wd33c93: Call scsi_done() directly
Conditional statements are faster than indirect calls. Hence call
scsi_done() directly.
Link: https://lore.kernel.org/r/20211007204618.2196847-4-bvanassche@acm.org  
Signed-off-by: Bart Van Assche <bvanassche@acm.org> 
Signed-off-by: Martin K. Petersen <martin.petersen@oracle.com> 
Bart Van Assche [Thu, 7 Oct 2021 20:46:03 +0000  (13:46 -0700)] 
 
scsi: vmw_pvscsi: Call scsi_done() directly
Conditional statements are faster than indirect calls. Hence call
scsi_done() directly.
Link: https://lore.kernel.org/r/20211007204618.2196847-3-bvanassche@acm.org  
Signed-off-by: Bart Van Assche <bvanassche@acm.org> 
Signed-off-by: Martin K. Petersen <martin.petersen@oracle.com> 
Bart Van Assche [Thu, 7 Oct 2021 20:46:02 +0000  (13:46 -0700)] 
 
scsi: virtio_scsi: Call scsi_done() directly
Conditional statements are faster than indirect calls. Hence call
scsi_done() directly. Additionally, update a comment that refers to the
REQ_ATOM_COMPLETE flag since that flag has been removed a long time ago.
Link: https://lore.kernel.org/r/20211007204618.2196847-2-bvanassche@acm.org  
Signed-off-by: Bart Van Assche <bvanassche@acm.org> 
Signed-off-by: Martin K. Petersen <martin.petersen@oracle.com> 
Bart Van Assche [Thu, 7 Oct 2021 20:46:01 +0000  (13:46 -0700)] 
 
scsi: ufs: Call scsi_done() directly
Conditional statements are faster than indirect calls. Hence call
scsi_done() directly.
Link: https://lore.kernel.org/r/20211007204618.2196847-1-bvanassche@acm.org  
Reviewed-by: Bean Huo <beanhuo@micron.com> 
Signed-off-by: Bart Van Assche <bvanassche@acm.org> 
Signed-off-by: Martin K. Petersen <martin.petersen@oracle.com> 
Bart Van Assche [Thu, 7 Oct 2021 20:29:09 +0000  (13:29 -0700)] 
 
scsi: sym53c8xx_2: Call scsi_done() directly
Conditional statements are faster than indirect calls. Hence call
scsi_done() directly.
Link: https://lore.kernel.org/r/20211007202923.2174984-75-bvanassche@acm.org  
Signed-off-by: Bart Van Assche <bvanassche@acm.org> 
Signed-off-by: Martin K. Petersen <martin.petersen@oracle.com> 
Bart Van Assche [Thu, 7 Oct 2021 20:29:08 +0000  (13:29 -0700)] 
 
scsi: storvsc_drv: Call scsi_done() directly
Conditional statements are faster than indirect calls. Hence call
scsi_done() directly.
Link: https://lore.kernel.org/r/20211007202923.2174984-74-bvanassche@acm.org  
Reviewed-by: Haiyang Zhang <haiyangz@microsoft.com> 
Signed-off-by: Bart Van Assche <bvanassche@acm.org> 
Signed-off-by: Martin K. Petersen <martin.petersen@oracle.com> 
Bart Van Assche [Thu, 7 Oct 2021 20:29:07 +0000  (13:29 -0700)] 
 
scsi: stex: Call scsi_done() directly
Conditional statements are faster than indirect calls. Hence call
scsi_done() directly.
Link: https://lore.kernel.org/r/20211007202923.2174984-73-bvanassche@acm.org  
Signed-off-by: Bart Van Assche <bvanassche@acm.org> 
Signed-off-by: Martin K. Petersen <martin.petersen@oracle.com> 
Bart Van Assche [Thu, 7 Oct 2021 20:29:06 +0000  (13:29 -0700)] 
 
scsi: snic: Call scsi_done() directly
Conditional statements are faster than indirect calls. Hence call
scsi_done() directly.
Link: https://lore.kernel.org/r/20211007202923.2174984-72-bvanassche@acm.org  
Signed-off-by: Bart Van Assche <bvanassche@acm.org> 
Signed-off-by: Martin K. Petersen <martin.petersen@oracle.com> 
Bart Van Assche [Thu, 7 Oct 2021 20:29:05 +0000  (13:29 -0700)] 
 
scsi: smartpqi: Call scsi_done() directly
Conditional statements are faster than indirect calls. Hence call
scsi_done() directly.
Link: https://lore.kernel.org/r/20211007202923.2174984-71-bvanassche@acm.org  
Signed-off-by: Bart Van Assche <bvanassche@acm.org> 
Signed-off-by: Martin K. Petersen <martin.petersen@oracle.com> 
Bart Van Assche [Thu, 7 Oct 2021 20:29:04 +0000  (13:29 -0700)] 
 
scsi: scsi_debug: Call scsi_done() directly
Conditional statements are faster than indirect calls. Hence call
scsi_done() directly.
Link: https://lore.kernel.org/r/20211007202923.2174984-70-bvanassche@acm.org  
Acked-by: Douglas Gilbert <dgilbert@interlog.com> 
Signed-off-by: Bart Van Assche <bvanassche@acm.org> 
Signed-off-by: Martin K. Petersen <martin.petersen@oracle.com> 
Bart Van Assche [Thu, 7 Oct 2021 20:29:03 +0000  (13:29 -0700)] 
 
scsi: qlogicpti: Call scsi_done() directly
Conditional statements are faster than indirect calls. Hence call
scsi_done() directly.
Link: https://lore.kernel.org/r/20211007202923.2174984-69-bvanassche@acm.org  
Signed-off-by: Bart Van Assche <bvanassche@acm.org> 
Signed-off-by: Martin K. Petersen <martin.petersen@oracle.com> 
Bart Van Assche [Thu, 7 Oct 2021 20:29:02 +0000  (13:29 -0700)] 
 
scsi: qlogicfas408: Call scsi_done() directly
Conditional statements are faster than indirect calls. Hence call
scsi_done() directly.
Link: https://lore.kernel.org/r/20211007202923.2174984-68-bvanassche@acm.org  
Signed-off-by: Bart Van Assche <bvanassche@acm.org> 
Signed-off-by: Martin K. Petersen <martin.petersen@oracle.com> 
Bart Van Assche [Thu, 7 Oct 2021 20:29:01 +0000  (13:29 -0700)] 
 
scsi: qla4xxx: Call scsi_done() directly
Conditional statements are faster than indirect calls. Hence call
scsi_done() directly.
Link: https://lore.kernel.org/r/20211007202923.2174984-67-bvanassche@acm.org  
Signed-off-by: Bart Van Assche <bvanassche@acm.org> 
Signed-off-by: Martin K. Petersen <martin.petersen@oracle.com> 
Bart Van Assche [Thu, 7 Oct 2021 20:29:00 +0000  (13:29 -0700)] 
 
scsi: qla2xxx: Call scsi_done() directly
Conditional statements are faster than indirect calls. Hence call
scsi_done() directly.
Link: https://lore.kernel.org/r/20211007202923.2174984-66-bvanassche@acm.org  
Signed-off-by: Bart Van Assche <bvanassche@acm.org> 
Signed-off-by: Martin K. Petersen <martin.petersen@oracle.com> 
Bart Van Assche [Thu, 7 Oct 2021 20:28:59 +0000  (13:28 -0700)] 
 
scsi: qla1280: Call scsi_done() directly
Conditional statements are faster than indirect calls. Hence call
scsi_done() directly.
Link: https://lore.kernel.org/r/20211007202923.2174984-65-bvanassche@acm.org  
Signed-off-by: Bart Van Assche <bvanassche@acm.org> 
Signed-off-by: Martin K. Petersen <martin.petersen@oracle.com> 
Bart Van Assche [Thu, 7 Oct 2021 20:28:58 +0000  (13:28 -0700)] 
 
scsi: qedf: Call scsi_done() directly
Conditional statements are faster than indirect calls. Hence call
scsi_done() directly.
Link: https://lore.kernel.org/r/20211007202923.2174984-64-bvanassche@acm.org  
Signed-off-by: Bart Van Assche <bvanassche@acm.org> 
Signed-off-by: Martin K. Petersen <martin.petersen@oracle.com> 
Bart Van Assche [Thu, 7 Oct 2021 20:28:57 +0000  (13:28 -0700)] 
 
scsi: ps3rom: Call scsi_done() directly
Conditional statements are faster than indirect calls. Hence call
scsi_done() directly.
Link: https://lore.kernel.org/r/20211007202923.2174984-63-bvanassche@acm.org  
Signed-off-by: Bart Van Assche <bvanassche@acm.org> 
Signed-off-by: Martin K. Petersen <martin.petersen@oracle.com> 
Bart Van Assche [Thu, 7 Oct 2021 20:28:56 +0000  (13:28 -0700)] 
 
scsi: ppa: Call scsi_done() directly
Conditional statements are faster than indirect calls. Hence call
scsi_done() directly.
Link: https://lore.kernel.org/r/20211007202923.2174984-62-bvanassche@acm.org  
Signed-off-by: Bart Van Assche <bvanassche@acm.org> 
Signed-off-by: Martin K. Petersen <martin.petersen@oracle.com> 
Bart Van Assche [Thu, 7 Oct 2021 20:28:55 +0000  (13:28 -0700)] 
 
scsi: pmcraid: Call scsi_done() directly
Conditional statements are faster than indirect calls. Hence call
scsi_done() directly.
Link: https://lore.kernel.org/r/20211007202923.2174984-61-bvanassche@acm.org  
Signed-off-by: Bart Van Assche <bvanassche@acm.org> 
Signed-off-by: Martin K. Petersen <martin.petersen@oracle.com> 
Bart Van Assche [Thu, 7 Oct 2021 20:28:54 +0000  (13:28 -0700)] 
 
scsi: pcmcia: Call scsi_done() directly
Conditional statements are faster than indirect calls. Hence call
scsi_done() directly.
Link: https://lore.kernel.org/r/20211007202923.2174984-60-bvanassche@acm.org  
Signed-off-by: Bart Van Assche <bvanassche@acm.org> 
Signed-off-by: Martin K. Petersen <martin.petersen@oracle.com> 
Bart Van Assche [Thu, 7 Oct 2021 20:28:53 +0000  (13:28 -0700)] 
 
scsi: nsp32: Call scsi_done() directly
Conditional statements are faster than indirect calls. Hence call
scsi_done() directly.
Link: https://lore.kernel.org/r/20211007202923.2174984-59-bvanassche@acm.org  
Signed-off-by: Bart Van Assche <bvanassche@acm.org> 
Signed-off-by: Martin K. Petersen <martin.petersen@oracle.com> 
Bart Van Assche [Thu, 7 Oct 2021 20:28:52 +0000  (13:28 -0700)] 
 
scsi: ncr53c8xx: Call scsi_done() directly
Conditional statements are faster than indirect calls. Hence call
scsi_done() directly.
Link: https://lore.kernel.org/r/20211007202923.2174984-58-bvanassche@acm.org  
Signed-off-by: Bart Van Assche <bvanassche@acm.org> 
Signed-off-by: Martin K. Petersen <martin.petersen@oracle.com> 
Bart Van Assche [Thu, 7 Oct 2021 20:28:50 +0000  (13:28 -0700)] 
 
scsi: myrs: Call scsi_done() directly
Conditional statements are faster than indirect calls. Hence call
scsi_done() directly.
Link: https://lore.kernel.org/r/20211007202923.2174984-56-bvanassche@acm.org  
Signed-off-by: Bart Van Assche <bvanassche@acm.org> 
Signed-off-by: Martin K. Petersen <martin.petersen@oracle.com> 
Bart Van Assche [Thu, 7 Oct 2021 20:28:49 +0000  (13:28 -0700)] 
 
scsi: myrb: Call scsi_done() directly
Conditional statements are faster than indirect calls. Hence call
scsi_done() directly.
Link: https://lore.kernel.org/r/20211007202923.2174984-55-bvanassche@acm.org  
Signed-off-by: Bart Van Assche <bvanassche@acm.org> 
Signed-off-by: Martin K. Petersen <martin.petersen@oracle.com> 
Bart Van Assche [Thu, 7 Oct 2021 20:28:48 +0000  (13:28 -0700)] 
 
scsi: mvumi: Call scsi_done() directly
Conditional statements are faster than indirect calls. Hence call
scsi_done() directly.
Link: https://lore.kernel.org/r/20211007202923.2174984-54-bvanassche@acm.org  
Signed-off-by: Bart Van Assche <bvanassche@acm.org> 
Signed-off-by: Martin K. Petersen <martin.petersen@oracle.com> 
Bart Van Assche [Thu, 7 Oct 2021 20:28:47 +0000  (13:28 -0700)] 
 
scsi: mpt3sas: Call scsi_done() directly
Conditional statements are faster than indirect calls. Hence call
scsi_done() directly.
Link: https://lore.kernel.org/r/20211007202923.2174984-53-bvanassche@acm.org  
Signed-off-by: Bart Van Assche <bvanassche@acm.org> 
Signed-off-by: Martin K. Petersen <martin.petersen@oracle.com>