432d268c05
On IA32 host or IA32 PAE host, at present, generally, we can't create an HVM guest with more than 2G memory, because generally it's almost impossible for Qemu to find a large enough and consecutive virtual address space to map an HVM guest's whole physical address space. The attached patch fixes this issue using dynamic mapping based on little blocks of memory. Each call to qemu_get_ram_ptr makes a call to qemu_map_cache with the lock option, so mapcache will not unmap these ram_ptr. Blocks that do not belong to the RAM, but usually to a device ROM or to a framebuffer, are handled in a separate function. So the whole RAMBlock can be map. Signed-off-by: Jun Nakajima <jun.nakajima@intel.com> Signed-off-by: Anthony PERARD <anthony.perard@citrix.com> Signed-off-by: Stefano Stabellini <stefano.stabellini@eu.citrix.com> Signed-off-by: Alexander Graf <agraf@suse.de>
62 lines
1.4 KiB
C
62 lines
1.4 KiB
C
#ifndef QEMU_HW_XEN_H
|
|
#define QEMU_HW_XEN_H 1
|
|
/*
|
|
* public xen header
|
|
* stuff needed outside xen-*.c, i.e. interfaces to qemu.
|
|
* must not depend on any xen headers being present in
|
|
* /usr/include/xen, so it can be included unconditionally.
|
|
*/
|
|
#include <inttypes.h>
|
|
|
|
#include "qemu-common.h"
|
|
|
|
/* xen-machine.c */
|
|
enum xen_mode {
|
|
XEN_EMULATE = 0, // xen emulation, using xenner (default)
|
|
XEN_CREATE, // create xen domain
|
|
XEN_ATTACH // attach to xen domain created by xend
|
|
};
|
|
|
|
extern uint32_t xen_domid;
|
|
extern enum xen_mode xen_mode;
|
|
|
|
extern int xen_allowed;
|
|
|
|
static inline int xen_enabled(void)
|
|
{
|
|
#ifdef CONFIG_XEN
|
|
return xen_allowed;
|
|
#else
|
|
return 0;
|
|
#endif
|
|
}
|
|
|
|
static inline int xen_mapcache_enabled(void)
|
|
{
|
|
#ifdef CONFIG_XEN_MAPCACHE
|
|
return xen_enabled();
|
|
#else
|
|
return 0;
|
|
#endif
|
|
}
|
|
|
|
int xen_pci_slot_get_pirq(PCIDevice *pci_dev, int irq_num);
|
|
void xen_piix3_set_irq(void *opaque, int irq_num, int level);
|
|
void xen_piix_pci_write_config_client(uint32_t address, uint32_t val, int len);
|
|
|
|
qemu_irq *xen_interrupt_controller_init(void);
|
|
|
|
int xen_init(void);
|
|
int xen_hvm_init(void);
|
|
void xen_vcpu_init(void);
|
|
|
|
#if defined(NEED_CPU_H) && !defined(CONFIG_USER_ONLY)
|
|
void xen_ram_alloc(ram_addr_t ram_addr, ram_addr_t size);
|
|
#endif
|
|
|
|
#if defined(CONFIG_XEN) && CONFIG_XEN_CTRL_INTERFACE_VERSION < 400
|
|
# define HVM_MAX_VCPUS 32
|
|
#endif
|
|
|
|
#endif /* QEMU_HW_XEN_H */
|