]>
www.infradead.org Git - users/willy/linux.git/log 
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> 
Bart Van Assche [Thu, 7 Oct 2021 20:28:46 +0000  (13:28 -0700)] 
 
scsi: mpi3mr: Call scsi_done() directly
Conditional statements are faster than indirect calls. Hence call
scsi_done() directly.
Link: https://lore.kernel.org/r/20211007202923.2174984-52-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:45 +0000  (13:28 -0700)] 
 
scsi: mesh: Call scsi_done() directly
Conditional statements are faster than indirect calls. Hence call
scsi_done() directly.
Link: https://lore.kernel.org/r/20211007202923.2174984-51-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:44 +0000  (13:28 -0700)] 
 
scsi: megaraid: Call scsi_done() directly
Conditional statements are faster than indirect calls. Hence call
scsi_done() directly.
Link: https://lore.kernel.org/r/20211007202923.2174984-50-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:43 +0000  (13:28 -0700)] 
 
scsi: megaraid_sas: Call scsi_done() directly
Conditional statements are faster than indirect calls. Hence call
scsi_done() directly.
Link: https://lore.kernel.org/r/20211007202923.2174984-49-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:43 +0000  (13:28 -0700)] 
 
scsi: megaraid_mbox: Call scsi_done() directly
Conditional statements are faster than indirect calls. Hence call
scsi_done() directly.
Link: https://lore.kernel.org/r/20211007202923.2174984-49-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:42 +0000  (13:28 -0700)] 
 
scsi: mac53c94: Call scsi_done() directly
Conditional statements are faster than indirect calls. Hence call
scsi_done() directly.
Link: https://lore.kernel.org/r/20211007202923.2174984-48-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:41 +0000  (13:28 -0700)] 
 
scsi: lpfc: Call scsi_done() directly
Conditional statements are faster than indirect calls. Hence call
scsi_done() directly.
Link: https://lore.kernel.org/r/20211007202923.2174984-47-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:40 +0000  (13:28 -0700)] 
 
scsi: libsas: Call scsi_done() directly
Conditional statements are faster than indirect calls. Hence call
scsi_done() directly.
Link: https://lore.kernel.org/r/20211007202923.2174984-46-bvanassche@acm.org  
Reviewed-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 [Thu, 7 Oct 2021 20:28:39 +0000  (13:28 -0700)] 
 
scsi: libiscsi: Call scsi_done() directly
Conditional statements are faster than indirect calls. Hence call
scsi_done() directly.
Link: https://lore.kernel.org/r/20211007202923.2174984-45-bvanassche@acm.org  
Reviewed-by: Lee Duncan <lduncanb@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:28:38 +0000  (13:28 -0700)] 
 
scsi: libfc: Call scsi_done() directly
Conditional statements are faster than indirect calls. Hence call
scsi_done() directly.
Link: https://lore.kernel.org/r/20211007202923.2174984-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 [Thu, 7 Oct 2021 20:28:37 +0000  (13:28 -0700)] 
 
scsi: ips: Call scsi_done() directly
Conditional statements are faster than indirect calls. Hence call
scsi_done() directly.
Link: https://lore.kernel.org/r/20211007202923.2174984-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 [Thu, 7 Oct 2021 20:28:36 +0000  (13:28 -0700)] 
 
scsi: ipr: Call scsi_done() directly
Conditional statements are faster than indirect calls. Hence call
scsi_done() directly.
Link: https://lore.kernel.org/r/20211007202923.2174984-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 [Thu, 7 Oct 2021 20:28:35 +0000  (13:28 -0700)] 
 
scsi: initio: Call scsi_done() directly
Conditional statements are faster than indirect calls. Hence call
scsi_done() directly.
Link: https://lore.kernel.org/r/20211007202923.2174984-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 [Thu, 7 Oct 2021 20:28:34 +0000  (13:28 -0700)] 
 
scsi: imm: Call scsi_done() directly
Conditional statements are faster than indirect calls. Hence call
scsi_done() directly.
Link: https://lore.kernel.org/r/20211007202923.2174984-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 [Thu, 7 Oct 2021 20:28:33 +0000  (13:28 -0700)] 
 
