Received: by 2002:a5b:505:0:0:0:0:0 with SMTP id o5csp5979794ybp; Tue, 15 Oct 2019 07:53:05 -0700 (PDT) X-Google-Smtp-Source: APXvYqzuTY733+Xv6vwamiqZ7l6BhPn7J5n+xUPYvKG4LKEt3JMv8lFAIaL7bRUcLNBc/0/sYFm4 X-Received: by 2002:a50:af45:: with SMTP id g63mr33509372edd.21.1571151185583; Tue, 15 Oct 2019 07:53:05 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1571151185; cv=none; d=google.com; s=arc-20160816; b=EkxmJy6F5F8zbpMKqUpqP8463tVog+F8u0GtbKGtO1YVPEQ52LvCzUOmDR2RMZPJzk yKKfDj+ai3xYRy/OuMoNRI8Kx9uctwpMi79EB4s5fpSN+7kM0+dj9AjfMYFam3VpJmwR DGvfE1tA8Y8wzLA8iJu+Nledng2jF1v5MehXJJwVeKnIaCBlD0QEK18HZ97KXC7aWmwK nsuwXZVyL6OkRoHH1J/reUxSpg/9bqgXxo62eNUJc003EzRLYF2bEullgF7fHdgAuQA4 4KXdhY1nQsq+gFrQK4YqKgiM6NpH3MXx+Uo1fWlHwB7Qwug3pwhbWIkTZnIaEznRBH2s RmiA== 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 :references:in-reply-to:message-id:date:subject:cc:to:from :dkim-signature; bh=zLfyJeA9wa/YShlK3MTXpdAT71OVQlJTB0HHADMFohY=; b=G7R3fO3TySLQFd7oo0z1tRAzSlCijf+Fb7yucwNujGdASZPx8aroHWiApKeYEKV6sp DVQ9kzZn7DSy1HgyWal4T0ab4r+Gp9iRX2OJ1nZSDOHPETkBBvF48YvxdNzUjRi5ZsD5 EozksvUDIfPnw2v/w7p+NfE0LrILO+deFtv2lQDn8eXPGT+dxj2jC49ofvuwKh9pNdAr 0aFCQ5E9nGHjbSXnnuVlw4quCKrHxaclFpfWX21q1ZdPUEV5zEpsH3nbootcSXqKXrh/ faPGDkdUEPJha2XyvAeAlmqaP4rLYDK1UQqzHdFmKZRrHBeGVMNYdjDTZk9TZdGpkE0C QDaw== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@gmail.com header.s=20161025 header.b=jJcLAGgH; 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=QUARANTINE dis=NONE) header.from=gmail.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id oq3si13377292ejb.220.2019.10.15.07.52.41; Tue, 15 Oct 2019 07:53:05 -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=@gmail.com header.s=20161025 header.b=jJcLAGgH; 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=QUARANTINE dis=NONE) header.from=gmail.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1733051AbfJOOwC (ORCPT + 99 others); Tue, 15 Oct 2019 10:52:02 -0400 Received: from mail-wr1-f66.google.com ([209.85.221.66]:36817 "EHLO mail-wr1-f66.google.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1733002AbfJOOwB (ORCPT ); Tue, 15 Oct 2019 10:52:01 -0400 Received: by mail-wr1-f66.google.com with SMTP id y19so24268002wrd.3 for ; Tue, 15 Oct 2019 07:52:00 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=gmail.com; s=20161025; h=from:to:cc:subject:date:message-id:in-reply-to:references :mime-version:content-transfer-encoding; bh=zLfyJeA9wa/YShlK3MTXpdAT71OVQlJTB0HHADMFohY=; b=jJcLAGgH3KuOU3eX27h1xp0fXk+FeZtURkHP/vua0EHtKL9+eYSnWolQZeqH7OkkHO d3bdzGyReUjNjy8cA66+kS5qLgIK1m4Wj374o0S6jdVR8ToTUbKv2oukynUtiUcmRvpc yjsLOGm1sciv3p2FzABejkzNm8JhpEfhm8JmqGGE7CjDtvXwfnpb8rHJhU/OJJKd6Q9g n/MCGzKLmRCZQ7nDEVMBJIlWjxmJoko2/SD8wQSD0KWuRKeFHsiktCMlEI5W0o8jAwgs EfqvcN1tGtFxsaGX3XRsf7LhOEstrVD3IKcEq9R+IrtUQW2ZgvPX0XPiuk8G/gvD6sem We6Q== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20161025; h=x-gm-message-state:from:to:cc:subject:date:message-id:in-reply-to :references:mime-version:content-transfer-encoding; bh=zLfyJeA9wa/YShlK3MTXpdAT71OVQlJTB0HHADMFohY=; b=VDaU0qpuyyMTOSocSEukf4U1Ninluap3TOJkqGhY9VYy8UybfZWY93hCymyDgRK/o1 /f0tdbDv4JEjzo+UZu7ibA3WMn2SwHj/NqCWBzguUzVZyIT9E6t9k3CTAknjCNjoq2tI T+H1Hw2Quw3msMDqEovv1C0SCdvbKiATI2xxB5NjXNWNI6NgF+hgGqfWkBy0sWKcrQh8 vI0m2sZCN3O54XHsxnAeGtqa/C/CcuoCyJ1jWR2ed6/o8CwnXIDNeZaadMdPtur2z8bv pIVy4eBsUFoaUvJoYhe6BPRI94nHbJPgbOZ7I809YDXcZ/k7akGD1dxqgG/VgpgD+5a3 c8wQ== X-Gm-Message-State: APjAAAWtmZm1duOVpJcQBPRF+ry6KZEzrpSFnqbTV1TmaGQPbj4R0Rvk i1kAJ147yviEplL3AacPT/M= X-Received: by 2002:a5d:46cb:: with SMTP id g11mr17438319wrs.346.1571151118976; Tue, 15 Oct 2019 07:51:58 -0700 (PDT) Received: from localhost (p2E5BE2CE.dip0.t-ipconnect.de. [46.91.226.206]) by smtp.gmail.com with ESMTPSA id o4sm52925154wre.91.2019.10.15.07.51.56 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Tue, 15 Oct 2019 07:51:57 -0700 (PDT) From: Thierry Reding To: Russell King , arm@kernel.org Cc: Arnd Bergmann , Olof Johansson , Guenter Roeck , Stefan Agner , Wolfram Sang , Catalin Marinas , Lorenzo Pieralisi , Stefano Stabellini , linux-arm-kernel@lists.infradead.org, linux-kernel@vger.kernel.org Subject: [PATCH 3/6] drivers: firmware: psci: Register with kernel restart handler Date: Tue, 15 Oct 2019 16:51:44 +0200 Message-Id: <20191015145147.1106247-4-thierry.reding@gmail.com> X-Mailer: git-send-email 2.23.0 In-Reply-To: <20191015145147.1106247-1-thierry.reding@gmail.com> References: <20191015145147.1106247-1-thierry.reding@gmail.com> MIME-Version: 1.0 Content-Transfer-Encoding: 8bit Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org From: Guenter Roeck Register with kernel restart handler instead of setting arm_pm_restart directly. This enables support for replacing the PSCI restart handler with a different handler if necessary for a specific board. Select a priority of 129 to indicate a higher than default priority, but keep it as low as possible since PSCI reset is known to fail on some boards. Acked-by: Arnd Bergmann Reviewed-by: Wolfram Sang Tested-by: Wolfram Sang Signed-off-by: Guenter Roeck Acked-by: Lorenzo Pieralisi Signed-off-by: Thierry Reding --- drivers/firmware/psci/psci.c | 12 ++++++++++-- 1 file changed, 10 insertions(+), 2 deletions(-) diff --git a/drivers/firmware/psci/psci.c b/drivers/firmware/psci/psci.c index 84f4ff351c62..a41c6ba043a2 100644 --- a/drivers/firmware/psci/psci.c +++ b/drivers/firmware/psci/psci.c @@ -250,7 +250,8 @@ static int get_set_conduit_method(struct device_node *np) return 0; } -static void psci_sys_reset(enum reboot_mode reboot_mode, const char *cmd) +static int psci_sys_reset(struct notifier_block *nb, unsigned long action, + void *data) { if ((reboot_mode == REBOOT_WARM || reboot_mode == REBOOT_SOFT) && psci_system_reset2_supported) { @@ -263,8 +264,15 @@ static void psci_sys_reset(enum reboot_mode reboot_mode, const char *cmd) } else { invoke_psci_fn(PSCI_0_2_FN_SYSTEM_RESET, 0, 0, 0); } + + return NOTIFY_DONE; } +static struct notifier_block psci_sys_reset_nb = { + .notifier_call = psci_sys_reset, + .priority = 129, +}; + static void psci_sys_poweroff(void) { invoke_psci_fn(PSCI_0_2_FN_SYSTEM_OFF, 0, 0, 0); @@ -431,7 +439,7 @@ static void __init psci_0_2_set_functions(void) psci_ops.migrate_info_type = psci_migrate_info_type; - arm_pm_restart = psci_sys_reset; + register_restart_handler(&psci_sys_reset_nb); pm_power_off = psci_sys_poweroff; } -- 2.23.0