Commit 2b1321e4 authored by Anton Vorontsov's avatar Anton Vorontsov Committed by Greg Kroah-Hartman

staging: android: persistent_ram: Introduce persistent_ram_vmap()

Factor out vmap logic out of persistent_ram_buffer_map(), this will
make the code a bit more understandable when we'll add support for
non-bootmem memory.
Signed-off-by: default avatarAnton Vorontsov <anton.vorontsov@linaro.org>
Signed-off-by: default avatarGreg Kroah-Hartman <gregkh@linuxfoundation.org>
parent 8cf5aff8
...@@ -318,14 +318,14 @@ void persistent_ram_free_old(struct persistent_ram_zone *prz) ...@@ -318,14 +318,14 @@ void persistent_ram_free_old(struct persistent_ram_zone *prz)
prz->old_log_size = 0; prz->old_log_size = 0;
} }
static int persistent_ram_buffer_map(phys_addr_t start, phys_addr_t size, static void *persistent_ram_vmap(phys_addr_t start, size_t size)
struct persistent_ram_zone *prz)
{ {
struct page **pages; struct page **pages;
phys_addr_t page_start; phys_addr_t page_start;
unsigned int page_count; unsigned int page_count;
pgprot_t prot; pgprot_t prot;
unsigned int i; unsigned int i;
void *vaddr;
page_start = start - offset_in_page(start); page_start = start - offset_in_page(start);
page_count = DIV_ROUND_UP(size + offset_in_page(start), PAGE_SIZE); page_count = DIV_ROUND_UP(size + offset_in_page(start), PAGE_SIZE);
...@@ -336,17 +336,26 @@ static int persistent_ram_buffer_map(phys_addr_t start, phys_addr_t size, ...@@ -336,17 +336,26 @@ static int persistent_ram_buffer_map(phys_addr_t start, phys_addr_t size,
if (!pages) { if (!pages) {
pr_err("%s: Failed to allocate array for %u pages\n", __func__, pr_err("%s: Failed to allocate array for %u pages\n", __func__,
page_count); page_count);
return -ENOMEM; return NULL;
} }
for (i = 0; i < page_count; i++) { for (i = 0; i < page_count; i++) {
phys_addr_t addr = page_start + i * PAGE_SIZE; phys_addr_t addr = page_start + i * PAGE_SIZE;
pages[i] = pfn_to_page(addr >> PAGE_SHIFT); pages[i] = pfn_to_page(addr >> PAGE_SHIFT);
} }
prz->vaddr = vmap(pages, page_count, VM_MAP, prot); vaddr = vmap(pages, page_count, VM_MAP, prot);
kfree(pages); kfree(pages);
return vaddr;
}
static int persistent_ram_buffer_map(phys_addr_t start, phys_addr_t size,
struct persistent_ram_zone *prz)
{
prz->vaddr = persistent_ram_vmap(start, size);
if (!prz->vaddr) { if (!prz->vaddr) {
pr_err("%s: Failed to map %u pages\n", __func__, page_count); pr_err("%s: Failed to map 0x%llx pages at 0x%llx\n", __func__,
(unsigned long long)size, (unsigned long long)start);
return -ENOMEM; return -ENOMEM;
} }
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment