1 // SPDX-License-Identifier: GPL-2.0
3 * Simple stub driver to reserve a PCI device
5 * Copyright (C) 2008 Red Hat, Inc.
9 * Usage is simple, allocate a new id to the stub driver and bind the
10 * device to it. For example:
12 * # echo "8086 10f5" > /sys/bus/pci/drivers/pci-stub/new_id
13 * # echo -n 0000:00:19.0 > /sys/bus/pci/drivers/e1000e/unbind
14 * # echo -n 0000:00:19.0 > /sys/bus/pci/drivers/pci-stub/bind
15 * # ls -l /sys/bus/pci/devices/0000:00:19.0/driver
16 * .../0000:00:19.0/driver -> ../../../bus/pci/drivers/pci-stub
19 #include <linux/module.h>
20 #include <linux/pci.h>
22 static char ids
[1024] __initdata
;
24 module_param_string(ids
, ids
, sizeof(ids
), 0);
25 MODULE_PARM_DESC(ids
, "Initial PCI IDs to add to the stub driver, format is "
26 "\"vendor:device[:subvendor[:subdevice[:class[:class_mask]]]]\""
27 " and multiple comma separated entries can be specified");
29 static int pci_stub_probe(struct pci_dev
*dev
, const struct pci_device_id
*id
)
31 pci_info(dev
, "claimed by stub\n");
35 static struct pci_driver stub_driver
= {
37 .id_table
= NULL
, /* only dynamic id's */
38 .probe
= pci_stub_probe
,
39 .driver_managed_dma
= true,
42 static int __init
pci_stub_init(void)
47 rc
= pci_register_driver(&stub_driver
);
51 /* no ids passed actually */
55 /* add ids specified in the module parameter */
57 while ((id
= strsep(&p
, ","))) {
58 unsigned int vendor
, device
, subvendor
= PCI_ANY_ID
,
59 subdevice
= PCI_ANY_ID
, class = 0, class_mask
= 0;
65 fields
= sscanf(id
, "%x:%x:%x:%x:%x:%x",
66 &vendor
, &device
, &subvendor
, &subdevice
,
70 pr_warn("pci-stub: invalid ID string \"%s\"\n", id
);
74 pr_info("pci-stub: add %04X:%04X sub=%04X:%04X cls=%08X/%08X\n",
75 vendor
, device
, subvendor
, subdevice
, class, class_mask
);
77 rc
= pci_add_dynid(&stub_driver
, vendor
, device
,
78 subvendor
, subdevice
, class, class_mask
, 0);
80 pr_warn("pci-stub: failed to add dynamic ID (%d)\n",
87 static void __exit
pci_stub_exit(void)
89 pci_unregister_driver(&stub_driver
);
92 module_init(pci_stub_init
);
93 module_exit(pci_stub_exit
);
95 MODULE_DESCRIPTION("VM device assignment stub driver");
96 MODULE_LICENSE("GPL");
97 MODULE_AUTHOR("Chris Wright <chrisw@sous-sol.org>");