scsi: ibmvscsi: Call scsi_done() directly
Conditional statements are faster than indirect calls. Hence call
scsi_done() directly.
Link: https://lore.kernel.org/r/20211007202923.2174984-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 [Thu, 7 Oct 2021 20:28:32 +0000  (13:28 -0700)] 
 
scsi: hptiop: Call scsi_done() directly
Conditional statements are faster than indirect calls. Hence call
scsi_done() directly.
Link: https://lore.kernel.org/r/20211007202923.2174984-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 [Thu, 7 Oct 2021 20:28:31 +0000  (13:28 -0700)] 
 
scsi: hpsa: Call scsi_done() directly
Conditional statements are faster than indirect calls. Hence call
scsi_done() directly.
Link: https://lore.kernel.org/r/20211007202923.2174984-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 [Thu, 7 Oct 2021 20:28:30 +0000  (13:28 -0700)] 
 
scsi: fnic: Call scsi_done() directly
Conditional statements are faster than indirect calls. Hence call
scsi_done() directly.
Link: https://lore.kernel.org/r/20211007202923.2174984-36-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:29 +0000  (13:28 -0700)] 
 
scsi: fdomain: Call scsi_done() directly
Conditional statements are faster than indirect calls. Hence call
scsi_done() directly.
Link: https://lore.kernel.org/r/20211007202923.2174984-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 [Thu, 7 Oct 2021 20:28:28 +0000  (13:28 -0700)] 
 
scsi: fas216: Stop using scsi_cmnd.scsi_done
Store the completion callback pointer in struct fas216_cmd_priv instead of
in struct scsi_cmnd. This patch prepares for removal of the scsi_done
member from struct scsi_cmnd.
Link: https://lore.kernel.org/r/20211007202923.2174984-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 [Thu, 7 Oct 2021 20:28:27 +0000  (13:28 -0700)] 
 
scsi: fas216: Introduce struct fas216_cmd_priv
Introduce a structure with driver-private data per SCSI command. This data
structure will be used by the next patch to store a function pointer.
Link: https://lore.kernel.org/r/20211007202923.2174984-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 [Thu, 7 Oct 2021 20:28:26 +0000  (13:28 -0700)] 
 
scsi: esp_scsi: Call scsi_done() directly
Conditional statements are faster than indirect calls. Hence call
scsi_done() directly.
Link: https://lore.kernel.org/r/20211007202923.2174984-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 [Thu, 7 Oct 2021 20:28:25 +0000  (13:28 -0700)] 
 
scsi: esas2r: Call scsi_done() directly
Conditional statements are faster than indirect calls. Hence call
scsi_done() directly.
Link: https://lore.kernel.org/r/20211007202923.2174984-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 [Thu, 7 Oct 2021 20:28:24 +0000  (13:28 -0700)] 
 
scsi: dpt_i2o: Call scsi_done() directly
Conditional statements are faster than indirect calls. Hence call
scsi_done() directly.
Link: https://lore.kernel.org/r/20211007202923.2174984-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 [Thu, 7 Oct 2021 20:28:23 +0000  (13:28 -0700)] 
 
scsi: dc395x: Call scsi_done() directly
Conditional statements are faster than indirect calls. Hence call
scsi_done() directly.
Link: https://lore.kernel.org/r/20211007202923.2174984-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 [Thu, 7 Oct 2021 20:28:22 +0000  (13:28 -0700)] 
 
scsi: cxlflash: Call scsi_done() directly
Conditional statements are faster than indirect calls. Hence call
scsi_done() directly.
Link: https://lore.kernel.org/r/20211007202923.2174984-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 [Thu, 7 Oct 2021 20:28:21 +0000  (13:28 -0700)] 
 
scsi: csiostor: Call scsi_done() directly
Conditional statements are faster than indirect calls. Hence call
scsi_done() directly.
Link: https://lore.kernel.org/r/20211007202923.2174984-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 [Thu, 7 Oct 2021 20:28:20 +0000  (13:28 -0700)] 
 
scsi: bnx2fc: Call scsi_done() directly
Conditional statements are faster than indirect calls. Hence call
scsi_done() directly.
Link: https://lore.kernel.org/r/20211007202923.2174984-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 [Thu, 7 Oct 2021 20:28:19 +0000  (13:28 -0700)] 
 
