From: Claudio Imbrenda <imbrenda@linux.ibm.com>
To: kvm@vger.kernel.org, pbonzini@redhat.com
Cc: frankja@linux.ibm.com, thuth@redhat.com, david@redhat.com
Subject: [kvm-unit-tests PATCH v1 4/4] lib/vmalloc: allow vm_memalign with alignment > PAGE_SIZE
Date: Fri, 3 Jul 2020 13:51:09 +0200 [thread overview]
Message-ID: <20200703115109.39139-5-imbrenda@linux.ibm.com> (raw)
In-Reply-To: <20200703115109.39139-1-imbrenda@linux.ibm.com>
Allow allocating aligned virtual memory with alignment larger than only
one page.
Add a check that the backing pages were actually allocated.
Export the alloc_vpages_aligned function to allow users to allocate
non-backed aligned virtual addresses.
Signed-off-by: Claudio Imbrenda <imbrenda@linux.ibm.com>
---
lib/vmalloc.h | 3 +++
lib/vmalloc.c | 40 ++++++++++++++++++++++++++++++++--------
2 files changed, 35 insertions(+), 8 deletions(-)
diff --git a/lib/vmalloc.h b/lib/vmalloc.h
index 2b563f4..fa3fa22 100644
--- a/lib/vmalloc.h
+++ b/lib/vmalloc.h
@@ -5,6 +5,9 @@
/* Allocate consecutive virtual pages (without backing) */
extern void *alloc_vpages(ulong nr);
+/* Allocate consecutive and aligned virtual pages (without backing) */
+extern void *alloc_vpages_aligned(ulong nr, unsigned int alignment_pages);
+
/* Allocate one virtual page (without backing) */
extern void *alloc_vpage(void);
/* Set the top of the virtual address space */
diff --git a/lib/vmalloc.c b/lib/vmalloc.c
index 9237a0f..2c482aa 100644
--- a/lib/vmalloc.c
+++ b/lib/vmalloc.c
@@ -12,19 +12,28 @@
#include "alloc.h"
#include "alloc_phys.h"
#include "alloc_page.h"
+#include <bitops.h>
#include "vmalloc.h"
static struct spinlock lock;
static void *vfree_top = 0;
static void *page_root;
-void *alloc_vpages(ulong nr)
+/*
+ * Allocate a certain number of pages from the virtual address space (without
+ * physical backing).
+ *
+ * nr is the number of pages to allocate
+ * alignment_pages is the alignment of the allocation *in pages*
+ */
+static void *alloc_vpages_intern(ulong nr, unsigned int alignment_pages)
{
uintptr_t ptr;
spin_lock(&lock);
ptr = (uintptr_t)vfree_top;
ptr -= PAGE_SIZE * nr;
+ ptr &= GENMASK_ULL(63, PAGE_SHIFT + get_order(alignment_pages));
vfree_top = (void *)ptr;
spin_unlock(&lock);
@@ -32,6 +41,16 @@ void *alloc_vpages(ulong nr)
return (void *)ptr;
}
+void *alloc_vpages(ulong nr)
+{
+ return alloc_vpages_intern(nr, 1);
+}
+
+void *alloc_vpages_aligned(ulong nr, unsigned int alignment_pages)
+{
+ return alloc_vpages_intern(nr, alignment_pages);
+}
+
void *alloc_vpage(void)
{
return alloc_vpages(1);
@@ -55,17 +74,22 @@ void *vmap(phys_addr_t phys, size_t size)
return mem;
}
+/*
+ * Allocate virtual memory, with the specified minimum alignment.
+ */
static void *vm_memalign(size_t alignment, size_t size)
{
+ phys_addr_t pa;
void *mem, *p;
- size_t pages;
- assert(alignment <= PAGE_SIZE);
- size = PAGE_ALIGN(size);
- pages = size / PAGE_SIZE;
- mem = p = alloc_vpages(pages);
- while (pages--) {
- phys_addr_t pa = virt_to_phys(alloc_page());
+ assert(is_power_of_2(alignment));
+
+ size = PAGE_ALIGN(size) / PAGE_SIZE;
+ alignment = PAGE_ALIGN(alignment) / PAGE_SIZE;
+ mem = p = alloc_vpages_intern(size, alignment);
+ while (size--) {
+ pa = virt_to_phys(alloc_page());
+ assert(pa);
install_page(page_root, pa, p);
p += PAGE_SIZE;
}
--
2.26.2
next prev parent reply other threads:[~2020-07-03 11:51 UTC|newest]
Thread overview: 9+ messages / expand[flat|nested] mbox.gz Atom feed top
2020-07-03 11:51 [kvm-unit-tests PATCH v1 0/4] More lib/alloc cleanup and a minor improvement Claudio Imbrenda
2020-07-03 11:51 ` [kvm-unit-tests PATCH v1 1/4] lib/vmalloc: fix pages count local variable to be size_t Claudio Imbrenda
2020-07-03 11:51 ` [kvm-unit-tests PATCH v1 2/4] lib/alloc_page: change some parameter types Claudio Imbrenda
2020-07-03 11:51 ` [kvm-unit-tests PATCH v1 3/4] lib/alloc_page: move get_order and is_power_of_2 to a bitops.h Claudio Imbrenda
2020-07-03 11:51 ` Claudio Imbrenda [this message]
2020-07-03 12:30 ` [kvm-unit-tests PATCH v1 4/4] lib/vmalloc: allow vm_memalign with alignment > PAGE_SIZE Andrew Jones
2020-07-03 13:49 ` Claudio Imbrenda
2020-07-03 16:20 ` Paolo Bonzini
2020-07-03 12:30 ` [kvm-unit-tests PATCH v1 0/4] More lib/alloc cleanup and a minor improvement Andrew Jones
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=20200703115109.39139-5-imbrenda@linux.ibm.com \
--to=imbrenda@linux.ibm.com \
--cc=david@redhat.com \
--cc=frankja@linux.ibm.com \
--cc=kvm@vger.kernel.org \
--cc=pbonzini@redhat.com \
--cc=thuth@redhat.com \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox