aboutsummaryrefslogtreecommitdiffstats
path: root/xen
diff options
context:
space:
mode:
authorIan Campbell <ian.campbell@citrix.com>2012-12-19 14:16:20 +0000
committerIan Campbell <ian.campbell@citrix.com>2012-12-19 14:16:20 +0000
commit5f430567eb0b98493e48ea13b2e503fe5ad7d3ae (patch)
treea0e68d1473ccc800b7f5f9ff164eb21a3e214421 /xen
parent0a4021dd047c9a0b95da8f2106ed1719df58882a (diff)
downloadxen-5f430567eb0b98493e48ea13b2e503fe5ad7d3ae.tar.gz
xen-5f430567eb0b98493e48ea13b2e503fe5ad7d3ae.tar.bz2
xen-5f430567eb0b98493e48ea13b2e503fe5ad7d3ae.zip
xen: arm: implement arch_get_info_guest
Untested, but basically the inverse of arch_set_info_guest. Signed-off-by: Ian Campbell <ian.campbell@citrix.com> Acked-by: Tim Deegan <tim@xen.org> Acked-by: Stefano Stabellini <stefano.stabellini@eu.citrix.com> Committed-by: Ian Campbell <ian.campbell@citrix.com>
Diffstat (limited to 'xen')
-rw-r--r--xen/arch/arm/domctl.c17
-rw-r--r--xen/arch/arm/dummy.S1
2 files changed, 17 insertions, 1 deletions
diff --git a/xen/arch/arm/domctl.c b/xen/arch/arm/domctl.c
index d54a387d5e..c7ffd8a745 100644
--- a/xen/arch/arm/domctl.c
+++ b/xen/arch/arm/domctl.c
@@ -8,6 +8,7 @@
#include <xen/types.h>
#include <xen/lib.h>
#include <xen/errno.h>
+#include <xen/sched.h>
#include <public/domctl.h>
long arch_do_domctl(struct xen_domctl *domctl, struct domain *d,
@@ -16,6 +17,22 @@ long arch_do_domctl(struct xen_domctl *domctl, struct domain *d,
return -ENOSYS;
}
+void arch_get_info_guest(struct vcpu *v, vcpu_guest_context_u c)
+{
+ struct vcpu_guest_context *ctxt = c.nat;
+ struct cpu_user_regs *regs = &c.nat->user_regs;
+
+ *regs = v->arch.cpu_info->guest_cpu_user_regs;
+
+ ctxt->sctlr = v->arch.sctlr;
+ ctxt->ttbr0 = v->arch.ttbr0;
+ ctxt->ttbr1 = v->arch.ttbr1;
+ ctxt->ttbcr = v->arch.ttbcr;
+
+ if ( !test_bit(_VPF_down, &v->pause_flags) )
+ ctxt->flags |= VGCF_online;
+}
+
/*
* Local variables:
* mode: C
diff --git a/xen/arch/arm/dummy.S b/xen/arch/arm/dummy.S
index bfd948acb6..5ac6af9ec9 100644
--- a/xen/arch/arm/dummy.S
+++ b/xen/arch/arm/dummy.S
@@ -14,7 +14,6 @@ DUMMY(pirq_guest_unbind);
DUMMY(pirq_set_affinity);
/* VCPU */
-DUMMY(arch_get_info_guest);
DUMMY(arch_vcpu_reset);
NOP(update_vcpu_system_time);