scsi: bfa: Call scsi_done() directly
Conditional statements are faster than indirect calls. Hence call
scsi_done() directly.
Link: https://lore.kernel.org/r/20211007202923.2174984-25-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:18 +0000  (13:28 -0700)] 
 
scsi: atp870u: Call scsi_done() directly
Conditional statements are faster than indirect calls. Hence call
scsi_done() directly.
Link: https://lore.kernel.org/r/20211007202923.2174984-24-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:17 +0000  (13:28 -0700)] 
 
scsi: arcmsr: Call scsi_done() directly
Conditional statements are faster than indirect calls. Hence call
scsi_done() directly.
Link: https://lore.kernel.org/r/20211007202923.2174984-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 [Thu, 7 Oct 2021 20:28:16 +0000  (13:28 -0700)] 
 
scsi: aic7xxx: Call scsi_done() directly
Conditional statements are faster than indirect calls. Hence call
scsi_done() directly.
Link: https://lore.kernel.org/r/20211007202923.2174984-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 [Thu, 7 Oct 2021 20:28:15 +0000  (13:28 -0700)] 
 
scsi: aha1542: Call scsi_done() directly
Conditional statements are faster than indirect calls. Hence call
scsi_done() directly.
Link: https://lore.kernel.org/r/20211007202923.2174984-21-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:14 +0000  (13:28 -0700)] 
 
scsi: aha152x: Call scsi_done() directly
Conditional statements are faster than indirect calls. Hence call
scsi_done() and reset_done() directly. The changes in this patch are as
follows:
 - Remove the 'done' argument from aha152x_internal_queue().
 - Change ptr->scsi_done(ptr) into aha152x_scsi_done(ptr).
 - Inside aha152x_scsi_done(), check the 'resetting' flag of SCp.phase
   since aha152x_internal_queue() specifies the 'reset_done' function
   pointer if and only if the third argument has the value 'resetting'.
Link: https://lore.kernel.org/r/20211007202923.2174984-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 [Thu, 7 Oct 2021 20:28:13 +0000  (13:28 -0700)] 
 
scsi: advansys: Call scsi_done() directly
Conditional statements are faster than indirect calls. Hence call
scsi_done() directly.
Link: https://lore.kernel.org/r/20211007202923.2174984-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 [Thu, 7 Oct 2021 20:28:12 +0000  (13:28 -0700)] 
 
scsi: acornscsi: Call scsi_done() directly
Conditional statements are faster than indirect calls. Hence call
scsi_done() directly.
Link: https://lore.kernel.org/r/20211007202923.2174984-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 [Thu, 7 Oct 2021 20:28:11 +0000  (13:28 -0700)] 
 
scsi: aacraid: Call scsi_done() directly
The aacraid driver invokes scmd->scsi_done(scmd) for two types of SCSI
commands:
 - SCSI commands initialized by the SCSI mid-layer.
 - SCSI commands initialized by aac_probe_container().
The processing sequence for SCSI commands allocated by
aac_probe_container() is as follows:
aac_probe_container()
-> _aac_probe_container(scmd, aac_probe_container_callback1)
  -> scmd->SCp.ptr = aac_probe_container_callback1
  -> aac_fib_send(..., _aac_probe_container1, scmd)
    -> fibptr->callback = _aac_probe_container1
    -> fibptr->callback_data = scmd
fibptr->callback(scmd)
-> _aac_probe_container1(scmd, fibptr)
   [ ... ]
   -> _aac_probe_container2(scmd, fibptr)
     -> Call scmd->SCp.ptr == aac_probe_container_callback1
       -> scmd->device = NULL;
The processing sequence for SCSI commands allocated by the SCSI mid-layer
if _aac_probe_container() is called is as follows:
aac_queuecommand()
-> aac_scsi_cmd()
  -> _aac_probe_container(scmd, aac_probe_container_callback2)
    -> scmd->SCp.ptr = aac_probe_container_callback2
    -> aac_fib_send(..., _aac_probe_container1, scmd)
