mirror of
https://gitlab.com/libvirt/libvirt.git
synced 2025-01-03 05:17:54 +03:00
run: detect daemons when run via wrapper commands
The run script tries to detect when a daemon is being run in order to shutdown other systemd unit files that clash. As implemented this only works if the daemon name is the first argument. This won't be the case if running via GDB or strace eg ./run strace -e trace=openat ./build/src/virtqemud We need to check all argv to find which might be a daemon path/name. Reviewed-by: Ján Tomko <jtomko@redhat.com> Signed-off-by: Daniel P. Berrangé <berrange@redhat.com>
This commit is contained in:
parent
6e1baedd2f
commit
f17b9c57c5
22
run.in
22
run.in
@ -130,18 +130,18 @@ def change_unit(name, action):
|
|||||||
|
|
||||||
try_stop_units = []
|
try_stop_units = []
|
||||||
if is_systemd_host():
|
if is_systemd_host():
|
||||||
name = os.path.basename(prog)
|
|
||||||
|
|
||||||
maybe_stopped_units = []
|
maybe_stopped_units = []
|
||||||
if is_modular_daemon(name):
|
for arg in sys.argv:
|
||||||
# Only need to stop libvirtd or this specific modular unit
|
name = os.path.basename(arg)
|
||||||
maybe_stopped_units += daemon_units("libvirtd")
|
if is_modular_daemon(name):
|
||||||
maybe_stopped_units += daemon_units(name)
|
# Only need to stop libvirtd or this specific modular unit
|
||||||
elif is_monolithic_daemon(name):
|
maybe_stopped_units += daemon_units("libvirtd")
|
||||||
# Need to stop libvirtd and/or all modular units
|
maybe_stopped_units += daemon_units(name)
|
||||||
maybe_stopped_units += daemon_units("libvirtd")
|
elif is_monolithic_daemon(name):
|
||||||
for entry in modular_daemons:
|
# Need to stop libvirtd and/or all modular units
|
||||||
maybe_stopped_units += daemon_units(entry)
|
maybe_stopped_units += daemon_units("libvirtd")
|
||||||
|
for entry in modular_daemons:
|
||||||
|
maybe_stopped_units += daemon_units(entry)
|
||||||
|
|
||||||
for unit in maybe_stopped_units:
|
for unit in maybe_stopped_units:
|
||||||
if is_unit_active(unit):
|
if is_unit_active(unit):
|
||||||
|
Loading…
Reference in New Issue
Block a user