diff --git a/include/arch/x86/page.h b/include/arch/x86/page.h index 992835de..f5f3fdfb 100644 --- a/include/arch/x86/page.h +++ b/include/arch/x86/page.h @@ -193,6 +193,7 @@ typedef unsigned long mfn_t; #define MAP_FAILED ((void *) 1) #define IS_ADDR_SPACE_VA(va, as) (_ul(va) >= (as)) +#define PADDR_TO_ORDER(addr) (ctz(addr) - PAGE_SHIFT) /* External declarations */ @@ -218,10 +219,10 @@ static inline bool has_vmap_flags(vmap_flags_t flags) { } static inline mfn_t paddr_to_mfn(paddr_t pa) { - return (mfn_t)(pa >> PAGE_SHIFT); + return (mfn_t) (pa >> PAGE_SHIFT); } static inline paddr_t mfn_to_paddr(mfn_t mfn) { - return (paddr_t)(mfn << PAGE_SHIFT); + return (paddr_t) (mfn << PAGE_SHIFT); } static inline void *_paddr_to_virt(paddr_t pa, unsigned long addr_space) { diff --git a/include/compiler.h b/include/compiler.h index 656c2a61..d94fd355 100644 --- a/include/compiler.h +++ b/include/compiler.h @@ -105,7 +105,7 @@ typedef uint64_t off_t; #define memberof(type, member) (((type *) 0)->member) #ifndef offsetof -#define offsetof(type, member) ((off_t) &memberof(type, member)) +#define offsetof(type, member) ((off_t) & memberof(type, member)) #endif #define BUILD_BUG_ON(cond) ({ _Static_assert(!(cond), "!(" STR(cond) ")"); }) @@ -157,4 +157,6 @@ typedef uint64_t off_t; _str; \ }) +/* count trailing zeros */ +#define ctz __builtin_ctz #endif /* KTF_COMPILER_H */ diff --git a/mm/pmm.c b/mm/pmm.c index 949a4349..2527ac7f 100644 --- a/mm/pmm.c +++ b/mm/pmm.c @@ -293,7 +293,6 @@ static unsigned find_first_avail_region(void) { static size_t process_memory_range(unsigned index, unsigned first_avail_region) { paddr_t start, end, cur; - unsigned int max_order; addr_range_t range; size_t size; @@ -310,39 +309,34 @@ static size_t process_memory_range(unsigned index, unsigned first_avail_region) * because initial virtual memory mapping is small. */ - /* Add initial 4K frames and align to 2M. */ - while ((cur < MB(EARLY_VIRT_MEM) || cur % PAGE_SIZE_2M) && cur + PAGE_SIZE <= end) { - if (index <= first_avail_region) - add_early_frame(paddr_to_mfn(cur), PAGE_ORDER_4K); - else - add_frame(paddr_to_mfn(cur), PAGE_ORDER_4K); + /* Add initial 4K frames for early memory. */ + while (cur < MB(EARLY_VIRT_MEM) && cur + PAGE_SIZE <= end) { + add_early_frame(paddr_to_mfn(cur), PAGE_ORDER_4K); cur += ORDER_TO_SIZE(PAGE_ORDER_4K); } - max_order = find_max_avail_order(end - cur); - - /* Add all available max_order frames. */ - while (cur + ORDER_TO_SIZE(max_order) <= end) { - add_frame(paddr_to_mfn(cur), max_order); - cur += ORDER_TO_SIZE(max_order); - } + while (cur + PAGE_SIZE <= end) { + unsigned int order = PADDR_TO_ORDER(cur); + if (order >= PAGE_ORDER_1G && cur + PAGE_SIZE_1G <= end) { + add_frame(paddr_to_mfn(cur), PAGE_ORDER_1G); + cur += ORDER_TO_SIZE(PAGE_ORDER_1G); + continue; + } - /* Add all remaining 2M frames. */ - while (cur + PAGE_SIZE_2M <= end) { - add_frame(paddr_to_mfn(cur), PAGE_ORDER_2M); - cur += ORDER_TO_SIZE(PAGE_ORDER_2M); - } + if (order >= PAGE_ORDER_2M && cur + PAGE_SIZE_2M <= end) { + add_frame(paddr_to_mfn(cur), PAGE_ORDER_2M); + cur += ORDER_TO_SIZE(PAGE_ORDER_2M); + continue; + } - /* Add all remaining 4K frames. */ - while (cur < end) { add_frame(paddr_to_mfn(cur), PAGE_ORDER_4K); cur += ORDER_TO_SIZE(PAGE_ORDER_4K); } if (cur != end) { - warning( - "PMM range processing failed: start=0x%016lx end=0x%016lx current=0x%016lx", - start, end, cur); + warning("PMM range processing failed: start=0x%016lx end=0x%016lx " + "current=0x%016lx", + start, end, cur); } return size;