diff options
Diffstat (limited to 'trunk/2.6.22/20027_82-blkdev-wait.patch1')
-rw-r--r-- | trunk/2.6.22/20027_82-blkdev-wait.patch1 | 92 |
1 files changed, 92 insertions, 0 deletions
diff --git a/trunk/2.6.22/20027_82-blkdev-wait.patch1 b/trunk/2.6.22/20027_82-blkdev-wait.patch1 new file mode 100644 index 0000000..8f5fdc2 --- /dev/null +++ b/trunk/2.6.22/20027_82-blkdev-wait.patch1 @@ -0,0 +1,92 @@ +# HG changeset 82 patch +# User Christian Limpach <Christian.Limpach@xensource.com> +# Date 1183716504 -3600 +# Node ID 11483a00c017ea82a4c2948724eb36ba6ec5c0ba +# Parent cb040341e05af32c804afef4216ec5491dcbf9e3 +Subject: Delay wait for block devices until after the disk is added. + +Signed-off-by: Christian Limpach <Christian.Limpach@xensource.com> + +Acked-by: jbeulich@novell.com + +--- + drivers/xen/blkfront/blkfront.c | 10 ++++++++++ + drivers/xen/blkfront/block.h | 1 + + drivers/xen/xenbus/xenbus_probe.c | 5 ++++- + include/xen/xenbus.h | 1 + + 4 files changed, 16 insertions(+), 1 deletion(-) + +--- a/drivers/xen/blkfront/blkfront.c 2007-08-27 14:01:25.000000000 -0400 ++++ b/drivers/xen/blkfront/blkfront.c 2007-08-27 14:02:03.000000000 -0400 +@@ -354,6 +354,8 @@ static void connect(struct blkfront_info + spin_unlock_irq(&blkif_io_lock); + + add_disk(info->gd); ++ ++ info->is_ready = 1; + } + + /** +@@ -862,6 +864,13 @@ static void blkif_recover(struct blkfron + spin_unlock_irq(&blkif_io_lock); + } + ++int blkfront_is_ready(struct xenbus_device *dev) ++{ ++ struct blkfront_info *info = dev->dev.driver_data; ++ ++ return info->is_ready; ++} ++ + + /* ** Driver Registration ** */ + +@@ -880,6 +889,7 @@ static struct xenbus_driver blkfront = { + .remove = blkfront_remove, + .resume = blkfront_resume, + .otherend_changed = backend_changed, ++ .is_ready = blkfront_is_ready, + }; + + +--- a/drivers/xen/blkfront/block.h 2007-08-27 14:01:25.000000000 -0400 ++++ b/drivers/xen/blkfront/block.h 2007-08-27 14:01:25.000000000 -0400 +@@ -111,6 +111,7 @@ struct blkfront_info + struct blk_shadow shadow[BLK_RING_SIZE]; + unsigned long shadow_free; + int feature_barrier; ++ int is_ready; + + /** + * The number of people holding this device open. We won't allow a +--- a/drivers/xen/xenbus/xenbus_probe.c 2007-08-27 14:01:25.000000000 -0400 ++++ b/drivers/xen/xenbus/xenbus_probe.c 2007-08-27 14:02:01.000000000 -0400 +@@ -992,6 +992,7 @@ static int is_disconnected_device(struct + { + struct xenbus_device *xendev = to_xenbus_device(dev); + struct device_driver *drv = data; ++ struct xenbus_driver *xendrv; + + /* + * A device with no driver will never connect. We care only about +@@ -1004,7 +1005,9 @@ static int is_disconnected_device(struct + if (drv && (dev->driver != drv)) + return 0; + +- return (xendev->state != XenbusStateConnected); ++ xendrv = to_xenbus_driver(dev->driver); ++ return (xendev->state != XenbusStateConnected || ++ (xendrv->is_ready && !xendrv->is_ready(xendev))); + } + + static int exists_disconnected_device(struct device_driver *drv) +--- a/include/xen/xenbus.h 2007-08-27 14:01:25.000000000 -0400 ++++ b/include/xen/xenbus.h 2007-08-27 14:01:25.000000000 -0400 +@@ -106,6 +106,7 @@ struct xenbus_driver { + int (*uevent)(struct xenbus_device *, char **, int, char *, int); + struct device_driver driver; + int (*read_otherend_details)(struct xenbus_device *dev); ++ int (*is_ready)(struct xenbus_device *dev); + }; + + static inline struct xenbus_driver *to_xenbus_driver(struct device_driver *drv) |