From patchwork Sun Feb 4 19:15:02 2018 Content-Type: text/plain; charset="utf-8" MIME-Version: 1.0 Content-Transfer-Encoding: 7bit X-Patchwork-Submitter: Yoshihiro Kaneko X-Patchwork-Id: 869078 Return-Path: X-Original-To: incoming@patchwork.ozlabs.org Delivered-To: patchwork-incoming@bilbo.ozlabs.org Authentication-Results: ozlabs.org; spf=none (mailfrom) smtp.mailfrom=vger.kernel.org (client-ip=209.132.180.67; helo=vger.kernel.org; envelope-from=linux-gpio-owner@vger.kernel.org; receiver=) Authentication-Results: ozlabs.org; dkim=fail reason="signature verification failed" (2048-bit key; unprotected) header.d=gmail.com header.i=@gmail.com header.b="KDhF3eOZ"; dkim-atps=neutral Received: from vger.kernel.org (vger.kernel.org [209.132.180.67]) by ozlabs.org (Postfix) with ESMTP id 3zZL666qCFz9sP9 for ; Mon, 5 Feb 2018 06:15:42 +1100 (AEDT) Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1752074AbeBDTPl (ORCPT ); Sun, 4 Feb 2018 14:15:41 -0500 Received: from mail-pl0-f68.google.com ([209.85.160.68]:36345 "EHLO mail-pl0-f68.google.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1752027AbeBDTPk (ORCPT ); Sun, 4 Feb 2018 14:15:40 -0500 Received: by mail-pl0-f68.google.com with SMTP id v3so10293260plg.3; Sun, 04 Feb 2018 11:15:40 -0800 (PST) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=gmail.com; s=20161025; h=from:to:cc:subject:date:message-id; bh=F77Phd0yAeKHoTqPzem2eiWwJCBmtF4YVjjY9JgFpcc=; b=KDhF3eOZdRl3olBFoKnPm5kJ/XKaPzJwC+zejMm9wZMQ++3tHroFtSrr0UW6O1Hgs1 E95Lwiav8WR2yJFXa8kn0oNXlG7UIcsAu7XHU6Ja2Xej4Wm8Z19SfgS/vqyg9FzdUnHr hk65gfcVNidMvkLjAEWh4hcXv/5aVsLkGCUR4IQt1x6k4hWUnaRFTa0C/RdkygrGzP0e p+epcgoY/nfMdKlByEecEj27H4q0k2z67XByWG4UX0QiFqCx5xjCUeWJlDcEhoRcYrMK KmsC/TvBXO2UusY9Lc/AaYo4nZcic0Bt57IZPw8fvz3A3I+cNy5r9BwW0dvTTzzIhiWO byyQ== 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; bh=F77Phd0yAeKHoTqPzem2eiWwJCBmtF4YVjjY9JgFpcc=; b=r6SXhK+KRsrojYlYJlO8t2eJ2hF0Wwi4l8BG8BObE48eQG8tU3T3jAAU9cHqzRa9kH jd55zbT9/7JTM2S4b7mHfiZlOSkrvkhlNjE4YxRS83umUSRn4sdzICqDmawZ1/A6aX6K TGzdP5QXGrPPwXzhvs9mm4qj4ybxFHagJEzRCOZoD62RLijaiJYfhZqQC5+YaL3hyNru 0VAQWE3B2dWEGLCWg3OpDsQtCfC6ACXcS54D1+8Ml0+jHKaaCVGsEhQ1XV8VdcklqRjJ wfhVpMUNiIjYsh9H0WzzjUqXcMY/nkNWz8aZzPm4KG5IPJ8A34ncGSa4UO01W6azFC0j TidA== X-Gm-Message-State: AKwxytf9QPs8Cp20m9BCfS6/EgBKWPldm5ksiGlxQV9lvRqMZkA2CXro 90cDioGAnAUzcnFtlo5o1Z2e5g== X-Google-Smtp-Source: AH8x224+WG0RwH3190QR8OH6v/c2RYPcfhcfF/pc5UJ/qMpVD2SpZbOUXgyIWhvnEPT3t6Z0UW165w== X-Received: by 2002:a17:902:4003:: with SMTP id b3-v6mr40445896pld.154.1517771739511; Sun, 04 Feb 2018 11:15:39 -0800 (PST) Received: from localhost.localdomain (KD118152108246.ppp-bb.dion.ne.jp. [118.152.108.246]) by smtp.gmail.com with ESMTPSA id u86sm13275394pfa.102.2018.02.04.11.15.37 (version=TLS1_2 cipher=ECDHE-RSA-AES128-SHA bits=128/128); Sun, 04 Feb 2018 11:15:38 -0800 (PST) From: Yoshihiro Kaneko To: linux-gpio@vger.kernel.org Cc: Linus Walleij , Simon Horman , Magnus Damm , Geert Uytterhoeven , linux-renesas-soc@vger.kernel.org Subject: [PATCH/RFT v4] gpio: gpio-rcar: Support S2RAM Date: Mon, 5 Feb 2018 04:15:02 +0900 Message-Id: <1517771702-16984-1-git-send-email-ykaneko0929@gmail.com> X-Mailer: git-send-email 1.9.1 Sender: linux-gpio-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-gpio@vger.kernel.org From: Hien Dang This patch adds an implementation that saves and restores the state of GPIO configuration on suspend and resume. Signed-off-by: Hien Dang Signed-off-by: Takeshi Kihara [Modify structure of the bank info to simplify a saving registers] [Remove DEV_PM_OPS macro] Signed-off-by: Yoshihiro Kaneko Tested-by: Nguyen Viet Dung Reviewed-by: Simon Horman --- This patch is based on the for-next branch of linux-gpio tree. v2 [Yoshihiro Kaneko] * Modify structure of the bank info as suggested by Geert Uytterhoeven v3 [Yoshihiro Kaneko] * Remove DEV_PM_OPS macro as suggested by Vladimir Zapolskiy v4 [Yoshihiro Kaneko] * As suggested by Geert Uytterhoeven - make the name of all members of gpio_rcar_bank_info accord with the name of the registers - fix type of the 'offset' variable in unsigned int - fix the inverted logic in gpio_rcar_resume() drivers/gpio/gpio-rcar.c | 66 ++++++++++++++++++++++++++++++++++++++++++++++++ 1 file changed, 66 insertions(+) diff --git a/drivers/gpio/gpio-rcar.c b/drivers/gpio/gpio-rcar.c index e76de57..e5b0dbe 100644 --- a/drivers/gpio/gpio-rcar.c +++ b/drivers/gpio/gpio-rcar.c @@ -31,6 +31,16 @@ #include #include +struct gpio_rcar_bank_info { + u32 iointsel; + u32 inoutsel; + u32 outdt; + u32 posneg; + u32 edglevel; + u32 bothedge; + u32 intmsk; +}; + struct gpio_rcar_priv { void __iomem *base; spinlock_t lock; @@ -41,6 +51,7 @@ struct gpio_rcar_priv { unsigned int irq_parent; bool has_both_edge_trigger; bool needs_clk; + struct gpio_rcar_bank_info bank_info; }; #define IOINTSEL 0x00 /* General IO/Interrupt Switching Register */ @@ -531,11 +542,66 @@ static int gpio_rcar_remove(struct platform_device *pdev) return 0; } +#ifdef CONFIG_PM_SLEEP +static int gpio_rcar_suspend(struct device *dev) +{ + struct gpio_rcar_priv *p = dev_get_drvdata(dev); + + p->bank_info.iointsel = gpio_rcar_read(p, IOINTSEL); + p->bank_info.inoutsel = gpio_rcar_read(p, INOUTSEL); + p->bank_info.outdt = gpio_rcar_read(p, OUTDT); + p->bank_info.intmsk = gpio_rcar_read(p, INTMSK); + p->bank_info.posneg = gpio_rcar_read(p, POSNEG); + p->bank_info.edglevel = gpio_rcar_read(p, EDGLEVEL); + if (p->has_both_edge_trigger) + p->bank_info.bothedge = gpio_rcar_read(p, BOTHEDGE); + + return 0; +} + +static int gpio_rcar_resume(struct device *dev) +{ + struct gpio_rcar_priv *p = dev_get_drvdata(dev); + unsigned int offset; + u32 mask; + + for (offset = 0; offset < p->gpio_chip.ngpio; offset++) { + mask = BIT(offset); + /* I/O pin */ + if (!(p->bank_info.iointsel & mask)) { + if (p->bank_info.inoutsel & mask) + gpio_rcar_direction_output( + &p->gpio_chip, offset, + !!(p->bank_info.outdt & mask)); + else + gpio_rcar_direction_input(&p->gpio_chip, + offset); + } else { + /* Interrupt pin */ + gpio_rcar_config_interrupt_input_mode( + p, + offset, + !(p->bank_info.posneg & mask), + !(p->bank_info.edglevel & mask), + !!(p->bank_info.bothedge & mask)); + + if (p->bank_info.intmsk & mask) + gpio_rcar_write(p, MSKCLR, mask); + } + } + + return 0; +} +#endif /* CONFIG_PM_SLEEP*/ + +static SIMPLE_DEV_PM_OPS(gpio_rcar_pm_ops, gpio_rcar_suspend, gpio_rcar_resume); + static struct platform_driver gpio_rcar_device_driver = { .probe = gpio_rcar_probe, .remove = gpio_rcar_remove, .driver = { .name = "gpio_rcar", + .pm = &gpio_rcar_pm_ops, .of_match_table = of_match_ptr(gpio_rcar_of_table), } };