2011-02-14 16:09:39 +00:00
|
|
|
/*
|
2013-07-26 14:24:55 +02:00
|
|
|
* qemu_process.h: QEMU process management
|
2011-02-14 16:09:39 +00:00
|
|
|
*
|
2015-01-08 15:37:50 +01:00
|
|
|
* Copyright (C) 2006-2012, 2015 Red Hat, Inc.
|
2011-02-14 16:09:39 +00:00
|
|
|
*
|
|
|
|
* This library is free software; you can redistribute it and/or
|
|
|
|
* modify it under the terms of the GNU Lesser General Public
|
|
|
|
* License as published by the Free Software Foundation; either
|
|
|
|
* version 2.1 of the License, or (at your option) any later version.
|
|
|
|
*
|
|
|
|
* This library is distributed in the hope that it will be useful,
|
|
|
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
|
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
|
|
|
|
* Lesser General Public License for more details.
|
|
|
|
*
|
|
|
|
* You should have received a copy of the GNU Lesser General Public
|
2012-09-20 16:30:55 -06:00
|
|
|
* License along with this library. If not, see
|
2012-07-21 18:06:23 +08:00
|
|
|
* <http://www.gnu.org/licenses/>.
|
2011-02-14 16:09:39 +00:00
|
|
|
*
|
|
|
|
*/
|
|
|
|
|
|
|
|
#ifndef __QEMU_PROCESS_H__
|
|
|
|
# define __QEMU_PROCESS_H__
|
|
|
|
|
|
|
|
# include "qemu_conf.h"
|
qemu: fix crash when mixing sync and async monitor jobs
Currently, we attempt to run sync job and async job at the same time. It
means that the monitor commands for two jobs can be run in any order.
In the function qemuDomainObjEnterMonitorInternal():
if (priv->job.active == QEMU_JOB_NONE && priv->job.asyncJob) {
if (qemuDomainObjBeginNestedJob(driver, obj) < 0)
We check whether the caller is an async job by priv->job.active and
priv->job.asynJob. But when an async job is running, and a sync job is
also running at the time of the check, then priv->job.active is not
QEMU_JOB_NONE. So we cannot check whether the caller is an async job
in the function qemuDomainObjEnterMonitorInternal(), and must instead
put the burden on the caller to tell us when an async command wants
to do a nested job.
Once the burden is on the caller, then only async monitor enters need
to worry about whether the VM is still running; for sync monitor enter,
the internal return is always 0, so lots of ignore_value can be dropped.
* src/qemu/THREADS.txt: Reflect new rules.
* src/qemu/qemu_domain.h (qemuDomainObjEnterMonitorAsync): New
prototype.
* src/qemu/qemu_process.h (qemuProcessStartCPUs)
(qemuProcessStopCPUs): Add parameter.
* src/qemu/qemu_migration.h (qemuMigrationToFile): Likewise.
(qemuMigrationWaitForCompletion): Make static.
* src/qemu/qemu_domain.c (qemuDomainObjEnterMonitorInternal): Add
parameter.
(qemuDomainObjEnterMonitorAsync): New function.
(qemuDomainObjEnterMonitor, qemuDomainObjEnterMonitorWithDriver):
Update callers.
* src/qemu/qemu_driver.c (qemuDomainSaveInternal)
(qemudDomainCoreDump, doCoreDump, processWatchdogEvent)
(qemudDomainSuspend, qemudDomainResume, qemuDomainSaveImageStartVM)
(qemuDomainSnapshotCreateActive, qemuDomainRevertToSnapshot):
Likewise.
* src/qemu/qemu_process.c (qemuProcessStopCPUs)
(qemuProcessFakeReboot, qemuProcessRecoverMigration)
(qemuProcessRecoverJob, qemuProcessStart): Likewise.
* src/qemu/qemu_migration.c (qemuMigrationToFile)
(qemuMigrationWaitForCompletion, qemuMigrationUpdateJobStatus)
(qemuMigrationJobStart, qemuDomainMigrateGraphicsRelocate)
(doNativeMigrate, doTunnelMigrate, qemuMigrationPerformJob)
(qemuMigrationPerformPhase, qemuMigrationFinish)
(qemuMigrationConfirm): Likewise.
* src/qemu/qemu_hotplug.c: Drop unneeded ignore_value.
2011-07-28 17:18:24 -06:00
|
|
|
# include "qemu_domain.h"
|
2011-02-14 16:09:39 +00:00
|
|
|
|
2016-02-26 09:15:55 +01:00
|
|
|
int qemuProcessPrepareMonitorChr(virDomainChrSourceDefPtr monConfig,
|
|
|
|
const char *domainDir);
|
2011-02-14 16:09:39 +00:00
|
|
|
|
2012-11-28 16:43:10 +00:00
|
|
|
int qemuProcessStartCPUs(virQEMUDriverPtr driver,
|
2011-05-04 11:07:01 +02:00
|
|
|
virDomainObjPtr vm,
|
qemu: fix crash when mixing sync and async monitor jobs
Currently, we attempt to run sync job and async job at the same time. It
means that the monitor commands for two jobs can be run in any order.
In the function qemuDomainObjEnterMonitorInternal():
if (priv->job.active == QEMU_JOB_NONE && priv->job.asyncJob) {
if (qemuDomainObjBeginNestedJob(driver, obj) < 0)
We check whether the caller is an async job by priv->job.active and
priv->job.asynJob. But when an async job is running, and a sync job is
also running at the time of the check, then priv->job.active is not
QEMU_JOB_NONE. So we cannot check whether the caller is an async job
in the function qemuDomainObjEnterMonitorInternal(), and must instead
put the burden on the caller to tell us when an async command wants
to do a nested job.
Once the burden is on the caller, then only async monitor enters need
to worry about whether the VM is still running; for sync monitor enter,
the internal return is always 0, so lots of ignore_value can be dropped.
* src/qemu/THREADS.txt: Reflect new rules.
* src/qemu/qemu_domain.h (qemuDomainObjEnterMonitorAsync): New
prototype.
* src/qemu/qemu_process.h (qemuProcessStartCPUs)
(qemuProcessStopCPUs): Add parameter.
* src/qemu/qemu_migration.h (qemuMigrationToFile): Likewise.
(qemuMigrationWaitForCompletion): Make static.
* src/qemu/qemu_domain.c (qemuDomainObjEnterMonitorInternal): Add
parameter.
(qemuDomainObjEnterMonitorAsync): New function.
(qemuDomainObjEnterMonitor, qemuDomainObjEnterMonitorWithDriver):
Update callers.
* src/qemu/qemu_driver.c (qemuDomainSaveInternal)
(qemudDomainCoreDump, doCoreDump, processWatchdogEvent)
(qemudDomainSuspend, qemudDomainResume, qemuDomainSaveImageStartVM)
(qemuDomainSnapshotCreateActive, qemuDomainRevertToSnapshot):
Likewise.
* src/qemu/qemu_process.c (qemuProcessStopCPUs)
(qemuProcessFakeReboot, qemuProcessRecoverMigration)
(qemuProcessRecoverJob, qemuProcessStart): Likewise.
* src/qemu/qemu_migration.c (qemuMigrationToFile)
(qemuMigrationWaitForCompletion, qemuMigrationUpdateJobStatus)
(qemuMigrationJobStart, qemuDomainMigrateGraphicsRelocate)
(doNativeMigrate, doTunnelMigrate, qemuMigrationPerformJob)
(qemuMigrationPerformPhase, qemuMigrationFinish)
(qemuMigrationConfirm): Likewise.
* src/qemu/qemu_hotplug.c: Drop unneeded ignore_value.
2011-07-28 17:18:24 -06:00
|
|
|
virDomainRunningReason reason,
|
2014-06-15 13:32:56 -03:00
|
|
|
qemuDomainAsyncJob asyncJob);
|
2012-11-28 16:43:10 +00:00
|
|
|
int qemuProcessStopCPUs(virQEMUDriverPtr driver,
|
2011-05-04 11:07:01 +02:00
|
|
|
virDomainObjPtr vm,
|
qemu: fix crash when mixing sync and async monitor jobs
Currently, we attempt to run sync job and async job at the same time. It
means that the monitor commands for two jobs can be run in any order.
In the function qemuDomainObjEnterMonitorInternal():
if (priv->job.active == QEMU_JOB_NONE && priv->job.asyncJob) {
if (qemuDomainObjBeginNestedJob(driver, obj) < 0)
We check whether the caller is an async job by priv->job.active and
priv->job.asynJob. But when an async job is running, and a sync job is
also running at the time of the check, then priv->job.active is not
QEMU_JOB_NONE. So we cannot check whether the caller is an async job
in the function qemuDomainObjEnterMonitorInternal(), and must instead
put the burden on the caller to tell us when an async command wants
to do a nested job.
Once the burden is on the caller, then only async monitor enters need
to worry about whether the VM is still running; for sync monitor enter,
the internal return is always 0, so lots of ignore_value can be dropped.
* src/qemu/THREADS.txt: Reflect new rules.
* src/qemu/qemu_domain.h (qemuDomainObjEnterMonitorAsync): New
prototype.
* src/qemu/qemu_process.h (qemuProcessStartCPUs)
(qemuProcessStopCPUs): Add parameter.
* src/qemu/qemu_migration.h (qemuMigrationToFile): Likewise.
(qemuMigrationWaitForCompletion): Make static.
* src/qemu/qemu_domain.c (qemuDomainObjEnterMonitorInternal): Add
parameter.
(qemuDomainObjEnterMonitorAsync): New function.
(qemuDomainObjEnterMonitor, qemuDomainObjEnterMonitorWithDriver):
Update callers.
* src/qemu/qemu_driver.c (qemuDomainSaveInternal)
(qemudDomainCoreDump, doCoreDump, processWatchdogEvent)
(qemudDomainSuspend, qemudDomainResume, qemuDomainSaveImageStartVM)
(qemuDomainSnapshotCreateActive, qemuDomainRevertToSnapshot):
Likewise.
* src/qemu/qemu_process.c (qemuProcessStopCPUs)
(qemuProcessFakeReboot, qemuProcessRecoverMigration)
(qemuProcessRecoverJob, qemuProcessStart): Likewise.
* src/qemu/qemu_migration.c (qemuMigrationToFile)
(qemuMigrationWaitForCompletion, qemuMigrationUpdateJobStatus)
(qemuMigrationJobStart, qemuDomainMigrateGraphicsRelocate)
(doNativeMigrate, doTunnelMigrate, qemuMigrationPerformJob)
(qemuMigrationPerformPhase, qemuMigrationFinish)
(qemuMigrationConfirm): Likewise.
* src/qemu/qemu_hotplug.c: Drop unneeded ignore_value.
2011-07-28 17:18:24 -06:00
|
|
|
virDomainPausedReason reason,
|
2014-06-15 13:32:56 -03:00
|
|
|
qemuDomainAsyncJob asyncJob);
|
2011-02-14 16:09:39 +00:00
|
|
|
|
2017-11-07 15:19:43 +01:00
|
|
|
int qemuProcessBuildDestroyMemoryPaths(virQEMUDriverPtr driver,
|
|
|
|
virDomainObjPtr vm,
|
|
|
|
virDomainMemoryDefPtr mem,
|
|
|
|
bool build);
|
2017-06-07 14:47:37 +02:00
|
|
|
|
2018-01-11 13:02:52 +01:00
|
|
|
int qemuProcessDestroyMemoryBackingPath(virQEMUDriverPtr driver,
|
|
|
|
virDomainObjPtr vm,
|
|
|
|
virDomainMemoryDefPtr mem);
|
|
|
|
|
2012-11-28 16:43:10 +00:00
|
|
|
void qemuProcessAutostartAll(virQEMUDriverPtr driver);
|
2018-02-09 17:19:44 +00:00
|
|
|
void qemuProcessReconnectAll(virQEMUDriverPtr driver);
|
2011-02-14 16:09:39 +00:00
|
|
|
|
2015-11-06 18:41:37 +01:00
|
|
|
typedef struct _qemuProcessIncomingDef qemuProcessIncomingDef;
|
|
|
|
typedef qemuProcessIncomingDef *qemuProcessIncomingDefPtr;
|
|
|
|
struct _qemuProcessIncomingDef {
|
2016-01-08 00:07:37 +01:00
|
|
|
char *address; /* address where QEMU is supposed to listen */
|
2015-11-06 18:41:37 +01:00
|
|
|
char *launchURI; /* used as a parameter for -incoming command line option */
|
2015-11-11 18:02:23 +01:00
|
|
|
char *deferredURI; /* used when calling migrate-incoming QMP command */
|
2015-11-06 18:41:37 +01:00
|
|
|
int fd; /* for fd:N URI */
|
|
|
|
const char *path; /* path associated with fd */
|
|
|
|
};
|
|
|
|
|
|
|
|
qemuProcessIncomingDefPtr qemuProcessIncomingDefNew(virQEMUCapsPtr qemuCaps,
|
2016-01-08 00:07:37 +01:00
|
|
|
const char *listenAddress,
|
2015-11-06 18:41:37 +01:00
|
|
|
const char *migrateFrom,
|
|
|
|
int fd,
|
|
|
|
const char *path);
|
|
|
|
void qemuProcessIncomingDefFree(qemuProcessIncomingDefPtr inc);
|
|
|
|
|
2015-10-21 10:55:43 +02:00
|
|
|
int qemuProcessBeginJob(virQEMUDriverPtr driver,
|
2017-04-26 12:00:09 +02:00
|
|
|
virDomainObjPtr vm,
|
|
|
|
virDomainJobOperation operation);
|
2015-10-21 10:55:43 +02:00
|
|
|
void qemuProcessEndJob(virQEMUDriverPtr driver,
|
|
|
|
virDomainObjPtr vm);
|
|
|
|
|
2012-03-08 14:20:19 +01:00
|
|
|
typedef enum {
|
|
|
|
VIR_QEMU_PROCESS_START_COLD = 1 << 0,
|
|
|
|
VIR_QEMU_PROCESS_START_PAUSED = 1 << 1,
|
2013-02-27 16:53:08 +00:00
|
|
|
VIR_QEMU_PROCESS_START_AUTODESTROY = 1 << 2,
|
2016-03-15 13:00:59 +01:00
|
|
|
VIR_QEMU_PROCESS_START_PRETEND = 1 << 3,
|
2016-05-27 13:45:05 +02:00
|
|
|
VIR_QEMU_PROCESS_START_NEW = 1 << 4, /* internal, new VM is starting */
|
2012-03-08 14:20:19 +01:00
|
|
|
} qemuProcessStartFlags;
|
|
|
|
|
2011-02-14 16:09:39 +00:00
|
|
|
int qemuProcessStart(virConnectPtr conn,
|
2012-11-28 16:43:10 +00:00
|
|
|
virQEMUDriverPtr driver,
|
2011-02-14 16:09:39 +00:00
|
|
|
virDomainObjPtr vm,
|
2017-05-31 12:34:10 +02:00
|
|
|
virCPUDefPtr updatedCPU,
|
2015-10-21 10:55:43 +02:00
|
|
|
qemuDomainAsyncJob asyncJob,
|
2011-02-14 16:09:39 +00:00
|
|
|
const char *migrateFrom,
|
|
|
|
int stdin_fd,
|
|
|
|
const char *stdin_path,
|
2011-08-25 14:44:48 -06:00
|
|
|
virDomainSnapshotObjPtr snapshot,
|
2014-04-26 21:15:22 -03:00
|
|
|
virNetDevVPortProfileOp vmop,
|
2012-03-08 14:20:19 +01:00
|
|
|
unsigned int flags);
|
2011-02-14 16:09:39 +00:00
|
|
|
|
2018-02-09 16:36:24 +00:00
|
|
|
virCommandPtr qemuProcessCreatePretendCmd(virQEMUDriverPtr driver,
|
2016-03-22 13:17:27 +01:00
|
|
|
virDomainObjPtr vm,
|
|
|
|
const char *migrateURI,
|
2016-04-25 07:47:59 +02:00
|
|
|
bool enableFips,
|
2016-03-22 13:17:27 +01:00
|
|
|
bool standalone,
|
|
|
|
unsigned int flags);
|
2016-02-04 15:25:29 +01:00
|
|
|
|
2015-11-10 16:58:12 +01:00
|
|
|
int qemuProcessInit(virQEMUDriverPtr driver,
|
|
|
|
virDomainObjPtr vm,
|
2017-05-31 12:34:10 +02:00
|
|
|
virCPUDefPtr updatedCPU,
|
2016-01-28 15:56:07 +01:00
|
|
|
qemuDomainAsyncJob asyncJob,
|
2016-02-04 15:25:29 +01:00
|
|
|
bool migration,
|
2016-03-17 13:51:20 +01:00
|
|
|
unsigned int flags);
|
2015-11-10 16:58:12 +01:00
|
|
|
|
2018-02-09 16:36:24 +00:00
|
|
|
int qemuProcessPrepareDomain(virQEMUDriverPtr driver,
|
2016-03-15 13:00:59 +01:00
|
|
|
virDomainObjPtr vm,
|
|
|
|
unsigned int flags);
|
|
|
|
|
2016-03-22 13:16:05 +01:00
|
|
|
int qemuProcessPrepareHost(virQEMUDriverPtr driver,
|
|
|
|
virDomainObjPtr vm,
|
2017-10-03 10:14:21 +02:00
|
|
|
unsigned int flags);
|
2016-03-22 13:16:05 +01:00
|
|
|
|
2015-11-10 16:58:41 +01:00
|
|
|
int qemuProcessLaunch(virConnectPtr conn,
|
|
|
|
virQEMUDriverPtr driver,
|
|
|
|
virDomainObjPtr vm,
|
|
|
|
qemuDomainAsyncJob asyncJob,
|
|
|
|
qemuProcessIncomingDefPtr incoming,
|
|
|
|
virDomainSnapshotObjPtr snapshot,
|
|
|
|
virNetDevVPortProfileOp vmop,
|
|
|
|
unsigned int flags);
|
|
|
|
|
2018-02-09 15:40:51 +00:00
|
|
|
int qemuProcessFinishStartup(virQEMUDriverPtr driver,
|
2015-11-10 13:29:40 +01:00
|
|
|
virDomainObjPtr vm,
|
|
|
|
qemuDomainAsyncJob asyncJob,
|
|
|
|
bool startCPUs,
|
|
|
|
virDomainPausedReason pausedReason);
|
|
|
|
|
2018-02-01 15:02:17 +01:00
|
|
|
int qemuProcessRefreshState(virQEMUDriverPtr driver,
|
|
|
|
virDomainObjPtr vm,
|
|
|
|
qemuDomainAsyncJob asyncJob);
|
|
|
|
|
2012-06-11 15:20:44 +02:00
|
|
|
typedef enum {
|
2012-06-11 15:57:19 +02:00
|
|
|
VIR_QEMU_PROCESS_STOP_MIGRATED = 1 << 0,
|
|
|
|
VIR_QEMU_PROCESS_STOP_NO_RELABEL = 1 << 1,
|
2012-06-11 15:20:44 +02:00
|
|
|
} qemuProcessStopFlags;
|
|
|
|
|
2016-02-11 15:13:09 +01:00
|
|
|
int qemuProcessBeginStopJob(virQEMUDriverPtr driver,
|
|
|
|
virDomainObjPtr vm,
|
|
|
|
qemuDomainJob job,
|
|
|
|
bool forceKill);
|
2012-11-28 16:43:10 +00:00
|
|
|
void qemuProcessStop(virQEMUDriverPtr driver,
|
2011-02-14 16:09:39 +00:00
|
|
|
virDomainObjPtr vm,
|
2012-06-11 15:20:44 +02:00
|
|
|
virDomainShutoffReason reason,
|
2016-02-11 11:20:28 +01:00
|
|
|
qemuDomainAsyncJob asyncJob,
|
2012-06-11 15:20:44 +02:00
|
|
|
unsigned int flags);
|
2011-02-14 16:09:39 +00:00
|
|
|
|
2011-05-05 17:32:21 +01:00
|
|
|
int qemuProcessAttach(virConnectPtr conn,
|
2012-11-28 16:43:10 +00:00
|
|
|
virQEMUDriverPtr driver,
|
2011-05-05 17:32:21 +01:00
|
|
|
virDomainObjPtr vm,
|
build: use correct type for pid and similar types
No thanks to 64-bit windows, with 64-bit pid_t, we have to avoid
constructs like 'int pid'. Our API in libvirt-qemu cannot be
changed without breaking ABI; but then again, libvirt-qemu can
only be used on systems that support UNIX sockets, which rules
out Windows (even if qemu could be compiled there) - so for all
points on the call chain that interact with this API decision,
we require a different variable name to make it clear that we
audited the use for safety.
Adding a syntax-check rule only solves half the battle; anywhere
that uses printf on a pid_t still needs to be converted, but that
will be a separate patch.
* cfg.mk (sc_correct_id_types): New syntax check.
* src/libvirt-qemu.c (virDomainQemuAttach): Document why we didn't
use pid_t for pid, and validate for overflow.
* include/libvirt/libvirt-qemu.h (virDomainQemuAttach): Tweak name
for syntax check.
* src/vmware/vmware_conf.c (vmwareExtractPid): Likewise.
* src/driver.h (virDrvDomainQemuAttach): Likewise.
* tools/virsh.c (cmdQemuAttach): Likewise.
* src/remote/qemu_protocol.x (qemu_domain_attach_args): Likewise.
* src/qemu_protocol-structs (qemu_domain_attach_args): Likewise.
* src/util/cgroup.c (virCgroupPidCode, virCgroupKillInternal):
Likewise.
* src/qemu/qemu_command.c(qemuParseProcFileStrings): Likewise.
(qemuParseCommandLinePid): Use pid_t for pid.
* daemon/libvirtd.c (daemonForkIntoBackground): Likewise.
* src/conf/domain_conf.h (_virDomainObj): Likewise.
* src/probes.d (rpc_socket_new): Likewise.
* src/qemu/qemu_command.h (qemuParseCommandLinePid): Likewise.
* src/qemu/qemu_driver.c (qemudGetProcessInfo, qemuDomainAttach):
Likewise.
* src/qemu/qemu_process.c (qemuProcessAttach): Likewise.
* src/qemu/qemu_process.h (qemuProcessAttach): Likewise.
* src/uml/uml_driver.c (umlGetProcessInfo): Likewise.
* src/util/virnetdev.h (virNetDevSetNamespace): Likewise.
* src/util/virnetdev.c (virNetDevSetNamespace): Likewise.
* tests/testutils.c (virtTestCaptureProgramOutput): Likewise.
* src/conf/storage_conf.h (_virStoragePerms): Use mode_t, uid_t,
and gid_t rather than int.
* src/security/security_dac.c (virSecurityDACSetOwnership): Likewise.
* src/conf/storage_conf.c (virStorageDefParsePerms): Avoid
compiler warning.
2012-02-10 16:08:11 -07:00
|
|
|
pid_t pid,
|
2011-05-05 17:32:21 +01:00
|
|
|
const char *pidfile,
|
|
|
|
virDomainChrSourceDefPtr monConfig,
|
|
|
|
bool monJSON);
|
|
|
|
|
qemu: new GRACEFUL flag for virDomainDestroy w/ QEMU support
When libvirt's virDomainDestroy API is shutting down the qemu process,
it first sends SIGTERM, then waits for 1.6 seconds and, if it sees the
process still there, sends a SIGKILL.
There have been reports that this behavior can lead to data loss
because the guest running in qemu doesn't have time to flush its disk
cache buffers before it's unceremoniously whacked.
This patch maintains that default behavior, but provides a new flag
VIR_DOMAIN_DESTROY_GRACEFUL to alter the behavior. If this flag is set
in the call to virDomainDestroyFlags, SIGKILL will never be sent to
the qemu process; instead, if the timeout is reached and the qemu
process still exists, virDomainDestroy will return an error.
Once this patch is in, the recommended method for applications to call
virDomainDestroyFlags will be with VIR_DOMAIN_DESTROY_GRACEFUL
included. If that fails, then the application can decide if and when
to call virDomainDestroyFlags again without
VIR_DOMAIN_DESTROY_GRACEFUL (to force the issue with SIGKILL).
(Note that this does not address the issue of existing applications
that have not yet been modified to use VIR_DOMAIN_DESTROY_GRACEFUL.
That is a separate patch.)
2012-01-27 13:28:23 -05:00
|
|
|
typedef enum {
|
|
|
|
VIR_QEMU_PROCESS_KILL_FORCE = 1 << 0,
|
|
|
|
VIR_QEMU_PROCESS_KILL_NOWAIT = 1 << 1,
|
2012-03-30 14:21:49 +08:00
|
|
|
VIR_QEMU_PROCESS_KILL_NOCHECK = 1 << 2, /* bypass the running vm check */
|
qemu: new GRACEFUL flag for virDomainDestroy w/ QEMU support
When libvirt's virDomainDestroy API is shutting down the qemu process,
it first sends SIGTERM, then waits for 1.6 seconds and, if it sees the
process still there, sends a SIGKILL.
There have been reports that this behavior can lead to data loss
because the guest running in qemu doesn't have time to flush its disk
cache buffers before it's unceremoniously whacked.
This patch maintains that default behavior, but provides a new flag
VIR_DOMAIN_DESTROY_GRACEFUL to alter the behavior. If this flag is set
in the call to virDomainDestroyFlags, SIGKILL will never be sent to
the qemu process; instead, if the timeout is reached and the qemu
process still exists, virDomainDestroy will return an error.
Once this patch is in, the recommended method for applications to call
virDomainDestroyFlags will be with VIR_DOMAIN_DESTROY_GRACEFUL
included. If that fails, then the application can decide if and when
to call virDomainDestroyFlags again without
VIR_DOMAIN_DESTROY_GRACEFUL (to force the issue with SIGKILL).
(Note that this does not address the issue of existing applications
that have not yet been modified to use VIR_DOMAIN_DESTROY_GRACEFUL.
That is a separate patch.)
2012-01-27 13:28:23 -05:00
|
|
|
} virQemuProcessKillMode;
|
|
|
|
|
2013-02-06 18:17:20 +00:00
|
|
|
int qemuProcessKill(virDomainObjPtr vm, unsigned int flags);
|
2011-04-21 11:19:06 -04:00
|
|
|
|
2013-06-07 18:23:33 +08:00
|
|
|
void qemuProcessShutdownOrReboot(virQEMUDriverPtr driver,
|
|
|
|
virDomainObjPtr vm);
|
|
|
|
|
2012-11-28 16:43:10 +00:00
|
|
|
int qemuProcessAutoDestroyInit(virQEMUDriverPtr driver);
|
|
|
|
void qemuProcessAutoDestroyShutdown(virQEMUDriverPtr driver);
|
|
|
|
int qemuProcessAutoDestroyAdd(virQEMUDriverPtr driver,
|
2011-06-23 10:37:57 +01:00
|
|
|
virDomainObjPtr vm,
|
|
|
|
virConnectPtr conn);
|
2012-11-28 16:43:10 +00:00
|
|
|
int qemuProcessAutoDestroyRemove(virQEMUDriverPtr driver,
|
2011-06-23 10:37:57 +01:00
|
|
|
virDomainObjPtr vm);
|
2012-11-28 16:43:10 +00:00
|
|
|
bool qemuProcessAutoDestroyActive(virQEMUDriverPtr driver,
|
2011-06-23 11:41:57 +01:00
|
|
|
virDomainObjPtr vm);
|
2011-06-23 10:37:57 +01:00
|
|
|
|
2015-01-08 15:37:50 +01:00
|
|
|
int qemuProcessSetSchedParams(int id, pid_t pid, size_t nsp,
|
|
|
|
virDomainThreadSchedParamPtr sp);
|
|
|
|
|
2015-03-13 16:59:26 +01:00
|
|
|
virDomainDiskDefPtr qemuProcessFindDomainDiskByAlias(virDomainObjPtr vm,
|
|
|
|
const char *alias);
|
|
|
|
|
2015-04-24 16:48:26 +02:00
|
|
|
int qemuConnectAgent(virQEMUDriverPtr driver, virDomainObjPtr vm);
|
|
|
|
|
2016-01-13 16:36:52 +01:00
|
|
|
|
|
|
|
int qemuProcessSetupVcpu(virDomainObjPtr vm,
|
|
|
|
unsigned int vcpuid);
|
2016-01-14 10:38:02 +01:00
|
|
|
int qemuProcessSetupIOThread(virDomainObjPtr vm,
|
|
|
|
virDomainIOThreadIDDefPtr iothread);
|
2016-01-13 16:36:52 +01:00
|
|
|
|
2016-01-08 17:03:48 +01:00
|
|
|
int qemuRefreshVirtioChannelState(virQEMUDriverPtr driver,
|
2016-06-29 15:52:49 +02:00
|
|
|
virDomainObjPtr vm,
|
|
|
|
qemuDomainAsyncJob asyncJob);
|
2016-04-06 15:57:57 +02:00
|
|
|
|
|
|
|
int qemuProcessRefreshBalloonState(virQEMUDriverPtr driver,
|
|
|
|
virDomainObjPtr vm,
|
|
|
|
int asyncJob);
|
2016-05-23 14:00:35 +02:00
|
|
|
|
|
|
|
int qemuProcessRefreshDisks(virQEMUDriverPtr driver,
|
|
|
|
virDomainObjPtr vm,
|
|
|
|
qemuDomainAsyncJob asyncJob);
|
|
|
|
|
2011-02-14 16:09:39 +00:00
|
|
|
#endif /* __QEMU_PROCESS_H__ */
|