mirror of
https://github.com/Fishwaldo/linux-bl808.git
synced 2025-03-20 22:15:59 +00:00
arm/xen: Don't probe xenbus as part of an early initcall
After Commit3499ba8198
("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:3499ba8198
("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>
This commit is contained in:
parent
2e92493637
commit
c4295ab0b4
4 changed files with 1 additions and 6 deletions
|
@ -370,8 +370,6 @@ static int __init xen_guest_init(void)
|
||||||
return -ENOMEM;
|
return -ENOMEM;
|
||||||
}
|
}
|
||||||
gnttab_init();
|
gnttab_init();
|
||||||
if (!xen_initial_domain())
|
|
||||||
xenbus_probe();
|
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Making sure board specific code will not set up ops for
|
* Making sure board specific code will not set up ops for
|
||||||
|
|
|
@ -115,7 +115,6 @@ int xenbus_probe_node(struct xen_bus_type *bus,
|
||||||
const char *type,
|
const char *type,
|
||||||
const char *nodename);
|
const char *nodename);
|
||||||
int xenbus_probe_devices(struct xen_bus_type *bus);
|
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);
|
void xenbus_dev_changed(const char *node, struct xen_bus_type *bus);
|
||||||
|
|
||||||
|
|
|
@ -683,7 +683,7 @@ void unregister_xenstore_notifier(struct notifier_block *nb)
|
||||||
}
|
}
|
||||||
EXPORT_SYMBOL_GPL(unregister_xenstore_notifier);
|
EXPORT_SYMBOL_GPL(unregister_xenstore_notifier);
|
||||||
|
|
||||||
void xenbus_probe(void)
|
static void xenbus_probe(void)
|
||||||
{
|
{
|
||||||
xenstored_ready = 1;
|
xenstored_ready = 1;
|
||||||
|
|
||||||
|
|
|
@ -192,8 +192,6 @@ void xs_suspend_cancel(void);
|
||||||
|
|
||||||
struct work_struct;
|
struct work_struct;
|
||||||
|
|
||||||
void xenbus_probe(void);
|
|
||||||
|
|
||||||
#define XENBUS_IS_ERR_READ(str) ({ \
|
#define XENBUS_IS_ERR_READ(str) ({ \
|
||||||
if (!IS_ERR(str) && strlen(str) == 0) { \
|
if (!IS_ERR(str) && strlen(str) == 0) { \
|
||||||
kfree(str); \
|
kfree(str); \
|
||||||
|
|
Loading…
Add table
Reference in a new issue