Blame view

arch/ia64/xen/xenivt.S 1.22 KB
5142ec469   Isaku Yamahata   ia64/pv_ops/xen: ...
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
  /*
   * arch/ia64/xen/ivt.S
   *
   * 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.
   *                    pv_ops.
   */
  
  #include <asm/asmmacro.h>
  #include <asm/kregs.h>
  #include <asm/pgtable.h>
  
  #include "../kernel/minstate.h"
  
  	.section .text,"ax"
  GLOBAL_ENTRY(xen_event_callback)
  	mov r31=pr		// prepare to save predicates
  	;;
  	SAVE_MIN_WITH_COVER	// uses r31; defines r2 and r3
  	;;
  	movl r3=XSI_PSR_IC
  	mov r14=1
  	;;
  	st4 [r3]=r14
  	;;
  	adds r3=8,r2		// set up second base pointer for SAVE_REST
  	srlz.i			// ensure everybody knows psr.ic is back on
  	;;
  	SAVE_REST
  	;;
  1:
  	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
  	;;
  	movl r20=XSI_PSR_I_ADDR
  	;;
  	ld8 r20=[r20]
  	;;
  	adds r20=-1,r20		// vcpu_info->evtchn_upcall_pending
  	;;
  	ld1 r20=[r20]
  	;;
  	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
  END(xen_event_callback)