Skip to content

Commit

Permalink
---
Browse files Browse the repository at this point in the history
yaml
---
r: 99534
b: refs/heads/master
c: 7b1333a
h: refs/heads/master
v: v3
  • Loading branch information
Jeremy Fitzhardinge authored and Thomas Gleixner committed May 27, 2008
1 parent 7423086 commit 2e96e1a
Show file tree
Hide file tree
Showing 3 changed files with 34 additions and 3 deletions.
2 changes: 1 addition & 1 deletion [refs]
Original file line number Diff line number Diff line change
@@ -1,2 +1,2 @@
---
refs/heads/master: 0922abdc3982ae54cbe1b24ac5aa91a260eca1bb
refs/heads/master: 7b1333aa4cb546ddeb9c05098a53d9a777623a05
28 changes: 26 additions & 2 deletions trunk/arch/x86/xen/enlighten.c
Original file line number Diff line number Diff line change
Expand Up @@ -607,6 +607,30 @@ static void xen_flush_tlb_others(const cpumask_t *cpus, struct mm_struct *mm,
xen_mc_issue(PARAVIRT_LAZY_MMU);
}

static void xen_clts(void)
{
struct multicall_space mcs;

mcs = xen_mc_entry(0);

MULTI_fpu_taskswitch(mcs.mc, 0);

xen_mc_issue(PARAVIRT_LAZY_CPU);
}

static void xen_write_cr0(unsigned long cr0)
{
struct multicall_space mcs;

/* Only pay attention to cr0.TS; everything else is
ignored. */
mcs = xen_mc_entry(0);

MULTI_fpu_taskswitch(mcs.mc, (cr0 & X86_CR0_TS) != 0);

xen_mc_issue(PARAVIRT_LAZY_CPU);
}

static void xen_write_cr2(unsigned long cr2)
{
x86_read_percpu(xen_vcpu)->arch.cr2 = cr2;
Expand Down Expand Up @@ -978,10 +1002,10 @@ static const struct pv_cpu_ops xen_cpu_ops __initdata = {
.set_debugreg = xen_set_debugreg,
.get_debugreg = xen_get_debugreg,

.clts = native_clts,
.clts = xen_clts,

.read_cr0 = native_read_cr0,
.write_cr0 = native_write_cr0,
.write_cr0 = xen_write_cr0,

.read_cr4 = native_read_cr4,
.read_cr4_safe = native_read_cr4_safe,
Expand Down
7 changes: 7 additions & 0 deletions trunk/include/asm-x86/xen/hypercall.h
Original file line number Diff line number Diff line change
Expand Up @@ -314,6 +314,13 @@ HYPERVISOR_nmi_op(unsigned long op, unsigned long arg)
return _hypercall2(int, nmi_op, op, arg);
}

static inline void
MULTI_fpu_taskswitch(struct multicall_entry *mcl, int set)
{
mcl->op = __HYPERVISOR_fpu_taskswitch;
mcl->args[0] = set;
}

static inline void
MULTI_update_va_mapping(struct multicall_entry *mcl, unsigned long va,
pte_t new_val, unsigned long flags)
Expand Down

0 comments on commit 2e96e1a

Please sign in to comment.