aboutsummaryrefslogtreecommitdiffstats
path: root/arch/mips
diff options
context:
space:
mode:
authorDavid Daney <david.daney@cavium.com>2014-05-28 17:52:12 -0400
committerRalf Baechle <ralf@linux-mips.org>2014-05-30 15:01:11 -0400
commit90dfdc7ceb577c0d7b7635def3c62039a091e50d (patch)
treee20938cbe7d542786d79371b38a6ba0090c8829a /arch/mips
parentcd3f5389489146297eb2c11e4f9d1c4e8aaeb59f (diff)
MIPS: Add functions for hypervisor call
Introduce kvm_hypercall[0-3]. Define three new hypercalls for MIPS: GET_CLOCK_FREQ, EXIT_VM, and CONSOLE_OUTPUT. [andreas.herrmann: * Properly define hypercalls and HC numbers for MIPS in kvm_para.h header files] Signed-off-by: David Daney <david.daney@cavium.com> Signed-off-by: Andreas Herrmann <andreas.herrmann@caviumnetworks.com> Cc: linux-mips@linux-mips.org Cc: James Hogan <james.hogan@imgtec.com> Cc: kvm@vger.kernel.org Patchwork: https://patchwork.linux-mips.org/patch/7005/ Signed-off-by: Ralf Baechle <ralf@linux-mips.org>
Diffstat (limited to 'arch/mips')
-rw-r--r--arch/mips/include/asm/kvm_para.h109
-rw-r--r--arch/mips/include/uapi/asm/kvm_para.h6
2 files changed, 114 insertions, 1 deletions
diff --git a/arch/mips/include/asm/kvm_para.h b/arch/mips/include/asm/kvm_para.h
new file mode 100644
index 000000000000..5a9aa918abe6
--- /dev/null
+++ b/arch/mips/include/asm/kvm_para.h
@@ -0,0 +1,109 @@
1#ifndef _ASM_MIPS_KVM_PARA_H
2#define _ASM_MIPS_KVM_PARA_H
3
4#include <uapi/asm/kvm_para.h>
5
6#define KVM_HYPERCALL ".word 0x42000028"
7
8/*
9 * Hypercalls for KVM.
10 *
11 * Hypercall number is passed in v0.
12 * Return value will be placed in v0.
13 * Up to 3 arguments are passed in a0, a1, and a2.
14 */
15static inline unsigned long kvm_hypercall0(unsigned long num)
16{
17 register unsigned long n asm("v0");
18 register unsigned long r asm("v0");
19
20 n = num;
21 __asm__ __volatile__(
22 KVM_HYPERCALL
23 : "=r" (r) : "r" (n) : "memory"
24 );
25
26 return r;
27}
28
29static inline unsigned long kvm_hypercall1(unsigned long num,
30 unsigned long arg0)
31{
32 register unsigned long n asm("v0");
33 register unsigned long r asm("v0");
34 register unsigned long a0 asm("a0");
35
36 n = num;
37 a0 = arg0;
38 __asm__ __volatile__(
39 KVM_HYPERCALL
40 : "=r" (r) : "r" (n), "r" (a0) : "memory"
41 );
42
43 return r;
44}
45
46static inline unsigned long kvm_hypercall2(unsigned long num,
47 unsigned long arg0, unsigned long arg1)
48{
49 register unsigned long n asm("v0");
50 register unsigned long r asm("v0");
51 register unsigned long a0 asm("a0");
52 register unsigned long a1 asm("a1");
53
54 n = num;
55 a0 = arg0;
56 a1 = arg1;
57 __asm__ __volatile__(
58 KVM_HYPERCALL
59 : "=r" (r) : "r" (n), "r" (a0), "r" (a1) : "memory"
60 );
61
62 return r;
63}
64
65static inline unsigned long kvm_hypercall3(unsigned long num,
66 unsigned long arg0, unsigned long arg1, unsigned long arg2)
67{
68 register unsigned long n asm("v0");
69 register unsigned long r asm("v0");
70 register unsigned long a0 asm("a0");
71 register unsigned long a1 asm("a1");
72 register unsigned long a2 asm("a2");
73
74 n = num;
75 a0 = arg0;
76 a1 = arg1;
77 a2 = arg2;
78 __asm__ __volatile__(
79 KVM_HYPERCALL
80 : "=r" (r) : "r" (n), "r" (a0), "r" (a1), "r" (a2) : "memory"
81 );
82
83 return r;
84}
85
86static inline bool kvm_check_and_clear_guest_paused(void)
87{
88 return false;
89}
90
91static inline unsigned int kvm_arch_para_features(void)
92{
93 return 0;
94}
95
96#ifdef CONFIG_MIPS_PARAVIRT
97static inline bool kvm_para_available(void)
98{
99 return true;
100}
101#else
102static inline bool kvm_para_available(void)
103{
104 return false;
105}
106#endif
107
108
109#endif /* _ASM_MIPS_KVM_PARA_H */
diff --git a/arch/mips/include/uapi/asm/kvm_para.h b/arch/mips/include/uapi/asm/kvm_para.h
index 14fab8f0b957..7e16d7c42e65 100644
--- a/arch/mips/include/uapi/asm/kvm_para.h
+++ b/arch/mips/include/uapi/asm/kvm_para.h
@@ -1 +1,5 @@
1#include <asm-generic/kvm_para.h> 1#ifndef _UAPI_ASM_MIPS_KVM_PARA_H
2#define _UAPI_ASM_MIPS_KVM_PARA_H
3
4
5#endif /* _UAPI_ASM_MIPS_KVM_PARA_H */