]> git.ipfire.org Git - thirdparty/kernel/stable.git/commit
xen: netback: read hotplug script once at start of day.
authorIan Campbell <Ian.Campbell@citrix.com>
Mon, 1 Jun 2015 10:30:24 +0000 (11:30 +0100)
committerSasha Levin <sasha.levin@oracle.com>
Mon, 15 Jun 2015 18:26:53 +0000 (14:26 -0400)
commitfe38ed618ce5e0f8c7f7e9f47497c3637a0ffbd2
tree076deee41a135c4bcfff58d0dd6c8a1948a30b22
parent189debb56afd572f29cbd35abea68b4391185627
xen: netback: read hotplug script once at start of day.

[ Upstream commit 31a418986a5852034d520a5bab546821ff1ccf3d ]

When we come to tear things down in netback_remove() and generate the
uevent it is possible that the xenstore directory has already been
removed (details below).

In such cases netback_uevent() won't be able to read the hotplug
script and will write a xenstore error node.

A recent change to the hypervisor exposed this race such that we now
sometimes lose it (where apparently we didn't ever before).

Instead read the hotplug script configuration during setup and use it
for the lifetime of the backend device.

The apparently more obvious fix of moving the transition to
state=Closed in netback_remove() to after the uevent does not work
because it is possible that we are already in state=Closed (in
reaction to the guest having disconnected as it shutdown). Being
already in Closed means the toolstack is at liberty to start tearing
down the xenstore directories. In principal it might be possible to
arrange to unregister the device sooner (e.g on transition to Closing)
such that xenstore would still be there but this state machine is
fragile and prone to anger...

A modern Xen system only relies on the hotplug uevent for driver
domains, when the backend is in the same domain as the toolstack it
will run the necessary setup/teardown directly in the correct sequence
wrt xenstore changes.

Signed-off-by: Ian Campbell <ian.campbell@citrix.com>
Acked-by: Wei Liu <wei.liu2@citrix.com>
Signed-off-by: David S. Miller <davem@davemloft.net>
Signed-off-by: Sasha Levin <sasha.levin@oracle.com>
drivers/net/xen-netback/xenbus.c