Received: by 2002:a05:6a10:f3d0:0:0:0:0 with SMTP id a16csp243726pxv; Wed, 14 Jul 2021 03:03:26 -0700 (PDT) X-Google-Smtp-Source: ABdhPJwi7PNIi2359Nlo5lg6oQXeE0TiyAo/21NPCWiyONkGmG14y3OTdPL9U1ebbH8IrA4q4ifl X-Received: by 2002:a05:6402:516c:: with SMTP id d12mr12154448ede.323.1626257006410; Wed, 14 Jul 2021 03:03:26 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1626257006; cv=none; d=google.com; s=arc-20160816; b=uNe85EtuyB1x0LuuulZxwpGgrARVxLJlnbdP0Bap7xZkp244OZXfzWou0w+lXBVbWg fsmJ0XNnmnXKMib8PFziyRo8NXTyEvjKpXZAznWIQmAVnFuKQm/Znr0QGukzPr60bebJ 3xzOw8SnURPfcMPNbFAr2uX6nc4RH9Gn/eFiRtF/C1dZPndvTMrmElnRtWqfk/TdNI+h O2ZdpBIjnjdNSTY6Qx9WVC30/j8oPRstFKrUxonpJP/a/otDSLm8w0fvItPjzen4j7Nl XIu4QXK25d32Hwmr8orG7h8tocu8G3cYv4Dj1kr+hjaIVQ5EQHSEIQqAqmlKQuNzznjo yFDg== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:references:in-reply-to:message-id:date:subject :cc:to:from:dkim-signature; bh=l1bjuoaTVbYtnhNI71QZX5Bx6fnm6uPZuv4M80rHUjI=; b=cvrhqlrr3PhEaey9b1f3r61+BvcoRZcAbj0TXD6OYrSybekHM80RNiEI+mWD8eLbdQ Cs2sTnZZr1cko+2DUKala9JPehRp9XAS4pmhicLx6VC+uk4uclQhOXFRStVfXeG3nWJ7 V8sFT4T+q5ZVcQMog2JeOcyjDPJjHaIuhz4jmcy4xSkSnWSXI1xesNAyXMumbyTdeWHQ SkiQLNbyPLf8vQ/Q8uspVAxfSOhV0j4fKMer+93uZlYwGS9rygTQDSKYroZG4YMRvmGq 68neoOnQM06Ou9GuNSaO9HUvpl5xPKez92R1SWHE3aJ5m1AsscTymRWo5qwYhBFGjb3R ZI0g== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@linaro.org header.s=google header.b=EM4ks1xn; 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; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=linaro.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id bi15si2216217edb.459.2021.07.14.03.03.03; Wed, 14 Jul 2021 03:03:26 -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=@linaro.org header.s=google header.b=EM4ks1xn; 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; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=linaro.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S239029AbhGNKCD (ORCPT + 99 others); Wed, 14 Jul 2021 06:02:03 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:55708 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S239030AbhGNKCC (ORCPT ); Wed, 14 Jul 2021 06:02:02 -0400 Received: from mail-pl1-x634.google.com (mail-pl1-x634.google.com [IPv6:2607:f8b0:4864:20::634]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id EC415C061760 for ; Wed, 14 Jul 2021 02:59:10 -0700 (PDT) Received: by mail-pl1-x634.google.com with SMTP id b12so1224411plh.10 for ; Wed, 14 Jul 2021 02:59:10 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=linaro.org; s=google; h=from:to:cc:subject:date:message-id:in-reply-to:references; bh=l1bjuoaTVbYtnhNI71QZX5Bx6fnm6uPZuv4M80rHUjI=; b=EM4ks1xnAhxy/oyMPK+YmsxsS8bDIyg6oX+je8bM1orlDBciQn00YRtWkJ0vI93Prn U8/+BVyPocLBJLw91waPql/4SmUgMaS5kDcPbxb9Pqb56PehJDlipv5vKTuglcl4oYUB BY/uh9Gt3fJZDwJL3gVTrRsLNyQoTaI3jKQxgiaUy54G3AeuLrdn8Qf931iK5E1atSz7 qNHHsRAmujlZBUVJfgVhXfUv9e9xKxY79+WaKIxRqyBNFZxkPFG8pmsVUXptDTdlI1o7 swi/NTWbePwxQwz7qTU/7E1Sqpb/Awqp8F+b9t+etHf/aiZ/PTLqyCrm9y7HhlCGp++s sToQ== 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; bh=l1bjuoaTVbYtnhNI71QZX5Bx6fnm6uPZuv4M80rHUjI=; b=Y9BqBm2fXrRDrXGiYYPEpVFiw8f2uVDxqsEhbimcjiYItBZ2Lr8Qo0EHE0vfjGdiNq WdUI7MmdyQiMZDy7eVxXm4QKF/dlUM9SaYBYIIrppjGfNXw+XW8TO2fguVDxVkhEnNeh 8e3sMdDFina7bjnFXeXieC+NevxiS8UXmVu/r2iougBtubrFUEqnY3t9zEhhTQHB62Dn REALI5QlMkCo1+6rlMWEStRdXxOkUO2pI6pDNDmi3iefzL+IiGEsChwpFkGkG0rUNKm0 pRsP7ieBlF51ytEmkDyPy2rtmAken85aQ/P15ODFtmu2JacuaLDiEeIdG+HP8fqjzRbF ZyEQ== X-Gm-Message-State: AOAM532WqYhqyaxuXnZRW5/AJE2S5p2wapm5CDEeVVVgKzuqpl/HnuMO TLPQEfYyN5VMAxjw1KySiEi4cQ== X-Received: by 2002:a17:902:d217:b029:105:e265:65c7 with SMTP id t23-20020a170902d217b0290105e26565c7mr7203320ply.16.1626256750527; Wed, 14 Jul 2021 02:59:10 -0700 (PDT) Received: from localhost.localdomain (80.251.214.228.16clouds.com. [80.251.214.228]) by smtp.gmail.com with ESMTPSA id g1sm2283304pgs.23.2021.07.14.02.59.07 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Wed, 14 Jul 2021 02:59:10 -0700 (PDT) From: Shawn Guo To: Dmitry Torokhov Cc: Luca Weiss , Bjorn Andersson , Matteo Croce , Andrew Morton , Petr Mladek , "Rafael J . Wysocki" , linux-arm-msm@vger.kernel.org, linux-input@vger.kernel.org, linux-kernel@vger.kernel.org, Shawn Guo Subject: [PATCH v2 2/2] Input: pm8941-pwrkey - Respect reboot_mode for warm reset Date: Wed, 14 Jul 2021 17:58:49 +0800 Message-Id: <20210714095850.27185-3-shawn.guo@linaro.org> X-Mailer: git-send-email 2.17.1 In-Reply-To: <20210714095850.27185-1-shawn.guo@linaro.org> References: <20210714095850.27185-1-shawn.guo@linaro.org> Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On some devices, e.g. Sony Xperia M4 Aqua, warm reset is used to reboot device into bootloader and recovery mode. Instead of always doing hard reset, add a check on reboot_mode for possible warm reset. Signed-off-by: Shawn Guo --- drivers/input/misc/pm8941-pwrkey.c | 6 +++++- 1 file changed, 5 insertions(+), 1 deletion(-) diff --git a/drivers/input/misc/pm8941-pwrkey.c b/drivers/input/misc/pm8941-pwrkey.c index cf8104454e74..9b14d6eb1918 100644 --- a/drivers/input/misc/pm8941-pwrkey.c +++ b/drivers/input/misc/pm8941-pwrkey.c @@ -27,6 +27,7 @@ #define PON_PS_HOLD_RST_CTL2 0x5b #define PON_PS_HOLD_ENABLE BIT(7) #define PON_PS_HOLD_TYPE_MASK 0x0f +#define PON_PS_HOLD_TYPE_WARM_RESET 1 #define PON_PS_HOLD_TYPE_SHUTDOWN 4 #define PON_PS_HOLD_TYPE_HARD_RESET 7 @@ -93,7 +94,10 @@ static int pm8941_reboot_notify(struct notifier_block *nb, break; case SYS_RESTART: default: - reset_type = PON_PS_HOLD_TYPE_HARD_RESET; + if (reboot_mode == REBOOT_WARM) + reset_type = PON_PS_HOLD_TYPE_WARM_RESET; + else + reset_type = PON_PS_HOLD_TYPE_HARD_RESET; break; } -- 2.17.1