arm/xen: Don't probe xenbus as part of an early initcall
authorJulien Grall <jgrall@amazon.com>
Wed, 10 Feb 2021 17:06:54 +0000 (17:06 +0000)
committerJuergen Gross <jgross@suse.com>
Thu, 11 Feb 2021 06:49:37 +0000 (07:49 +0100)
After Commit 3499ba8198cad ("xen: Fix event channel callback via
INTX/GSI"), xenbus_probe() will be called too early on Arm. This will
recent to a guest hang during boot.

If the hang wasn't there, we would have ended up to call
xenbus_probe() twice (the second time is in xenbus_probe_initcall()).

We don't need to initialize xenbus_probe() early for Arm guest.
Therefore, the call in xen_guest_init() is now removed.

After this change, there is no more external caller for xenbus_probe().
So the function is turned to a static one. Interestingly there were two
prototypes for it.

Cc: stable@vger.kernel.org
Fixes: 3499ba8198cad ("xen: Fix event channel callback via INTX/GSI")
Reported-by: Ian Jackson <iwj@xenproject.org>
Signed-off-by: Julien Grall <jgrall@amazon.com>
Reviewed-by: David Woodhouse <dwmw@amazon.co.uk>
Reviewed-by: Stefano Stabellini <sstabellini@kernel.org>
Link: https://lore.kernel.org/r/20210210170654.5377-1-julien@xen.org
Signed-off-by: Juergen Gross <jgross@suse.com>
arch/arm/xen/enlighten.c
drivers/xen/xenbus/xenbus.h
drivers/xen/xenbus/xenbus_probe.c
include/xen/xenbus.h

index 5a957a9a09843c1031b7a9a3a46d5a454c417867..8ad576ecd0f1db808a03f57e014b88ec7eae7347 100644 (file)
@@ -370,8 +370,6 @@ static int __init xen_guest_init(void)
                return -ENOMEM;
        }
        gnttab_init();
-       if (!xen_initial_domain())
-               xenbus_probe();
 
        /*
         * Making sure board specific code will not set up ops for
index dc153733541441ed624066829d88b407effe429a..2a93b7c9c159929557f845c549b7f7676efd3a11 100644 (file)
@@ -115,7 +115,6 @@ int xenbus_probe_node(struct xen_bus_type *bus,
                      const char *type,
                      const char *nodename);
 int xenbus_probe_devices(struct xen_bus_type *bus);
-void xenbus_probe(void);
 
 void xenbus_dev_changed(const char *node, struct xen_bus_type *bus);
 
index 18ffd0551b5429cbe3fc7ca4f431f45d0bad478e..8a75092bb148b6b5ed3efb9ab48197aa9a8589e9 100644 (file)
@@ -683,7 +683,7 @@ void unregister_xenstore_notifier(struct notifier_block *nb)
 }
 EXPORT_SYMBOL_GPL(unregister_xenstore_notifier);
 
-void xenbus_probe(void)
+static void xenbus_probe(void)
 {
        xenstored_ready = 1;
 
index 2c43b0ef1e4d504a652d0d574d5b6e41fa107091..bf3cfc7c35d0b53816657e36120a8b170c034c9e 100644 (file)
@@ -192,8 +192,6 @@ void xs_suspend_cancel(void);
 
 struct work_struct;
 
-void xenbus_probe(void);
-
 #define XENBUS_IS_ERR_READ(str) ({                     \
        if (!IS_ERR(str) && strlen(str) == 0) {         \
                kfree(str);                             \