Blame xendump.h

Packit Service 501009
/* 
Packit Service 501009
 * xendump.h
Packit Service 501009
 *
Packit Service 501009
 * Copyright (C) 2006, 2007, 2009, 2010, 2014 David Anderson
Packit Service 501009
 * Copyright (C) 2006, 2007, 2009, 2010, 2014 Red Hat, Inc. All rights reserved.
Packit Service 501009
 *
Packit Service 501009
 * This program is free software; you can redistribute it and/or modify
Packit Service 501009
 * it under the terms of the GNU General Public License as published by
Packit Service 501009
 * the Free Software Foundation; either version 2 of the License, or
Packit Service 501009
 * (at your option) any later version.
Packit Service 501009
 *
Packit Service 501009
 * This program is distributed in the hope that it will be useful,
Packit Service 501009
 * but WITHOUT ANY WARRANTY; without even the implied warranty of
Packit Service 501009
 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
Packit Service 501009
 * GNU General Public License for more details.
Packit Service 501009
 */
Packit Service 501009
#include <endian.h>
Packit Service 501009
#include <elf.h>
Packit Service 501009
Packit Service 501009
#define XC_SAVE_SIGNATURE  "LinuxGuestRecord"
Packit Service 501009
#define XC_CORE_MAGIC      0xF00FEBED
Packit Service 501009
#define XC_CORE_MAGIC_HVM  0xF00FEBEE
Packit Service 501009
Packit Service 501009
/*
Packit Service 501009
 *  From xenctrl.h, but probably not on most host machines.
Packit Service 501009
 */
Packit Service 501009
typedef struct xc_core_header {
Packit Service 501009
    unsigned int xch_magic;
Packit Service 501009
    unsigned int xch_nr_vcpus;
Packit Service 501009
    unsigned int xch_nr_pages;
Packit Service 501009
    unsigned int xch_ctxt_offset;
Packit Service 501009
    unsigned int xch_index_offset;
Packit Service 501009
    unsigned int xch_pages_offset;
Packit Service 501009
} xc_core_header_t;
Packit Service 501009
Packit Service 501009
/*
Packit Service 501009
 *  Based upon the original xensource xc_core_header struct above, 
Packit Service 501009
 *  but with unsigned long offset values so that it can be used
Packit Service 501009
 *  with the original dumpfile format and new ELF-style format.
Packit Service 501009
 */
Packit Service 501009
struct xen_core_header {
Packit Service 501009
    unsigned int xch_magic;
Packit Service 501009
    unsigned int xch_nr_vcpus;
Packit Service 501009
    unsigned int xch_nr_pages;
Packit Service 501009
    off_t xch_ctxt_offset;
Packit Service 501009
    off_t xch_index_offset;
Packit Service 501009
    off_t xch_pages_offset;
Packit Service 501009
};
Packit Service 501009
Packit Service 501009
struct pfn_offset_cache {
Packit Service 501009
	off_t file_offset;
Packit Service 501009
	ulong pfn;
Packit Service 501009
	ulong cnt;
Packit Service 501009
};
Packit Service 501009
#define PFN_TO_OFFSET_CACHE_ENTRIES  (5000)
Packit Service 501009
Packit Service 501009
struct elf_index_pfn {
Packit Service 501009
	ulong index;
Packit Service 501009
	ulong pfn;
Packit Service 501009
};
Packit Service 501009
#define INDEX_PFN_COUNT (128)
Packit Service 501009
Packit Service 501009
struct last_batch {
Packit Service 501009
	ulong index;
Packit Service 501009
	ulong start;
Packit Service 501009
	ulong end;
Packit Service 501009
	ulong accesses;
Packit Service 501009
	ulong duplicates; 
Packit Service 501009
};
Packit Service 501009
Packit Service 501009
struct xendump_data {
Packit Service 501009
        ulong flags;       /* XENDUMP_LOCAL, plus anything else... */
Packit Service 501009
	int xfd;
Packit Service 501009
	int pc_next;
Packit Service 501009
	uint page_size;
Packit Service 501009
	FILE *ofp;
Packit Service 501009
	char *page;
Packit Service 501009
	ulong accesses;
Packit Service 501009
	ulong cache_hits;
Packit Service 501009
	ulong redundant;
Packit Service 501009
	ulong last_pfn;
Packit Service 501009
	struct pfn_offset_cache *poc;
Packit Service 501009
Packit Service 501009
	struct xc_core_data {
Packit Service 501009
		int p2m_frames;
Packit Service 501009
		ulong *p2m_frame_index_list;
Packit Service 501009
		struct xen_core_header header;
Packit Service 501009
		int elf_class;
Packit Service 501009
		uint64_t format_version;
Packit Service 501009
		off_t elf_strtab_offset;
Packit Service 501009
		off_t shared_info_offset;
Packit Service 501009
		off_t ia64_mapped_regs_offset;
Packit Service 501009
		struct elf_index_pfn elf_index_pfn[INDEX_PFN_COUNT];
Packit Service 501009
		struct last_batch last_batch;
Packit Service 501009
		Elf32_Ehdr *elf32;
Packit Service 501009
		Elf64_Ehdr *elf64;
Packit Service 501009
	} xc_core;
Packit Service 501009
Packit Service 501009
	struct xc_save_data {
Packit Service 501009
		ulong nr_pfns;
Packit Service 501009
		int vmconfig_size;
Packit Service 501009
		char *vmconfig_buf;
Packit Service 501009
		ulong *p2m_frame_list;
Packit Service 501009
		uint pfns_not;
Packit Service 501009
		off_t pfns_not_offset;
Packit Service 501009
		off_t vcpu_ctxt_offset;
Packit Service 501009
		off_t shared_info_page_offset;
Packit Service 501009
		off_t *batch_offsets;
Packit Service 501009
		ulong batch_count;
Packit Service 501009
		ulong *region_pfn_type;
Packit Service 501009
		ulong ia64_version;
Packit Service 501009
		ulong *ia64_page_offsets;
Packit Service 501009
	} xc_save;
Packit Service 501009
Packit Service 501009
	ulong panic_pc;
Packit Service 501009
	ulong panic_sp;
Packit Service 501009
};
Packit Service 501009
Packit Service 501009
#define XC_SAVE            (XENDUMP_LOCAL << 1)
Packit Service 501009
#define XC_CORE_ORIG       (XENDUMP_LOCAL << 2)
Packit Service 501009
#define XC_CORE_P2M_CREATE (XENDUMP_LOCAL << 3)
Packit Service 501009
#define XC_CORE_PFN_CREATE (XENDUMP_LOCAL << 4)
Packit Service 501009
#define XC_CORE_NO_P2M     (XENDUMP_LOCAL << 5)
Packit Service 501009
#define XC_SAVE_IA64       (XENDUMP_LOCAL << 6)
Packit Service 501009
#define XC_CORE_64BIT_HOST (XENDUMP_LOCAL << 7)
Packit Service 501009
#define XC_CORE_ELF        (XENDUMP_LOCAL << 8)
Packit Service 501009
Packit Service 501009
#define MACHINE_BYTE_ORDER()  \
Packit Service 501009
        (machine_type("X86") || \
Packit Service 501009
         machine_type("X86_64") || \
Packit Service 501009
         machine_type("IA64") ? __LITTLE_ENDIAN : __BIG_ENDIAN)
