Received: by 2002:a05:6a10:9848:0:0:0:0 with SMTP id x8csp3407653pxf; Mon, 22 Mar 2021 05:53:58 -0700 (PDT) X-Google-Smtp-Source: ABdhPJzvNLLVcOAZqLeslFlvVHpUPaxEnzlLyfhHtoSStjHNu5LfJkpxCFXcdzNkVsZhgMeZTQVW X-Received: by 2002:a17:906:2710:: with SMTP id z16mr19403153ejc.176.1616417638470; Mon, 22 Mar 2021 05:53:58 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1616417638; cv=none; d=google.com; s=arc-20160816; b=c2qkNh8T2R0DEoVPIFvGrtXTbBG+WRsyKSENmsGWyJguMGaYflYt0Ixi6VrlSPI4ym /9G6fIWQ5uUJtagdo+n9cPt0sODTiLtDVOBMhH6sNGX9r35/0HBPXoJvOT2maNpjGTuK bpBCmTgO5OLr89JsrtqECt3Apr0bDNzOli0uQeRkPwAlA/THqrl7/57/9EFNIRtp+blA mfG1rhufiGeKswm3rm7/wKs9KNod62sLNzR7oabgV9S57TMETePX2hVhpByJXftoLQMG jqcbcJ87PIn/qaVG2L+hLL6H4VEKx3UNUe/UPPcxj2bqXEVeXkqB+OEnaS837jOsDALf RXKg== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:content-transfer-encoding:mime-version :user-agent:references:in-reply-to:message-id:date:subject:cc:to :from:dkim-signature; bh=XDMp0FBvxz4sg/pADiW3gb+M1O3YVahsWaA8ycXpRdQ=; b=cZ/eHyJxTVrn2FtpOCS/QRorobYLmqHDqTNSFsrEVShIZNEw0qoMT+dN3FrbiQRiom g2orEE1JhuDgaTUAwIhzf8fU3GCs51og59tzAZMb1nxkVUs0kBDJ5SAbaUFlDN+bQp58 xjgZBCP+Np1GD/UEeiIvI793rkcRutjTtJljs/ktXi9wkrpEbHmGXWzHH7r41mK62pLt Im7hJfckkZyaDtguPm6hshEXl075fQM9H0dro8eybwNRUCxJGfiPfA6mYhleMO3K9iz5 46OCkAh4bd4ESiB+IStZ34itQmxDf5b2LVvRQ2DWjzN8DMEbTEfkKAHX1xqcpv8Ue/s3 4geA== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@linuxfoundation.org header.s=korg header.b=0Jd3eqko; 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=linuxfoundation.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id d21si11062774ejw.331.2021.03.22.05.53.35; Mon, 22 Mar 2021 05:53:58 -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=@linuxfoundation.org header.s=korg header.b=0Jd3eqko; 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=linuxfoundation.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S232825AbhCVMwx (ORCPT + 99 others); Mon, 22 Mar 2021 08:52:53 -0400 Received: from mail.kernel.org ([198.145.29.99]:35426 "EHLO mail.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S232626AbhCVMmz (ORCPT ); Mon, 22 Mar 2021 08:42:55 -0400 Received: by mail.kernel.org (Postfix) with ESMTPSA id 1D494619CB; Mon, 22 Mar 2021 12:40:46 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=linuxfoundation.org; s=korg; t=1616416847; bh=VXkTG6rOTkWlJ9hdLPjJeSzlcFrA8+DVDxsQY5T/Fys=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=0Jd3eqkoL0HtUdb55eWVanT9HvPGavHjhPCEsshoePwrAy1h13oUJKK8NKhiO/Nki 08XKoB3/is8CCrnXKDscWVvkqI0aApfWCREH8BW5ogCcxu4w58Llb0mHWecKqqEI5U FGfDT2Pz9sNgI+WYZ3cW/jstn2oeLAxqGcVgt8u0= From: Greg Kroah-Hartman To: linux-kernel@vger.kernel.org Cc: Greg Kroah-Hartman , stable@vger.kernel.org, Frieder Schrempf , Mark Brown , Sasha Levin Subject: [PATCH 5.10 110/157] regulator: pca9450: Enable system reset on WDOG_B assertion Date: Mon, 22 Mar 2021 13:27:47 +0100 Message-Id: <20210322121937.256484882@linuxfoundation.org> X-Mailer: git-send-email 2.31.0 In-Reply-To: <20210322121933.746237845@linuxfoundation.org> References: <20210322121933.746237845@linuxfoundation.org> User-Agent: quilt/0.66 MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org From: Frieder Schrempf [ Upstream commit f7684f5a048febd2a7bc98ee81d6dce52f7268b8 ] By default the PCA9450 doesn't handle the assertion of the WDOG_B signal, but this is required to guarantee that things like software resets triggered by the watchdog work reliably. As we don't want to rely on the bootloader to enable this, we tell the PMIC to issue a cold reset in case the WDOG_B signal is asserted (WDOG_B_CFG = 10), just as the NXP U-Boot code does. Signed-off-by: Frieder Schrempf Link: https://lore.kernel.org/r/20210211105534.38972-3-frieder.schrempf@kontron.de Signed-off-by: Mark Brown Signed-off-by: Sasha Levin --- drivers/regulator/pca9450-regulator.c | 8 ++++++++ include/linux/regulator/pca9450.h | 7 +++++++ 2 files changed, 15 insertions(+) diff --git a/drivers/regulator/pca9450-regulator.c b/drivers/regulator/pca9450-regulator.c index 1bba8fdcb7b7..833d398c6aa2 100644 --- a/drivers/regulator/pca9450-regulator.c +++ b/drivers/regulator/pca9450-regulator.c @@ -797,6 +797,14 @@ static int pca9450_i2c_probe(struct i2c_client *i2c, return ret; } + /* Set reset behavior on assertion of WDOG_B signal */ + ret = regmap_update_bits(pca9450->regmap, PCA9450_REG_RESET_CTRL, + WDOG_B_CFG_MASK, WDOG_B_CFG_COLD_LDO12); + if (ret) { + dev_err(&i2c->dev, "Failed to set WDOG_B reset behavior\n"); + return ret; + } + /* * The driver uses the LDO5CTRL_H register to control the LDO5 regulator. * This is only valid if the SD_VSEL input of the PMIC is high. Let's diff --git a/include/linux/regulator/pca9450.h b/include/linux/regulator/pca9450.h index 1bbd3014f906..ccdb5320a240 100644 --- a/include/linux/regulator/pca9450.h +++ b/include/linux/regulator/pca9450.h @@ -216,4 +216,11 @@ enum { #define IRQ_THERM_105 0x02 #define IRQ_THERM_125 0x01 +/* PCA9450_REG_RESET_CTRL bits */ +#define WDOG_B_CFG_MASK 0xC0 +#define WDOG_B_CFG_NONE 0x00 +#define WDOG_B_CFG_WARM 0x40 +#define WDOG_B_CFG_COLD_LDO12 0x80 +#define WDOG_B_CFG_COLD 0xC0 + #endif /* __LINUX_REG_PCA9450_H__ */ -- 2.30.1