diff options
author | Stefano Stabellini <stefano.stabellini@eu.citrix.com> | 2010-05-14 07:44:30 -0400 |
---|---|---|
committer | Jeremy Fitzhardinge <jeremy.fitzhardinge@citrix.com> | 2010-07-27 02:13:25 -0400 |
commit | c1c5413ad58cb73267d328e6020268aa2e50d8ca (patch) | |
tree | f2c66141ab8d9fdb7b16a13d4d510ad09b2430ed /drivers | |
parent | 409771d258e9dd71c30f3c9520fd2b796ffc40f0 (diff) |
x86: Unplug emulated disks and nics.
Add a xen_emul_unplug command line option to the kernel to unplug
xen emulated disks and nics.
Set the default value of xen_emul_unplug depending on whether or
not the Xen PV frontends and the Xen platform PCI driver have
been compiled for this kernel (modules or built-in are both OK).
The user can specify xen_emul_unplug=ignore to enable PV drivers on HVM
even if the host platform doesn't support unplug.
Signed-off-by: Stefano Stabellini <stefano.stabellini@eu.citrix.com>
Signed-off-by: Jeremy Fitzhardinge <jeremy.fitzhardinge@citrix.com>
Diffstat (limited to 'drivers')
-rw-r--r-- | drivers/block/xen-blkfront.c | 17 | ||||
-rw-r--r-- | drivers/xen/platform-pci.c | 6 | ||||
-rw-r--r-- | drivers/xen/xenbus/xenbus_probe.c | 4 |
3 files changed, 27 insertions, 0 deletions
diff --git a/drivers/block/xen-blkfront.c b/drivers/block/xen-blkfront.c index 82ed403147c0..6eb2989a9d0a 100644 --- a/drivers/block/xen-blkfront.c +++ b/drivers/block/xen-blkfront.c | |||
@@ -48,6 +48,7 @@ | |||
48 | #include <xen/grant_table.h> | 48 | #include <xen/grant_table.h> |
49 | #include <xen/events.h> | 49 | #include <xen/events.h> |
50 | #include <xen/page.h> | 50 | #include <xen/page.h> |
51 | #include <xen/platform_pci.h> | ||
51 | 52 | ||
52 | #include <xen/interface/grant_table.h> | 53 | #include <xen/interface/grant_table.h> |
53 | #include <xen/interface/io/blkif.h> | 54 | #include <xen/interface/io/blkif.h> |
@@ -737,6 +738,22 @@ static int blkfront_probe(struct xenbus_device *dev, | |||
737 | } | 738 | } |
738 | } | 739 | } |
739 | 740 | ||
741 | /* no unplug has been done: do not hook devices != xen vbds */ | ||
742 | if (xen_hvm_domain() && (xen_platform_pci_unplug & XEN_UNPLUG_IGNORE)) { | ||
743 | int major; | ||
744 | |||
745 | if (!VDEV_IS_EXTENDED(vdevice)) | ||
746 | major = BLKIF_MAJOR(vdevice); | ||
747 | else | ||
748 | major = XENVBD_MAJOR; | ||
749 | |||
750 | if (major != XENVBD_MAJOR) { | ||
751 | printk(KERN_INFO | ||
752 | "%s: HVM does not support vbd %d as xen block device\n", | ||
753 | __FUNCTION__, vdevice); | ||
754 | return -ENODEV; | ||
755 | } | ||
756 | } | ||
740 | info = kzalloc(sizeof(*info), GFP_KERNEL); | 757 | info = kzalloc(sizeof(*info), GFP_KERNEL); |
741 | if (!info) { | 758 | if (!info) { |
742 | xenbus_dev_fatal(dev, -ENOMEM, "allocating info structure"); | 759 | xenbus_dev_fatal(dev, -ENOMEM, "allocating info structure"); |
diff --git a/drivers/xen/platform-pci.c b/drivers/xen/platform-pci.c index bdb44f2473e8..c01b5ddce529 100644 --- a/drivers/xen/platform-pci.c +++ b/drivers/xen/platform-pci.c | |||
@@ -27,6 +27,7 @@ | |||
27 | #include <linux/module.h> | 27 | #include <linux/module.h> |
28 | #include <linux/pci.h> | 28 | #include <linux/pci.h> |
29 | 29 | ||
30 | #include <xen/platform_pci.h> | ||
30 | #include <xen/grant_table.h> | 31 | #include <xen/grant_table.h> |
31 | #include <xen/xenbus.h> | 32 | #include <xen/xenbus.h> |
32 | #include <xen/events.h> | 33 | #include <xen/events.h> |
@@ -195,6 +196,11 @@ static struct pci_driver platform_driver = { | |||
195 | 196 | ||
196 | static int __init platform_pci_module_init(void) | 197 | static int __init platform_pci_module_init(void) |
197 | { | 198 | { |
199 | /* no unplug has been done, IGNORE hasn't been specified: just | ||
200 | * return now */ | ||
201 | if (!xen_platform_pci_unplug) | ||
202 | return -ENODEV; | ||
203 | |||
198 | return pci_register_driver(&platform_driver); | 204 | return pci_register_driver(&platform_driver); |
199 | } | 205 | } |
200 | 206 | ||
diff --git a/drivers/xen/xenbus/xenbus_probe.c b/drivers/xen/xenbus/xenbus_probe.c index a9e83c438cbb..37e8894b50d6 100644 --- a/drivers/xen/xenbus/xenbus_probe.c +++ b/drivers/xen/xenbus/xenbus_probe.c | |||
@@ -56,6 +56,7 @@ | |||
56 | #include <xen/events.h> | 56 | #include <xen/events.h> |
57 | #include <xen/page.h> | 57 | #include <xen/page.h> |
58 | 58 | ||
59 | #include <xen/platform_pci.h> | ||
59 | #include <xen/hvm.h> | 60 | #include <xen/hvm.h> |
60 | 61 | ||
61 | #include "xenbus_comms.h" | 62 | #include "xenbus_comms.h" |
@@ -977,6 +978,9 @@ static void wait_for_devices(struct xenbus_driver *xendrv) | |||
977 | #ifndef MODULE | 978 | #ifndef MODULE |
978 | static int __init boot_wait_for_devices(void) | 979 | static int __init boot_wait_for_devices(void) |
979 | { | 980 | { |
981 | if (xen_hvm_domain() && !xen_platform_pci_unplug) | ||
982 | return -ENODEV; | ||
983 | |||
980 | ready_to_wait_for_devices = 1; | 984 | ready_to_wait_for_devices = 1; |
981 | wait_for_devices(NULL); | 985 | wait_for_devices(NULL); |
982 | return 0; | 986 | return 0; |