&id_phys->alternate_paths_phys_connector,
                sizeof(device->phys_connector));
        device->bay = id_phys->phys_bay_in_box;
-       device->multi_lun_device_lun_count = id_phys->multi_lun_device_lun_count;
-       if (!device->multi_lun_device_lun_count)
-               device->multi_lun_device_lun_count = 1;
+       device->lun_count = id_phys->multi_lun_device_lun_count;
        if ((id_phys->even_more_flags & PQI_DEVICE_PHY_MAP_SUPPORTED) &&
                id_phys->phy_count)
                device->phy_id =
        return offline;
 }
 
-static int pqi_get_device_info(struct pqi_ctrl_info *ctrl_info,
+static int pqi_get_device_info_phys_logical(struct pqi_ctrl_info *ctrl_info,
        struct pqi_scsi_dev *device,
        struct bmic_identify_physical_device *id_phys)
 {
        return rc;
 }
 
+static int pqi_get_device_info(struct pqi_ctrl_info *ctrl_info,
+       struct pqi_scsi_dev *device,
+       struct bmic_identify_physical_device *id_phys)
+{
+       int rc;
+
+       rc = pqi_get_device_info_phys_logical(ctrl_info, device, id_phys);
+
+       if (rc == 0 && device->lun_count == 0)
+               device->lun_count = 1;
+
+       return rc;
+}
+
 static void pqi_show_volume_status(struct pqi_ctrl_info *ctrl_info,
        struct pqi_scsi_dev *device)
 {
        int rc;
        int lun;
 
-       for (lun = 0; lun < device->multi_lun_device_lun_count; lun++) {
+       for (lun = 0; lun < device->lun_count; lun++) {
                rc = pqi_device_wait_for_pending_io(ctrl_info, device, lun,
                        PQI_REMOVE_DEVICE_PENDING_IO_TIMEOUT_MSECS);
                if (rc)
        existing_device->sas_address = new_device->sas_address;
        existing_device->queue_depth = new_device->queue_depth;
        existing_device->device_offline = false;
+       existing_device->lun_count = new_device->lun_count;
 
        if (pqi_is_logical_device(existing_device)) {
                existing_device->is_external_raid_device = new_device->is_external_raid_device;
                existing_device->phy_connected_dev_type = new_device->phy_connected_dev_type;
                memcpy(existing_device->box, new_device->box, sizeof(existing_device->box));
                memcpy(existing_device->phys_connector, new_device->phys_connector, sizeof(existing_device->phys_connector));
-
-               existing_device->multi_lun_device_lun_count = new_device->multi_lun_device_lun_count;
-               if (existing_device->multi_lun_device_lun_count == 0)
-                       existing_device->multi_lun_device_lun_count = 1;
        }
 }
 
                return;
        }
 
+       device->lun_count--;
+       if (device->lun_count > 0) {
+               mutex_unlock(&ctrl_info->scan_mutex);
+               return;
+       }
+
        spin_lock_irqsave(&ctrl_info->scsi_device_list_lock, flags);
        list_del(&device->scsi_device_list_entry);
        spin_unlock_irqrestore(&ctrl_info->scsi_device_list_lock, flags);