Donate to e Foundation | Murena handsets with /e/OS | Own a part of Murena! Learn more

Commit 7095e3eb authored by Jiri Slaby's avatar Jiri Slaby Committed by Jeff Garzik
Browse files

pata_via: fix double put on isa bridge



In via_init_one, when via_isa_bridges iterator reaches
PCI_DEVICE_ID_VIA_ANON and last but one via_isa_bridges bridge is
found but rev doesn't match, pci_dev_put(isa) is called twice.

Do pci_dev_put only once.

Signed-off-by: default avatarJiri Slaby <jirislaby@gmail.com>
Signed-off-by: default avatarJeff Garzik <jgarzik@redhat.com>
parent ba3a221c
Loading
Loading
Loading
Loading
+4 −6
Original line number Diff line number Diff line
@@ -526,7 +526,7 @@ static int via_init_one(struct pci_dev *pdev, const struct pci_device_id *id)
		.port_ops = &via_port_ops
	};
	const struct ata_port_info *ppi[] = { NULL, NULL };
	struct pci_dev *isa = NULL;
	struct pci_dev *isa;
	const struct via_isa_bridge *config;
	static int printed_version;
	u8 enable;
@@ -551,15 +551,13 @@ static int via_init_one(struct pci_dev *pdev, const struct pci_device_id *id)
		if ((isa = pci_get_device(PCI_VENDOR_ID_VIA +
			!!(config->flags & VIA_BAD_ID),
			config->id, NULL))) {
			u8 rev = isa->revision;
			pci_dev_put(isa);

			if (isa->revision >= config->rev_min &&
			    isa->revision <= config->rev_max)
			if (rev >= config->rev_min && rev <= config->rev_max)
				break;
			pci_dev_put(isa);
		}

	pci_dev_put(isa);

	if (!(config->flags & VIA_NO_ENABLES)) {
		/* 0x40 low bits indicate enabled channels */
		pci_read_config_byte(pdev, 0x40 , &enable);