]> xenbits.xensource.com Git - pvdrivers/win/xenvbd.git/commitdiff
Move StorPort*() calls to adapter.c
authorOwen Smith <owen.smith@citrix.com>
Tue, 20 Jun 2017 14:17:10 +0000 (15:17 +0100)
committerPaul Durrant <paul.durrant@citrix.com>
Tue, 27 Jun 2017 14:25:34 +0000 (15:25 +0100)
Signed-off-by: Owen Smith <owen.smith@citrix.com>
src/xenvbd/adapter.c
src/xenvbd/adapter.h
src/xenvbd/target.c

index 2e85f9f78ea0ac946eac02b8ea1b1a2a0fca7fdc..ec6711ad84bc8a0c3334a701a09bbf1b6c93ab89 100644 (file)
@@ -58,7 +58,8 @@
 #include "debug.h"
 #include "assert.h"
 
-#define MAXNAMELEN  128
+#define XENVBD_MAX_QUEUE_DEPTH  254
+#define MAXNAMELEN              128
 #define ADAPTER_POOL_TAG        'adAX'
 
 struct _XENVBD_ADAPTER {
@@ -498,9 +499,7 @@ __AdapterEnumerate(
     }
 
     if (NeedInvalidate)
-        StorPortNotification(BusChangeDetected,
-                             Adapter,
-                             NULL);
+        AdapterTargetListChanged(Adapter);
     if (NeedReboot)
         DriverRequestReboot();
 }
@@ -1408,6 +1407,31 @@ AdapterCompleteSrb(
     StorPortNotification(RequestComplete, Adapter, Srb);
 }
 
+VOID
+AdapterTargetListChanged(
+    IN  PXENVBD_ADAPTER Adapter
+    )
+{
+    StorPortNotification(BusChangeDetected,
+                         Adapter,
+                         NULL);
+}
+
+VOID
+AdapterSetDeviceQueueDepth(
+    IN  PXENVBD_ADAPTER Adapter,
+    IN  ULONG           TargetId
+    )
+{
+    if (!StorPortSetDeviceQueueDepth(Adapter,
+                                     0,
+                                     (UCHAR)TargetId,
+                                     0,
+                                     XENVBD_MAX_QUEUE_DEPTH))
+        Verbose("Target[%d] : Failed to set queue depth\n",
+                TargetId);
+}
+
 static VOID
 AdapterUnplugRequest(
     IN  PXENVBD_ADAPTER Adapter,
@@ -1713,15 +1737,16 @@ AdapterHwBuildIo(
         Srb->SrbStatus = SRB_STATUS_ABORT_FAILED;
         break;
     case SRB_FUNCTION_RESET_BUS:
-        Srb->SrbStatus = SRB_STATUS_SUCCESS;
         AdapterHwResetBus(Adapter, Srb->PathId);
+        Srb->SrbStatus = SRB_STATUS_SUCCESS;
         break;
 
     default:
+        Srb->SrbStatus = SRB_STATUS_INVALID_REQUEST;
         break;
     }
 
-    StorPortNotification(RequestComplete, Adapter, Srb);
+    AdapterCompleteSrb(Adapter, Srb);
     return FALSE;
 }
 
@@ -1747,6 +1772,7 @@ AdapterHwStartIo(
     return TRUE;
 
 fail1:
+    Srb->SrbStatus = SRB_STATUS_INVALID_TARGET_ID;
     AdapterCompleteSrb(Adapter, Srb);
     return TRUE;
 }
index 5dd2e626ba46076a8f65164b53659ca3a38af0a2..b8706fd95500322a88b9a1d1b514a0596953beb2 100644 (file)
@@ -70,6 +70,17 @@ AdapterCompleteSrb(
     IN  PSCSI_REQUEST_BLOCK Srb
     );
 
+extern VOID
+AdapterTargetListChanged(
+    IN  PXENVBD_ADAPTER Adapter
+    );
+
+extern VOID
+AdapterSetDeviceQueueDepth(
+    IN  PXENVBD_ADAPTER Adapter,
+    IN  ULONG           TargetId
+    );
+
 extern NTSTATUS
 AdapterDispatchPnp(
     IN  PXENVBD_ADAPTER Adapter,
index c5dffa9d7829deb06634fd494138e2e88a352e65..5bab44012b1bc455db1e8e047d8f03096db7dac6 100644 (file)
@@ -49,8 +49,6 @@
 #include <suspend_interface.h>
 #include <stdlib.h>
 
-#define XENVBD_MAX_QUEUE_DEPTH          (254)
-
 typedef struct _XENVBD_SG_LIST {
     // SGList from SRB
     PSTOR_SCATTER_GATHER_LIST   SGList;
@@ -2021,13 +2019,8 @@ __TargetExecuteScsi(
         break;
 
     case SCSIOP_INQUIRY:
-        if (!StorPortSetDeviceQueueDepth(TargetGetAdapter(Target),
-                                         0,
-                                         (UCHAR)TargetGetTargetId(Target),
-                                         0,
-                                         XENVBD_MAX_QUEUE_DEPTH))
-            Verbose("Target[%d] : Failed to set queue depth\n",
-                    TargetGetTargetId(Target));
+        AdapterSetDeviceQueueDepth(TargetGetAdapter(Target),
+                                   TargetGetTargetId(Target));
         PdoInquiry(TargetGetTargetId(Target), FrontendGetInquiry(Target->Frontend), Srb);
         break;
     case SCSIOP_MODE_SENSE:
@@ -2305,13 +2298,13 @@ __TargetRemoveDevice(
     case SurpriseRemovePending:
         TargetSetMissing(Target, "Surprise Remove");
         TargetSetDevicePnpState(Target, Deleted);
-        StorPortNotification(BusChangeDetected, TargetGetAdapter(Target), 0);
+        AdapterTargetListChanged(TargetGetAdapter(Target));
         break;
 
     default:
         TargetSetMissing(Target, "Removed");
         TargetSetDevicePnpState(Target, Deleted);
-        StorPortNotification(BusChangeDetected, TargetGetAdapter(Target), 0);
+        AdapterTargetListChanged(TargetGetAdapter(Target));
         break;
     }
 }
@@ -2323,7 +2316,7 @@ __TargetEject(
 {
     TargetSetMissing(Target, "Ejected");
     TargetSetDevicePnpState(Target, Deleted);
-    StorPortNotification(BusChangeDetected, TargetGetAdapter(Target), 0);
+    AdapterTargetListChanged(TargetGetAdapter(Target));
 }
 
 __checkReturn
@@ -2417,7 +2410,7 @@ TargetIssueDeviceEject(
         IoRequestDeviceEject(Target->DeviceObject);
     } else {
         Verbose("Target[%d] : Triggering BusChangeDetected to detect device\n", TargetGetTargetId(Target));
-        StorPortNotification(BusChangeDetected, TargetGetAdapter(Target), 0);
+        AdapterTargetListChanged(TargetGetAdapter(Target));
     }
 }