Packit Service 501009
Packit Service 501009
#define BYTE_SWAP_REQUIRED(endian) (endian != MACHINE_BYTE_ORDER())
Packit Service 501009
Packit Service 501009
static inline uint32_t
Packit Service 501009
swab32(uint32_t x)
Packit Service 501009
{
Packit Service 501009
        return (((x & 0x000000ffU) << 24) |
Packit Service 501009
                ((x & 0x0000ff00U) <<  8) |
Packit Service 501009
                ((x & 0x00ff0000U) >>  8) |
Packit Service 501009
                ((x & 0xff000000U) >> 24));
Packit Service 501009
}
Packit Service 501009
Packit Service 501009
#define MFN_NOT_FOUND (-1)
Packit Service 501009
#define PFN_NOT_FOUND (-1)
Packit Service 501009
Packit Service 501009
#define INVALID_MFN (~0UL)
Packit Service 501009
Packit Service 501009
/*
Packit Service 501009
 *  ia64 "xm save" format is completely different than the others.
Packit Service 501009
 */
Packit Service 501009
typedef struct xen_domctl_arch_setup {
Packit Service 501009
    uint64_t flags;      /* XEN_DOMAINSETUP_* */
Packit Service 501009
/* #ifdef __ia64__ */
Packit Service 501009
    uint64_t bp;            /* mpaddr of boot param area */
Packit Service 501009
    uint64_t maxmem;        /* Highest memory address for MDT.  */
Packit Service 501009
    uint64_t xsi_va;        /* Xen shared_info area virtual address.  */
Packit Service 501009
    uint32_t hypercall_imm; /* Break imm for Xen hypercalls.  */
Packit Service 501009
/* #endif */
Packit Service 501009
} xen_domctl_arch_setup_t;
Packit Service 501009
Packit Service 501009
/*
Packit Service 501009
 *  xc_core ELF note, which differs from the standard Elf[32|64]_Nhdr
Packit Service 501009
 *  structure by the additional name field.
Packit Service 501009
 */
Packit Service 501009
struct elfnote {
Packit Service 501009
	uint32_t namesz; 
Packit Service 501009
	uint32_t descsz;
Packit Service 501009
	uint32_t type;
Packit Service 501009
	char name[4]; 
Packit Service 501009
};
Packit Service 501009
Packit Service 501009
#define XEN_ELFNOTE_DUMPCORE_NONE            0x2000000
Packit Service 501009
#define XEN_ELFNOTE_DUMPCORE_HEADER          0x2000001
Packit Service 501009
#define XEN_ELFNOTE_DUMPCORE_XEN_VERSION     0x2000002
Packit Service 501009
#define XEN_ELFNOTE_DUMPCORE_FORMAT_VERSION  0x2000003
Packit Service 501009
Packit Service 501009
struct xen_dumpcore_elfnote_header_desc {
Packit Service 501009
	uint64_t xch_magic;
Packit Service 501009
	uint64_t xch_nr_vcpus;
Packit Service 501009
	uint64_t xch_nr_pages;
Packit Service 501009
	uint64_t xch_page_size;
Packit Service 501009
}; 
Packit Service 501009
Packit Service 501009
#define FORMAT_VERSION_0000000000000001 0x0000000000000001ULL
Packit Service 501009
Packit Service 501009
struct xen_dumpcore_elfnote_format_version_desc {
Packit Service 501009
	uint64_t version;
Packit Service 501009
}; 
Packit Service 501009
Packit Service 501009
struct xen_dumpcore_p2m {
Packit Service 501009
	uint64_t pfn;
Packit Service 501009
	uint64_t gmfn; 
Packit Service 501009
};
Packit Service 501009
Packit Service 501009
extern struct xendump_data *xd;