The disable slot implementation on s390 currently just detaches the
pci function from the partition - without informing the pci layer.
Fix this by calling pci_stop_and_remove_bus_device prior to the
operation.
Reviewed-by: Gerald Schaefer <gerald.schaefer@de.ibm.com>
Signed-off-by: Sebastian Ott <sebott@linux.vnet.ibm.com>
Signed-off-by: Martin Schwidefsky <schwidefsky@de.ibm.com>
        if (!zdev_enabled(zdev))
                return 0;
 
-       dev_info(&zdev->pdev->dev, "disabling fn handle: 0x%x\n", fh);
        rc = clp_set_pci_fn(&fh, 0, CLP_SET_DISABLE_PCI_FN);
        if (!rc)
                /* Success -> store disabled handle in zdev */
 
        if (!zpci_fn_configured(slot->zdev->state))
                return -EIO;
 
+       if (slot->zdev->pdev)
+               pci_stop_and_remove_bus_device(slot->zdev->pdev);
+
        rc = zpci_disable_device(slot->zdev);
        if (rc)
                return rc;
-       /* TODO: we rely on the user to unbind/remove the device, is that plausible
-        *       or do we need to trigger that here?
-        */
+
        return slot_deconfigure(slot);
 }