The new state is required as a prerequisite to implementing soft reset operation for domains. In this operation we need to make sure that source domain's mappings don't change while we are reassigning all its memory to the destination domain. This new state indicates that the particular domain is dying (so its mappings are locked and do not change) but the cleanup procedure has not being started yet. It will be set from outside of the domain_kill() function.
Signed-off-by: Vitaly Kuznetsov <vkuzn...@redhat.com> --- xen/common/domain.c | 1 + xen/include/xen/sched.h | 3 ++- 2 files changed, 3 insertions(+), 1 deletion(-) diff --git a/xen/common/domain.c b/xen/common/domain.c index 6803c4d..7825c56 100644 --- a/xen/common/domain.c +++ b/xen/common/domain.c @@ -605,6 +605,7 @@ int domain_kill(struct domain *d) switch ( d->is_dying ) { case DOMDYING_alive: + case DOMDYING_locked: domain_pause(d); d->is_dying = DOMDYING_dying; spin_barrier(&d->domain_lock); diff --git a/xen/include/xen/sched.h b/xen/include/xen/sched.h index 80c6f62..f53b91d 100644 --- a/xen/include/xen/sched.h +++ b/xen/include/xen/sched.h @@ -354,7 +354,8 @@ struct domain enum guest_type guest_type; /* Is this guest dying (i.e., a zombie)? */ - enum { DOMDYING_alive, DOMDYING_dying, DOMDYING_dead } is_dying; + enum { DOMDYING_alive, DOMDYING_locked, DOMDYING_dying, DOMDYING_dead } + is_dying; /* Domain is paused by controller software? */ int controller_pause_count; -- 1.9.3 _______________________________________________ Xen-devel mailing list Xen-devel@lists.xen.org http://lists.xen.org/xen-devel