fibptr->callback(scmd)
-> _aac_probe_container1(scmd, fibptr)
   [ ... ]
   -> _aac_probe_container2(scmd, fibptr)
     -> Call scmd->SCp.ptr == aac_probe_container_callback2
Preserve the existing call sequences by calling scsi_done() for commands
submitted by the mid-layer or aac_probe_container_scsi_done() for commands
submitted by aac_probe_container().
Link: https://lore.kernel.org/r/20211007202923.2174984-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 [Thu, 7 Oct 2021 20:28:10 +0000  (13:28 -0700)] 
 
scsi: aacraid: Introduce aac_scsi_done()
This patch does not change any functionality but makes the next patch in
this series easier to read.
Link: https://lore.kernel.org/r/20211007202923.2174984-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 [Thu, 7 Oct 2021 20:28:09 +0000  (13:28 -0700)] 
 
scsi: a100u2w: Call scsi_done() directly
Conditional statements are faster than indirect calls. Hence call
scsi_done() directly.
Link: https://lore.kernel.org/r/20211007202923.2174984-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 [Thu, 7 Oct 2021 20:28:08 +0000  (13:28 -0700)] 
 
scsi: NCR5380: Call scsi_done() directly
Conditional statements are faster than indirect calls. Hence call
scsi_done() directly.
Link: https://lore.kernel.org/r/20211007202923.2174984-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:28:07 +0000  (13:28 -0700)] 
 
scsi: BusLogic: Call scsi_done() directly
Conditional statements are faster than indirect calls. Hence call
scsi_done() directly.
Link: https://lore.kernel.org/r/20211007202923.2174984-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:28:06 +0000  (13:28 -0700)] 
 
scsi: 53c700: Call scsi_done() directly
Conditional statements are faster than indirect calls. Hence call
scsi_done() directly.
Link: https://lore.kernel.org/r/20211007202923.2174984-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:28:05 +0000  (13:28 -0700)] 
 
scsi: 3w-xxxx: Call scsi_done() directly
Conditional statements are faster than indirect calls. Hence call
scsi_done() directly.
Link: https://lore.kernel.org/r/20211007202923.2174984-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 [Thu, 7 Oct 2021 20:28:04 +0000  (13:28 -0700)] 
 
scsi: 3w-sas: Call scsi_done() directly
Conditional statements are faster than indirect calls. Hence call
scsi_done() directly.
Link: https://lore.kernel.org/r/20211007202923.2174984-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:28:03 +0000  (13:28 -0700)] 
 
scsi: 3w-9xxx: Call scsi_done() directly
Conditional statements are faster than indirect calls. Hence call
scsi_done() directly.
Link: https://lore.kernel.org/r/20211007202923.2174984-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:28:02 +0000  (13:28 -0700)] 
 
scsi: zfcp_scsi: Call scsi_done() directly
Conditional statements are faster than indirect calls. Hence call
scsi_done() directly.
Link: https://lore.kernel.org/r/20211007202923.2174984-8-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 [Thu, 7 Oct 2021 20:28:01 +0000  (13:28 -0700)] 
 
scsi: message: fusion: Call scsi_done() directly
Conditional statements are faster than indirect calls. Hence call
scsi_done() directly.
Link: https://lore.kernel.org/r/20211007202923.2174984-7-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:00 +0000  (13:28 -0700)] 
 
scsi: ib_srp: Call scsi_done() directly
Conditional statements are faster than indirect calls. Hence call
scsi_done() directly.
Link: https://lore.kernel.org/r/20211007202923.2174984-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 [Thu, 7 Oct 2021 20:27:59 +0000  (13:27 -0700)] 
 
scsi: firewire: sbp2: Call scsi_done() directly
Conditional statements are faster than indirect calls. Hence call
scsi_done() directly.
Link: https://lore.kernel.org/r/20211007202923.2174984-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:27:58 +0000  (13:27 -0700)] 
 
scsi: ata: Call scsi_done() directly
Conditional statements are faster than indirect calls. Hence call
scsi_done() directly.
Link: https://lore.kernel.org/r/20211007202923.2174984-4-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 [Thu, 7 Oct 2021 20:27:57 +0000  (13:27 -0700)] 
 
