Commit adfe67dd authored by David S. Miller's avatar David S. Miller

sparc64: Use free_bootmem_late() in mdesc_lmb_free().

Signed-off-by: default avatarDavid S. Miller <davem@davemloft.net>
parent 121dd5f2
...@@ -10,6 +10,7 @@ ...@@ -10,6 +10,7 @@
#include <linux/slab.h> #include <linux/slab.h>
#include <linux/mm.h> #include <linux/mm.h>
#include <linux/miscdevice.h> #include <linux/miscdevice.h>
#include <linux/bootmem.h>
#include <asm/cpudata.h> #include <asm/cpudata.h>
#include <asm/hypervisor.h> #include <asm/hypervisor.h>
...@@ -108,25 +109,15 @@ static struct mdesc_handle * __init mdesc_lmb_alloc(unsigned int mdesc_size) ...@@ -108,25 +109,15 @@ static struct mdesc_handle * __init mdesc_lmb_alloc(unsigned int mdesc_size)
static void mdesc_lmb_free(struct mdesc_handle *hp) static void mdesc_lmb_free(struct mdesc_handle *hp)
{ {
unsigned int alloc_size, handle_size = hp->handle_size; unsigned int alloc_size;
unsigned long start, end; unsigned long start;
BUG_ON(atomic_read(&hp->refcnt) != 0); BUG_ON(atomic_read(&hp->refcnt) != 0);
BUG_ON(!list_empty(&hp->list)); BUG_ON(!list_empty(&hp->list));
alloc_size = PAGE_ALIGN(handle_size); alloc_size = PAGE_ALIGN(hp->handle_size);
start = __pa(hp);
start = (unsigned long) hp; free_bootmem_late(start, alloc_size);
end = start + alloc_size;
while (start < end) {
struct page *p;
p = virt_to_page(start);
ClearPageReserved(p);
__free_page(p);
start += PAGE_SIZE;
}
} }
static struct mdesc_mem_ops lmb_mdesc_ops = { static struct mdesc_mem_ops lmb_mdesc_ops = {
......
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