These changes are the raw update to linux-4.4.6-rt14. Kernel sources
[kvmfornfv.git] / kernel / drivers / virtio / virtio_pci_legacy.c
index 256a527..48bc979 100644 (file)
@@ -215,6 +215,7 @@ static const struct virtio_config_ops virtio_pci_config_ops = {
 int virtio_pci_legacy_probe(struct virtio_pci_device *vp_dev)
 {
        struct pci_dev *pci_dev = vp_dev->pci_dev;
+       int rc;
 
        /* We only own devices >= 0x1000 and <= 0x103f: leave the rest. */
        if (pci_dev->device < 0x1000 || pci_dev->device > 0x103f)
@@ -226,9 +227,14 @@ int virtio_pci_legacy_probe(struct virtio_pci_device *vp_dev)
                return -ENODEV;
        }
 
+       rc = pci_request_region(pci_dev, 0, "virtio-pci-legacy");
+       if (rc)
+               return rc;
+
+       rc = -ENOMEM;
        vp_dev->ioaddr = pci_iomap(pci_dev, 0, 0);
        if (!vp_dev->ioaddr)
-               return -ENOMEM;
+               goto err_iomap;
 
        vp_dev->isr = vp_dev->ioaddr + VIRTIO_PCI_ISR;
 
@@ -246,6 +252,10 @@ int virtio_pci_legacy_probe(struct virtio_pci_device *vp_dev)
        vp_dev->del_vq = del_vq;
 
        return 0;
+
+err_iomap:
+       pci_release_region(pci_dev, 0);
+       return rc;
 }
 
 void virtio_pci_legacy_remove(struct virtio_pci_device *vp_dev)
@@ -253,4 +263,5 @@ void virtio_pci_legacy_remove(struct virtio_pci_device *vp_dev)
        struct pci_dev *pci_dev = vp_dev->pci_dev;
 
        pci_iounmap(pci_dev, vp_dev->ioaddr);
+       pci_release_region(pci_dev, 0);
 }