Skip to content

Commit

Permalink
mm/vmalloc.c: use seq_open_private() instead of seq_open()
Browse files Browse the repository at this point in the history
Using seq_open_private() removes boilerplate code from vmalloc_open().

The resultant code is shorter and easier to follow.

However, please note that seq_open_private() call kzalloc() rather than
kmalloc() which may affect timing due to the memory initialisation
overhead.

Signed-off-by: Rob Jones <[email protected]>
Signed-off-by: Andrew Morton <[email protected]>
Signed-off-by: Linus Torvalds <[email protected]>
  • Loading branch information
Rob Jones authored and torvalds committed Oct 10, 2014
1 parent 1c93923 commit 703394c
Showing 1 changed file with 5 additions and 15 deletions.
20 changes: 5 additions & 15 deletions mm/vmalloc.c
Original file line number Diff line number Diff line change
Expand Up @@ -2646,21 +2646,11 @@ static const struct seq_operations vmalloc_op = {

static int vmalloc_open(struct inode *inode, struct file *file)
{
unsigned int *ptr = NULL;
int ret;

if (IS_ENABLED(CONFIG_NUMA)) {
ptr = kmalloc(nr_node_ids * sizeof(unsigned int), GFP_KERNEL);
if (ptr == NULL)
return -ENOMEM;
}
ret = seq_open(file, &vmalloc_op);
if (!ret) {
struct seq_file *m = file->private_data;
m->private = ptr;
} else
kfree(ptr);
return ret;
if (IS_ENABLED(CONFIG_NUMA))
return seq_open_private(file, &vmalloc_op,
nr_node_ids * sizeof(unsigned int));
else
return seq_open(file, &vmalloc_op);
}

static const struct file_operations proc_vmalloc_operations = {
Expand Down

0 comments on commit 703394c

Please sign in to comment.