xref: /freebsd/sys/xen/privcmd.h (revision 40e1d9d45f0f6798e404eb7d63afb3976e85cc02)
1bf7313e3SRoger Pau Monné /******************************************************************************
2*40e1d9d4SElliott Mitchell  * SPDX-License-Identifier: MIT OR GPL-2.0-only
3*40e1d9d4SElliott Mitchell  *
4bf7313e3SRoger Pau Monné  * privcmd.h
5bf7313e3SRoger Pau Monné  *
6bf7313e3SRoger Pau Monné  * Interface to /proc/xen/privcmd.
7bf7313e3SRoger Pau Monné  *
8bf7313e3SRoger Pau Monné  * Copyright (c) 2003-2005, K A Fraser
9bf7313e3SRoger Pau Monné  *
10bf7313e3SRoger Pau Monné  * This program is free software; you can redistribute it and/or
11bf7313e3SRoger Pau Monné  * modify it under the terms of the GNU General Public License version 2
12bf7313e3SRoger Pau Monné  * as published by the Free Software Foundation; or, when distributed
13bf7313e3SRoger Pau Monné  * separately from the Linux kernel or incorporated into other
14bf7313e3SRoger Pau Monné  * software packages, subject to the following license:
15bf7313e3SRoger Pau Monné  *
16bf7313e3SRoger Pau Monné  * Permission is hereby granted, free of charge, to any person obtaining a copy
17bf7313e3SRoger Pau Monné  * of this source file (the "Software"), to deal in the Software without
18bf7313e3SRoger Pau Monné  * restriction, including without limitation the rights to use, copy, modify,
19bf7313e3SRoger Pau Monné  * merge, publish, distribute, sublicense, and/or sell copies of the Software,
20bf7313e3SRoger Pau Monné  * and to permit persons to whom the Software is furnished to do so, subject to
21bf7313e3SRoger Pau Monné  * the following conditions:
22bf7313e3SRoger Pau Monné  *
23bf7313e3SRoger Pau Monné  * The above copyright notice and this permission notice shall be included in
24bf7313e3SRoger Pau Monné  * all copies or substantial portions of the Software.
25bf7313e3SRoger Pau Monné  *
26bf7313e3SRoger Pau Monné  * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
27bf7313e3SRoger Pau Monné  * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
28bf7313e3SRoger Pau Monné  * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
29bf7313e3SRoger Pau Monné  * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
30bf7313e3SRoger Pau Monné  * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING
31bf7313e3SRoger Pau Monné  * FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS
32bf7313e3SRoger Pau Monné  * IN THE SOFTWARE.
33bf7313e3SRoger Pau Monné  */
34bf7313e3SRoger Pau Monné 
35bf7313e3SRoger Pau Monné #ifndef __XEN_PRIVCMD_H__
36bf7313e3SRoger Pau Monné #define __XEN_PRIVCMD_H__
37bf7313e3SRoger Pau Monné 
38bf7313e3SRoger Pau Monné struct ioctl_privcmd_hypercall
39bf7313e3SRoger Pau Monné {
40bf7313e3SRoger Pau Monné 	unsigned long op; /* hypercall number */
41bf7313e3SRoger Pau Monné 	unsigned long arg[5]; /* arguments */
42bf7313e3SRoger Pau Monné 	long retval; /* return value */
43bf7313e3SRoger Pau Monné };
44bf7313e3SRoger Pau Monné 
45bf7313e3SRoger Pau Monné struct ioctl_privcmd_mmapbatch {
46bf7313e3SRoger Pau Monné 	int num;     /* number of pages to populate */
47bf7313e3SRoger Pau Monné 	domid_t dom; /* target domain */
48bf7313e3SRoger Pau Monné 	unsigned long addr;  /* virtual address */
49bf7313e3SRoger Pau Monné 	const xen_pfn_t *arr; /* array of mfns */
50bf7313e3SRoger Pau Monné 	int *err; /* array of error codes */
51bf7313e3SRoger Pau Monné };
52bf7313e3SRoger Pau Monné 
53658860e2SRoger Pau Monne struct ioctl_privcmd_mmapresource {
54658860e2SRoger Pau Monne 	domid_t dom; /* target domain */
55658860e2SRoger Pau Monne 	unsigned int type; /* type of resource to map */
56658860e2SRoger Pau Monne 	unsigned int id; /* type-specific resource identifier */
57658860e2SRoger Pau Monne 	unsigned int idx; /* the index of the initial frame to be mapped */
58658860e2SRoger Pau Monne 	unsigned long num; /* number of frames of the resource to be mapped */
59658860e2SRoger Pau Monne 	unsigned long addr; /* physical address to map into */
60658860e2SRoger Pau Monne 	/*
61658860e2SRoger Pau Monne 	 * Note: issuing an ioctl with num = addr = 0 will return the size of
62658860e2SRoger Pau Monne 	 * the resource.
63658860e2SRoger Pau Monne 	 */
64658860e2SRoger Pau Monne };
65658860e2SRoger Pau Monne 
66ed78016dSRoger Pau Monne struct privcmd_dmop_buf {
67ed78016dSRoger Pau Monne 	void *uptr; /* pointer to memory (in calling process) */
68ed78016dSRoger Pau Monne 	size_t size; /* size of the buffer */
69ed78016dSRoger Pau Monne };
70ed78016dSRoger Pau Monne 
71ed78016dSRoger Pau Monne struct ioctl_privcmd_dmop {
72ed78016dSRoger Pau Monne 	domid_t dom; /* target domain */
73ed78016dSRoger Pau Monne 	unsigned int num; /* num of buffers */
74ed78016dSRoger Pau Monne 	const struct privcmd_dmop_buf *ubufs; /* array of buffers */
75ed78016dSRoger Pau Monne };
76ed78016dSRoger Pau Monne 
77bf7313e3SRoger Pau Monné #define IOCTL_PRIVCMD_HYPERCALL					\
78bf7313e3SRoger Pau Monné 	_IOWR('E', 0, struct ioctl_privcmd_hypercall)
79bf7313e3SRoger Pau Monné #define IOCTL_PRIVCMD_MMAPBATCH					\
80bf7313e3SRoger Pau Monné 	_IOWR('E', 1, struct ioctl_privcmd_mmapbatch)
81658860e2SRoger Pau Monne #define IOCTL_PRIVCMD_MMAP_RESOURCE				\
8250d7d967SRoger Pau Monné 	_IOWR('E', 2, struct ioctl_privcmd_mmapresource)
83ed78016dSRoger Pau Monne #define IOCTL_PRIVCMD_DM_OP					\
84ed78016dSRoger Pau Monne 	_IOW('E', 3, struct ioctl_privcmd_dmop)
85a7650787SRoger Pau Monne #define IOCTL_PRIVCMD_RESTRICT					\
86a7650787SRoger Pau Monne 	_IOW('E', 4, domid_t)
87bf7313e3SRoger Pau Monné 
88bf7313e3SRoger Pau Monné #endif /* !__XEN_PRIVCMD_H__ */
89