| * Copyright (C) 2005 Hewlett-Packard Co |
| * Dan Magenheimer <dan.magenheimer@hp.com> |
| * Copyright (c) 2008 Isaku Yamahata <yamahata at valinux co jp> |
| * VA Linux Systems Japan K.K. |
| #include <asm/asmmacro.h> |
| #include "../kernel/minstate.h" |
| GLOBAL_ENTRY(xen_event_callback) |
| mov r31=pr // prepare to save predicates |
| SAVE_MIN_WITH_COVER // uses r31; defines r2 and r3 |
| adds r3=8,r2 // set up second base pointer for SAVE_REST |
| srlz.i // ensure everybody knows psr.ic is back on |
| alloc r14=ar.pfs,0,0,1,0 // must be first in an insn group |
| add out0=16,sp // pass pointer to pt_regs as first arg |
| br.call.sptk.many b0=xen_evtchn_do_upcall |
| adds r20=-1,r20 // vcpu_info->evtchn_upcall_pending |
| cmp.ne p6,p0=r20,r0 // if there are pending events, |
| (p6) br.spnt.few 1b // call evtchn_do_upcall again. |
| br.sptk.many xen_leave_kernel // we know ia64_leave_kernel is |
| // paravirtualized as xen_leave_kernel |