OXIESEC PANEL
- Current Dir:
/
/
usr
/
src
/
linux-headers-4.15.0-197
/
include
/
xen
/
interface
/
io
Server IP: 139.59.38.164
Upload:
Create Dir:
Name
Size
Modified
Perms
📁
..
-
11/17/2022 06:42:23 AM
rwxr-xr-x
📄
9pfs.h
1.43 KB
01/28/2018 09:20:33 PM
rw-r--r--
📄
blkif.h
12.9 KB
01/28/2018 09:20:33 PM
rw-r--r--
📄
console.h
587 bytes
01/28/2018 09:20:33 PM
rw-r--r--
📄
displif.h
39.03 KB
01/28/2018 09:20:33 PM
rw-r--r--
📄
fbif.h
4.48 KB
01/28/2018 09:20:33 PM
rw-r--r--
📄
kbdif.h
22.25 KB
01/28/2018 09:20:33 PM
rw-r--r--
📄
netif.h
34.08 KB
01/28/2018 09:20:33 PM
rw-r--r--
📄
pciif.h
3.52 KB
01/28/2018 09:20:33 PM
rw-r--r--
📄
protocols.h
697 bytes
01/28/2018 09:20:33 PM
rw-r--r--
📄
pvcalls.h
3.04 KB
01/28/2018 09:20:33 PM
rw-r--r--
📄
ring.h
23.2 KB
11/01/2022 04:52:05 PM
rw-r--r--
📄
sndif.h
34.89 KB
01/28/2018 09:20:33 PM
rw-r--r--
📄
tpmif.h
1.67 KB
01/28/2018 09:20:33 PM
rw-r--r--
📄
vscsiif.h
8.7 KB
01/28/2018 09:20:33 PM
rw-r--r--
📄
xenbus.h
1.29 KB
01/28/2018 09:20:33 PM
rw-r--r--
📄
xs_wire.h
2.21 KB
01/28/2018 09:20:33 PM
rw-r--r--
Editing: pvcalls.h
Close
#ifndef __XEN_PUBLIC_IO_XEN_PVCALLS_H__ #define __XEN_PUBLIC_IO_XEN_PVCALLS_H__ #include <linux/net.h> #include <xen/interface/io/ring.h> #include <xen/interface/grant_table.h> /* "1" means socket, connect, release, bind, listen, accept and poll */ #define XENBUS_FUNCTIONS_CALLS "1" /* * See docs/misc/pvcalls.markdown in xen.git for the full specification: * https://xenbits.xen.org/docs/unstable/misc/pvcalls.html */ struct pvcalls_data_intf { RING_IDX in_cons, in_prod, in_error; uint8_t pad1[52]; RING_IDX out_cons, out_prod, out_error; uint8_t pad2[52]; RING_IDX ring_order; grant_ref_t ref[]; }; DEFINE_XEN_FLEX_RING(pvcalls); #define PVCALLS_SOCKET 0 #define PVCALLS_CONNECT 1 #define PVCALLS_RELEASE 2 #define PVCALLS_BIND 3 #define PVCALLS_LISTEN 4 #define PVCALLS_ACCEPT 5 #define PVCALLS_POLL 6 struct xen_pvcalls_request { uint32_t req_id; /* private to guest, echoed in response */ uint32_t cmd; /* command to execute */ union { struct xen_pvcalls_socket { uint64_t id; uint32_t domain; uint32_t type; uint32_t protocol; } socket; struct xen_pvcalls_connect { uint64_t id; uint8_t addr[28]; uint32_t len; uint32_t flags; grant_ref_t ref; uint32_t evtchn; } connect; struct xen_pvcalls_release { uint64_t id; uint8_t reuse; } release; struct xen_pvcalls_bind { uint64_t id; uint8_t addr[28]; uint32_t len; } bind; struct xen_pvcalls_listen { uint64_t id; uint32_t backlog; } listen; struct xen_pvcalls_accept { uint64_t id; uint64_t id_new; grant_ref_t ref; uint32_t evtchn; } accept; struct xen_pvcalls_poll { uint64_t id; } poll; /* dummy member to force sizeof(struct xen_pvcalls_request) * to match across archs */ struct xen_pvcalls_dummy { uint8_t dummy[56]; } dummy; } u; }; struct xen_pvcalls_response { uint32_t req_id; uint32_t cmd; int32_t ret; uint32_t pad; union { struct _xen_pvcalls_socket { uint64_t id; } socket; struct _xen_pvcalls_connect { uint64_t id; } connect; struct _xen_pvcalls_release { uint64_t id; } release; struct _xen_pvcalls_bind { uint64_t id; } bind; struct _xen_pvcalls_listen { uint64_t id; } listen; struct _xen_pvcalls_accept { uint64_t id; } accept; struct _xen_pvcalls_poll { uint64_t id; } poll; struct _xen_pvcalls_dummy { uint8_t dummy[8]; } dummy; } u; }; DEFINE_RING_TYPES(xen_pvcalls, struct xen_pvcalls_request, struct xen_pvcalls_response); #endif