Lines Matching refs:pcidev
131 void (*exit)(struct pci_dev *pcidev);
214 static int default_setup(struct exar8250 *priv, struct pci_dev *pcidev, in default_setup() argument
223 port->port.mapbase = pci_resource_start(pcidev, bar) + offset; in default_setup()
253 pci_fastcom335_setup(struct exar8250 *priv, struct pci_dev *pcidev, in pci_fastcom335_setup() argument
263 err = default_setup(priv, pcidev, idx, offset, port); in pci_fastcom335_setup()
278 switch (pcidev->device) { in pci_fastcom335_setup()
301 pci_connect_tech_setup(struct exar8250 *priv, struct pci_dev *pcidev, in pci_connect_tech_setup() argument
308 return default_setup(priv, pcidev, idx, offset, port); in pci_connect_tech_setup()
312 pci_xr17c154_setup(struct exar8250 *priv, struct pci_dev *pcidev, in pci_xr17c154_setup() argument
319 return default_setup(priv, pcidev, idx, offset, port); in pci_xr17c154_setup()
322 static void setup_gpio(struct pci_dev *pcidev, u8 __iomem *p) in setup_gpio() argument
332 if ((pcidev->vendor == PCI_VENDOR_ID_EXAR) && in setup_gpio()
333 (pcidev->subsystem_vendor != PCI_VENDOR_ID_SEALEVEL)) { in setup_gpio()
356 __xr17v35x_register_gpio(struct pci_dev *pcidev, in __xr17v35x_register_gpio() argument
365 pdev->dev.parent = &pcidev->dev; in __xr17v35x_register_gpio()
366 ACPI_COMPANION_SET(&pdev->dev, ACPI_COMPANION(&pcidev->dev)); in __xr17v35x_register_gpio()
383 static int xr17v35x_register_gpio(struct pci_dev *pcidev, in xr17v35x_register_gpio() argument
386 if (pcidev->vendor == PCI_VENDOR_ID_EXAR) in xr17v35x_register_gpio()
388 __xr17v35x_register_gpio(pcidev, exar_gpio_properties); in xr17v35x_register_gpio()
460 static int iot2040_register_gpio(struct pci_dev *pcidev, in iot2040_register_gpio() argument
471 __xr17v35x_register_gpio(pcidev, iot2040_gpio_properties); in iot2040_register_gpio()
497 pci_xr17v35x_setup(struct exar8250 *priv, struct pci_dev *pcidev, in pci_xr17v35x_setup() argument
523 ret = default_setup(priv, pcidev, idx, offset, port); in pci_xr17v35x_setup()
536 setup_gpio(pcidev, p); in pci_xr17v35x_setup()
538 ret = platform->register_gpio(pcidev, port); in pci_xr17v35x_setup()
544 static void pci_xr17v35x_exit(struct pci_dev *pcidev) in pci_xr17v35x_exit() argument
546 struct exar8250 *priv = pci_get_drvdata(pcidev); in pci_xr17v35x_exit()
581 exar_pci_probe(struct pci_dev *pcidev, const struct pci_device_id *ent) in exar_pci_probe() argument
593 rc = pcim_enable_device(pcidev); in exar_pci_probe()
597 maxnr = pci_resource_len(pcidev, bar) >> (board->reg_shift + 3); in exar_pci_probe()
599 nr_ports = board->num_ports ? board->num_ports : pcidev->device & 0x0f; in exar_pci_probe()
601 priv = devm_kzalloc(&pcidev->dev, struct_size(priv, line, nr_ports), GFP_KERNEL); in exar_pci_probe()
606 priv->virt = pcim_iomap(pcidev, bar, 0); in exar_pci_probe()
610 pci_set_master(pcidev); in exar_pci_probe()
612 rc = pci_alloc_irq_vectors(pcidev, 1, 1, PCI_IRQ_ALL_TYPES); in exar_pci_probe()
618 uart.port.irq = pci_irq_vector(pcidev, 0); in exar_pci_probe()
619 uart.port.dev = &pcidev->dev; in exar_pci_probe()
621 rc = devm_request_irq(&pcidev->dev, uart.port.irq, exar_misc_handler, in exar_pci_probe()
630 rc = board->setup(priv, pcidev, &uart, i); in exar_pci_probe()
632 dev_err(&pcidev->dev, "Failed to setup port %u\n", i); in exar_pci_probe()
636 dev_dbg(&pcidev->dev, "Setup PCI port: port %lx, irq %d, type %d\n", in exar_pci_probe()
641 dev_err(&pcidev->dev, in exar_pci_probe()
649 pci_set_drvdata(pcidev, priv); in exar_pci_probe()
653 static void exar_pci_remove(struct pci_dev *pcidev) in exar_pci_remove() argument
655 struct exar8250 *priv = pci_get_drvdata(pcidev); in exar_pci_remove()
662 priv->board->exit(pcidev); in exar_pci_remove()
667 struct pci_dev *pcidev = to_pci_dev(dev); in exar_suspend() local
668 struct exar8250 *priv = pci_get_drvdata(pcidev); in exar_suspend()
677 priv->board->exit(pcidev); in exar_suspend()