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

staging: android: persistent_ram: Introduce persistent_ram_free()

A corresponding function to persistent_ram_new().
Signed-off-by: default avatarAnton Vorontsov <anton.vorontsov@linaro.org>
Signed-off-by: default avatarGreg Kroah-Hartman <gregkh@linuxfoundation.org>
parent 24c3d2f3
...@@ -364,6 +364,9 @@ static void *persistent_ram_iomap(phys_addr_t start, size_t size) ...@@ -364,6 +364,9 @@ static void *persistent_ram_iomap(phys_addr_t start, size_t size)
static int persistent_ram_buffer_map(phys_addr_t start, phys_addr_t size, static int persistent_ram_buffer_map(phys_addr_t start, phys_addr_t size,
struct persistent_ram_zone *prz) struct persistent_ram_zone *prz)
{ {
prz->paddr = start;
prz->size = size;
if (pfn_valid(start >> PAGE_SHIFT)) if (pfn_valid(start >> PAGE_SHIFT))
prz->vaddr = persistent_ram_vmap(start, size); prz->vaddr = persistent_ram_vmap(start, size);
else else
...@@ -437,6 +440,18 @@ static int __init persistent_ram_post_init(struct persistent_ram_zone *prz, bool ...@@ -437,6 +440,18 @@ static int __init persistent_ram_post_init(struct persistent_ram_zone *prz, bool
return 0; return 0;
} }
void persistent_ram_free(struct persistent_ram_zone *prz)
{
if (pfn_valid(prz->paddr >> PAGE_SHIFT)) {
vunmap(prz->vaddr);
} else {
iounmap(prz->vaddr);
release_mem_region(prz->paddr, prz->size);
}
persistent_ram_free_old(prz);
kfree(prz);
}
struct persistent_ram_zone * __init persistent_ram_new(phys_addr_t start, struct persistent_ram_zone * __init persistent_ram_new(phys_addr_t start,
size_t size, size_t size,
bool ecc) bool ecc)
......
...@@ -39,6 +39,8 @@ struct persistent_ram { ...@@ -39,6 +39,8 @@ struct persistent_ram {
}; };
struct persistent_ram_zone { struct persistent_ram_zone {
phys_addr_t paddr;
size_t size;
void *vaddr; void *vaddr;
struct persistent_ram_buffer *buffer; struct persistent_ram_buffer *buffer;
size_t buffer_size; size_t buffer_size;
...@@ -66,6 +68,7 @@ int persistent_ram_early_init(struct persistent_ram *ram); ...@@ -66,6 +68,7 @@ int persistent_ram_early_init(struct persistent_ram *ram);
struct persistent_ram_zone * __init persistent_ram_new(phys_addr_t start, struct persistent_ram_zone * __init persistent_ram_new(phys_addr_t start,
size_t size, size_t size,
bool ecc); bool ecc);
void persistent_ram_free(struct persistent_ram_zone *prz);
struct persistent_ram_zone *persistent_ram_init_ringbuffer(struct device *dev, struct persistent_ram_zone *persistent_ram_init_ringbuffer(struct device *dev,
bool ecc); bool ecc);
......
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