scsi: core: Rename scsi_mq_done() into scsi_done() and export it
Since the removal of the legacy block layer there is only one completion
function left in the SCSI core, namely scsi_mq_done(). Rename it into
scsi_done(). Export that function to allow SCSI LLDs to call it directly.
Link: https://lore.kernel.org/r/20211007202923.2174984-3-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:27:56 +0000  (13:27 -0700)] 
 
scsi: core: Use a structure member to track the SCSI command submitter
Conditional statements are faster than indirect calls. Use a structure
member to track the SCSI command submitter such that later patches can call
scsi_done(scmd) instead of scmd->scsi_done(scmd).
The asymmetric behavior that scsi_send_eh_cmnd() sets the submission
context to the SCSI error handler and that it does not restore the
submission context to the SCSI core is retained.
Link: https://lore.kernel.org/r/20211007202923.2174984-2-bvanassche@acm.org  
Cc: Hannes Reinecke <hare@suse.com> 
Cc: Ming Lei <ming.lei@redhat.com> 
Cc: Christoph Hellwig <hch@lst.de> 
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 [Wed, 6 Oct 2021 21:54:53 +0000  (14:54 -0700)] 
 
scsi: core: pm: Only runtime resume if necessary
The following query shows which drivers define callbacks that are called by
the power management support code in the SCSI core (scsi_pm.c):
$ git grep -nHEwA16 "$(echo $(git grep -h 'scsi_register_driver(&' |
      sed 's/.*&//;s/\..*//') | sed 's/ /|/g')" |
    grep '\.pm[[:blank:]]*=[[:blank:]]'
drivers/scsi/sd.c-620-			.pm = &sd_pm_ops,
drivers/scsi/sr.c-100-			.pm = &sr_pm_ops,
drivers/scsi/ufs/ufshcd.c-9765-		.pm = &ufshcd_wl_pm_ops,
Since unconditionally runtime resuming a device during system resume is not
necessary, remove that code. Modify the SCSI disk (sd) driver such that it
follows the same approach as the UFS driver, namely to skip system suspend
and resume for devices that are runtime suspended. The CD-ROM code does not
need to be updated since its PM callbacks do not affect the device power
state.
This patch has been tested as follows:
[ shell 1 ]
cd /sys/kernel/debug/tracing
grep -E 'blk_(pre|post)_runtime|runtime_(suspend|resume)|autosuspend_delay|pm_runtime_(get|put)' available_filter_functions |
  while read a b; do echo "$a"; done |
  grep -v __pm_runtime_resume >set_ftrace_filter
echo function > current_tracer
echo 1 > tracing_on
cat trace_pipe
[ shell 2 ]
cd /sys/block/sr0
 # Increase the event poll interval to make it easier to derive from the
 # tracing output whether runtime power actions are the result of sg_inq.
echo 30000 > events_poll_msecs
cd device/power
 # Enable runtime power management.
echo auto > control
echo 1000 > autosuspend_delay_ms
sleep 1
 # Verify in shell 1 that sr0 has been runtime suspended
sg_inq /dev/sr0
eject /dev/sr0
sg_inq /dev/sr0
 # Disable runtime power management.
echo on > control
cd /sys/block/sda/device/power
echo auto > control
echo 1000 > autosuspend_delay_ms
sleep 1
 # Verify in shell 1 that sr0 has been runtime suspended
sg_inq /dev/sda
Link: https://lore.kernel.org/r/20211006215453.3318929-4-bvanassche@acm.org  
Cc: Alan Stern <stern@rowland.harvard.edu> 
Cc: Dan Williams <dan.j.williams@intel.com> 
Cc: Hannes Reinecke <hare@suse.com> 
Cc: Adrian Hunter <adrian.hunter@intel.com> 
Cc: Martin Kepplinger <martin.kepplinger@puri.sm> 
Tested-by: Martin Kepplinger <martin.kepplinger@puri.sm> 
Signed-off-by: Bart Van Assche <bvanassche@acm.org> 
Signed-off-by: Martin K. Petersen <martin.petersen@oracle.com> 
Bart Van Assche [Wed, 6 Oct 2021 21:54:52 +0000  (14:54 -0700)] 
 
