Received: by 2002:a25:ad19:0:0:0:0:0 with SMTP id y25csp2402626ybi; Thu, 18 Jul 2019 07:53:17 -0700 (PDT) X-Google-Smtp-Source: APXvYqxX+B00Z0oVZ9kbZ11kz95W43KmzRNj7WxmhbvDbjnZBCwB97wKz7UVrBI58Op0LNnm3WTG X-Received: by 2002:a17:90a:1ae2:: with SMTP id p89mr48868946pjp.26.1563461597081; Thu, 18 Jul 2019 07:53:17 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1563461597; cv=none; d=google.com; s=arc-20160816; b=Xn0aLpUO07bQ/JuZbB5XHfpWoOefwn93wsypvELzjwhgbusDfkkkSlPCZUKwRru4Wm Mk6MkeN6OZXY6HlIeUnqrr8QaADBc+tPS632b4YnumlpNrRLDV5Ghjv4LF/raaN8tsow 2eHrw5oieCO9D9wEvaM891rR9N4NKPhC5Ebb3Iy3t6DK2YDUkdzCS3il4qzGqwdheobh oTt6B61rVSvEPeI8yCwxFO5foU710UOP5ZpnGKbIF6Hubz6NXJkqIeWL24SkQhfBLxzi E6HUcHtTxAKei4QJ9XFw9kt5NCE+IJ1FgnkFXszOyfDf7Lw4tSrzFadIEmqDWyJrsS2L gEBA== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:content-disposition :content-transfer-encoding:mime-version:robot-unsubscribe:robot-id :git-commit-id:subject:to:references:in-reply-to:reply-to:cc :message-id:from:date:dkim-signature:dkim-filter; bh=A3YdLeuls4rg/UNG7F4whLwwLK+7fliRjPcY2W75YgY=; b=kMhDHiMERVGnoNCUKeygOLT6ByohDwgDRAXSxU5cYaAgQWu5T4EPqNiFPWvDKHKg8N 1ebjXxcXe52dRIsa+qN6KE2OifXQp7EGhYF6CcqRSfrWp6OZY5W5zkbdcNXJkSfQb6Uq iu//RXwVkny2maYJLcJ/+YFOEoYqDIu9SAH7NATjZOUYtDMY7amGmR72fr75/Nh9m9rh BgY+wc/9SZCpBijKONlhL4G3/6WCxc5Hrrps9CmaVsxkVwYZ7tXU5302QdxBvWPPTkyG yDoTXkGsK06oOK6HVZCQ+Adn1qk5DCB7Rl2nEidZRIBHnLzJollddcCv/dyHnOlFZC6J RL+A== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@zytor.com header.s=2019061801 header.b=eJB1Eb8z; 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; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=zytor.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id g7si1287480plb.29.2019.07.18.07.53.00; Thu, 18 Jul 2019 07:53:17 -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=@zytor.com header.s=2019061801 header.b=eJB1Eb8z; 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; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=zytor.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S2390703AbfGROwd (ORCPT + 99 others); Thu, 18 Jul 2019 10:52:33 -0400 Received: from terminus.zytor.com ([198.137.202.136]:41681 "EHLO terminus.zytor.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1727730AbfGROwd (ORCPT ); Thu, 18 Jul 2019 10:52:33 -0400 Received: from terminus.zytor.com (localhost [127.0.0.1]) by terminus.zytor.com (8.15.2/8.15.2) with ESMTPS id x6IEq5jr2033251 (version=TLSv1.3 cipher=TLS_AES_256_GCM_SHA384 bits=256 verify=NO); Thu, 18 Jul 2019 07:52:05 -0700 DKIM-Filter: OpenDKIM Filter v2.11.0 terminus.zytor.com x6IEq5jr2033251 DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=zytor.com; s=2019061801; t=1563461525; bh=A3YdLeuls4rg/UNG7F4whLwwLK+7fliRjPcY2W75YgY=; h=Date:From:Cc:Reply-To:In-Reply-To:References:To:Subject:From; b=eJB1Eb8zpeddDcWz5i6n14kUMN8OmNwZz0vpBcwh11I5q7LzNOYGXgRSf4pc2O1Xa UowH9r1hwVAsPgPQXnUfvXoBoMLKAdalBkiAf+sVElzdO96Lp66hJTKYWDBteWXrd5 FjYSS3XI2BZ6lOxF25akIElrzydTxKz2JiWduR8Z+aD9sci62Yy+4ehQs5rSRjymOx SJJ+EF0m5B+GDKOOFuAy0bzNK8tbTKFzCHhAnROnjsW4u7fPPdXouNEtI3wqHk2Bsp V5DH5kOqNIc56u92L71E0CwdNS3mMQyVkrIeIrTTyJBYCbvOW3MW5NUywVSqBN/lw6 p62Wm/ZglMbww== Received: (from tipbot@localhost) by terminus.zytor.com (8.15.2/8.15.2/Submit) id x6IEq4ba2033246; Thu, 18 Jul 2019 07:52:04 -0700 Date: Thu, 18 Jul 2019 07:52:04 -0700 X-Authentication-Warning: terminus.zytor.com: tipbot set sender to tipbot@zytor.com using -f From: tip-bot for Peter Zijlstra Message-ID: Cc: tglx@linutronix.de, mingo@kernel.org, vegard.nossum@oracle.com, devel@etsukata.com, linux-kernel@vger.kernel.org, hpa@zytor.com, joel@joelfernandes.org, peterz@infradead.org Reply-To: peterz@infradead.org, joel@joelfernandes.org, hpa@zytor.com, linux-kernel@vger.kernel.org, mingo@kernel.org, vegard.nossum@oracle.com, devel@etsukata.com, tglx@linutronix.de In-Reply-To: <20190718085754.GM3402@hirez.programming.kicks-ass.net> References: <20190718085754.GM3402@hirez.programming.kicks-ass.net> To: linux-tip-commits@vger.kernel.org Subject: [tip:core/urgent] stacktrace: Force USER_DS for stack_trace_save_user() Git-Commit-ID: cac9b9a4b08304f11daace03b8b48659355e44c1 X-Mailer: tip-git-log-daemon Robot-ID: Robot-Unsubscribe: Contact to get blacklisted from these emails MIME-Version: 1.0 Content-Transfer-Encoding: 8bit Content-Type: text/plain; charset=UTF-8 Content-Disposition: inline X-Spam-Status: No, score=-0.9 required=5.0 tests=ALL_TRUSTED,BAYES_00, DATE_IN_FUTURE_48_96,DKIM_SIGNED,DKIM_VALID,DKIM_VALID_AU, DKIM_VALID_EF autolearn=no autolearn_force=no version=3.4.2 X-Spam-Checker-Version: SpamAssassin 3.4.2 (2018-09-13) on terminus.zytor.com Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Commit-ID: cac9b9a4b08304f11daace03b8b48659355e44c1 Gitweb: https://git.kernel.org/tip/cac9b9a4b08304f11daace03b8b48659355e44c1 Author: Peter Zijlstra AuthorDate: Thu, 18 Jul 2019 10:47:47 +0200 Committer: Thomas Gleixner CommitDate: Thu, 18 Jul 2019 16:47:24 +0200 stacktrace: Force USER_DS for stack_trace_save_user() When walking userspace stacks, USER_DS needs to be set, otherwise access_ok() will not function as expected. Reported-by: Vegard Nossum Reported-by: Eiichi Tsukata Signed-off-by: Peter Zijlstra (Intel) Signed-off-by: Thomas Gleixner Tested-by: Vegard Nossum Reviewed-by: Joel Fernandes (Google) Link: https://lkml.kernel.org/r/20190718085754.GM3402@hirez.programming.kicks-ass.net --- kernel/stacktrace.c | 5 +++++ 1 file changed, 5 insertions(+) diff --git a/kernel/stacktrace.c b/kernel/stacktrace.c index e6a02b274b73..f5440abb7532 100644 --- a/kernel/stacktrace.c +++ b/kernel/stacktrace.c @@ -226,12 +226,17 @@ unsigned int stack_trace_save_user(unsigned long *store, unsigned int size) .store = store, .size = size, }; + mm_segment_t fs; /* Trace user stack if not a kernel thread */ if (current->flags & PF_KTHREAD) return 0; + fs = get_fs(); + set_fs(USER_DS); arch_stack_walk_user(consume_entry, &c, task_pt_regs(current)); + set_fs(fs); + return c.len; } #endif