Received: by 2002:a25:31c3:0:0:0:0:0 with SMTP id x186csp4499078ybx; Mon, 4 Nov 2019 14:25:01 -0800 (PST) X-Google-Smtp-Source: APXvYqwLyqcYCrhoAg6dBVR4udpcXp9z1okfKtVIBVQ1B2Xpskw1igPSzypzjV8F8i9Jz0Hwr7Q0 X-Received: by 2002:a50:aad2:: with SMTP id r18mr32758900edc.44.1572906301306; Mon, 04 Nov 2019 14:25:01 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1572906301; cv=none; d=google.com; s=arc-20160816; b=OV3dfvNHfRz7ivhKSRtk4S6VdvwIoo+3l2BXacxEGh0UTXdYYpvPlY2E2CqI7ACn9c kof5cpf4Bh2PEyG7Rqk7u4qv8A61FfyrHXaaKSQwFHsKYYM1mSLuHPFstgimNAEvoQPw gdnZn4dt7htdoqdPd5x1MwWd8U20sUJdUePfQz9zSV69J8EwffGfqwjjweSG7f8ttAJn 3yKiHCQdTBRT196o0P8aXqxPknWEJerwmdImqHNum34AtdrAeoe8GDmWgSvLs1KTg58w y2Fi7QuOpI93Gwp10CaoX9IHS9WbK2I/nFcz6k7yqbBKnAERuG4slG+6R7C6SsQDUyXz KaNw== 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=xXVZNKSJNW6lgpOaKv5qcJjko4t0CQ+ni8jEiglDBhg=; b=yl91wbh5YdEhhw0UpLr4DJB9a0d2BEk6XrHAg9+48RtJem/oWGq++A0dgqg1Vw/8fC MTCxkt0XfPkGtXXJIPQtY45qvi225G5F3HKreQjmU5N1Hq4uC67wRavgvXJRVhIWr2eP Dyni5GDyxGGi/FTkswuhFBBHm4C9rPRZ291HonhZxaSC3wXS235Nm4B6YCxBJ2f/tbTl Bj11ke1uvw5Hhg7Vn2IJTkZ7vgTbTILxQvFQPpLdHT+F50ruQP5/zuekMkYQRYu4XCCu 3bAHV2A3tA5wnOgtDt8l1d/+27gRTo1s9ZswdTjiKZODhCNa1PdyZDgCCFBnywgZ/HaQ Gctg== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@kernel.org header.s=default header.b="DYQ/MSUy"; 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 g3si13279811ejw.13.2019.11.04.14.24.38; Mon, 04 Nov 2019 14:25:01 -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="DYQ/MSUy"; 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 S2387831AbfKDWXp (ORCPT + 99 others); Mon, 4 Nov 2019 17:23:45 -0500 Received: from mail.kernel.org ([198.145.29.99]:48244 "EHLO mail.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S2387814AbfKDVyA (ORCPT ); Mon, 4 Nov 2019 16:54:00 -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 374FD21D7D; Mon, 4 Nov 2019 21:53:57 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=kernel.org; s=default; t=1572904438; bh=CpmR5KCxaZdYZAuo/G9nFJCamGR7Fa+x8iD1T/oOxEI=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=DYQ/MSUyTbOXbE6Upu+tIpsfAlpbjy2QPhWONxAssNzI++OB5nlIGJ84xl0r91ICd 8xH/kCWhsNLgUrXbLYihCOGWrZvgd9qy7nXvassxdQEhk0Gq4QBN2sy8TZZI+Sm2I2 bax3NAlfmaGBRZie+MUTB5Micc9PZqPbwu86KNMM= 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.14 44/95] x86/xen: Return from panic notifier Date: Mon, 4 Nov 2019 22:44:42 +0100 Message-Id: <20191104212102.348306265@linuxfoundation.org> X-Mailer: git-send-email 2.23.0 In-Reply-To: <20191104212038.056365853@linuxfoundation.org> References: <20191104212038.056365853@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 b67a6cd08ca16..671f518b09eeb 100644 --- a/Documentation/admin-guide/kernel-parameters.txt +++ b/Documentation/admin-guide/kernel-parameters.txt @@ -4875,6 +4875,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 515d5e4414c29..00fc683a20110 100644 --- a/arch/x86/xen/enlighten.c +++ b/arch/x86/xen/enlighten.c @@ -259,19 +259,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