mirror of
https://mirrors.bfsu.edu.cn/git/linux.git
synced 2025-01-21 05:14:52 +08:00
mm: vmalloc: refactor vmalloc_dump_obj() function
This patch tends to simplify the function in question, by removing an extra stack "objp" variable, returning back to an early exit approach if spin_trylock() fails or VA was not found. Link: https://lkml.kernel.org/r/20240124180920.50725-2-urezki@gmail.com Signed-off-by: Uladzislau Rezki (Sony) <urezki@gmail.com> Reviewed-by: Lorenzo Stoakes <lstoakes@gmail.com> Cc: Baoquan He <bhe@redhat.com> Cc: Christoph Hellwig <hch@infradead.org> Cc: Dave Chinner <david@fromorbit.com> Cc: Matthew Wilcox (Oracle) <willy@infradead.org> Cc: Oleksiy Avramchenko <oleksiy.avramchenko@sony.com> Signed-off-by: Andrew Morton <akpm@linux-foundation.org>
This commit is contained in:
parent
15e02a39fb
commit
8be4d46e12
33
mm/vmalloc.c
33
mm/vmalloc.c
@ -4696,34 +4696,35 @@ void pcpu_free_vm_areas(struct vm_struct **vms, int nr_vms)
|
||||
#ifdef CONFIG_PRINTK
|
||||
bool vmalloc_dump_obj(void *object)
|
||||
{
|
||||
void *objp = (void *)PAGE_ALIGN((unsigned long)object);
|
||||
const void *caller;
|
||||
struct vm_struct *vm;
|
||||
struct vmap_area *va;
|
||||
struct vmap_node *vn;
|
||||
unsigned long addr;
|
||||
unsigned int nr_pages;
|
||||
bool success = false;
|
||||
|
||||
vn = addr_to_node((unsigned long)objp);
|
||||
addr = PAGE_ALIGN((unsigned long) object);
|
||||
vn = addr_to_node(addr);
|
||||
|
||||
if (spin_trylock(&vn->busy.lock)) {
|
||||
va = __find_vmap_area((unsigned long)objp, &vn->busy.root);
|
||||
|
||||
if (va && va->vm) {
|
||||
addr = (unsigned long)va->vm->addr;
|
||||
caller = va->vm->caller;
|
||||
nr_pages = va->vm->nr_pages;
|
||||
success = true;
|
||||
}
|
||||
if (!spin_trylock(&vn->busy.lock))
|
||||
return false;
|
||||
|
||||
va = __find_vmap_area(addr, &vn->busy.root);
|
||||
if (!va || !va->vm) {
|
||||
spin_unlock(&vn->busy.lock);
|
||||
return false;
|
||||
}
|
||||
|
||||
if (success)
|
||||
pr_cont(" %u-page vmalloc region starting at %#lx allocated at %pS\n",
|
||||
nr_pages, addr, caller);
|
||||
vm = va->vm;
|
||||
addr = (unsigned long) vm->addr;
|
||||
caller = vm->caller;
|
||||
nr_pages = vm->nr_pages;
|
||||
spin_unlock(&vn->busy.lock);
|
||||
|
||||
return success;
|
||||
pr_cont(" %u-page vmalloc region starting at %#lx allocated at %pS\n",
|
||||
nr_pages, addr, caller);
|
||||
|
||||
return true;
|
||||
}
|
||||
#endif
|
||||
|
||||
|
Loading…
Reference in New Issue
Block a user