xref: /freebsd/sys/contrib/xen/callback.h (revision 3a9fd8242b35884921dfc4e886f284a75870a536)
1*3a9fd824SRoger Pau Monné /******************************************************************************
2*3a9fd824SRoger Pau Monné  * callback.h
3*3a9fd824SRoger Pau Monné  *
4*3a9fd824SRoger Pau Monné  * Register guest OS callbacks with Xen.
5*3a9fd824SRoger Pau Monné  *
6*3a9fd824SRoger Pau Monné  * Permission is hereby granted, free of charge, to any person obtaining a copy
7*3a9fd824SRoger Pau Monné  * of this software and associated documentation files (the "Software"), to
8*3a9fd824SRoger Pau Monné  * deal in the Software without restriction, including without limitation the
9*3a9fd824SRoger Pau Monné  * rights to use, copy, modify, merge, publish, distribute, sublicense, and/or
10*3a9fd824SRoger Pau Monné  * sell copies of the Software, and to permit persons to whom the Software is
11*3a9fd824SRoger Pau Monné  * furnished to do so, subject to the following conditions:
12*3a9fd824SRoger Pau Monné  *
13*3a9fd824SRoger Pau Monné  * The above copyright notice and this permission notice shall be included in
14*3a9fd824SRoger Pau Monné  * all copies or substantial portions of the Software.
15*3a9fd824SRoger Pau Monné  *
16*3a9fd824SRoger Pau Monné  * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
17*3a9fd824SRoger Pau Monné  * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
18*3a9fd824SRoger Pau Monné  * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
19*3a9fd824SRoger Pau Monné  * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
20*3a9fd824SRoger Pau Monné  * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING
21*3a9fd824SRoger Pau Monné  * FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER
22*3a9fd824SRoger Pau Monné  * DEALINGS IN THE SOFTWARE.
23*3a9fd824SRoger Pau Monné  *
24*3a9fd824SRoger Pau Monné  * Copyright (c) 2006, Ian Campbell
25*3a9fd824SRoger Pau Monné  */
26*3a9fd824SRoger Pau Monné 
27*3a9fd824SRoger Pau Monné #ifndef __XEN_PUBLIC_CALLBACK_H__
28*3a9fd824SRoger Pau Monné #define __XEN_PUBLIC_CALLBACK_H__
29*3a9fd824SRoger Pau Monné 
30*3a9fd824SRoger Pau Monné #include "xen.h"
31*3a9fd824SRoger Pau Monné 
32*3a9fd824SRoger Pau Monné /*
33*3a9fd824SRoger Pau Monné  * Prototype for this hypercall is:
34*3a9fd824SRoger Pau Monné  *   long callback_op(int cmd, void *extra_args)
35*3a9fd824SRoger Pau Monné  * @cmd        == CALLBACKOP_??? (callback operation).
36*3a9fd824SRoger Pau Monné  * @extra_args == Operation-specific extra arguments (NULL if none).
37*3a9fd824SRoger Pau Monné  */
38*3a9fd824SRoger Pau Monné 
39*3a9fd824SRoger Pau Monné /* x86: Callback for event delivery. */
40*3a9fd824SRoger Pau Monné #define CALLBACKTYPE_event                 0
41*3a9fd824SRoger Pau Monné 
42*3a9fd824SRoger Pau Monné /* x86: Failsafe callback when guest state cannot be restored by Xen. */
43*3a9fd824SRoger Pau Monné #define CALLBACKTYPE_failsafe              1
44*3a9fd824SRoger Pau Monné 
45*3a9fd824SRoger Pau Monné /* x86/64 hypervisor: Syscall by 64-bit guest app ('64-on-64-on-64'). */
46*3a9fd824SRoger Pau Monné #define CALLBACKTYPE_syscall               2
47*3a9fd824SRoger Pau Monné 
48*3a9fd824SRoger Pau Monné /*
49*3a9fd824SRoger Pau Monné  * x86/32 hypervisor: Only available on x86/32 when supervisor_mode_kernel
50*3a9fd824SRoger Pau Monné  *     feature is enabled. Do not use this callback type in new code.
51*3a9fd824SRoger Pau Monné  */
52*3a9fd824SRoger Pau Monné #define CALLBACKTYPE_sysenter_deprecated   3
53*3a9fd824SRoger Pau Monné 
54*3a9fd824SRoger Pau Monné /* x86: Callback for NMI delivery. */
55*3a9fd824SRoger Pau Monné #define CALLBACKTYPE_nmi                   4
56*3a9fd824SRoger Pau Monné 
57*3a9fd824SRoger Pau Monné /*
58*3a9fd824SRoger Pau Monné  * x86: sysenter is only available as follows:
59*3a9fd824SRoger Pau Monné  * - 32-bit hypervisor: with the supervisor_mode_kernel feature enabled
60*3a9fd824SRoger Pau Monné  * - 64-bit hypervisor: 32-bit guest applications on Intel CPUs
61*3a9fd824SRoger Pau Monné  *                      ('32-on-32-on-64', '32-on-64-on-64')
62*3a9fd824SRoger Pau Monné  *                      [nb. also 64-bit guest applications on Intel CPUs
63*3a9fd824SRoger Pau Monné  *                           ('64-on-64-on-64'), but syscall is preferred]
64*3a9fd824SRoger Pau Monné  */
65*3a9fd824SRoger Pau Monné #define CALLBACKTYPE_sysenter              5
66*3a9fd824SRoger Pau Monné 
67*3a9fd824SRoger Pau Monné /*
68*3a9fd824SRoger Pau Monné  * x86/64 hypervisor: Syscall by 32-bit guest app on AMD CPUs
69*3a9fd824SRoger Pau Monné  *                    ('32-on-32-on-64', '32-on-64-on-64')
70*3a9fd824SRoger Pau Monné  */
71*3a9fd824SRoger Pau Monné #define CALLBACKTYPE_syscall32             7
72*3a9fd824SRoger Pau Monné 
73*3a9fd824SRoger Pau Monné /*
74*3a9fd824SRoger Pau Monné  * Disable event deliver during callback? This flag is ignored for event and
75*3a9fd824SRoger Pau Monné  * NMI callbacks: event delivery is unconditionally disabled.
76*3a9fd824SRoger Pau Monné  */
77*3a9fd824SRoger Pau Monné #define _CALLBACKF_mask_events             0
78*3a9fd824SRoger Pau Monné #define CALLBACKF_mask_events              (1U << _CALLBACKF_mask_events)
79*3a9fd824SRoger Pau Monné 
80*3a9fd824SRoger Pau Monné /*
81*3a9fd824SRoger Pau Monné  * Register a callback.
82*3a9fd824SRoger Pau Monné  */
83*3a9fd824SRoger Pau Monné #define CALLBACKOP_register                0
84*3a9fd824SRoger Pau Monné struct callback_register {
85*3a9fd824SRoger Pau Monné     uint16_t type;
86*3a9fd824SRoger Pau Monné     uint16_t flags;
87*3a9fd824SRoger Pau Monné     xen_callback_t address;
88*3a9fd824SRoger Pau Monné };
89*3a9fd824SRoger Pau Monné typedef struct callback_register callback_register_t;
90*3a9fd824SRoger Pau Monné DEFINE_XEN_GUEST_HANDLE(callback_register_t);
91*3a9fd824SRoger Pau Monné 
92*3a9fd824SRoger Pau Monné /*
93*3a9fd824SRoger Pau Monné  * Unregister a callback.
94*3a9fd824SRoger Pau Monné  *
95*3a9fd824SRoger Pau Monné  * Not all callbacks can be unregistered. -EINVAL will be returned if
96*3a9fd824SRoger Pau Monné  * you attempt to unregister such a callback.
97*3a9fd824SRoger Pau Monné  */
98*3a9fd824SRoger Pau Monné #define CALLBACKOP_unregister              1
99*3a9fd824SRoger Pau Monné struct callback_unregister {
100*3a9fd824SRoger Pau Monné     uint16_t type;
101*3a9fd824SRoger Pau Monné     uint16_t _unused;
102*3a9fd824SRoger Pau Monné };
103*3a9fd824SRoger Pau Monné typedef struct callback_unregister callback_unregister_t;
104*3a9fd824SRoger Pau Monné DEFINE_XEN_GUEST_HANDLE(callback_unregister_t);
105*3a9fd824SRoger Pau Monné 
106*3a9fd824SRoger Pau Monné #if __XEN_INTERFACE_VERSION__ < 0x00030207
107*3a9fd824SRoger Pau Monné #undef CALLBACKTYPE_sysenter
108*3a9fd824SRoger Pau Monné #define CALLBACKTYPE_sysenter CALLBACKTYPE_sysenter_deprecated
109*3a9fd824SRoger Pau Monné #endif
110*3a9fd824SRoger Pau Monné 
111*3a9fd824SRoger Pau Monné #endif /* __XEN_PUBLIC_CALLBACK_H__ */
112*3a9fd824SRoger Pau Monné 
113*3a9fd824SRoger Pau Monné /*
114*3a9fd824SRoger Pau Monné  * Local variables:
115*3a9fd824SRoger Pau Monné  * mode: C
116*3a9fd824SRoger Pau Monné  * c-file-style: "BSD"
117*3a9fd824SRoger Pau Monné  * c-basic-offset: 4
118*3a9fd824SRoger Pau Monné  * tab-width: 4
119*3a9fd824SRoger Pau Monné  * indent-tabs-mode: nil
120*3a9fd824SRoger Pau Monné  * End:
121*3a9fd824SRoger Pau Monné  */
122