Received: by 2002:a25:1985:0:0:0:0:0 with SMTP id 127csp690605ybz; Fri, 1 May 2020 06:53:51 -0700 (PDT) X-Google-Smtp-Source: APiQypLJYgCCJoKEE8vW5+t354ImgNz4bivJfRwFSVuVn4Hxi7V8b9q/In1BgkRsO0gRaXkq+PP2 X-Received: by 2002:a17:906:f106:: with SMTP id gv6mr3339508ejb.271.1588341231556; Fri, 01 May 2020 06:53:51 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1588341231; cv=none; d=google.com; s=arc-20160816; b=Ux27rAs5yN2au81i/JjuKeUclF2ieonKWWwGI6OKDHt0jT+QwyPfPwArKGvgW+Mk55 85cAs/RQDejZi5uDOLVfrQZpn033rDThP5pxRghWL4toMAH4H+M51USp1T5+MXrTBtNC VdznhgqvsLVN8tJtcnHbWjWjaJ5qKYfDpa0ysE649zju8T/BT5nWn9kLEGk6453QSn4T SRdbXzsW2XKmEZCveMa+QfCtLMDMTfASr8UQ4e/Sa6/S1sY6szYvfEdnFz68cmEAGnW6 adPb14urrPGDIXbHqjz2T85hSQ7iunKPjiXUFFW2lZHc3HZDLvn4RR9vCjhAyEPHfXYB wgJA== 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=hulEpRBbZzmb4De2mQgtuqqx5EoLUkgWqy+1wISj8h8=; b=dU55R5WEYjNu4K3jry/FBz8Gz52kYtfzHdZ+J6AWEy/FBwo1VdAqF3iHuOK/xLZzar ADjwY6fTeadpSKR0dFxTCY13FPVqMYEvRDhohbWVWaDQWX3nmKW+N2ZC3/oVLn1ir3me X0ttvepXp6r3NZB6KqqEHwOAzaQmkB71EaEWpITNQFuBDgcekbiEXewwoWMzRy6DAMxb A2PSToJBHZaM0MEHTyYvqfr/s8va5TjzkhzXCyfdTaF8KQqhU8TvyK1Dxya19ou712ZI LYkHJpeDiYEgteCk56byUuF/DZhP7jr8QW/YPrk1Ts/z31DqmCgZbJy1kJoMc12Y5ERZ XxxQ== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@kernel.org header.s=default header.b=yYOinUR7; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id g26si1610984edu.55.2020.05.01.06.53.28; Fri, 01 May 2020 06:53:51 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) client-ip=23.128.96.18; Authentication-Results: mx.google.com; dkim=pass header.i=@kernel.org header.s=default header.b=yYOinUR7; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1731093AbgEANvf (ORCPT + 99 others); Fri, 1 May 2020 09:51:35 -0400 Received: from mail.kernel.org ([198.145.29.99]:38058 "EHLO mail.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1730772AbgEANic (ORCPT ); Fri, 1 May 2020 09:38:32 -0400 Received: from localhost (83-86-89-107.cable.dynamic.v4.ziggo.nl [83.86.89.107]) (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 C17912173E; Fri, 1 May 2020 13:38:31 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=kernel.org; s=default; t=1588340312; bh=CKIMJQM3BUgv/kNo+zVhPYPGAjCSUM4KvYD2NODQKhk=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=yYOinUR7FAYWBey5qBSmlaXl/AUJ0gJiHnl35mjtV2rtuZ0xUpYqrPxyIhAEIb+O4 FRf+2S2zeyNN1CyiDVFR5mMOCmfZI1Jjeoae3Y+z2jK0X+Fzuh7cYbfVXwbh9BSqGP RrSFH4qGrFhaRA/Q7AvnLjcJFFdU0HlgWWe69W/s= From: Greg Kroah-Hartman To: linux-kernel@vger.kernel.org Cc: Greg Kroah-Hartman , stable@vger.kernel.org, Philipp Rudo , Vasily Gorbik Subject: [PATCH 5.4 14/83] s390/ftrace: fix potential crashes when switching tracers Date: Fri, 1 May 2020 15:22:53 +0200 Message-Id: <20200501131527.389876682@linuxfoundation.org> X-Mailer: git-send-email 2.26.2 In-Reply-To: <20200501131524.004332640@linuxfoundation.org> References: <20200501131524.004332640@linuxfoundation.org> User-Agent: quilt/0.66 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 From: Philipp Rudo commit 8ebf6da9db1b2a20bb86cc1bee2552e894d03308 upstream. Switching tracers include instruction patching. To prevent that a instruction is patched while it's read the instruction patching is done in stop_machine 'context'. This also means that any function called during stop_machine must not be traced. Thus add 'notrace' to all functions called within stop_machine. Fixes: 1ec2772e0c3c ("s390/diag: add a statistic for diagnose calls") Fixes: 38f2c691a4b3 ("s390: improve wait logic of stop_machine") Fixes: 4ecf0a43e729 ("processor: get rid of cpu_relax_yield") Signed-off-by: Philipp Rudo Signed-off-by: Vasily Gorbik Signed-off-by: Greg Kroah-Hartman --- arch/s390/kernel/diag.c | 2 +- arch/s390/kernel/smp.c | 4 ++-- arch/s390/kernel/trace.c | 2 +- 3 files changed, 4 insertions(+), 4 deletions(-) --- a/arch/s390/kernel/diag.c +++ b/arch/s390/kernel/diag.c @@ -133,7 +133,7 @@ void diag_stat_inc(enum diag_stat_enum n } EXPORT_SYMBOL(diag_stat_inc); -void diag_stat_inc_norecursion(enum diag_stat_enum nr) +void notrace diag_stat_inc_norecursion(enum diag_stat_enum nr) { this_cpu_inc(diag_stat.counter[nr]); trace_s390_diagnose_norecursion(diag_map[nr].code); --- a/arch/s390/kernel/smp.c +++ b/arch/s390/kernel/smp.c @@ -403,7 +403,7 @@ int smp_find_processor_id(u16 address) return -1; } -bool arch_vcpu_is_preempted(int cpu) +bool notrace arch_vcpu_is_preempted(int cpu) { if (test_cpu_flag_of(CIF_ENABLED_WAIT, cpu)) return false; @@ -413,7 +413,7 @@ bool arch_vcpu_is_preempted(int cpu) } EXPORT_SYMBOL(arch_vcpu_is_preempted); -void smp_yield_cpu(int cpu) +void notrace smp_yield_cpu(int cpu) { if (MACHINE_HAS_DIAG9C) { diag_stat_inc_norecursion(DIAG_STAT_X09C); --- a/arch/s390/kernel/trace.c +++ b/arch/s390/kernel/trace.c @@ -14,7 +14,7 @@ EXPORT_TRACEPOINT_SYMBOL(s390_diagnose); static DEFINE_PER_CPU(unsigned int, diagnose_trace_depth); -void trace_s390_diagnose_norecursion(int diag_nr) +void notrace trace_s390_diagnose_norecursion(int diag_nr) { unsigned long flags; unsigned int *depth;