Loading...
1/* SPDX-License-Identifier: GPL-2.0 */
2#ifndef _ASM_MIPS_KVM_PARA_H
3#define _ASM_MIPS_KVM_PARA_H
4
5#include <uapi/asm/kvm_para.h>
6
7#define KVM_HYPERCALL ".word 0x42000028"
8
9/*
10 * Hypercalls for KVM.
11 *
12 * Hypercall number is passed in v0.
13 * Return value will be placed in v0.
14 * Up to 3 arguments are passed in a0, a1, and a2.
15 */
16static inline unsigned long kvm_hypercall0(unsigned long num)
17{
18 register unsigned long n asm("v0");
19 register unsigned long r asm("v0");
20
21 n = num;
22 __asm__ __volatile__(
23 KVM_HYPERCALL
24 : "=r" (r) : "r" (n) : "memory"
25 );
26
27 return r;
28}
29
30static inline unsigned long kvm_hypercall1(unsigned long num,
31 unsigned long arg0)
32{
33 register unsigned long n asm("v0");
34 register unsigned long r asm("v0");
35 register unsigned long a0 asm("a0");
36
37 n = num;
38 a0 = arg0;
39 __asm__ __volatile__(
40 KVM_HYPERCALL
41 : "=r" (r) : "r" (n), "r" (a0) : "memory"
42 );
43
44 return r;
45}
46
47static inline unsigned long kvm_hypercall2(unsigned long num,
48 unsigned long arg0, unsigned long arg1)
49{
50 register unsigned long n asm("v0");
51 register unsigned long r asm("v0");
52 register unsigned long a0 asm("a0");
53 register unsigned long a1 asm("a1");
54
55 n = num;
56 a0 = arg0;
57 a1 = arg1;
58 __asm__ __volatile__(
59 KVM_HYPERCALL
60 : "=r" (r) : "r" (n), "r" (a0), "r" (a1) : "memory"
61 );
62
63 return r;
64}
65
66static inline unsigned long kvm_hypercall3(unsigned long num,
67 unsigned long arg0, unsigned long arg1, unsigned long arg2)
68{
69 register unsigned long n asm("v0");
70 register unsigned long r asm("v0");
71 register unsigned long a0 asm("a0");
72 register unsigned long a1 asm("a1");
73 register unsigned long a2 asm("a2");
74
75 n = num;
76 a0 = arg0;
77 a1 = arg1;
78 a2 = arg2;
79 __asm__ __volatile__(
80 KVM_HYPERCALL
81 : "=r" (r) : "r" (n), "r" (a0), "r" (a1), "r" (a2) : "memory"
82 );
83
84 return r;
85}
86
87static inline bool kvm_check_and_clear_guest_paused(void)
88{
89 return false;
90}
91
92static inline unsigned int kvm_arch_para_features(void)
93{
94 return 0;
95}
96
97static inline unsigned int kvm_arch_para_hints(void)
98{
99 return 0;
100}
101
102#ifdef CONFIG_MIPS_PARAVIRT
103static inline bool kvm_para_available(void)
104{
105 return true;
106}
107#else
108static inline bool kvm_para_available(void)
109{
110 return false;
111}
112#endif
113
114
115#endif /* _ASM_MIPS_KVM_PARA_H */
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 */