diff options
author | Michael Kerrisk (man-pages) <mtk.manpages@gmail.com> | 2016-10-11 16:53:34 -0400 |
---|---|---|
committer | Linus Torvalds <torvalds@linux-foundation.org> | 2016-10-11 18:06:32 -0400 |
commit | 09b4d1990094dd22c27fb0163534db419458569c (patch) | |
tree | e01eedf92ae4880800cdf515f3bda8a5177c56f6 | |
parent | b0b91d18e2e97b741b294af9333824ecc3fadfd8 (diff) |
pipe: simplify logic in alloc_pipe_info()
Replace an 'if' block that covers most of the code in this function
with a 'goto'. This makes the code a little simpler to read, and also
simplifies the next patch (fix limit checking in alloc_pipe_info())
Link: http://lkml.kernel.org/r/aef030c1-0257-98a9-4988-186efa48530c@gmail.com
Signed-off-by: Michael Kerrisk <mtk.manpages@gmail.com>
Reviewed-by: Vegard Nossum <vegard.nossum@oracle.com>
Cc: Willy Tarreau <w@1wt.eu>
Cc: <socketpair@gmail.com>
Cc: Tetsuo Handa <penguin-kernel@I-love.SAKURA.ne.jp>
Cc: Jens Axboe <axboe@fb.com>
Cc: Al Viro <viro@zeniv.linux.org.uk>
Signed-off-by: Andrew Morton <akpm@linux-foundation.org>
Signed-off-by: Linus Torvalds <torvalds@linux-foundation.org>
-rw-r--r-- | fs/pipe.c | 45 |
1 files changed, 23 insertions, 22 deletions
@@ -622,33 +622,34 @@ static bool too_many_pipe_buffers_hard(struct user_struct *user) | |||
622 | struct pipe_inode_info *alloc_pipe_info(void) | 622 | struct pipe_inode_info *alloc_pipe_info(void) |
623 | { | 623 | { |
624 | struct pipe_inode_info *pipe; | 624 | struct pipe_inode_info *pipe; |
625 | unsigned long pipe_bufs = PIPE_DEF_BUFFERS; | ||
626 | struct user_struct *user = get_current_user(); | ||
625 | 627 | ||
626 | pipe = kzalloc(sizeof(struct pipe_inode_info), GFP_KERNEL_ACCOUNT); | 628 | pipe = kzalloc(sizeof(struct pipe_inode_info), GFP_KERNEL_ACCOUNT); |
627 | if (pipe) { | 629 | if (pipe == NULL) |
628 | unsigned long pipe_bufs = PIPE_DEF_BUFFERS; | 630 | goto out_free_uid; |
629 | struct user_struct *user = get_current_user(); | 631 | |
630 | 632 | if (!too_many_pipe_buffers_hard(user)) { | |
631 | if (!too_many_pipe_buffers_hard(user)) { | 633 | if (too_many_pipe_buffers_soft(user)) |
632 | if (too_many_pipe_buffers_soft(user)) | 634 | pipe_bufs = 1; |
633 | pipe_bufs = 1; | 635 | pipe->bufs = kcalloc(pipe_bufs, |
634 | pipe->bufs = kcalloc(pipe_bufs, | 636 | sizeof(struct pipe_buffer), |
635 | sizeof(struct pipe_buffer), | 637 | GFP_KERNEL_ACCOUNT); |
636 | GFP_KERNEL_ACCOUNT); | 638 | } |
637 | } | ||
638 | 639 | ||
639 | if (pipe->bufs) { | 640 | if (pipe->bufs) { |
640 | init_waitqueue_head(&pipe->wait); | 641 | init_waitqueue_head(&pipe->wait); |
641 | pipe->r_counter = pipe->w_counter = 1; | 642 | pipe->r_counter = pipe->w_counter = 1; |
642 | pipe->buffers = pipe_bufs; | 643 | pipe->buffers = pipe_bufs; |
643 | pipe->user = user; | 644 | pipe->user = user; |
644 | account_pipe_buffers(user, 0, pipe_bufs); | 645 | account_pipe_buffers(user, 0, pipe_bufs); |
645 | mutex_init(&pipe->mutex); | 646 | mutex_init(&pipe->mutex); |
646 | return pipe; | 647 | return pipe; |
647 | } | ||
648 | free_uid(user); | ||
649 | kfree(pipe); | ||
650 | } | 648 | } |
651 | 649 | ||
650 | kfree(pipe); | ||
651 | out_free_uid: | ||
652 | free_uid(user); | ||
652 | return NULL; | 653 | return NULL; |
653 | } | 654 | } |
654 | 655 | ||