diff options
Diffstat (limited to 'arch/sh/kernel/dwarf.c')
| -rw-r--r-- | arch/sh/kernel/dwarf.c | 18 | 
1 files changed, 9 insertions, 9 deletions
| diff --git a/arch/sh/kernel/dwarf.c b/arch/sh/kernel/dwarf.c index 67a049e75ec1..9d209a07235e 100644 --- a/arch/sh/kernel/dwarf.c +++ b/arch/sh/kernel/dwarf.c @@ -993,7 +993,7 @@ static struct unwinder dwarf_unwinder = {  	.rating = 150,  }; -static void dwarf_unwinder_cleanup(void) +static void __init dwarf_unwinder_cleanup(void)  {  	struct dwarf_fde *fde, *next_fde;  	struct dwarf_cie *cie, *next_cie; @@ -1009,6 +1009,10 @@ static void dwarf_unwinder_cleanup(void)  	rbtree_postorder_for_each_entry_safe(cie, next_cie, &cie_root, node)  		kfree(cie); +	if (dwarf_reg_pool) +		mempool_destroy(dwarf_reg_pool); +	if (dwarf_frame_pool) +		mempool_destroy(dwarf_frame_pool);  	kmem_cache_destroy(dwarf_reg_cachep);  	kmem_cache_destroy(dwarf_frame_cachep);  } @@ -1176,17 +1180,13 @@ static int __init dwarf_unwinder_init(void)  			sizeof(struct dwarf_reg), 0,  			SLAB_PANIC | SLAB_HWCACHE_ALIGN | SLAB_NOTRACK, NULL); -	dwarf_frame_pool = mempool_create(DWARF_FRAME_MIN_REQ, -					  mempool_alloc_slab, -					  mempool_free_slab, -					  dwarf_frame_cachep); +	dwarf_frame_pool = mempool_create_slab_pool(DWARF_FRAME_MIN_REQ, +						    dwarf_frame_cachep);  	if (!dwarf_frame_pool)  		goto out; -	dwarf_reg_pool = mempool_create(DWARF_REG_MIN_REQ, -					 mempool_alloc_slab, -					 mempool_free_slab, -					 dwarf_reg_cachep); +	dwarf_reg_pool = mempool_create_slab_pool(DWARF_REG_MIN_REQ, +						  dwarf_reg_cachep);  	if (!dwarf_reg_pool)  		goto out; | 
