Received: by 2002:ac0:a5b6:0:0:0:0:0 with SMTP id m51-v6csp2270932imm; Thu, 7 Jun 2018 08:01:23 -0700 (PDT) X-Google-Smtp-Source: ADUXVKKThsNOgSlMmmayj084YoUSScoOeHGQnb9H8v6ENR4u/FBYaQZ/Lw7lxGJmcTYbN4T7rNer X-Received: by 2002:a63:12:: with SMTP id 18-v6mr1925436pga.121.1528383683891; Thu, 07 Jun 2018 08:01:23 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1528383683; cv=none; d=google.com; s=arc-20160816; b=hC3gRo+XWnYrGlBKn+ar82ye76u4TDju2+UNse6vUXFumMYTEtuAvwhPJBxJevcAb1 jY4pWrfVsX9r0r5ytx8g88tI3h/fAcLITCqbzVnIato+pBtSuJaDSbzUlP8doNVC5dRn lMWoBgAsJerhehAedwXomAmsnVQ98TLrkHfAwadFielKRlkme8Vv1L3CjY3w4A+uUaa4 XSBLpreozedAMWgenc6jbeEGV/07MuSYfpjKDZOUDHaZad13Fy8eqNmgawwQTI9Ot+FO IJaO3pzqrSPKOPSOWJCRi0qD2ZZduJV5zoq3kDGGie83nWJ9tFmtmcgjn5dAXP5bCzPe F/gQ== 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=BOKRZDvUQBPm5qnuyjPBMXFCsd8kPo8rqMfWTne7TYQ=; b=NrgsKjnVPmoVR6hIL8NJi/a/DvDE+UxYl4LMmTivi9jXNZHWm2nwDcFn3HkDQWrF1k rBnytXQhpGSd1AvlXkUB5qPeHz1QTUtqC16scn+rEVPVwXDMpDqDJY+H98kt1n0l44xI KLGZyTklN2wBrd+KvHyJcst1GinHD9yP+6L145le8Ddrpx+Yq8/b4EM4djeP3HPRQJPx e+1+FwH5wVNT+syxGu63VF7Q3md9kz75OR4yJODUNYF3YDXDNJRcMQe1+Dr3W54toi0D pm9FUatE/4N5ZDbcaB8ZlcNULI8SUgBKTOWzVvNU/56IWBWQP8AzKz9a8qnTV8kDeVPt hYZQ== 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 64-v6si38499204plk.33.2018.06.07.08.01.08; Thu, 07 Jun 2018 08:01:23 -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 S935786AbeFGPAL (ORCPT + 99 others); Thu, 7 Jun 2018 11:00:11 -0400 Received: from shadbolt.e.decadent.org.uk ([88.96.1.126]:41327 "EHLO shadbolt.e.decadent.org.uk" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S935764AbeFGPAH (ORCPT ); Thu, 7 Jun 2018 11:00:07 -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-0005Zq-P9; Thu, 07 Jun 2018 15:09:40 +0100 Received: from ben by deadeye with local (Exim 4.91) (envelope-from ) id 1fQvb6-00031m-K9; 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, "Michael Kerrisk" , "Kees Cook" , "Mikulas Patocka" , "Eric Biggers" , "Joe Lawrence" , "Willy Tarreau" , "Alexander Viro" , "Luis R . Rodriguez" , "Linus Torvalds" Date: Thu, 07 Jun 2018 15:05:21 +0100 Message-ID: X-Mailer: LinuxStableQueue (scripts by bwh) Subject: [PATCH 3.16 214/410] pipe: reject F_SETPIPE_SZ with size over UINT_MAX 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: Eric Biggers commit 96e99be40e4cff870a83233731121ec0f7f95075 upstream. A pipe's size is represented as an 'unsigned int'. As expected, writing a value greater than UINT_MAX to /proc/sys/fs/pipe-max-size fails with EINVAL. However, the F_SETPIPE_SZ fcntl silently truncates such values to 32 bits, rather than failing with EINVAL as expected. (It *does* fail with EINVAL for values above (1 << 31) but <= UINT_MAX.) Fix this by moving the check against UINT_MAX into round_pipe_size() which is called in both cases. Link: http://lkml.kernel.org/r/20180111052902.14409-6-ebiggers3@gmail.com Signed-off-by: Eric Biggers Acked-by: Kees Cook Acked-by: Joe Lawrence Cc: Alexander Viro Cc: "Luis R . Rodriguez" Cc: Michael Kerrisk Cc: Mikulas Patocka Cc: Willy Tarreau Signed-off-by: Andrew Morton Signed-off-by: Linus Torvalds Signed-off-by: Ben Hutchings --- fs/pipe.c | 5 ++++- include/linux/pipe_fs_i.h | 2 +- kernel/sysctl.c | 3 --- 3 files changed, 5 insertions(+), 5 deletions(-) --- a/fs/pipe.c +++ b/fs/pipe.c @@ -1008,10 +1008,13 @@ const struct file_operations pipefifo_fo * Currently we rely on the pipe array holding a power-of-2 number * of pages. Returns 0 on error. */ -unsigned int round_pipe_size(unsigned int size) +unsigned int round_pipe_size(unsigned long size) { unsigned long nr_pages; + if (size > UINT_MAX) + return 0; + /* Minimum pipe size, as required by POSIX */ if (size < PAGE_SIZE) size = PAGE_SIZE; --- a/include/linux/pipe_fs_i.h +++ b/include/linux/pipe_fs_i.h @@ -148,6 +148,6 @@ long pipe_fcntl(struct file *, unsigned struct pipe_inode_info *get_pipe_info(struct file *file); int create_pipe_files(struct file **, int); -unsigned int round_pipe_size(unsigned int size); +unsigned int round_pipe_size(unsigned long size); #endif --- a/kernel/sysctl.c +++ b/kernel/sysctl.c @@ -2230,9 +2230,6 @@ static int do_proc_dopipe_max_size_conv( if (write) { unsigned int val; - if (*lvalp > UINT_MAX) - return -EINVAL; - val = round_pipe_size(*lvalp); if (*negp || val == 0) return -EINVAL;