@@ -5,6 +5,7 @@
* with page granularity.
*/
#include "libcflat.h"
+#include "alloc.h"
#include "alloc_phys.h"
#include <asm/page.h>
#include <asm/io.h>
@@ -134,3 +135,30 @@ void free_page(void *page)
freelist = page;
spin_unlock(&lock);
}
+
+static void *page_memalign(size_t alignment, size_t size)
+{
+ unsigned long order;
+
+ if (!size)
+ return NULL;
+
+ order = 64 - __builtin_clzll(ALIGN(size, PAGE_SIZE) >> PAGE_SHIFT) - 1;
+ return alloc_pages(order);
+}
+
+static void page_free(void *mem, size_t size)
+{
+ free_pages(mem, size);
+}
+
+static struct alloc_ops page_alloc_ops = {
+ .memalign = page_memalign,
+ .free = page_free,
+ .align_min = PAGE_SIZE,
+};
+
+void page_alloc_ops_enable(void)
+{
+ alloc_ops = &page_alloc_ops;
+}
@@ -9,6 +9,7 @@
#define ALLOC_PAGE_H 1
bool page_alloc_initialized(void);
+void page_alloc_ops_enable(void);
void *alloc_page();
void *alloc_pages(unsigned long order);
void free_page(void *page);
If we want both early alloc ops and alloc_page(), then it's best to just give all the memory to page_alloc and then base the early alloc ops on that. Signed-off-by: Andrew Jones <drjones@redhat.com> --- lib/alloc_page.c | 28 ++++++++++++++++++++++++++++ lib/alloc_page.h | 1 + 2 files changed, 29 insertions(+)