/* SPDX-License-Identifier: MIT */ /****************************************************************************** * version.h * * Xen version, type, and compile information. * * Copyright (c) 2005, Nguyen Anh Quynh <aquynh@gmail.com> * Copyright (c) 2005, Keir Fraser <keir@xensource.com> */ #ifndef __XEN_PUBLIC_VERSION_H__ #define __XEN_PUBLIC_VERSION_H__ #include "xen.h" /* NB. All ops return zero on success, except XENVER_{version,pagesize} * XENVER_{version,pagesize,build_id} */ /* arg == NULL; returns major:minor (16:16). */ #define XENVER_version 0 /* * arg == xen_extraversion_t. * * This API/ABI is broken. Use XENVER_extraversion2 where possible. */ #define XENVER_extraversion 1 typedef char xen_extraversion_t[16]; #define XEN_EXTRAVERSION_LEN (sizeof(xen_extraversion_t)) /* * arg == xen_compile_info_t. * * This API/ABI is broken and truncates data. */ #define XENVER_compile_info 2 struct xen_compile_info { char compiler[64]; char compile_by[16]; char compile_domain[32]; char compile_date[32]; }; typedef struct xen_compile_info xen_compile_info_t; /* * arg == xen_capabilities_info_t. * * This API/ABI is broken. Use XENVER_capabilities2 where possible. */ #define XENVER_capabilities 3 typedef char xen_capabilities_info_t[1024]; #define XEN_CAPABILITIES_INFO_LEN (sizeof(xen_capabilities_info_t)) /* * arg == xen_changeset_info_t. * * This API/ABI is broken. Use XENVER_changeset2 where possible. */ #define XENVER_changeset 4 typedef char xen_changeset_info_t[64]; #define XEN_CHANGESET_INFO_LEN (sizeof(xen_changeset_info_t)) /* * This API is problematic. * * It is only applicable to guests which share pagetables with Xen (x86 PV * guests), but unfortunately has leaked into other guest types and * architectures with an expectation of never failing. * * It is intended to identify the virtual address split between guest kernel * and Xen. * * For 32bit PV guests, there is a split, and it is variable (between two * fixed bounds), and this boundary is reported to guests. The detail missing * from the hypercall is that the second boundary is the 32bit architectural * boundary at 4G. * * For 64bit PV guests, Xen lives at the bottom of the upper canonical range. * This hypercall happens to report the architectural boundary, not the one * which would be necessary to make a variable split work. As such, this * hypercall entirely useless for 64bit PV guests, and all inspected * implementations at the time of writing were found to have compile time * expectations about the split. * * For architectures where this hypercall is implemented, for backwards * compatibility with the expectation of the hypercall never failing Xen will * return 0 instead of failing with -ENOSYS in cases where the guest should * not be making the hypercall. */ #define XENVER_platform_parameters 5 struct xen_platform_parameters { xen_ulong_t virt_start; }; typedef struct xen_platform_parameters xen_platform_parameters_t; #define XENVER_get_features 6 struct xen_feature_info { uint32_t submap_idx; /* IN: which 32-bit submap to return */ uint32_t submap; /* OUT: 32-bit submap */ }; typedef struct xen_feature_info xen_feature_info_t; /* Declares the features reported by XENVER_get_features. */ #include "features.h" /* arg == NULL; returns host memory page size. */ #define XENVER_pagesize 7 /* arg == xen_domain_handle_t. * * The toolstack fills it out for guest consumption. It is intended to hold * the UUID of the guest. */ #define XENVER_guest_handle 8 /* * arg == xen_commandline_t. * * This API/ABI is broken. Use XENVER_commandline2 where possible. */ #define XENVER_commandline 9 typedef char xen_commandline_t[1024]; /* * Return value is the number of bytes written, or XEN_Exx on error. * Calling with empty parameter returns the size of build_id. * * Note: structure only kept for backwards compatibility. Xen operates in * terms of xen_varbuf_t. */ struct xen_build_id { uint32_t len; /* IN: size of buf[]. */ unsigned char buf[XEN_FLEX_ARRAY_DIM]; /* OUT: Variable length buffer with build_id. */ }; typedef struct xen_build_id xen_build_id_t; /* * Container for an arbitrary variable length buffer. */ struct xen_varbuf { uint32_t len; /* IN: size of buf[] in bytes. */ unsigned char buf[XEN_FLEX_ARRAY_DIM]; /* OUT: requested data. */ }; typedef struct xen_varbuf xen_varbuf_t; /* * arg == xen_varbuf_t * * Equivalent to the original ops, but with a non-truncating API/ABI. * * These hypercalls can fail for a number of reasons. All callers must handle * -XEN_xxx return values appropriately. * * Passing arg == NULL is a request for size, which will be signalled with a * non-negative return value. Note: a return size of 0 may be legitimate for * the requested subop. * * Otherwise, the input xen_varbuf_t provides the size of the following * buffer. Xen will fill the buffer, and return the number of bytes written * (e.g. if the input buffer was longer than necessary). * * Some subops may return binary data. Some subops may be expected to return * textural data. These are returned without a NUL terminator, and while the * contents is expected to be ASCII/UTF-8, Xen makes no guarentees to this * effect. e.g. Xen has no control over the formatting used for the command * line. */ #define XENVER_build_id 10 #define XENVER_extraversion2 11 #define XENVER_capabilities2 12 #define XENVER_changeset2 13 #define XENVER_commandline2 14 #endif /* __XEN_PUBLIC_VERSION_H__ */ /* * Local variables: * mode: C * c-file-style: "BSD" * c-basic-offset: 4 * tab-width: 4 * indent-tabs-mode: nil * End: */