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); 23*a4b87a16SGleb Natapov void *alloc_vpage(void); 247d36db35SAvi Kivity 257d36db35SAvi Kivity void install_pte(unsigned long *cr3, 267d36db35SAvi Kivity int pte_level, 277d36db35SAvi Kivity void *virt, 287d36db35SAvi Kivity unsigned long pte, 297d36db35SAvi Kivity unsigned long *pt_page); 307d36db35SAvi Kivity 317d36db35SAvi Kivity void *alloc_page(); 327d36db35SAvi Kivity 337d36db35SAvi Kivity void install_large_page(unsigned long *cr3,unsigned long phys, 347d36db35SAvi Kivity void *virt); 357d36db35SAvi Kivity void install_page(unsigned long *cr3, unsigned long phys, void *virt); 367d36db35SAvi Kivity 377d36db35SAvi Kivity static inline unsigned long virt_to_phys(const void *virt) 387d36db35SAvi Kivity { 397d36db35SAvi Kivity return (unsigned long)virt; 407d36db35SAvi Kivity } 417d36db35SAvi Kivity 427d36db35SAvi Kivity static inline void *phys_to_virt(unsigned long phys) 437d36db35SAvi Kivity { 447d36db35SAvi Kivity return (void *)phys; 457d36db35SAvi Kivity } 467d36db35SAvi Kivity 477d36db35SAvi Kivity #endif 48