Received: by 2002:ac0:a5b6:0:0:0:0:0 with SMTP id m51-v6csp2241311imm; Thu, 7 Jun 2018 07:34:29 -0700 (PDT) X-Google-Smtp-Source: ADUXVKJEUOx4VVQzHVXskreHnAQO1TMksBEWUobKHR5TalWYeUvat391OsADlficzrnuoIjJxwLW X-Received: by 2002:a63:8c10:: with SMTP id m16-v6mr1865194pgd.120.1528382069528; Thu, 07 Jun 2018 07:34:29 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1528382069; cv=none; d=google.com; s=arc-20160816; b=kzqxGBg6b6O7rEjzbNxJePrFU6t2FzsPRqzS+61D1ZR51DlYL9dtL1mhlOmeV4nJiy pMU5Ly6GCrxGxLBaZWLvIfLbKah58f1Fh6lkJrgmt7ba3Q6s7NIuRRGcZddgGyyJRw+r FOurKgXC+hxls8YJk329zistA4FeNGnhqvrqtLz4Gfh+lgnmuLLnvfPLG/QjhZEvdTnk 2Yib39bYYF/Db+UEk30Sk8BO2NTh+SW4azRjGHthNyJg2z2YhZ4yhcDtkwAFigtGBGwi PO2o3qUmgD4ny38vzH6A1exGa0s9xVDEK/W9PTOCCVEL1xoPvGXgGqYnSi6xQGbKn4Uk tnZQ== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:in-reply-to:subject:message-id:date:cc:to :from:mime-version:content-transfer-encoding:content-disposition :arc-authentication-results; bh=fm63OGO4DB1VavI8bsqCjlLLhi1VR8ycUvbYEWYlijo=; b=xTnAFPN0JL0yV2W2Dp5djwH5gYmMd9LaFPQsmvtp9VJhPJGjHzdvv36erJZEwEPQDa xCr5ceZenQ67xN4ZoF8NT//cKt5ZvOmTdNGUQFDSgSMgy/SK2PMt4L4RoicJZ7XUlGRt M3WLvF3spebMsP3TnGjp+1qaTuHAZdFY3Wo/nIG6ce0rQBhZUXY8No3LGpMBDPaUtL4n /B430AnzBY8mvQkN1yRNcU300TsSfjmW1ntrzSe7hdcTJZ2ncOohQHqI3twMLvlL7+l3 kyOEiVnTifLXvB0cTELmImTLmv3N6oUNWPw4U0TUW1i57pwtfm+HVfOrbBdWxDLDRhCQ R5yA== ARC-Authentication-Results: i=1; mx.google.com; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id a143-v6si13834590pfd.258.2018.06.07.07.34.15; Thu, 07 Jun 2018 07:34:29 -0700 (PDT) Received-SPF: pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) client-ip=209.132.180.67; Authentication-Results: mx.google.com; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S933699AbeFGOcQ (ORCPT + 99 others); Thu, 7 Jun 2018 10:32:16 -0400 Received: from shadbolt.e.decadent.org.uk ([88.96.1.126]:40273 "EHLO shadbolt.e.decadent.org.uk" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S932911AbeFGOcN (ORCPT ); Thu, 7 Jun 2018 10:32:13 -0400 Received: from [148.252.241.226] (helo=deadeye) by shadbolt.decadent.org.uk with esmtps (TLS1.2:ECDHE_RSA_AES_256_GCM_SHA384:256) (Exim 4.84_2) (envelope-from ) id 1fQvbg-0005Zp-G9; Thu, 07 Jun 2018 15:09:40 +0100 Received: from ben by deadeye with local (Exim 4.91) (envelope-from ) id 1fQvb6-0002zh-23; Thu, 07 Jun 2018 15:09:04 +0100 Content-Type: text/plain; charset="UTF-8" Content-Disposition: inline Content-Transfer-Encoding: 8bit MIME-Version: 1.0 From: Ben Hutchings To: linux-kernel@vger.kernel.org, stable@vger.kernel.org CC: akpm@linux-foundation.org, "Linus Torvalds" , "Tetsuo Handa" , "Vegard Nossum" , "Michael Kerrisk (man-pages)" , "" , "Al Viro" , "Willy Tarreau" , "Jens Axboe" Date: Thu, 07 Jun 2018 15:05:21 +0100 Message-ID: X-Mailer: LinuxStableQueue (scripts by bwh) Subject: [PATCH 3.16 203/410] pipe: simplify logic in alloc_pipe_info() In-Reply-To: X-SA-Exim-Connect-IP: 148.252.241.226 X-SA-Exim-Mail-From: ben@decadent.org.uk X-SA-Exim-Scanned: No (on shadbolt.decadent.org.uk); SAEximRunCond expanded to false Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org 3.16.57-rc1 review patch. If anyone has any objections, please let me know. ------------------ From: "Michael Kerrisk (man-pages)" commit 09b4d1990094dd22c27fb0163534db419458569c upstream. 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 Reviewed-by: Vegard Nossum Cc: Willy Tarreau Cc: Cc: Tetsuo Handa Cc: Jens Axboe Cc: Al Viro Signed-off-by: Andrew Morton Signed-off-by: Linus Torvalds [bwh: Backported to 3.16: - Don't use GFP_KERNEL_ACCOUNT - Adjust context] Signed-off-by: Ben Hutchings --- --- a/fs/pipe.c +++ b/fs/pipe.c @@ -611,31 +611,34 @@ static bool too_many_pipe_buffers_hard(s struct pipe_inode_info *alloc_pipe_info(void) { struct pipe_inode_info *pipe; + unsigned long pipe_bufs = PIPE_DEF_BUFFERS; + struct user_struct *user = get_current_user(); pipe = kzalloc(sizeof(struct pipe_inode_info), GFP_KERNEL); - if (pipe) { - unsigned long pipe_bufs = PIPE_DEF_BUFFERS; - struct user_struct *user = get_current_user(); + if (pipe == NULL) + goto out_free_uid; - if (!too_many_pipe_buffers_hard(user)) { - if (too_many_pipe_buffers_soft(user)) - pipe_bufs = 1; - pipe->bufs = kzalloc(sizeof(struct pipe_buffer) * pipe_bufs, GFP_KERNEL); - } + if (!too_many_pipe_buffers_hard(user)) { + if (too_many_pipe_buffers_soft(user)) + pipe_bufs = 1; + pipe->bufs = kcalloc(pipe_bufs, + sizeof(struct pipe_buffer), + GFP_KERNEL); + } - if (pipe->bufs) { - init_waitqueue_head(&pipe->wait); - pipe->r_counter = pipe->w_counter = 1; - pipe->buffers = pipe_bufs; - pipe->user = user; - account_pipe_buffers(user, 0, pipe_bufs); - mutex_init(&pipe->mutex); - return pipe; - } - free_uid(user); - kfree(pipe); + if (pipe->bufs) { + init_waitqueue_head(&pipe->wait); + pipe->r_counter = pipe->w_counter = 1; + pipe->buffers = pipe_bufs; + pipe->user = user; + account_pipe_buffers(user, 0, pipe_bufs); + mutex_init(&pipe->mutex); + return pipe; } + kfree(pipe); +out_free_uid: + free_uid(user); return NULL; }