Blame xendump.h

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