scsi: sd: Rename sd_resume() into sd_resume_system()
This patch does not change any functionality but makes the next patch in
this series easier to read.
Link: https://lore.kernel.org/r/20211006215453.3318929-3-bvanassche@acm.org  
Cc: Alan Stern <stern@rowland.harvard.edu> 
Cc: Dan Williams <dan.j.williams@intel.com> 
Cc: Hannes Reinecke <hare@suse.com> 
Cc: Adrian Hunter <adrian.hunter@intel.com> 
Cc: Martin Kepplinger <martin.kepplinger@puri.sm> 
Signed-off-by: Bart Van Assche <bvanassche@acm.org> 
Signed-off-by: Martin K. Petersen <martin.petersen@oracle.com> 
Bart Van Assche [Wed, 6 Oct 2021 21:54:51 +0000  (14:54 -0700)] 
 
scsi: core: pm: Rely on the device driver core for async power management
Instead of implementing asynchronous resume support in the SCSI core, rely
on the device driver core for resuming SCSI devices asynchronously.
Instead of only supporting asynchronous resumes, also support asynchronous
suspends.
Link: https://lore.kernel.org/r/20211006215453.3318929-2-bvanassche@acm.org  
Cc: Alan Stern <stern@rowland.harvard.edu> 
Cc: Dan Williams <dan.j.williams@intel.com> 
Cc: Hannes Reinecke <hare@suse.com> 
Cc: Adrian Hunter <adrian.hunter@intel.com> 
Cc: Martin Kepplinger <martin.kepplinger@puri.sm> 
Signed-off-by: Bart Van Assche <bvanassche@acm.org> 
Signed-off-by: Martin K. Petersen <martin.petersen@oracle.com> 
Sohaib Mohamed [Wed, 6 Oct 2021 15:48:03 +0000  (17:48 +0200)] 
 
scsi: Documentation: Fix typo in sysfs-driver-ufs
Remove repeated word: "the The amount"
Link: https://lore.kernel.org/r/20211006154804.135184-1-sohaib.amhmd@gmail.com  
Signed-off-by: Sohaib Mohamed <sohaib.amhmd@gmail.com> 
Signed-off-by: Martin K. Petersen <martin.petersen@oracle.com> 
Luo Jiaxing [Tue, 12 Oct 2021 12:26:28 +0000  (20:26 +0800)] 
 
scsi: hisi_sas: Disable SATA disk phy for severe I_T nexus reset failure
If the softreset fails in the I_T reset, libsas will then continue to issue
a controller reset to try to recover.
However a faulty disk may cause the softreset to fail, and resetting the
controller will not help this scenario. Indeed, we will just continue the
cycle of error handle handling to try to recover.
So if the softreset fails upon certain conditions, just disable the phy
associated with the disk. The user needs to handle this problem.
Link: https://lore.kernel.org/r/1634041588-74824-5-git-send-email-john.garry@huawei.com  
Signed-off-by: Luo Jiaxing <luojiaxing@huawei.com> 
Signed-off-by: John Garry <john.garry@huawei.com> 
Signed-off-by: Martin K. Petersen <martin.petersen@oracle.com> 
Luo Jiaxing [Tue, 12 Oct 2021 12:26:27 +0000  (20:26 +0800)] 
 
scsi: libsas: Export sas_phy_enable()
Export sas_phy_enable() so LLDDs can directly use it to control remote
phys.
We already do this for companion function sas_phy_reset().
Link: https://lore.kernel.org/r/1634041588-74824-4-git-send-email-john.garry@huawei.com  
Signed-off-by: Luo Jiaxing <luojiaxing@huawei.com> 
Signed-off-by: John Garry <john.garry@huawei.com> 
Signed-off-by: Martin K. Petersen <martin.petersen@oracle.com> 
Xiang Chen [Tue, 12 Oct 2021 12:26:26 +0000  (20:26 +0800)] 
 
