Author: sephe
Date: Fri Oct 14 03:22:19 2016
New Revision: 307254
URL: https://svnweb.freebsd.org/changeset/base/307254

Log:
  MFC 306426
  
      hyperv/storvsc: Fix the blkvsc disk attachment issues.
  
      - The original 'disengage' ATA controller model does not work properly
        for all possible disk configurations.  Use the newly added ATA disk
        veto eventhandler to fit into all possible disk configuration.
      - If the 'invalid LUN' happens on blkvsc controllers, return
        CAM_DEV_NOT_THERE so that CAM will not destroy attached disks under
        the blkvsc controllers.
  
      Submitted by:   Hongjiang Zhang <honzhan microsoft com>
      Discussed with: mav
      Sponsored by:   Microsoft
      Differential Revision:  https://reviews.freebsd.org/D7693

Deleted:
  stable/10/sys/dev/hyperv/stordisengage/
  stable/10/sys/modules/hyperv/stordisengage/
Modified:
  stable/10/sys/conf/files.amd64
  stable/10/sys/conf/files.i386
  stable/10/sys/dev/hyperv/storvsc/hv_storvsc_drv_freebsd.c
  stable/10/sys/modules/hyperv/Makefile
Directory Properties:
  stable/10/   (props changed)

Modified: stable/10/sys/conf/files.amd64
==============================================================================
--- stable/10/sys/conf/files.amd64      Fri Oct 14 03:11:31 2016        
(r307253)
+++ stable/10/sys/conf/files.amd64      Fri Oct 14 03:22:19 2016        
(r307254)
@@ -264,7 +264,6 @@ dev/hwpmc/hwpmc_x86.c               optional        hwpmc
 dev/hyperv/netvsc/hv_net_vsc.c                         optional        hyperv
 dev/hyperv/netvsc/hv_netvsc_drv_freebsd.c              optional        hyperv
 dev/hyperv/netvsc/hv_rndis_filter.c                    optional        hyperv
-dev/hyperv/stordisengage/hv_ata_pci_disengage.c                optional        
hyperv
 dev/hyperv/storvsc/hv_storvsc_drv_freebsd.c            optional        hyperv
 dev/hyperv/utilities/hv_heartbeat.c                    optional        hyperv
 dev/hyperv/utilities/hv_kvp.c                          optional        hyperv

Modified: stable/10/sys/conf/files.i386
==============================================================================
--- stable/10/sys/conf/files.i386       Fri Oct 14 03:11:31 2016        
(r307253)
+++ stable/10/sys/conf/files.i386       Fri Oct 14 03:22:19 2016        
(r307254)
@@ -241,7 +241,6 @@ dev/hwpmc/hwpmc_x86.c               optional hwpmc
 dev/hyperv/netvsc/hv_net_vsc.c                         optional        hyperv
 dev/hyperv/netvsc/hv_netvsc_drv_freebsd.c              optional        hyperv
 dev/hyperv/netvsc/hv_rndis_filter.c                    optional        hyperv
-dev/hyperv/stordisengage/hv_ata_pci_disengage.c                optional        
hyperv
 dev/hyperv/storvsc/hv_storvsc_drv_freebsd.c            optional        hyperv
 dev/hyperv/utilities/hv_heartbeat.c                    optional        hyperv
 dev/hyperv/utilities/hv_kvp.c                          optional        hyperv

Modified: stable/10/sys/dev/hyperv/storvsc/hv_storvsc_drv_freebsd.c
==============================================================================
--- stable/10/sys/dev/hyperv/storvsc/hv_storvsc_drv_freebsd.c   Fri Oct 14 
03:11:31 2016        (r307253)
+++ stable/10/sys/dev/hyperv/storvsc/hv_storvsc_drv_freebsd.c   Fri Oct 14 
03:22:19 2016        (r307254)
@@ -60,6 +60,7 @@ __FBSDID("$FreeBSD$");
 #include <sys/lock.h>
 #include <sys/sema.h>
 #include <sys/sglist.h>
