Received: by 10.223.176.46 with SMTP id f43csp821765wra; Fri, 26 Jan 2018 07:27:05 -0800 (PST) X-Google-Smtp-Source: AH8x224E0IT0xL6pgClOYZm+5pY1ZVf9ScO0EI65juA+DCqHZMZe6p9VLW/4rJ711ac2EfoMH9FI X-Received: by 2002:a17:902:b485:: with SMTP id y5-v6mr15008961plr.392.1516980425803; Fri, 26 Jan 2018 07:27:05 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1516980425; cv=none; d=google.com; s=arc-20160816; b=XTAPcZH4MZKMZwS2HYXG1TJX5s0D55q2MYV0g77oRey1hsxmYnZWZiJHULkeKDnqPE 5xciTTew55jA+rGfljTgl9BVLonEecqmM+hkNp1kZiVsDr9N4FrUKWTSeCXMttp/Yb+l sQI6kqkDPQtlP/DNbykOP+fZ1ZkgbnXCXtImLRN18bOg7T1hXEzCeW03/Wv8Tzz7Cbse UayfAsfP3kJ8g7Hs9DZNDeZoNr54+p3fgSUboiBCecsfvoVAxCu0qKmCLjqXlKDGhemK wZrChhPLsZo0J5wHxEkE7qGXbu60ezdGNESEi9bNMrF5uMP6eI8WrrzHE1Dc4ZVM69PS siPQ== 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=KpJ5BHkW2mKISxU9J9/RzYW1WvVHxVI0bdE8qjoVRoE=; b=NsD/vlKQGcCQJoXRbu4b273/1atc07CkczurrwkyKWn8mAqo2+lfihL47Cun8lyHZH F+q/eZzWdfKSCD4RckX1Aewsa+xEf8mbCjfxpoWj7vVF46aEa2b/ddzVXFyey2gwLP00 toQI9+Td9MTDTCuxMo0SYJfG30+VsBNgtWB7PX6/zciFfn84Fr7Z3dxLu44+QGJ0oy1G DAl97PoSp+rY8Oli6/vJMtiJOA9UyWn3laRHAGkAW2HFTlFJ43SDDIztpyOET/8R1LIw pdEXApsosnEJjFePUavbrAu6jV+L9gWhtCPNwogy75C0rYd+UBb6wck3B5O/+gI+BoG/ v/4w== ARC-Authentication-Results: i=1; mx.google.com; dkim=fail header.i=@sirena.org.uk header.s=20170815-heliosphere header.b=LR/fTC45; 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 a89si6520993pfj.107.2018.01.26.07.26.51; Fri, 26 Jan 2018 07:27:05 -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=fail header.i=@sirena.org.uk header.s=20170815-heliosphere header.b=LR/fTC45; 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 S1752830AbeAZP0G (ORCPT + 99 others); Fri, 26 Jan 2018 10:26:06 -0500 Received: from heliosphere.sirena.org.uk ([172.104.155.198]:38408 "EHLO heliosphere.sirena.org.uk" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1751484AbeAZP0D (ORCPT ); Fri, 26 Jan 2018 10:26:03 -0500 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=KpJ5BHkW2mKISxU9J9/RzYW1WvVHxVI0bdE8qjoVRoE=; b=LR/fTC45AHno /sONbl5qNue6/iN03jvF/sJ82v7tGdwFLL1mFEuOjiBjic6hRCRBhk85rMlRKhUpNa3mrjoFFfF27 cIlN5yhamfu8tRNKBgu3ilqTS6x1qeJAWp2TCcgVdqT87WBtiXX/RecSpQmubX1GJNpE2cCCwUYjl 6jnps=; 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 1ef5tB-0007Dv-LJ; Fri, 26 Jan 2018 15:26:01 +0000 Received: from broonie by debutante with local (Exim 4.90) (envelope-from ) id 1ef5tB-0006cf-4u; Fri, 26 Jan 2018 15:26:01 +0000 From: Mark Brown To: Chunyan Zhang Cc: Mark Brown , Mark Brown , Rob Herring , devicetree@vger.kernel.org, linux-kernel@vger.kernel.org, Chunyan Zhang , linux-kernel@vger.kernel.org Subject: Applied "regulator: empty the old suspend functions" to the regulator tree In-Reply-To: <1513837506-26543-5-git-send-email-zhang.chunyan@linaro.org> Message-Id: Date: Fri, 26 Jan 2018 15:26:01 +0000 Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org The patch regulator: empty the old suspend functions 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 aa27bbc6c6c60227c096d515f55ffe6cdfef7d2b Mon Sep 17 00:00:00 2001 From: Chunyan Zhang Date: Fri, 26 Jan 2018 21:08:46 +0800 Subject: [PATCH] regulator: empty the old suspend functions Regualtor suspend/resume functions should only be called by PM suspend core via registering dev_pm_ops, and regulator devices should implement the callback functions. Thus, any regulator consumer shouldn't call the regulator suspend/resume functions directly. In order to avoid compile errors, two empty functions with the same name still be left for the time being. Signed-off-by: Chunyan Zhang Signed-off-by: Mark Brown --- drivers/regulator/core.c | 74 --------------------------------------- include/linux/regulator/machine.h | 5 ++- 2 files changed, 2 insertions(+), 77 deletions(-) diff --git a/drivers/regulator/core.c b/drivers/regulator/core.c index 5ea80e94eb69..080c2334edc5 100644 --- a/drivers/regulator/core.c +++ b/drivers/regulator/core.c @@ -4179,80 +4179,6 @@ void regulator_unregister(struct regulator_dev *rdev) } EXPORT_SYMBOL_GPL(regulator_unregister); -static int _regulator_suspend_prepare(struct device *dev, void *data) -{ - struct regulator_dev *rdev = dev_to_rdev(dev); - const suspend_state_t *state = data; - int ret; - - mutex_lock(&rdev->mutex); - ret = suspend_prepare(rdev, *state); - mutex_unlock(&rdev->mutex); - - return ret; -} - -/** - * regulator_suspend_prepare - prepare regulators for system wide suspend - * @state: system suspend state - * - * Configure each regulator with it's suspend operating parameters for state. - * This will usually be called by machine suspend code prior to supending. - */ -int regulator_suspend_prepare(suspend_state_t state) -{ - /* ON is handled by regulator active state */ - if (state == PM_SUSPEND_ON) - return -EINVAL; - - return class_for_each_device(®ulator_class, NULL, &state, - _regulator_suspend_prepare); -} -EXPORT_SYMBOL_GPL(regulator_suspend_prepare); - -static int _regulator_suspend_finish(struct device *dev, void *data) -{ - struct regulator_dev *rdev = dev_to_rdev(dev); - int ret; - - mutex_lock(&rdev->mutex); - if (rdev->use_count > 0 || rdev->constraints->always_on) { - if (!_regulator_is_enabled(rdev)) { - ret = _regulator_do_enable(rdev); - if (ret) - dev_err(dev, - "Failed to resume regulator %d\n", - ret); - } - } else { - if (!have_full_constraints()) - goto unlock; - if (!_regulator_is_enabled(rdev)) - goto unlock; - - ret = _regulator_do_disable(rdev); - if (ret) - dev_err(dev, "Failed to suspend regulator %d\n", ret); - } -unlock: - mutex_unlock(&rdev->mutex); - - /* Keep processing regulators in spite of any errors */ - return 0; -} - -/** - * regulator_suspend_finish - resume regulators from system wide suspend - * - * Turn on regulators that might be turned off by regulator_suspend_prepare - * and that should be turned on according to the regulators properties. - */ -int regulator_suspend_finish(void) -{ - return class_for_each_device(®ulator_class, NULL, NULL, - _regulator_suspend_finish); -} -EXPORT_SYMBOL_GPL(regulator_suspend_finish); /** * regulator_has_full_constraints - the system has fully specified constraints diff --git a/include/linux/regulator/machine.h b/include/linux/regulator/machine.h index ce89c5548c89..c4a56df8931b 100644 --- a/include/linux/regulator/machine.h +++ b/include/linux/regulator/machine.h @@ -236,12 +236,12 @@ struct regulator_init_data { #ifdef CONFIG_REGULATOR void regulator_has_full_constraints(void); -int regulator_suspend_prepare(suspend_state_t state); -int regulator_suspend_finish(void); #else static inline void regulator_has_full_constraints(void) { } +#endif + static inline int regulator_suspend_prepare(suspend_state_t state) { return 0; @@ -250,6 +250,5 @@ static inline int regulator_suspend_finish(void) { return 0; } -#endif #endif -- 2.15.1