scsi: hisi_sas: Wait for phyup in hisi_sas_control_phy()
When issuing a hardreset/linkreset/phy_set_linkrate from sysfs, the phy
will be disabled and re-enabled for the directly attached scenario.
It takes some time for the phy to come back up after re-enabling the phy.
If the controller becomes suspended while waiting for the phy to come back,
the phy up may be lost (along with the disk).
To solve this problem, wait for the phy up to occur with a timeout. Indeed
this is already done in hisi_sas_debug_I_T_nexus_reset() for local phys, so
just relocate the functionality to hisi_sas_control_phy().
Since the HA workqueue is drained when suspending the controller, and the
phy control function is called from the same workqueue, we can guarantee
that the controller will not be suspended during this period.
Link: https://lore.kernel.org/r/1634041588-74824-3-git-send-email-john.garry@huawei.com  
Signed-off-by: Xiang Chen <chenxiang66@hisilicon.com> 
Signed-off-by: John Garry <john.garry@huawei.com> 
Signed-off-by: Martin K. Petersen <martin.petersen@oracle.com> 
Xiang Chen [Tue, 12 Oct 2021 12:26:25 +0000  (20:26 +0800)] 
 
scsi: hisi_sas: Initialise devices in .slave_alloc callback
Perform driver-specific SCSI device initialization in the designated SCSI
midlayer callback instead of relying on the libsas "device found" callback.
The SCSI midlayer .slave_alloc interface is called prior to sending any I/O
to the device.
Link: https://lore.kernel.org/r/1634041588-74824-2-git-send-email-john.garry@huawei.com  
Signed-off-by: Xiang Chen <chenxiang66@hisilicon.com> 
Signed-off-by: John Garry <john.garry@huawei.com> 
Signed-off-by: Martin K. Petersen <martin.petersen@oracle.com> 
Adrian Hunter [Fri, 8 Oct 2021 08:40:48 +0000  (11:40 +0300)] 
 
scsi: ufs: core: Fix synchronization between scsi_unjam_host() and ufshcd_queuecommand()
The SCSI error handler calls scsi_unjam_host() which can call the queue
function ufshcd_queuecommand() indirectly. The error handler changes the
state to UFSHCD_STATE_RESET while running, but error interrupts that
happen while the error handler is running could change the state to
UFSHCD_STATE_EH_SCHEDULED_NON_FATAL which would allow requests to go
through ufshcd_queuecommand() even though the error handler is running.
Block that hole by checking whether the error handler is in progress.
Link: https://lore.kernel.org/r/20211008084048.257498-1-adrian.hunter@intel.com  
Reviewed-by: Asutosh Das <asutoshd@codeaurora.org> 
Signed-off-by: Adrian Hunter <adrian.hunter@intel.com> 
Signed-off-by: Martin K. Petersen <martin.petersen@oracle.com> 
Peter Wang [Wed, 6 Oct 2021 05:47:05 +0000  (13:47 +0800)] 
 
scsi: ufs: mediatek: Support vops pre suspend to disable auto-hibern8
Mediatek UFS needs auto-hibern8 disabled before suspend. Introduce a
solution to do pre-suspend before SSU (sleep).
Link: https://lore.kernel.org/r/20211006054705.21885-1-peter.wang@mediatek.com  
Reviewed-by: Bart Van Assche <bvanassche@acm.org> 
Reviewed-by: Bean Huo <beanhuo@micron.com> 
Signed-off-by: Peter Wang <peter.wang@mediatek.com> 
Signed-off-by: Martin K. Petersen <martin.petersen@oracle.com> 
Dan Carpenter [Wed, 6 Oct 2021 07:32:43 +0000  (10:32 +0300)] 
 
scsi: csiostor: Uninitialized data in csio_ln_vnp_read_cbfn()
This variable is just a temporary variable, used to do an endian
conversion.  The problem is that the last byte is not initialized.  After
the conversion is completely done, the last byte is discarded so it doesn't
cause a problem.  But static checkers and the KMSan runtime checker can
detect the uninitialized read and will complain about it.
Link: https://lore.kernel.org/r/20211006073242.GA8404@kili  
Fixes: 5036f0a0ecd3 ("[SCSI] csiostor: Fix sparse warnings.") 
Signed-off-by: Dan Carpenter <dan.carpenter@oracle.com> 
Signed-off-by: Martin K. Petersen <martin.petersen@oracle.com>