2 * asm-s390/kvm_para.h - definition for paravirtual devices on s390
4 * Copyright IBM Corp. 2008
6 * This program is free software; you can redistribute it and/or modify
7 * it under the terms of the GNU General Public License (version 2 only)
8 * as published by the Free Software Foundation.
10 * Author(s): Christian Borntraeger <borntraeger@de.ibm.com>
13 #ifndef __S390_KVM_PARA_H
14 #define __S390_KVM_PARA_H
17 * Hypercalls for KVM on s390. The calling convention is similar to the
18 * s390 ABI, so we use R2-R6 for parameters 1-5. In addition we use R1
19 * as hypercall number and R7 as parameter 6. The return value is
20 * written to R2. We use the diagnose instruction as hypercall. To avoid
21 * conflicts with existing diagnoses for LPAR and z/VM, we do not use
22 * the instruction encoded number, but specify the number in R1 and
23 * use 0x500 as KVM hypercall
25 * Copyright IBM Corp. 2007,2008
26 * Author(s): Christian Borntraeger <borntraeger@de.ibm.com>
28 * This work is licensed under the terms of the GNU GPL, version 2.
31 static inline long kvm_hypercall0(unsigned long nr
)
33 register unsigned long __nr
asm("1") = nr
;
34 register long __rc
asm("2");
36 asm volatile ("diag 2,4,0x500\n"
37 : "=d" (__rc
) : "d" (__nr
): "memory", "cc");
41 static inline long kvm_hypercall1(unsigned long nr
, unsigned long p1
)
43 register unsigned long __nr
asm("1") = nr
;
44 register unsigned long __p1
asm("2") = p1
;
45 register long __rc
asm("2");
47 asm volatile ("diag 2,4,0x500\n"
48 : "=d" (__rc
) : "d" (__nr
), "0" (__p1
) : "memory", "cc");
52 static inline long kvm_hypercall2(unsigned long nr
, unsigned long p1
,
55 register unsigned long __nr
asm("1") = nr
;
56 register unsigned long __p1
asm("2") = p1
;
57 register unsigned long __p2
asm("3") = p2
;
58 register long __rc
asm("2");
60 asm volatile ("diag 2,4,0x500\n"
61 : "=d" (__rc
) : "d" (__nr
), "0" (__p1
), "d" (__p2
)
66 static inline long kvm_hypercall3(unsigned long nr
, unsigned long p1
,
67 unsigned long p2
, unsigned long p3
)
69 register unsigned long __nr
asm("1") = nr
;
70 register unsigned long __p1
asm("2") = p1
;
71 register unsigned long __p2
asm("3") = p2
;
72 register unsigned long __p3
asm("4") = p3
;
73 register long __rc
asm("2");
75 asm volatile ("diag 2,4,0x500\n"
76 : "=d" (__rc
) : "d" (__nr
), "0" (__p1
), "d" (__p2
),
77 "d" (__p3
) : "memory", "cc");
82 static inline long kvm_hypercall4(unsigned long nr
, unsigned long p1
,
83 unsigned long p2
, unsigned long p3
,
86 register unsigned long __nr
asm("1") = nr
;
87 register unsigned long __p1
asm("2") = p1
;
88 register unsigned long __p2
asm("3") = p2
;
89 register unsigned long __p3
asm("4") = p3
;
90 register unsigned long __p4
asm("5") = p4
;
91 register long __rc
asm("2");
93 asm volatile ("diag 2,4,0x500\n"
94 : "=d" (__rc
) : "d" (__nr
), "0" (__p1
), "d" (__p2
),
95 "d" (__p3
), "d" (__p4
) : "memory", "cc");
99 static inline long kvm_hypercall5(unsigned long nr
, unsigned long p1
,
100 unsigned long p2
, unsigned long p3
,
101 unsigned long p4
, unsigned long p5
)
103 register unsigned long __nr
asm("1") = nr
;
104 register unsigned long __p1
asm("2") = p1
;
105 register unsigned long __p2
asm("3") = p2
;
106 register unsigned long __p3
asm("4") = p3
;
107 register unsigned long __p4
asm("5") = p4
;
108 register unsigned long __p5
asm("6") = p5
;
109 register long __rc
asm("2");
111 asm volatile ("diag 2,4,0x500\n"
112 : "=d" (__rc
) : "d" (__nr
), "0" (__p1
), "d" (__p2
),
113 "d" (__p3
), "d" (__p4
), "d" (__p5
) : "memory", "cc");
117 static inline long kvm_hypercall6(unsigned long nr
, unsigned long p1
,
118 unsigned long p2
, unsigned long p3
,
119 unsigned long p4
, unsigned long p5
,
122 register unsigned long __nr
asm("1") = nr
;
123 register unsigned long __p1
asm("2") = p1
;
124 register unsigned long __p2
asm("3") = p2
;
125 register unsigned long __p3
asm("4") = p3
;
126 register unsigned long __p4
asm("5") = p4
;
127 register unsigned long __p5
asm("6") = p5
;
128 register unsigned long __p6
asm("7") = p6
;
129 register long __rc
asm("2");
131 asm volatile ("diag 2,4,0x500\n"
132 : "=d" (__rc
) : "d" (__nr
), "0" (__p1
), "d" (__p2
),
133 "d" (__p3
), "d" (__p4
), "d" (__p5
), "d" (__p6
)
138 /* kvm on s390 is always paravirtualization enabled */
139 static inline int kvm_para_available(void)
144 /* No feature bits are currently assigned for kvm on s390 */
145 static inline unsigned int kvm_arch_para_features(void)
150 #endif /* __S390_KVM_PARA_H */