Skip to content

Commit

Permalink
---
Browse files Browse the repository at this point in the history
yaml
---
r: 80101
b: refs/heads/master
c: 2e47d3e
h: refs/heads/master
i:
  80099: 639fbb0
v: v3
  • Loading branch information
Glauber de Oliveira Costa authored and Ingo Molnar committed Jan 30, 2008
1 parent 78c69be commit 6326705
Show file tree
Hide file tree
Showing 2 changed files with 31 additions and 14 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: 6057fc827b3a9f2fe5db18b882ebf96500500b64
refs/heads/master: 2e47d3e6c35bb5b78fea2b2584c7eeaf782f138d
43 changes: 30 additions & 13 deletions trunk/include/asm-x86/paravirt.h
Original file line number Diff line number Diff line change
Expand Up @@ -1085,52 +1085,68 @@ struct paravirt_patch_site {
extern struct paravirt_patch_site __parainstructions[],
__parainstructions_end[];

#ifdef CONFIG_X86_32
#define PV_SAVE_REGS "pushl %%ecx; pushl %%edx;"
#define PV_RESTORE_REGS "popl %%edx; popl %%ecx"
#define PV_FLAGS_ARG "0"
#define PV_EXTRA_CLOBBERS
#define PV_VEXTRA_CLOBBERS
#else
/* We save some registers, but all of them, that's too much. We clobber all
* caller saved registers but the argument parameter */
#define PV_SAVE_REGS "pushq %%rdi;"
#define PV_RESTORE_REGS "popq %%rdi;"
#define PV_EXTRA_CLOBBERS EXTRA_CLOBBERS, "rcx" , "rdx"
#define PV_VEXTRA_CLOBBERS EXTRA_CLOBBERS, "rdi", "rcx" , "rdx"
#define PV_FLAGS_ARG "D"
#endif

static inline unsigned long __raw_local_save_flags(void)
{
unsigned long f;

asm volatile(paravirt_alt("pushl %%ecx; pushl %%edx;"
asm volatile(paravirt_alt(PV_SAVE_REGS
PARAVIRT_CALL
"popl %%edx; popl %%ecx")
PV_RESTORE_REGS)
: "=a"(f)
: paravirt_type(pv_irq_ops.save_fl),
paravirt_clobber(CLBR_EAX)
: "memory", "cc");
: "memory", "cc" PV_VEXTRA_CLOBBERS);
return f;
}

static inline void raw_local_irq_restore(unsigned long f)
{
asm volatile(paravirt_alt("pushl %%ecx; pushl %%edx;"
asm volatile(paravirt_alt(PV_SAVE_REGS
PARAVIRT_CALL
"popl %%edx; popl %%ecx")
PV_RESTORE_REGS)
: "=a"(f)
: "0"(f),
: PV_FLAGS_ARG(f),
paravirt_type(pv_irq_ops.restore_fl),
paravirt_clobber(CLBR_EAX)
: "memory", "cc");
: "memory", "cc" PV_EXTRA_CLOBBERS);
}

static inline void raw_local_irq_disable(void)
{
asm volatile(paravirt_alt("pushl %%ecx; pushl %%edx;"
asm volatile(paravirt_alt(PV_SAVE_REGS
PARAVIRT_CALL
"popl %%edx; popl %%ecx")
PV_RESTORE_REGS)
:
: paravirt_type(pv_irq_ops.irq_disable),
paravirt_clobber(CLBR_EAX)
: "memory", "eax", "cc");
: "memory", "eax", "cc" PV_EXTRA_CLOBBERS);
}

static inline void raw_local_irq_enable(void)
{
asm volatile(paravirt_alt("pushl %%ecx; pushl %%edx;"
asm volatile(paravirt_alt(PV_SAVE_REGS
PARAVIRT_CALL
"popl %%edx; popl %%ecx")
PV_RESTORE_REGS)
:
: paravirt_type(pv_irq_ops.irq_enable),
paravirt_clobber(CLBR_EAX)
: "memory", "eax", "cc");
: "memory", "eax", "cc" PV_EXTRA_CLOBBERS);
}

static inline unsigned long __raw_local_irq_save(void)
Expand Down Expand Up @@ -1205,6 +1221,7 @@ static inline unsigned long __raw_local_irq_save(void)
CLBR_NONE, \
jmp *%cs:pv_cpu_ops+PV_CPU_irq_enable_syscall_ret)


#ifdef CONFIG_X86_32
#define GET_CR0_INTO_EAX \
push %ecx; push %edx; \
Expand Down

0 comments on commit 6326705

Please sign in to comment.