|
[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index] Re: [Xen-devel] [PATCH v9 04/15] tools/libxc: C implementation of stream format
On Fri, 2015-04-10 at 18:15 +0100, Andrew Cooper wrote:
> Provide the C structures matching the binary (wire) format of the new
> stream format. All header/record fields are naturally aligned and
> explicit padding fields are used to ensure the correct layout (i.e.,
> there is no need for any non-standard structure packing pragma or
> attribute).
>
> Provide some helper functions for converting types to string for
> diagnostic purposes.
>
> Signed-off-by: Andrew Cooper <andrew.cooper3@xxxxxxxxxx>
> CC: Ian Campbell <Ian.Campbell@xxxxxxxxxx>
> CC: Ian Jackson <Ian.Jackson@xxxxxxxxxxxxx>
> CC: Wei Liu <wei.liu2@xxxxxxxxxx>
I think I already acked a substantially similar version of this in
<1410432498.6166.79.camel@xxxxxxxxxxxxxxxxxxxxxx>, so given the lack of
an intra-patch changelog here:
Acked-by: Ian Campbell <ian.campbell@xxxxxxxxxx>
If there was some substantial change let me know and I'll actually read
the patch.
> ---
> tools/libxc/Makefile | 1 +
> tools/libxc/xc_sr_common.c | 72 ++++++++++++++++++
> tools/libxc/xc_sr_common.h | 8 ++
> tools/libxc/xc_sr_stream_format.h | 148
> +++++++++++++++++++++++++++++++++++++
> 4 files changed, 229 insertions(+)
> create mode 100644 tools/libxc/xc_sr_common.c
> create mode 100644 tools/libxc/xc_sr_stream_format.h
>
> diff --git a/tools/libxc/Makefile b/tools/libxc/Makefile
> index 0c9a7a7..c505fde 100644
> --- a/tools/libxc/Makefile
> +++ b/tools/libxc/Makefile
> @@ -53,6 +53,7 @@ GUEST_SRCS-y :=
> GUEST_SRCS-y += xg_private.c xc_suspend.c
> ifeq ($(CONFIG_MIGRATE),y)
> GUEST_SRCS-y += xc_domain_restore.c xc_domain_save.c
> +GUEST_SRCS-y += xc_sr_common.c
> GUEST_SRCS-y += xc_sr_restore.c
> GUEST_SRCS-y += xc_sr_save.c
> GUEST_SRCS-y += xc_offline_page.c xc_compression.c
> diff --git a/tools/libxc/xc_sr_common.c b/tools/libxc/xc_sr_common.c
> new file mode 100644
> index 0000000..294a626
> --- /dev/null
> +++ b/tools/libxc/xc_sr_common.c
> @@ -0,0 +1,72 @@
> +#include "xc_sr_common.h"
> +
> +static const char *dhdr_types[] =
> +{
> + [DHDR_TYPE_X86_PV] = "x86 PV",
> + [DHDR_TYPE_X86_HVM] = "x86 HVM",
> + [DHDR_TYPE_X86_PVH] = "x86 PVH",
> + [DHDR_TYPE_ARM] = "ARM",
> +};
> +
> +const char *dhdr_type_to_str(uint32_t type)
> +{
> + if ( type < ARRAY_SIZE(dhdr_types) && dhdr_types[type] )
> + return dhdr_types[type];
> +
> + return "Reserved";
> +}
> +
> +static const char *mandatory_rec_types[] =
> +{
> + [REC_TYPE_END] = "End",
> + [REC_TYPE_PAGE_DATA] = "Page data",
> + [REC_TYPE_X86_PV_INFO] = "x86 PV info",
> + [REC_TYPE_X86_PV_P2M_FRAMES] = "x86 PV P2M frames",
> + [REC_TYPE_X86_PV_VCPU_BASIC] = "x86 PV vcpu basic",
> + [REC_TYPE_X86_PV_VCPU_EXTENDED] = "x86 PV vcpu extended",
> + [REC_TYPE_X86_PV_VCPU_XSAVE] = "x86 PV vcpu xsave",
> + [REC_TYPE_SHARED_INFO] = "Shared info",
> + [REC_TYPE_TSC_INFO] = "TSC info",
> + [REC_TYPE_HVM_CONTEXT] = "HVM context",
> + [REC_TYPE_HVM_PARAMS] = "HVM params",
> + [REC_TYPE_TOOLSTACK] = "Toolstack",
> + [REC_TYPE_X86_PV_VCPU_MSRS] = "x86 PV vcpu msrs",
> + [REC_TYPE_VERIFY] = "Verify",
> +};
> +
> +const char *rec_type_to_str(uint32_t type)
> +{
> + if ( !(type & REC_TYPE_OPTIONAL) )
> + {
> + if ( (type < ARRAY_SIZE(mandatory_rec_types)) &&
> + (mandatory_rec_types[type]) )
> + return mandatory_rec_types[type];
> + }
> +
> + return "Reserved";
> +}
> +
> +static void __attribute__((unused)) build_assertions(void)
> +{
> + XC_BUILD_BUG_ON(sizeof(struct xc_sr_ihdr) != 24);
> + XC_BUILD_BUG_ON(sizeof(struct xc_sr_dhdr) != 16);
> + XC_BUILD_BUG_ON(sizeof(struct xc_sr_rhdr) != 8);
> +
> + XC_BUILD_BUG_ON(sizeof(struct xc_sr_rec_page_data_header) != 8);
> + XC_BUILD_BUG_ON(sizeof(struct xc_sr_rec_x86_pv_info) != 8);
> + XC_BUILD_BUG_ON(sizeof(struct xc_sr_rec_x86_pv_p2m_frames) != 8);
> + XC_BUILD_BUG_ON(sizeof(struct xc_sr_rec_x86_pv_vcpu_hdr) != 8);
> + XC_BUILD_BUG_ON(sizeof(struct xc_sr_rec_tsc_info) != 24);
> + XC_BUILD_BUG_ON(sizeof(struct xc_sr_rec_hvm_params_entry) != 16);
> + XC_BUILD_BUG_ON(sizeof(struct xc_sr_rec_hvm_params) != 8);
> +}
> +
> +/*
> + * Local variables:
> + * mode: C
> + * c-file-style: "BSD"
> + * c-basic-offset: 4
> + * tab-width: 4
> + * indent-tabs-mode: nil
> + * End:
> + */
> diff --git a/tools/libxc/xc_sr_common.h b/tools/libxc/xc_sr_common.h
> index ab7cb46..b65e52b 100644
> --- a/tools/libxc/xc_sr_common.h
> +++ b/tools/libxc/xc_sr_common.h
> @@ -3,6 +3,14 @@
>
> #include "xg_private.h"
>
> +#include "xc_sr_stream_format.h"
> +
> +/* String representation of Domain Header types. */
> +const char *dhdr_type_to_str(uint32_t type);
> +
> +/* String representation of Record types. */
> +const char *rec_type_to_str(uint32_t type);
> +
> #endif
> /*
> * Local variables:
> diff --git a/tools/libxc/xc_sr_stream_format.h
> b/tools/libxc/xc_sr_stream_format.h
> new file mode 100644
> index 0000000..d116ca6
> --- /dev/null
> +++ b/tools/libxc/xc_sr_stream_format.h
> @@ -0,0 +1,148 @@
> +#ifndef __STREAM_FORMAT__H
> +#define __STREAM_FORMAT__H
> +
> +/*
> + * C structures for the Migration v2 stream format.
> + * See docs/specs/libxc-migration-stream.pandoc
> + */
> +
> +#include <inttypes.h>
> +
> +/*
> + * Image Header
> + */
> +struct xc_sr_ihdr
> +{
> + uint64_t marker;
> + uint32_t id;
> + uint32_t version;
> + uint16_t options;
> + uint16_t _res1;
> + uint32_t _res2;
> +};
> +
> +#define IHDR_MARKER 0xffffffffffffffffULL
> +#define IHDR_ID 0x58454E46U
> +#define IHDR_VERSION 2
> +
> +#define _IHDR_OPT_ENDIAN 0
> +#define IHDR_OPT_LITTLE_ENDIAN (0 << _IHDR_OPT_ENDIAN)
> +#define IHDR_OPT_BIG_ENDIAN (1 << _IHDR_OPT_ENDIAN)
> +
> +/*
> + * Domain Header
> + */
> +struct xc_sr_dhdr
> +{
> + uint32_t type;
> + uint16_t page_shift;
> + uint16_t _res1;
> + uint32_t xen_major;
> + uint32_t xen_minor;
> +};
> +
> +#define DHDR_TYPE_X86_PV 0x00000001U
> +#define DHDR_TYPE_X86_HVM 0x00000002U
> +#define DHDR_TYPE_X86_PVH 0x00000003U
> +#define DHDR_TYPE_ARM 0x00000004U
> +
> +/*
> + * Record Header
> + */
> +struct xc_sr_rhdr
> +{
> + uint32_t type;
> + uint32_t length;
> +};
> +
> +/* All records must be aligned up to an 8 octet boundary */
> +#define REC_ALIGN_ORDER (3U)
> +/* Somewhat arbitrary - 8MB */
> +#define REC_LENGTH_MAX (8U << 20)
> +
> +#define REC_TYPE_END 0x00000000U
> +#define REC_TYPE_PAGE_DATA 0x00000001U
> +#define REC_TYPE_X86_PV_INFO 0x00000002U
> +#define REC_TYPE_X86_PV_P2M_FRAMES 0x00000003U
> +#define REC_TYPE_X86_PV_VCPU_BASIC 0x00000004U
> +#define REC_TYPE_X86_PV_VCPU_EXTENDED 0x00000005U
> +#define REC_TYPE_X86_PV_VCPU_XSAVE 0x00000006U
> +#define REC_TYPE_SHARED_INFO 0x00000007U
> +#define REC_TYPE_TSC_INFO 0x00000008U
> +#define REC_TYPE_HVM_CONTEXT 0x00000009U
> +#define REC_TYPE_HVM_PARAMS 0x0000000aU
> +#define REC_TYPE_TOOLSTACK 0x0000000bU
> +#define REC_TYPE_X86_PV_VCPU_MSRS 0x0000000cU
> +#define REC_TYPE_VERIFY 0x0000000dU
> +
> +#define REC_TYPE_OPTIONAL 0x80000000U
> +
> +/* PAGE_DATA */
> +struct xc_sr_rec_page_data_header
> +{
> + uint32_t count;
> + uint32_t _res1;
> + uint64_t pfn[0];
> +};
> +
> +#define PAGE_DATA_PFN_MASK 0x000fffffffffffffULL
> +#define PAGE_DATA_TYPE_MASK 0xf000000000000000ULL
> +
> +/* X86_PV_INFO */
> +struct xc_sr_rec_x86_pv_info
> +{
> + uint8_t guest_width;
> + uint8_t pt_levels;
> + uint8_t _res[6];
> +};
> +
> +/* X86_PV_P2M_FRAMES */
> +struct xc_sr_rec_x86_pv_p2m_frames
> +{
> + uint32_t start_pfn;
> + uint32_t end_pfn;
> + uint64_t p2m_pfns[0];
> +};
> +
> +/* X86_PV_VCPU_{BASIC,EXTENDED,XSAVE,MSRS} */
> +struct xc_sr_rec_x86_pv_vcpu_hdr
> +{
> + uint32_t vcpu_id;
> + uint32_t _res1;
> + uint8_t context[0];
> +};
> +
> +/* TSC_INFO */
> +struct xc_sr_rec_tsc_info
> +{
> + uint32_t mode;
> + uint32_t khz;
> + uint64_t nsec;
> + uint32_t incarnation;
> + uint32_t _res1;
> +};
> +
> +/* HVM_PARAMS */
> +struct xc_sr_rec_hvm_params_entry
> +{
> + uint64_t index;
> + uint64_t value;
> +};
> +
> +struct xc_sr_rec_hvm_params
> +{
> + uint32_t count;
> + uint32_t _res1;
> + struct xc_sr_rec_hvm_params_entry param[0];
> +};
> +
> +#endif
> +/*
> + * Local variables:
> + * mode: C
> + * c-file-style: "BSD"
> + * c-basic-offset: 4
> + * tab-width: 4
> + * indent-tabs-mode: nil
> + * End:
> + */
_______________________________________________
Xen-devel mailing list
Xen-devel@xxxxxxxxxxxxx
http://lists.xen.org/xen-devel
|
![]() |
Lists.xenproject.org is hosted with RackSpace, monitoring our |