/******************************************************************************
* privcmd.h
*
* Copyright (c) 2003-2004, K A Fraser
*
* This file may be distributed separately from the Linux kernel, or
* incorporated into other software packages, subject to the following license:
*
* Permission is hereby granted, free of charge, to any person obtaining a copy
* of this source file (the "Software"), to deal in the Software without
* restriction, including without limitation the rights to use, copy, modify,
* merge, publish, distribute, sublicense, and/or sell copies of the Software,
* and to permit persons to whom the Software is furnished to do so, subject to
* the following conditions:
*
* The above copyright notice and this permission notice shall be included in
* all copies or substantial portions of the Software.
*
* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
* IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
* FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
* AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
* LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING
* FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS
* IN THE SOFTWARE.
*/
#ifndef __XEN_XENIO_H__
#define __XEN_XENIO_H__
/* Interface to /proc/xen/privcmd */
#include <sys/ioccom.h>
typedef struct privcmd_hypercall
{
unsigned long op;
unsigned long arg[5];
long retval;
} privcmd_hypercall_t;
typedef struct privcmd_mmap_entry {
unsigned long va;
unsigned long mfn;
unsigned long npages;
} privcmd_mmap_entry_t;
typedef struct privcmd_mmapbatch {
int num; /* number of pages to populate */
domid_t dom; /* target domain */
unsigned long addr; /* virtual address */
unsigned long *arr; /* array of mfns - top nibble set on err */
} privcmd_mmapbatch_t;
typedef struct privcmd_mmapbatch_v2 {
int num; /* number of pages to populate */
domid_t dom; /* target domain */
uint64_t addr; /* virtual address */
const xen_pfn_t *arr; /* array of mfns */
int *err; /* array of error codes */
} privcmd_mmapbatch_v2_t;
typedef struct privcmd_blkmsg
{
unsigned long op;
void *buf;
int buf_size;
} privcmd_blkmsg_t;
/*
* @cmd: IOCTL_PRIVCMD_HYPERCALL
* @arg: &privcmd_hypercall_t
* Return: Value returned from execution of the specified hypercall.
*/
#define IOCTL_PRIVCMD_HYPERCALL \
_IOWR('P', 0, privcmd_hypercall_t)
/*
* @cmd: IOCTL_PRIVCMD_INITDOMAIN_EVTCHN
* @arg: n/a
* Return: Port associated with domain-controller end of control event channel
* for the initial domain.
*/
#define IOCTL_PRIVCMD_INITDOMAIN_EVTCHN \
_IOR('P', 5, int)
/*
* @cmd: IOCTL_GNTDEV_MMAP_GRANT_REF
* @arg &ioctl_gntdev_mmap_grant_ref
* Return:
* map the grant references at the virtual address provided by caller
* The grant ref already exists (e.g. comes from a remote domain)
*/
struct ioctl_gntdev_grant_ref {
/* The domain ID of the grant to be mapped. */
uint32_t domid;
/* The grant reference of the grant to be mapped. */
uint32_t ref;
};
struct ioctl_gntdev_mmap_grant_ref {
/* The number of grants to be mapped. */
uint32_t count;
uint32_t pad;
/* The virtual address where they should be mapped */
void *va;
/* notify action */
struct ioctl_gntdev_grant_notify notify;
/* Array of grant references, of size @count. */
struct ioctl_gntdev_grant_ref *refs;
};
/*
* @cmd: IOCTL_GNTDEV_ALLOC_GRANT_REF
* @arg &ioctl_gntdev_alloc_grant_ref
* Return:
* Allocate local memory and grant it to a remote domain.
* local memory is mmaped at the virtual address provided by caller
*/