17d36db35SAvi Kivity #ifndef VM_H 27d36db35SAvi Kivity #define VM_H 37d36db35SAvi Kivity 47d36db35SAvi Kivity #include "processor.h" 57d36db35SAvi Kivity 67d36db35SAvi Kivity #define PAGE_SIZE 4096ul 77d36db35SAvi Kivity #ifdef __x86_64__ 87d36db35SAvi Kivity #define LARGE_PAGE_SIZE (512 * PAGE_SIZE) 97d36db35SAvi Kivity #else 107d36db35SAvi Kivity #define LARGE_PAGE_SIZE (1024 * PAGE_SIZE) 117d36db35SAvi Kivity #endif 127d36db35SAvi Kivity 137d36db35SAvi Kivity #define PTE_PRESENT (1ull << 0) 147d36db35SAvi Kivity #define PTE_PSE (1ull << 7) 157d36db35SAvi Kivity #define PTE_WRITE (1ull << 1) 167d36db35SAvi Kivity #define PTE_ADDR (0xffffffffff000ull) 177d36db35SAvi Kivity 187d36db35SAvi Kivity void setup_vm(); 197d36db35SAvi Kivity 207d36db35SAvi Kivity void *vmalloc(unsigned long size); 217d36db35SAvi Kivity void vfree(void *mem); 227d36db35SAvi Kivity void *vmap(unsigned long long phys, unsigned long size); 23a4b87a16SGleb Natapov void *alloc_vpage(void); 24*524ae896SAvi Kivity void *alloc_vpages(ulong nr); 257d36db35SAvi Kivity 267d36db35SAvi Kivity void install_pte(unsigned long *cr3, 277d36db35SAvi Kivity int pte_level, 287d36db35SAvi Kivity void *virt, 297d36db35SAvi Kivity unsigned long pte, 307d36db35SAvi Kivity unsigned long *pt_page); 317d36db35SAvi Kivity 327d36db35SAvi Kivity void *alloc_page(); 337d36db35SAvi Kivity 347d36db35SAvi Kivity void install_large_page(unsigned long *cr3,unsigned long phys, 357d36db35SAvi Kivity void *virt); 367d36db35SAvi Kivity void install_page(unsigned long *cr3, unsigned long phys, void *virt); 377d36db35SAvi Kivity 387d36db35SAvi Kivity static inline unsigned long virt_to_phys(const void *virt) 397d36db35SAvi Kivity { 407d36db35SAvi Kivity return (unsigned long)virt; 417d36db35SAvi Kivity } 427d36db35SAvi Kivity 437d36db35SAvi Kivity static inline void *phys_to_virt(unsigned long phys) 447d36db35SAvi Kivity { 457d36db35SAvi Kivity return (void *)phys; 467d36db35SAvi Kivity } 477d36db35SAvi Kivity 487d36db35SAvi Kivity #endif 49