]> git.proxmox.com Git - mirror_edk2.git/commitdiff
MdeModulePkg ScsiBusDxe: Only signal caller event when PassThru() succeeds
authorHao Wu <hao.a.wu@intel.com>
Tue, 22 Dec 2015 13:55:34 +0000 (13:55 +0000)
committerhwu1225 <hwu1225@Edk2>
Tue, 22 Dec 2015 13:55:34 +0000 (13:55 +0000)
In ScsiExecuteSCSICommand(), when SCSI devices do not support non-blocking
I/O but an event is passed from caller (UefiScsiLib), the function will
execute the SCSI I/O command in a blocking manner and signal the caller
event when the command completes.

Originally, caller event from UefiScsiLib will be signaled if the SCSI
command fails. UefiScsiLib will continue to signal its caller (BlockIO2
request from ScsiDiskDxe driver), which is not aligned with the UEFI spec
that event will not be signaled when BlockIO2 request returns with error.

This commit will signal ScsiExecuteSCSICommand()'s caller event only when
the SCSI command succeeds.

Contributed-under: TianoCore Contribution Agreement 1.0
Signed-off-by: Hao Wu <hao.a.wu@intel.com>
Reviewed-by: Feng Tian <feng.tian@intel.com>
git-svn-id: https://svn.code.sf.net/p/edk2/code/trunk/edk2@19447 6f19259b-4bc3-4df7-8a09-765794883524

MdeModulePkg/Bus/Scsi/ScsiBusDxe/ScsiBus.c

index 8eb73e7673fab86a3eed6c0839b4a670ba72885a..b10e25a38e9cccb39a600464545b42b67e3fa484 100644 (file)
@@ -1007,9 +1007,10 @@ ScsiExecuteSCSICommand (
                                                 ExtRequestPacket,\r
                                                 NULL\r
                                                 );\r
-      if (Event != NULL) {\r
+      if ((!EFI_ERROR(Status)) && (Event != NULL)) {\r
         //\r
-        // Signal Event to tell caller to pick up the SCSI IO Packet.\r
+        // Signal Event to tell caller to pick up the SCSI IO packet if the\r
+        // PassThru() succeeds.\r
         //\r
         gBS->SignalEvent (Event);\r
       }\r