Received: by 2002:a25:31c3:0:0:0:0:0 with SMTP id x186csp4492883ybx; Mon, 4 Nov 2019 14:19:30 -0800 (PST) X-Google-Smtp-Source: APXvYqxScqyOiYsad8ETNXmlfuwH0OjY32ZMQM6IFWpx2Y16KjQ2c7dj1ZFb7/7Q9DLuUSIWU830 X-Received: by 2002:a50:cb86:: with SMTP id k6mr32510817edi.270.1572905970018; Mon, 04 Nov 2019 14:19:30 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1572905970; cv=none; d=google.com; s=arc-20160816; b=s9cG+nZ3Hv2nTEy4bJ+eKt47qvhWID30Ve7maW6gipK0BGl9fMMHLkpbvnpE1gAZmD n0FYkbWMRs8x2aw/DxQoLuK2a6k2P6fD/S/OhwTFUSQc9aRJ994v/oO0V6YZ8BHinwVA h9lu+XmADxTTMgIh8NDxYiHBKSQkMBDExT+7NvmVt8a4sAq4uTOLsg2ISCehZ5Hy7Uui xkxV+NXLEE7cERE4lt5VJjQ1JoL7H/wZzQfPCbBUfsLhe4y8fRmH4/O1M4lDoIgXXfMo u010XZVs4REqNp1sCl6mNxvbuixIvLZtnt4MozkoQNRUtm5gdBXBxBmUY2Ttes4wjUwo m9Ig== 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=sanYGR0dhabW0XA4Cc6Rm99Nq7lhMM6nfWgymdOdjI4=; b=B+jRbbhGWRgyV3i4PUMBE3g28lw4JsSaT5mwDlH6T2NpeDy94bmW7jQokQvxAmfVSs qkhRWQrCrVpYGtipgPHJE+UWfBrDfR5q0KM4wr99KnQXXwTIXKzu2PLLFO94hqCcf1hy /dnCCvDt6+4IFB5+EO6no0tE/Xo6EIq9Regfu3Z+d6b6IJxz7DgzH+KhhHtwB2Oag8hX dQRnrnAtVBmRh1yjaG1tOCnAN4Waj43VHlNOZN0+/rTDSwipxuFtLsAPzqfOQKnJLNpR 2kfe1+E/bS7TCsDBCx9pbX/AboSl4qpxFeINEsE7SBkvYCmpzqZBgZXDaPeg6bfVvEJA SZZg== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@kernel.org header.s=default header.b=MiFSTxde; 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 e56si8285606edb.355.2019.11.04.14.19.07; Mon, 04 Nov 2019 14:19:30 -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=MiFSTxde; 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 S2389629AbfKDWSh (ORCPT + 99 others); Mon, 4 Nov 2019 17:18:37 -0500 Received: from mail.kernel.org ([198.145.29.99]:59874 "EHLO mail.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S2388702AbfKDWBo (ORCPT ); Mon, 4 Nov 2019 17:01:44 -0500 Received: from localhost (6.204-14-84.ripe.coltfrance.com [84.14.204.6]) (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 0659D20659; Mon, 4 Nov 2019 22:01:42 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=kernel.org; s=default; t=1572904903; bh=LcmmwqOfby9yq1vOo2ElJ9bV8e0u3vySwHKazDJYZaE=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=MiFSTxdetVBC2dS1szYPLBkHExeZy5tG6DmYXT8o7yll5lbkOnPEBqAVNtAd/ZIIb dBcE3jenGcEA17Y+S8iFofCtVe2ZTWdFUnSQsff3apXQvYPYmqKnBW/Al/ZMEhEjOC V7cMPv/bNsmbI4bd4i6zS8+/KVIv8f4L1jCPsvvM= From: Greg Kroah-Hartman To: linux-kernel@vger.kernel.org Cc: Greg Kroah-Hartman , stable@vger.kernel.org, James Dingwall , Boris Ostrovsky , Juergen Gross , Sasha Levin Subject: [PATCH 4.19 084/149] x86/xen: Return from panic notifier Date: Mon, 4 Nov 2019 22:44:37 +0100 Message-Id: <20191104212142.465088911@linuxfoundation.org> X-Mailer: git-send-email 2.23.0 In-Reply-To: <20191104212126.090054740@linuxfoundation.org> References: <20191104212126.090054740@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: Boris Ostrovsky [ Upstream commit c6875f3aacf2a5a913205accddabf0bfb75cac76 ] Currently execution of panic() continues until Xen's panic notifier (xen_panic_event()) is called at which point we make a hypercall that never returns. This means that any notifier that is supposed to be called later as well as significant part of panic() code (such as pstore writes from kmsg_dump()) is never executed. There is no reason for xen_panic_event() to be this last point in execution since panic()'s emergency_restart() will call into xen_emergency_restart() from where we can perform our hypercall. Nevertheless, we will provide xen_legacy_crash boot option that will preserve original behavior during crash. This option could be used, for example, if running kernel dumper (which happens after panic notifiers) is undesirable. Reported-by: James Dingwall Signed-off-by: Boris Ostrovsky Reviewed-by: Juergen Gross Signed-off-by: Sasha Levin --- .../admin-guide/kernel-parameters.txt | 4 +++ arch/x86/xen/enlighten.c | 28 +++++++++++++++++-- 2 files changed, 29 insertions(+), 3 deletions(-) diff --git a/Documentation/admin-guide/kernel-parameters.txt b/Documentation/admin-guide/kernel-parameters.txt index 16607b178b474..a855f83defa6c 100644 --- a/Documentation/admin-guide/kernel-parameters.txt +++ b/Documentation/admin-guide/kernel-parameters.txt @@ -5117,6 +5117,10 @@ the unplug protocol never -- do not unplug even if version check succeeds + xen_legacy_crash [X86,XEN] + Crash from Xen panic notifier, without executing late + panic() code such as dumping handler. + xen_nopvspin [X86,XEN] Disables the ticketlock slowpath using Xen PV optimizations. diff --git a/arch/x86/xen/enlighten.c b/arch/x86/xen/enlighten.c index c6c7c9b7b5c19..2483ff345bbcd 100644 --- a/arch/x86/xen/enlighten.c +++ b/arch/x86/xen/enlighten.c @@ -266,19 +266,41 @@ void xen_reboot(int reason) BUG(); } +static int reboot_reason = SHUTDOWN_reboot; +static bool xen_legacy_crash; void xen_emergency_restart(void) { - xen_reboot(SHUTDOWN_reboot); + xen_reboot(reboot_reason); } static int xen_panic_event(struct notifier_block *this, unsigned long event, void *ptr) { - if (!kexec_crash_loaded()) - xen_reboot(SHUTDOWN_crash); + if (!kexec_crash_loaded()) { + if (xen_legacy_crash) + xen_reboot(SHUTDOWN_crash); + + reboot_reason = SHUTDOWN_crash; + + /* + * If panic_timeout==0 then we are supposed to wait forever. + * However, to preserve original dom0 behavior we have to drop + * into hypervisor. (domU behavior is controlled by its + * config file) + */ + if (panic_timeout == 0) + panic_timeout = -1; + } return NOTIFY_DONE; } +static int __init parse_xen_legacy_crash(char *arg) +{ + xen_legacy_crash = true; + return 0; +} +early_param("xen_legacy_crash", parse_xen_legacy_crash); + static struct notifier_block xen_panic_block = { .notifier_call = xen_panic_event, .priority = INT_MIN -- 2.20.1