Commit 3000f2e2 authored by Paolo Bonzini's avatar Paolo Bonzini

mm: use vmalloc_array and vcalloc for array allocations

Instead of using array_size or just a multiply, use a function that
takes care of both the multiplication and the overflow checks.
Acked-by: default avatarMichal Hocko <mhocko@suse.com>
Signed-off-by: default avatarPaolo Bonzini <pbonzini@redhat.com>
parent a8749a35
...@@ -144,7 +144,7 @@ static int percpu_stats_show(struct seq_file *m, void *v) ...@@ -144,7 +144,7 @@ static int percpu_stats_show(struct seq_file *m, void *v)
spin_unlock_irq(&pcpu_lock); spin_unlock_irq(&pcpu_lock);
/* there can be at most this many free and allocated fragments */ /* there can be at most this many free and allocated fragments */
buffer = vmalloc(array_size(sizeof(int), (2 * max_nr_alloc + 1))); buffer = vmalloc_array(2 * max_nr_alloc + 1, sizeof(int));
if (!buffer) if (!buffer)
return -ENOMEM; return -ENOMEM;
......
...@@ -167,14 +167,12 @@ unsigned short lookup_swap_cgroup_id(swp_entry_t ent) ...@@ -167,14 +167,12 @@ unsigned short lookup_swap_cgroup_id(swp_entry_t ent)
int swap_cgroup_swapon(int type, unsigned long max_pages) int swap_cgroup_swapon(int type, unsigned long max_pages)
{ {
void *array; void *array;
unsigned long array_size;
unsigned long length; unsigned long length;
struct swap_cgroup_ctrl *ctrl; struct swap_cgroup_ctrl *ctrl;
length = DIV_ROUND_UP(max_pages, SC_PER_PAGE); length = DIV_ROUND_UP(max_pages, SC_PER_PAGE);
array_size = length * sizeof(void *);
array = vzalloc(array_size); array = vcalloc(length, sizeof(void *));
if (!array) if (!array)
goto nomem; goto nomem;
......
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