|  | // SPDX-License-Identifier: GPL-2.0 | 
|  |  | 
|  | #include <linux/module.h> | 
|  | #include <linux/pci.h> | 
|  | #include "fdomain.h" | 
|  |  | 
|  | static int fdomain_pci_probe(struct pci_dev *pdev, | 
|  | const struct pci_device_id *d) | 
|  | { | 
|  | int err; | 
|  | struct Scsi_Host *sh; | 
|  |  | 
|  | err = pci_enable_device(pdev); | 
|  | if (err) | 
|  | goto fail; | 
|  |  | 
|  | err = pci_request_regions(pdev, "fdomain_pci"); | 
|  | if (err) | 
|  | goto disable_device; | 
|  |  | 
|  | err = -ENODEV; | 
|  | if (pci_resource_len(pdev, 0) == 0) | 
|  | goto release_region; | 
|  |  | 
|  | sh = fdomain_create(pci_resource_start(pdev, 0), pdev->irq, 7, | 
|  | &pdev->dev); | 
|  | if (!sh) | 
|  | goto release_region; | 
|  |  | 
|  | pci_set_drvdata(pdev, sh); | 
|  | return 0; | 
|  |  | 
|  | release_region: | 
|  | pci_release_regions(pdev); | 
|  | disable_device: | 
|  | pci_disable_device(pdev); | 
|  | fail: | 
|  | return err; | 
|  | } | 
|  |  | 
|  | static void fdomain_pci_remove(struct pci_dev *pdev) | 
|  | { | 
|  | struct Scsi_Host *sh = pci_get_drvdata(pdev); | 
|  |  | 
|  | fdomain_destroy(sh); | 
|  | pci_release_regions(pdev); | 
|  | pci_disable_device(pdev); | 
|  | } | 
|  |  | 
|  | static struct pci_device_id fdomain_pci_table[] = { | 
|  | { PCI_DEVICE(PCI_VENDOR_ID_FD, PCI_DEVICE_ID_FD_36C70) }, | 
|  | {} | 
|  | }; | 
|  | MODULE_DEVICE_TABLE(pci, fdomain_pci_table); | 
|  |  | 
|  | static struct pci_driver fdomain_pci_driver = { | 
|  | .name		= "fdomain_pci", | 
|  | .id_table	= fdomain_pci_table, | 
|  | .probe		= fdomain_pci_probe, | 
|  | .remove		= fdomain_pci_remove, | 
|  | .driver.pm	= FDOMAIN_PM_OPS, | 
|  | }; | 
|  |  | 
|  | module_pci_driver(fdomain_pci_driver); | 
|  |  | 
|  | MODULE_AUTHOR("Ondrej Zary, Rickard E. Faith"); | 
|  | MODULE_DESCRIPTION("Future Domain TMC-3260 PCI SCSI driver"); | 
|  | MODULE_LICENSE("GPL"); |