xref: /kvm-unit-tests/lib/x86/asm/page.h (revision 359575f6bfffda83a66a4277818be12a7e9900a0) !
13e394a58SAlexander Gordeev #ifndef _ASM_X86_PAGE_H_
23e394a58SAlexander Gordeev #define _ASM_X86_PAGE_H_
33e394a58SAlexander Gordeev /*
43e394a58SAlexander Gordeev  * Copyright (C) 2016, Red Hat Inc, Alexander Gordeev <agordeev@redhat.com>
53e394a58SAlexander Gordeev  *
63e394a58SAlexander Gordeev  * This work is licensed under the terms of the GNU LGPL, version 2.
73e394a58SAlexander Gordeev  */
83e394a58SAlexander Gordeev 
93e394a58SAlexander Gordeev 
101ad15f10SAlexander Gordeev #include <linux/const.h>
11d10d16e1SAlexander Gordeev #include <bitops.h>
121ad15f10SAlexander Gordeev 
131ad15f10SAlexander Gordeev #define PAGE_SHIFT	12
141ad15f10SAlexander Gordeev #define PAGE_SIZE	(_AC(1,UL) << PAGE_SHIFT)
151ad15f10SAlexander Gordeev #define PAGE_MASK	(~(PAGE_SIZE-1))
161ad15f10SAlexander Gordeev 
171ad15f10SAlexander Gordeev #ifndef __ASSEMBLY__
181ad15f10SAlexander Gordeev 
193e394a58SAlexander Gordeev #ifdef __x86_64__
203e394a58SAlexander Gordeev #define LARGE_PAGE_SIZE	(512 * PAGE_SIZE)
213e394a58SAlexander Gordeev #else
223e394a58SAlexander Gordeev #define LARGE_PAGE_SIZE	(1024 * PAGE_SIZE)
233e394a58SAlexander Gordeev #endif
243e394a58SAlexander Gordeev 
25d10d16e1SAlexander Gordeev #define PT_PRESENT_MASK		(1ull << 0)
26d10d16e1SAlexander Gordeev #define PT_WRITABLE_MASK	(1ull << 1)
27d10d16e1SAlexander Gordeev #define PT_USER_MASK		(1ull << 2)
28d10d16e1SAlexander Gordeev #define PT_ACCESSED_MASK	(1ull << 5)
29d10d16e1SAlexander Gordeev #define PT_DIRTY_MASK		(1ull << 6)
30d10d16e1SAlexander Gordeev #define PT_PAGE_SIZE_MASK	(1ull << 7)
31d10d16e1SAlexander Gordeev #define PT64_NX_MASK		(1ull << 63)
32d10d16e1SAlexander Gordeev #define PT_ADDR_MASK		GENMASK_ULL(51, 12)
333e394a58SAlexander Gordeev 
34*359575f6SPeter Feiner #define PT_AD_MASK              (PT_ACCESSED_MASK | PT_DIRTY_MASK)
35*359575f6SPeter Feiner 
363e394a58SAlexander Gordeev #ifdef __x86_64__
373e394a58SAlexander Gordeev #define	PAGE_LEVEL	4
383e394a58SAlexander Gordeev #define	PGDIR_WIDTH	9
393e394a58SAlexander Gordeev #define	PGDIR_MASK	511
403e394a58SAlexander Gordeev #else
413e394a58SAlexander Gordeev #define	PAGE_LEVEL	2
423e394a58SAlexander Gordeev #define	PGDIR_WIDTH	10
433e394a58SAlexander Gordeev #define	PGDIR_MASK	1023
443e394a58SAlexander Gordeev #endif
453e394a58SAlexander Gordeev 
469d7e08c0SPeter Xu #define PGDIR_BITS(lvl)        (((lvl) - 1) * PGDIR_WIDTH + PAGE_SHIFT)
479d7e08c0SPeter Xu #define PGDIR_OFFSET(va, lvl)  (((va) >> PGDIR_BITS(lvl)) & PGDIR_MASK)
489d7e08c0SPeter Xu 
491ad15f10SAlexander Gordeev #endif /* !__ASSEMBLY__ */
503e394a58SAlexander Gordeev #endif
51