Received: by 2002:ac0:a5a7:0:0:0:0:0 with SMTP id m36-v6csp768074imm; Thu, 26 Jul 2018 11:38:09 -0700 (PDT) X-Google-Smtp-Source: AAOMgpcKsGo9DNaS2lcY573TGU5Ns9wazX6nUI8b44QBa437W8jSzc0YP9GU8bwUNWF8nJiCvTrt X-Received: by 2002:a63:551e:: with SMTP id j30-v6mr2922110pgb.92.1532630289587; Thu, 26 Jul 2018 11:38:09 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1532630289; cv=none; d=google.com; s=arc-20160816; b=Z5ZqnddhfJRkTGiQUJlxhJ2qb91X0uhJg3HRxmcPPs9nCyvFYHXls0TSQebWmYigzg /EjgeIgwnwUjJymF5Z5miD7BpeHNcq/2kSP4Cu2B42DVkwcRDs28H1NKP7Eg6xt3zKEo Hg+t0avGzbCod86mMNA5Yh42XsaS74Ja6OiFVzq52KGUP/S8kYGD75KMAc89wEvQFzSA IEvbOnoDOiQTXSColTsHS321FqFSt8whEdlFBJBXWgsIKHJFbb2fEzKIUTx1Ee+ZqKEj ebixnU/eTrO1Q8phOH0NJhmMbDCDKPE8XqkFSTGtPl1+oUxJUJjMdSSgcd7Szs6VC98q 8+JQ== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:references:in-reply-to:message-id:date :subject:cc:to:from:dkim-signature:arc-authentication-results; bh=U06FaEejxyxvjAYaxOat2qv5fl7gaHh65Nf8HRFkW30=; b=V+q7t4hwGw36Ns1hKPo/rG2BFKAehrjl2vtX5hw+M58Yun5mpcn71Ul5y8L3SuqYbL C1lJa3iuNAz4CyL0gCY3duIe4mxuoMetRYml/4J0Od6jwkarUtzu8+G05BQVzvyNWIXv +ibwNUnJ3wb+IycBEDaxkUIEWQhw2ICoiTzojvptIdUSeKgznSc6ErQx8w15MWCy3HHL EKSSjZqWOdF9VX2KPHl/4A1Fi18sFw7kzt3S8JfnOLC3lm84pInXs7x6inq/7GAkqg1A Sw3+/vD+016dd0OeeP1YW9mQku9HbLalLIiqjpu81suZk2PQYAqwfFRMBp3gYtJELfRT +jXQ== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@broadcom.com header.s=google header.b=iKW1K+zF; 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=QUARANTINE sp=QUARANTINE dis=NONE) header.from=broadcom.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id e21-v6si2075064pgl.148.2018.07.26.11.37.54; Thu, 26 Jul 2018 11:38:09 -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=@broadcom.com header.s=google header.b=iKW1K+zF; 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=QUARANTINE sp=QUARANTINE dis=NONE) header.from=broadcom.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1732168AbeGZTyp (ORCPT + 99 others); Thu, 26 Jul 2018 15:54:45 -0400 Received: from mail-qt0-f196.google.com ([209.85.216.196]:36210 "EHLO mail-qt0-f196.google.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1730587AbeGZTyp (ORCPT ); Thu, 26 Jul 2018 15:54:45 -0400 Received: by mail-qt0-f196.google.com with SMTP id t5-v6so2577199qtn.3 for ; Thu, 26 Jul 2018 11:36:41 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=broadcom.com; s=google; h=from:to:cc:subject:date:message-id:in-reply-to:references; bh=U06FaEejxyxvjAYaxOat2qv5fl7gaHh65Nf8HRFkW30=; b=iKW1K+zFeuKqGM3QvPsDT28zCqN+1KJCTfmkloSeyTV98rdaEczFQrO+5w92nftoOH 8YjpOYcg9GsfLVwbQLv1FaV8rcQjrNv8jgm5Ybk8a6yQCSeS0jbAFxOHlPxMiqA8w3Qo YCKPlCnUW2Lyu7OuMiGg5T/0J8wnxbSmkUoVQ= 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=U06FaEejxyxvjAYaxOat2qv5fl7gaHh65Nf8HRFkW30=; b=GTT+bqz7NQ2ODb/6nAAUY2VjPZgGs7+WyPBGG6h+feSkPfHiJngf2wox9h2muWCLUW ldySBBAB+J5J0YAmTPcRY9TrX63qFdhwHl4YZ5eqAjFI03yZZ9G/TuWquj+afTyi6Jvx K3qObpH7A+tjTMgXrakUjMVL6Q9MIVrORn0nABzdRvaTeCSyQXzZoq2boOZvocgNKvrA 9FPiJs+5HLJgIcZDTGfAil1ytd9W/WhkTC3CYDAHYUTjCcyopt2ke51mCekM0EreLRGU co+Shv0xgmQ+g7bZq/kUkxozUZVjfKCaa1wUwvMBteOg1+ePkVb/xr2Mgc8I24JcxrhI 7lIg== X-Gm-Message-State: AOUpUlFsbrDNCxZVEFlvP244rrUL48aSuuB+9S0KsDPQ47K4obx2dZG0 jdyvUlkawW9RlnfYYxoKqpxcUg== X-Received: by 2002:a0c:8441:: with SMTP id l59-v6mr2785673qva.5.1532630200886; Thu, 26 Jul 2018 11:36:40 -0700 (PDT) Received: from lbrmn-lnxub86.ric.broadcom.com ([192.19.228.250]) by smtp.gmail.com with ESMTPSA id a187-v6sm1383359qkd.47.2018.07.26.11.36.38 (version=TLS1_2 cipher=ECDHE-RSA-AES128-SHA bits=128/128); Thu, 26 Jul 2018 11:36:40 -0700 (PDT) From: Arun Parameswaran To: "David S. Miller" , Florian Fainelli , Andrew Lunn , Rob Herring , Mark Rutland , Ray Jui , Scott Branden , Catalin Marinas , Will Deacon Cc: netdev@vger.kernel.org, devicetree@vger.kernel.org, linux-arm-kernel@lists.infradead.org, linux-kernel@vger.kernel.org, bcm-kernel-feedback-list@broadcom.com, Arun Parameswaran Subject: [PATCH 6/7] net: phy: Add pm support to Broadcom iProc mdio mux driver Date: Thu, 26 Jul 2018 11:36:23 -0700 Message-Id: <1532630184-29450-7-git-send-email-arun.parameswaran@broadcom.com> X-Mailer: git-send-email 1.9.1 In-Reply-To: <1532630184-29450-1-git-send-email-arun.parameswaran@broadcom.com> References: <1532630184-29450-1-git-send-email-arun.parameswaran@broadcom.com> Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Add support for suspend and resume to the Broadcom iProc mdio mux driver. Signed-off-by: Arun Parameswaran --- drivers/net/phy/mdio-mux-bcm-iproc.c | 42 ++++++++++++++++++++++++++++++++++++ 1 file changed, 42 insertions(+) diff --git a/drivers/net/phy/mdio-mux-bcm-iproc.c b/drivers/net/phy/mdio-mux-bcm-iproc.c index 6b400dd..89c18d6 100644 --- a/drivers/net/phy/mdio-mux-bcm-iproc.c +++ b/drivers/net/phy/mdio-mux-bcm-iproc.c @@ -51,13 +51,25 @@ #define MDIO_OPERATING_FREQUENCY 11000000 #define MDIO_RATE_ADJ_DIVIDENT 1 +#define MDIO_NUM_OF_REGS_TO_RESTORE 2 + struct iproc_mdiomux_desc { void *mux_handle; void __iomem *base; struct device *dev; struct mii_bus *mii_bus; struct clk *core_clk; +#ifdef CONFIG_PM_SLEEP + u32 restore_regs[MDIO_NUM_OF_REGS_TO_RESTORE]; +#endif +}; + +#ifdef CONFIG_PM_SLEEP +static const u16 restore_reg_offsets[MDIO_NUM_OF_REGS_TO_RESTORE] = { + MDIO_RATE_ADJ_EXT_OFFSET, + MDIO_RATE_ADJ_INT_OFFSET, }; +#endif static void mdio_mux_iproc_config_clk(struct iproc_mdiomux_desc *md) { @@ -258,6 +270,35 @@ static int mdio_mux_iproc_remove(struct platform_device *pdev) return 0; } +#ifdef CONFIG_PM_SLEEP +static int mdio_mux_iproc_suspend(struct device *dev) +{ + int i; + struct iproc_mdiomux_desc *md = dev_get_drvdata(dev); + + for (i = 0; i < MDIO_NUM_OF_REGS_TO_RESTORE; i++) + md->restore_regs[i] = readl(md->base + + restore_reg_offsets[i]); + + return 0; +} + +static int mdio_mux_iproc_resume(struct device *dev) +{ + int i; + struct iproc_mdiomux_desc *md = dev_get_drvdata(dev); + + for (i = 0; i < MDIO_NUM_OF_REGS_TO_RESTORE; i++) + writel(md->restore_regs[i], + md->base + restore_reg_offsets[i]); + + return 0; +} +#endif + +static SIMPLE_DEV_PM_OPS(mdio_mux_iproc_pm_ops, + mdio_mux_iproc_suspend, mdio_mux_iproc_resume); + static const struct of_device_id mdio_mux_iproc_match[] = { { .compatible = "brcm,mdio-mux-iproc", @@ -270,6 +311,7 @@ static int mdio_mux_iproc_remove(struct platform_device *pdev) .driver = { .name = "mdio-mux-iproc", .of_match_table = mdio_mux_iproc_match, + .pm = &mdio_mux_iproc_pm_ops, }, .probe = mdio_mux_iproc_probe, .remove = mdio_mux_iproc_remove, -- 1.9.1