+#include <sys/eventhandler.h>
 #include <machine/bus.h>
 #include <sys/bus_dma.h>
 
@@ -202,6 +203,7 @@ struct storvsc_softc {
        struct vmbus_channel            *hs_sel_chan[MAXCPU];
 };
 
+static eventhandler_tag storvsc_handler_tag;
 /*
  * The size of the vmscsi_request has changed in win8. The
  * additional size is for the newly added elements in the
@@ -898,21 +900,15 @@ hv_storvsc_on_channel_callback(struct vm
 static int
 storvsc_probe(device_t dev)
 {
-       int ata_disk_enable = 0;
        int ret = ENXIO;
        
        switch (storvsc_get_storage_type(dev)) {
        case DRIVER_BLKVSC:
                if(bootverbose)
-                       device_printf(dev, "DRIVER_BLKVSC-Emulated ATA/IDE 
probe\n");
-               if (!getenv_int("hw.ata.disk_enable", &ata_disk_enable)) {
-                       if(bootverbose)
-                               device_printf(dev,
-                                       "Enlightened ATA/IDE detected\n");
-                       device_set_desc(dev, 
g_drv_props_table[DRIVER_BLKVSC].drv_desc);
-                       ret = BUS_PROBE_DEFAULT;
-               } else if(bootverbose)
-                       device_printf(dev, "Emulated ATA/IDE set 
(hw.ata.disk_enable set)\n");
+                       device_printf(dev,
+                           "Enlightened ATA/IDE detected\n");
+               device_set_desc(dev, g_drv_props_table[DRIVER_BLKVSC].drv_desc);
+               ret = BUS_PROBE_DEFAULT;
                break;
        case DRIVER_STORVSC:
                if(bootverbose)
@@ -2155,27 +2151,45 @@ storvsc_io_done(struct hv_storvsc_reques
        ccb->ccb_h.status &= ~CAM_STATUS_MASK;
        if (vm_srb->scsi_status == SCSI_STATUS_OK) {
                const struct scsi_generic *cmd;
-
+               cmd = (const struct scsi_generic *)
+                   ((ccb->ccb_h.flags & CAM_CDB_POINTER) ?
+                    csio->cdb_io.cdb_ptr : csio->cdb_io.cdb_bytes);
                if (vm_srb->srb_status != SRB_STATUS_SUCCESS) {
-                       if (vm_srb->srb_status == SRB_STATUS_INVALID_LUN) {
-                               xpt_print(ccb->ccb_h.path, "invalid LUN %d\n",
-                                   vm_srb->lun);
-                       } else {
-                               xpt_print(ccb->ccb_h.path, "Unknown SRB flag: 
%d\n",
-                                   vm_srb->srb_status);
-                       }
                        /*
                         * If there are errors, for example, invalid LUN,
                         * host will inform VM through SRB status.
                         */
-                       ccb->ccb_h.status |= CAM_SEL_TIMEOUT;
+                       if (bootverbose) {
+                               if (vm_srb->srb_status == 
SRB_STATUS_INVALID_LUN) {
+                                       xpt_print(ccb->ccb_h.path,
+                                           "invalid LUN %d for op: %s\n",
+                                           vm_srb->lun,
+                                           scsi_op_desc(cmd->opcode, NULL));
+                               } else {
+                                       xpt_print(ccb->ccb_h.path,
+                                           "Unknown SRB flag: %d for op: %s\n",
+                                           vm_srb->srb_status,
+                                           scsi_op_desc(cmd->opcode, NULL));
+                               }
+                       }
+
+                       /*
+                        * XXX For a selection timeout, all of the LUNs
+                        * on the target will be gone.  It works for SCSI
+                        * disks, but does not work for IDE disks.
+                        *
+                        * For CAM_DEV_NOT_THERE, CAM will only get
+                        * rid of the device(s) specified by the path.
+                        */
+                       if (storvsc_get_storage_type(sc->hs_dev) ==
+                           DRIVER_STORVSC)
+                               ccb->ccb_h.status |= CAM_SEL_TIMEOUT;
+                       else
+                               ccb->ccb_h.status |= CAM_DEV_NOT_THERE;
                } else {
                        ccb->ccb_h.status |= CAM_REQ_CMP;
                }
 
