Received: by 2002:ac0:a582:0:0:0:0:0 with SMTP id m2-v6csp3912734imm; Mon, 8 Oct 2018 11:34:48 -0700 (PDT) X-Google-Smtp-Source: ACcGV62KCYtQOCNAvFubyjR2k5rU6hGIZ9yerZfg4zItDqne79++t+uSd8IRk/G9zuEfFlB6rxnh X-Received: by 2002:a63:7156:: with SMTP id b22-v6mr22053382pgn.342.1539023688385; Mon, 08 Oct 2018 11:34:48 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1539023688; cv=none; d=google.com; s=arc-20160816; b=DmjOk9cHt5/Ih+NuFV+SWpa6ATaZCkbULR3aSUnckmo5WZ8ui2z+HiDbNlRiQf0zED jOsK55YIrsdQANzSNKDaygRxYvFv93P2wNvOc0CCTiPdemIr9Pf7seZJV7g/yzYZOX1c FBaUSJkI8lEAqaty76q251rxjtXBdvsnPm6XqrWd2xuuNT2oQMcu4dBt8rqeS29Dq5P7 /GHRGvcUVjtCDvaikL6YT6KqAQen3J3E1HWlS9gzXr0ibW2ohK7mxac16j6sM4veUk14 un/JKs/Vkt/Rj9s1wvcLiRkVA1xn4h0KTQD+qU0lrj1TsJkXo+5OsOAUDbbNT+0mBIqT q8pQ== 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=WdcuXRYqXWSYoQjVfrjkN4U9wj+NVmSn/8lyh1tT5wE=; b=pmEHbFn2ah7G//7OgaruVvVqJFIqvLtZIaYOxl+97ZiJPbLEauCfWdu3RCSwfGA6FP 3W/b3de6lhs1Oq7N+JSiwJ/Q3klYJ7oBfmUGWg12zuCuHeaTNeO76OMYspXWuFK+bKrV xP91kD7h55gYwznO3cvKq6sO6gqT8GsxL8mCMyuosjeGOyg87YoW9md8W2eDAtzouKaa 6F4mhCVcaIFd+nFHCAJrwAD7Eth6s6jvXGLvd0cfLtEAsW1s1W6vOGbwLr18mxpeMQkj wF2STQqcUzbhvNVb+i251u1QqHRVbgNoPPLxTfOkd0S/bUIr0N7bV2TiM4GsQokSUUb6 Pf3w== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@kernel.org header.s=default header.b=XYFcOrKw; 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 y125-v6si16978544pgb.14.2018.10.08.11.34.33; Mon, 08 Oct 2018 11:34:48 -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; dkim=pass header.i=@kernel.org header.s=default header.b=XYFcOrKw; 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 S1727447AbeJIBq5 (ORCPT + 99 others); Mon, 8 Oct 2018 21:46:57 -0400 Received: from mail.kernel.org ([198.145.29.99]:57378 "EHLO mail.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1727376AbeJIBqx (ORCPT ); Mon, 8 Oct 2018 21:46:53 -0400 Received: from localhost (ip-213-127-77-176.ip.prioritytelecom.net [213.127.77.176]) (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 C95B82089D; Mon, 8 Oct 2018 18:33:50 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=kernel.org; s=default; t=1539023631; bh=GLGdy9ZKzUSAZFitwPHn+YDLaJVF878wgcg81n/HyJY=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=XYFcOrKw1S8ZJjRx336187aheE72X0I4MuxvU9CWPrkhqYQuv0k5fm3DMGY1KTDI4 4POilPXPRXkQQAlnHshGAjTFRu4DMVJ4bGwLJ9UHd9kw3k/XspqBJug/poH3QqLB0u YvlSMS5UF7wvYMh5K/WGbGK86toAE1SaPd3aZi8U= From: Greg Kroah-Hartman To: linux-kernel@vger.kernel.org Cc: Greg Kroah-Hartman , stable@vger.kernel.org, Team OWL337 , Thomas Gleixner , John Stultz , Sasha Levin Subject: [PATCH 4.4 022/113] alarmtimer: Prevent overflow for relative nanosleep Date: Mon, 8 Oct 2018 20:30:23 +0200 Message-Id: <20181008175531.915728942@linuxfoundation.org> X-Mailer: git-send-email 2.19.0 In-Reply-To: <20181008175530.864641368@linuxfoundation.org> References: <20181008175530.864641368@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.4-stable review patch. If anyone has any objections, please let me know. ------------------ From: Thomas Gleixner [ Upstream commit 5f936e19cc0ef97dbe3a56e9498922ad5ba1edef ] Air Icy reported: UBSAN: Undefined behaviour in kernel/time/alarmtimer.c:811:7 signed integer overflow: 1529859276030040771 + 9223372036854775807 cannot be represented in type 'long long int' Call Trace: alarm_timer_nsleep+0x44c/0x510 kernel/time/alarmtimer.c:811 __do_sys_clock_nanosleep kernel/time/posix-timers.c:1235 [inline] __se_sys_clock_nanosleep kernel/time/posix-timers.c:1213 [inline] __x64_sys_clock_nanosleep+0x326/0x4e0 kernel/time/posix-timers.c:1213 do_syscall_64+0xb8/0x3a0 arch/x86/entry/common.c:290 alarm_timer_nsleep() uses ktime_add() to add the current time and the relative expiry value. ktime_add() has no sanity checks so the addition can overflow when the relative timeout is large enough. Use ktime_add_safe() which has the necessary sanity checks in place and limits the result to the valid range. Fixes: 9a7adcf5c6de ("timers: Posix interface for alarm-timers") Reported-by: Team OWL337 Signed-off-by: Thomas Gleixner Cc: John Stultz Link: https://lkml.kernel.org/r/alpine.DEB.2.21.1807020926360.1595@nanos.tec.linutronix.de Signed-off-by: Sasha Levin Signed-off-by: Greg Kroah-Hartman --- kernel/time/alarmtimer.c | 3 ++- 1 file changed, 2 insertions(+), 1 deletion(-) --- a/kernel/time/alarmtimer.c +++ b/kernel/time/alarmtimer.c @@ -773,7 +773,8 @@ static int alarm_timer_nsleep(const cloc /* Convert (if necessary) to absolute time */ if (flags != TIMER_ABSTIME) { ktime_t now = alarm_bases[type].gettime(); - exp = ktime_add(now, exp); + + exp = ktime_add_safe(now, exp); } if (alarmtimer_do_nsleep(&alarm, exp))