Received: by 2002:ac0:a5a7:0:0:0:0:0 with SMTP id m36-v6csp471694imm; Wed, 18 Jul 2018 05:32:02 -0700 (PDT) X-Google-Smtp-Source: AAOMgpdAVdoMOApxWcbf+wKNAYLez+CgYgstmUTshL6SAs8waelRz5vjdxc3ebL9Ap3ef8hSgERC X-Received: by 2002:a62:8d16:: with SMTP id z22-v6mr5022191pfd.181.1531917121988; Wed, 18 Jul 2018 05:32:01 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1531917121; cv=none; d=google.com; s=arc-20160816; b=GAS+FzoJfOPIjDies2W+n9wPS6t2mV76dddBz41OB38HCDBbt/135BqCxsaRLElBzi mZTjYR5K26jh8Vm+HhoomBBmBemQH9W63kDhukBhaIW3dyTus/gtjN/6C1dqxph34V9n 3TCNZU+FeuTareFbuKnQ9iqOptWiZWC2nRN6RByXVnp9Y9/m0ElU9VY14Lu33J01P//X pfqUfXr/OiiCY2vOfjBqF/Nfiy3wYySVls1XEBCji07VxfHsgbcx2fZhOKPxwQWIKPHF TDPbv01X0HtkeBw0Vvd+giBBLVZXC1FnuSv3KxDnNSyYcM4y9COz51S+EmQHqGw1bSEx zlVg== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:date:message-id:in-reply-to:subject:cc:to :from:dkim-signature:arc-authentication-results; bh=HjYuyQ5m1tgAZ2ZY0IYLiVM+Ds7n0+8KgTnDF5RcgNs=; b=r1SVbbfnOtEmJov8btjQQFMI4FUSnY6xn7G/d1plA6PS4tvz0GFRi+7OnicMeMAqXM ZsOPifxDDL/Hsa/baFcD4dh2B41bjf4Uf3MaFKaDURo/E9xZoqQvrnbMnMyZjWqbnUpv SMbyaMfDNazd+PgmababwDukXA4dYFyGly3m1xXMERa3RSW+tICy+o+o+gnGF7WvWPkh vl/+9sSRecRYdt8HEdM5bIAJjmpjahxeHBT5KhjbAUuJvT8LZ2gscNu/DMy7S45aJQTq sVRJa4XTjIGQGOY45YWxJhrX7J1E90UP3RUDptIaChywAwkF/9N/kSMPp7bUbVrX/EGr lE9A== ARC-Authentication-Results: i=1; mx.google.com; dkim=fail header.i=@sirena.org.uk header.s=20170815-heliosphere header.b=O4HTzlQH; 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=fail (p=NONE sp=NONE dis=NONE) header.from=kernel.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id 39-v6si2400425ple.308.2018.07.18.05.31.46; Wed, 18 Jul 2018 05:32:01 -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=fail header.i=@sirena.org.uk header.s=20170815-heliosphere header.b=O4HTzlQH; 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=fail (p=NONE sp=NONE dis=NONE) header.from=kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1731439AbeGRNHf (ORCPT + 99 others); Wed, 18 Jul 2018 09:07:35 -0400 Received: from heliosphere.sirena.org.uk ([172.104.155.198]:50772 "EHLO heliosphere.sirena.org.uk" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1730369AbeGRNHe (ORCPT ); Wed, 18 Jul 2018 09:07:34 -0400 DKIM-Signature: v=1; a=rsa-sha256; q=dns/txt; c=relaxed/relaxed; d=sirena.org.uk; s=20170815-heliosphere; h=Date:Message-Id:In-Reply-To: Subject:Cc:To:From:Sender:Reply-To:MIME-Version:Content-Type: Content-Transfer-Encoding:Content-ID:Content-Description:Resent-Date: Resent-From:Resent-Sender:Resent-To:Resent-Cc:Resent-Message-ID:References: List-Id:List-Help:List-Unsubscribe:List-Subscribe:List-Post:List-Owner: List-Archive; bh=HjYuyQ5m1tgAZ2ZY0IYLiVM+Ds7n0+8KgTnDF5RcgNs=; b=O4HTzlQHD3wm qYJFOFA+N4jfaJ92nzYQ86OtEK8ctEo1k5wXGwC8TwKFrvtMjVwsQL+llWdlI7e5fpaREVXVJ45Da IOMwVojifqmCUXAhywpKP2UBOs7d+0RsC5OA2WUXF7bT0E+nLAmqAE5xkKtanfpWRNu8TPZ/ngT9Q i1z4s=; Received: from debutante.sirena.org.uk ([2001:470:1f1d:6b5::3] helo=debutante) by heliosphere.sirena.org.uk with esmtpsa (TLS1.2:ECDHE_RSA_AES_256_GCM_SHA384:256) (Exim 4.89) (envelope-from ) id 1fflaP-0003WQ-P4; Wed, 18 Jul 2018 12:29:41 +0000 Received: from broonie by debutante with local (Exim 4.91) (envelope-from ) id 1fflaP-0007Tt-AZ; Wed, 18 Jul 2018 13:29:41 +0100 From: Mark Brown To: Geert Uytterhoeven Cc: Mark Brown , Marek Vasut , Liam Girdwood , Mark Brown , "Rafael J . Wysocki" , Pavel Machek , Len Brown , linux-pm@vger.kernel.org, linux-renesas-soc@vger.kernel.org, linux-kernel@vger.kernel.org, linux-kernel@vger.kernel.org Subject: Applied "regulator: bd9571mwv: Add support for toggle power switches" to the regulator tree In-Reply-To: <20180716153052.1830-3-geert+renesas@glider.be> Message-Id: Date: Wed, 18 Jul 2018 13:29:41 +0100 Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org The patch regulator: bd9571mwv: Add support for toggle power switches has been applied to the regulator tree at https://git.kernel.org/pub/scm/linux/kernel/git/broonie/regulator.git All being well this means that it will be integrated into the linux-next tree (usually sometime in the next 24 hours) and sent to Linus during the next merge window (or sooner if it is a bug fix), however if problems are discovered then the patch may be dropped or reverted. You may get further e-mails resulting from automated or manual testing and review of the tree, please engage with people reporting problems and send followup patches addressing any issues that are reported if needed. If any updates are required or you are submitting further changes they should be sent as incremental updates against current git, existing patches will not be replaced. Please add any relevant lists and maintainers to the CCs when replying to this mail. Thanks, Mark From e436875f6f97708613976da75a92974f18998af9 Mon Sep 17 00:00:00 2001 From: Geert Uytterhoeven Date: Mon, 16 Jul 2018 17:30:51 +0200 Subject: [PATCH] regulator: bd9571mwv: Add support for toggle power switches MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit Extend the existing support for backup mode to toggle power switches. With a toggle power switch (or level signal), the following steps must be followed exactly: 1. Configure PMIC for backup mode, to change the role of the accessory power switch from a power switch to a wake-up switch, 2. Switch accessory power switch off, to prepare for system suspend, which is a manual step not controlled by software, 3. Suspend system, 4. Switch accessory power switch on, to resume the system. Hence the PMIC is configured for backup mode when "on" or "1" is written to the PMIC's "backup_mode" virtual file in sysfs. Conversely, writing "off" or "0" reverts the role of the accessory switch to a power switch. Unlike with momentary switches, backup mode is not enabled by default, as enabling it prevents the board from being powered off using the power switch, which may confuse the user. Signed-off-by: Geert Uytterhoeven Reviewed-by: Niklas Söderlund Signed-off-by: Mark Brown --- drivers/regulator/bd9571mwv-regulator.c | 20 ++++++++++++++++++++ 1 file changed, 20 insertions(+) diff --git a/drivers/regulator/bd9571mwv-regulator.c b/drivers/regulator/bd9571mwv-regulator.c index 1da36a6590c8..c44613b9423b 100644 --- a/drivers/regulator/bd9571mwv-regulator.c +++ b/drivers/regulator/bd9571mwv-regulator.c @@ -185,6 +185,7 @@ static ssize_t backup_mode_store(struct device *dev, const char *buf, size_t count) { struct bd9571mwv_reg *bdreg = dev_get_drvdata(dev); + unsigned int mode; int ret; if (!count) @@ -194,6 +195,25 @@ static ssize_t backup_mode_store(struct device *dev, if (ret) return ret; + if (!bdreg->rstbmode_level) + return count; + + /* + * Configure DDR Backup Mode, to change the role of the accessory power + * switch from a power switch to a wake-up switch, or vice versa + */ + ret = bd9571mwv_bkup_mode_read(bdreg->bd, &mode); + if (ret) + return ret; + + mode &= ~BD9571MWV_BKUP_MODE_CNT_KEEPON_MASK; + if (bdreg->bkup_mode_enabled) + mode |= bdreg->bkup_mode_cnt_keepon; + + ret = bd9571mwv_bkup_mode_write(bdreg->bd, mode); + if (ret) + return ret; + return count; } -- 2.18.0