mirror of
https://github.com/torvalds/linux.git
synced 2026-06-08 14:42:37 +02:00
vmalloc: conditionalize build of pcpu_get_vm_areas()
No matching upstream commit as it was resolved differently there. pcpu_get_vm_areas() is used only when dynamic percpu allocator is used by the architecture. In 2.6.32, ia64 doesn't use dynamic percpu allocator and has a macro which makes pcpu_get_vm_areas() buggy via local/global variable aliasing and triggers compile warning. The problem is fixed in upstream and ia64 uses dynamic percpu allocators, so the only left issue is inclusion of unnecessary code and compile warning on ia64 on 2.6.32. Don't build pcpu_get_vm_areas() if legacy percpu allocator is in use. Signed-off-by: Tejun Heo <tj@kernel.org> Reported-by: Jan Beulich <JBeulich@novell.com> Signed-off-by: Greg Kroah-Hartman <gregkh@suse.de>
This commit is contained in:
parent
f996ff1a93
commit
f0cc8412be
|
|
@ -115,9 +115,11 @@ extern rwlock_t vmlist_lock;
|
|||
extern struct vm_struct *vmlist;
|
||||
extern __init void vm_area_register_early(struct vm_struct *vm, size_t align);
|
||||
|
||||
#ifndef CONFIG_HAVE_LEGACY_PER_CPU_AREA
|
||||
struct vm_struct **pcpu_get_vm_areas(const unsigned long *offsets,
|
||||
const size_t *sizes, int nr_vms,
|
||||
size_t align, gfp_t gfp_mask);
|
||||
#endif
|
||||
|
||||
void pcpu_free_vm_areas(struct vm_struct **vms, int nr_vms);
|
||||
|
||||
|
|
|
|||
|
|
@ -1993,6 +1993,7 @@ void free_vm_area(struct vm_struct *area)
|
|||
}
|
||||
EXPORT_SYMBOL_GPL(free_vm_area);
|
||||
|
||||
#ifndef CONFIG_HAVE_LEGACY_PER_CPU_AREA
|
||||
static struct vmap_area *node_to_va(struct rb_node *n)
|
||||
{
|
||||
return n ? rb_entry(n, struct vmap_area, rb_node) : NULL;
|
||||
|
|
@ -2257,6 +2258,7 @@ struct vm_struct **pcpu_get_vm_areas(const unsigned long *offsets,
|
|||
kfree(vms);
|
||||
return NULL;
|
||||
}
|
||||
#endif
|
||||
|
||||
/**
|
||||
* pcpu_free_vm_areas - free vmalloc areas for percpu allocator
|
||||
|
|
|
|||
Loading…
Reference in New Issue
Block a user