-               cmd = (const struct scsi_generic *)
-                   ((ccb->ccb_h.flags & CAM_CDB_POINTER) ?
-                    csio->cdb_io.cdb_ptr : csio->cdb_io.cdb_bytes);
                if (cmd->opcode == INQUIRY) {
                        struct scsi_inquiry_data *inq_data =
                            (struct scsi_inquiry_data *)csio->data_ptr;
@@ -2287,3 +2301,58 @@ storvsc_get_storage_type(device_t dev)
                return DRIVER_STORVSC;
        return DRIVER_UNKNOWN;
 }
+
+#define        PCI_VENDOR_INTEL        0x8086
+#define        PCI_PRODUCT_PIIX4       0x7111
+
+static void
+storvsc_ada_probe_veto(void *arg __unused, struct cam_path *path,
+    struct ata_params *ident_buf __unused, int *veto)
+{
+
+       /*
+        * The ATA disks are shared with the controllers managed
+        * by this driver, so veto the ATA disks' attachment; the
+        * ATA disks will be attached as SCSI disks once this driver
+        * attached.
+        */
+       if (path->device->protocol == PROTO_ATA) {
+               struct ccb_pathinq cpi;
+
+               bzero(&cpi, sizeof(cpi));
+               xpt_setup_ccb(&cpi.ccb_h, path, CAM_PRIORITY_NONE);
+               cpi.ccb_h.func_code = XPT_PATH_INQ;
+               xpt_action((union ccb *)&cpi);
+               if (cpi.ccb_h.status == CAM_REQ_CMP &&
+                   cpi.hba_vendor == PCI_VENDOR_INTEL &&
+                   cpi.hba_device == PCI_PRODUCT_PIIX4) {
+                       (*veto)++;
+                       if (bootverbose) {
+                               xpt_print(path,
+                                   "Disable ATA disks on "
+                                   "simulated ATA controller (0x%04x%04x)\n",
+                                   cpi.hba_device, cpi.hba_vendor);
+                       }
+               }
+       }
+}
+
+static void
+storvsc_sysinit(void *arg __unused)
+{
+       if (vm_guest == VM_GUEST_HV) {
+               storvsc_handler_tag = EVENTHANDLER_REGISTER(ada_probe_veto,
+                   storvsc_ada_probe_veto, NULL, EVENTHANDLER_PRI_ANY);
+       }
+}
+SYSINIT(storvsc_sys_init, SI_SUB_DRIVERS, SI_ORDER_SECOND, storvsc_sysinit,
+    NULL);
+
+static void
+storvsc_sysuninit(void *arg __unused)
+{
+       if (storvsc_handler_tag != NULL)
+               EVENTHANDLER_DEREGISTER(ada_probe_veto, storvsc_handler_tag);
+}
+SYSUNINIT(storvsc_sys_uninit, SI_SUB_DRIVERS, SI_ORDER_SECOND,
+    storvsc_sysuninit, NULL);

Modified: stable/10/sys/modules/hyperv/Makefile
==============================================================================
--- stable/10/sys/modules/hyperv/Makefile       Fri Oct 14 03:11:31 2016        
(r307253)
+++ stable/10/sys/modules/hyperv/Makefile       Fri Oct 14 03:22:19 2016        
(r307254)
@@ -1,5 +1,5 @@
 # $FreeBSD$
 
-SUBDIR = vmbus netvsc stordisengage storvsc utilities
+SUBDIR = vmbus netvsc storvsc utilities
 
 .include <bsd.subdir.mk>
_______________________________________________
svn-src-all@freebsd.org mailing list
https://lists.freebsd.org/mailman/listinfo/svn-src-all
To unsubscribe, send any mail to "svn-src-all-unsubscr...@freebsd.org"

Reply via email to