Received: by 2002:ad5:474a:0:0:0:0:0 with SMTP id i10csp38724imu; Thu, 8 Nov 2018 14:21:22 -0800 (PST) X-Google-Smtp-Source: AJdET5e/LaeIIW0PZ2gbDQzG0o/78YvvIuHEsU0HEb/ULXYUjEYjG0kAgSHnWp9oudzHfWuHH1tE X-Received: by 2002:a62:1896:: with SMTP id 144-v6mr6578585pfy.88.1541715682452; Thu, 08 Nov 2018 14:21:22 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1541715682; cv=none; d=google.com; s=arc-20160816; b=kPzQC8fX9TxFGLOYT50G1PZb4rJZ5QeXrzXEN1gjkOrIkddCtd8nwFC+a3EkERZ7iA WE6DCJmeQz4mIG4XXc8NoclYMSR5XJKySmEa6HcWhc1z8ppl8/OUq/4Ss/4ywxNwvbk2 hw1IAD1jusw7vZ4mZtvnNbaFVcQ8n+6/QTzA+YQv1koXJQ6ictdDNGPN7CG8eJZBeHuB kS80yrmqoFkzIcJxNOSVDCtTAeASR8DCmZxJyF8Szg5l2VbHfYDP0bAAsZfBYhzXWSGu aNegw8F4IZyvhN3Ni5xp78NePNkJjkAGsHSVxfZrk8ywDaIhHlkE+lTCpi+Jn3dTIZ4S xFig== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:content-transfer-encoding:mime-version :user-agent:references:in-reply-to:message-id:date:subject:cc:to :from:dkim-signature; bh=UgAgN+d/q/zoMbmUM1IzJ8a8bSxfQ3mvUUUTl65Ftss=; b=jQuarXtza9H8/yMS+RPiZowXmm+04fcDshx1zTwn0Od+7/Ovoj+SoRQpxX0s7fbfEB xUr9c3/EJLUO+gkYIW/wGpnA/kGvwldVtpkcv+nI5Or2STWvxEhNPOPRmTf008aCS9WH yN+cBt7BcY0BZ5GYnV+srcpLCGV2I3bj6lp/7bwRPOtxmkl+zt4HFyoYQEaULNPQqJYS gcq+QX45h63R3t75mw1443r5HF5/lN/E8UwAEhx4lhggax06le5wrugvQqnyN1qP2BMs iESqEUJtVOcLx1+D2Qrx11eSlO/EWs0aXRfKyggIbwvndeDEPxk4WDWWTPR2VPUwwn+t KKxQ== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@kernel.org header.s=default header.b=uQXv42RZ; 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 o13-v6si4574971pgh.61.2018.11.08.14.21.07; Thu, 08 Nov 2018 14:21:22 -0800 (PST) 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; dkim=pass header.i=@kernel.org header.s=default header.b=uQXv42RZ; 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 S1730683AbeKIH6Q (ORCPT + 99 others); Fri, 9 Nov 2018 02:58:16 -0500 Received: from mail.kernel.org ([198.145.29.99]:35940 "EHLO mail.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1731810AbeKIHn3 (ORCPT ); Fri, 9 Nov 2018 02:43:29 -0500 Received: from localhost (unknown [208.72.13.198]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by mail.kernel.org (Postfix) with ESMTPSA id 8D43D21486; Thu, 8 Nov 2018 22:05:58 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=kernel.org; s=default; t=1541714758; bh=jDON1sgSOcYrYzARQpO+bZvm86jldaAIlVL84cMwr78=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=uQXv42RZ/iS5SL+ET2+cz24ZMAML1f68WOuSs6kCmULIRFr+Em5A/xxLRTjiI4Cx1 /pmWqHiqOc7r9mJGUKh7RgCqfjjYQRYZNYebegOdDSQib9Z+7jcSrx8qOtt7F63wsh yCIoItTvzD8DgDKFEifpkcjQP3yj/ow/SlYlfKYs= From: Greg Kroah-Hartman To: linux-kernel@vger.kernel.org Cc: Greg Kroah-Hartman , stable@vger.kernel.org, Jiri Slaby , Ingo Molnar , Peter Zijlstra , Darren Hart , Linus Torvalds , Sasha Levin Subject: [PATCH 4.9 111/171] futex: futex_wake_op, do not fail on invalid op Date: Thu, 8 Nov 2018 13:51:21 -0800 Message-Id: <20181108215135.344756191@linuxfoundation.org> X-Mailer: git-send-email 2.19.1 In-Reply-To: <20181108215127.257643509@linuxfoundation.org> References: <20181108215127.257643509@linuxfoundation.org> User-Agent: quilt/0.65 X-stable: review MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org 4.9-stable review patch. If anyone has any objections, please let me know. ------------------ [ Upstream commit e78c38f6bdd900b2ad9ac9df8eff58b745dc5b3c ] In commit 30d6e0a4190d ("futex: Remove duplicated code and fix undefined behaviour"), I let FUTEX_WAKE_OP to fail on invalid op. Namely when op should be considered as shift and the shift is out of range (< 0 or > 31). But strace's test suite does this madness: futex(0x7fabd78bcffc, 0x5, 0xfacefeed, 0xb, 0x7fabd78bcffc, 0xa0caffee); futex(0x7fabd78bcffc, 0x5, 0xfacefeed, 0xb, 0x7fabd78bcffc, 0xbadfaced); futex(0x7fabd78bcffc, 0x5, 0xfacefeed, 0xb, 0x7fabd78bcffc, 0xffffffff); When I pick the first 0xa0caffee, it decodes as: 0x80000000 & 0xa0caffee: oparg is shift 0x70000000 & 0xa0caffee: op is FUTEX_OP_OR 0x0f000000 & 0xa0caffee: cmp is FUTEX_OP_CMP_EQ 0x00fff000 & 0xa0caffee: oparg is sign-extended 0xcaf = -849 0x00000fff & 0xa0caffee: cmparg is sign-extended 0xfee = -18 That means the op tries to do this: (futex |= (1 << (-849))) == -18 which is completely bogus. The new check of op in the code is: if (encoded_op & (FUTEX_OP_OPARG_SHIFT << 28)) { if (oparg < 0 || oparg > 31) return -EINVAL; oparg = 1 << oparg; } which results obviously in the "Invalid argument" errno: FAIL: futex =========== futex(0x7fabd78bcffc, 0x5, 0xfacefeed, 0xb, 0x7fabd78bcffc, 0xa0caffee) = -1: Invalid argument futex.test: failed test: ../futex failed with code 1 So let us soften the failure to print only a (ratelimited) message, crop the value and continue as if it were right. When userspace keeps up, we can switch this to return -EINVAL again. [v2] Do not return 0 immediatelly, proceed with the cropped value. Fixes: 30d6e0a4190d ("futex: Remove duplicated code and fix undefined behaviour") Signed-off-by: Jiri Slaby Cc: Ingo Molnar Cc: Peter Zijlstra Cc: Darren Hart Signed-off-by: Linus Torvalds Signed-off-by: Sasha Levin --- kernel/futex.c | 12 ++++++++++-- 1 file changed, 10 insertions(+), 2 deletions(-) diff --git a/kernel/futex.c b/kernel/futex.c index c3ea6f2a6997..053d7be08be5 100644 --- a/kernel/futex.c +++ b/kernel/futex.c @@ -1467,8 +1467,16 @@ static int futex_atomic_op_inuser(unsigned int encoded_op, u32 __user *uaddr) int oldval, ret; if (encoded_op & (FUTEX_OP_OPARG_SHIFT << 28)) { - if (oparg < 0 || oparg > 31) - return -EINVAL; + if (oparg < 0 || oparg > 31) { + char comm[sizeof(current->comm)]; + /* + * kill this print and return -EINVAL when userspace + * is sane again + */ + pr_info_ratelimited("futex_wake_op: %s tries to shift op by %d; fix this program\n", + get_task_comm(comm, current), oparg); + oparg &= 31; + } oparg = 1 << oparg; } -- 2.17.1