Received: by 2002:a25:d7c1:0:0:0:0:0 with SMTP id o184csp4479050ybg; Tue, 29 Oct 2019 07:48:00 -0700 (PDT) X-Google-Smtp-Source: APXvYqyD1isOmBKHfADlH5jDjD38TZSZPpwknOsULAC4jzhtgEB5f7NE22F1sr3v67R162S1vI42 X-Received: by 2002:aa7:cc18:: with SMTP id q24mr25884174edt.150.1572360480093; Tue, 29 Oct 2019 07:48:00 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1572360480; cv=none; d=google.com; s=arc-20160816; b=H+v4+CEriophaxoo/dAgWGNlXqpj0ub0FrLo9MZiYP1QALfJfjPB7OTZyS/062DhMt TjqgBZhd0C7WNqHhjTx7wSzqRxCvvC8bOwIyCSw33Y1euwIeerM5LFxrCXGcB/oWWSVx ae/Wr2MayHHrrkTGULQ/9N5Vg6hBr4+4vv+LYsblrqMQHUDygoETIWMc512X85Y15Lf2 RXfrU1ftswQ4449JTv2p2JMsipodeJV6vaRQWhZ8JqUsxD6ghtXtkf/Jy/N+5mgCGqcZ MWn2hduJfOa0cTskYdHsrD75o//5VHLiPDu5rtLmFz0AufW7Qq3V6K4JY9jGRvA2m5Qs rJCA== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:content-transfer-encoding:mime-version :references:in-reply-to:message-id:date:subject:cc:to:from; bh=LqbLQQlKJtzzKrbaiyA8e/ZQkiT91Ni/DN6btlFH7IY=; b=RRMZP/8C1FJmQky9Ix3VPnblScTMLxLMScggrTVr/mQBHQ15QYomdzR7QIE/N46l1L JSHcEghh3+UhVHeuigiXdunA/wlf1+/zJ2/Py3yfu6YOoPDHJPzjSWWqKIY3I11I0lyX 4Rl+L/QXn0jLM96IM2s5j8sWFHgikcfXgu36wD638NtwaoGQBBEulcuzeNYKL21JiMdm yqWiqWccmqtqpGDzq0kMnMuiAaaC4gnaSJRq4ITYayUqPo6t42o+sVpgFlhih+UFxLkU FpZH6qemJeO5wsR4kki49uvsUfDSxpvGbxlutGrtf1FSlazKjLINVI6NZbEoWdT6u7lW iRyw== ARC-Authentication-Results: i=1; mx.google.com; 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 x31si11040067eda.334.2019.10.29.07.47.32; Tue, 29 Oct 2019 07:48:00 -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; 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 S2389614AbfJ2Oqo (ORCPT + 99 others); Tue, 29 Oct 2019 10:46:44 -0400 Received: from smtp2.goneo.de ([85.220.129.33]:52930 "EHLO smtp2.goneo.de" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S2389468AbfJ2Oqn (ORCPT ); Tue, 29 Oct 2019 10:46:43 -0400 Received: from localhost (localhost [127.0.0.1]) by smtp2.goneo.de (Postfix) with ESMTP id A947323F86A; Tue, 29 Oct 2019 15:46:40 +0100 (CET) X-Virus-Scanned: by goneo X-Spam-Flag: NO X-Spam-Score: -3.076 X-Spam-Level: X-Spam-Status: No, score=-3.076 tagged_above=-999 tests=[ALL_TRUSTED=-1, AWL=-0.176, BAYES_00=-1.9] autolearn=ham Received: from smtp2.goneo.de ([127.0.0.1]) by localhost (smtp2.goneo.de [127.0.0.1]) (amavisd-new, port 10024) with ESMTP id ZmTOegenedrS; Tue, 29 Oct 2019 15:46:39 +0100 (CET) Received: from lem-wkst-02.lemonage.de. (hq.lemonage.de [87.138.178.34]) by smtp2.goneo.de (Postfix) with ESMTPA id 1C6BA23F719; Tue, 29 Oct 2019 15:46:39 +0100 (CET) From: Lars Poeschel To: Lars Poeschel , Steve Winslow , Allison Randal , Kees Cook , "Gustavo A. R. Silva" , Thomas Gleixner , Greg Kroah-Hartman , netdev@vger.kernel.org (open list:NFC SUBSYSTEM), linux-kernel@vger.kernel.org (open list) Cc: Johan Hovold Subject: [PATCH v11 3/7] nfc: pn533: Add dev_up/dev_down hooks to phy_ops Date: Tue, 29 Oct 2019 15:46:29 +0100 Message-Id: <20191029144632.18097-1-poeschel@lemonage.de> X-Mailer: git-send-email 2.23.0 In-Reply-To: <20191029144320.17718-1-poeschel@lemonage.de> References: <20191029144320.17718-1-poeschel@lemonage.de> MIME-Version: 1.0 Content-Transfer-Encoding: 8bit Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org This adds hooks for dev_up and dev_down to the phy_ops. They are optional. The idea is to inform the phy driver when the nfc chip is really going to be used. When it is not used, the phy driver can suspend it's interface to the nfc chip to save some power. The nfc chip is considered not in use before dev_up and after dev_down. Cc: Johan Hovold Signed-off-by: Lars Poeschel --- Changes in v10: - Rebased the patch series on net-next 'Commit 503a64635d5e ("Merge branch 'DPAA-Ethernet-changes'")' Changes in v9: - Rebased the patch series on v5.4-rc2 Changes in v6: - Rebased the patch series on v5.3-rc5 Changes in v5: - (dev->phy_ops->dev_up) instead (dev->phy_ops) Changes in v4: - This patch is new in v4 drivers/nfc/pn533/pn533.c | 12 +++++++++++- drivers/nfc/pn533/pn533.h | 9 +++++++++ 2 files changed, 20 insertions(+), 1 deletion(-) diff --git a/drivers/nfc/pn533/pn533.c b/drivers/nfc/pn533/pn533.c index a172a32aa9d9..64836c727aee 100644 --- a/drivers/nfc/pn533/pn533.c +++ b/drivers/nfc/pn533/pn533.c @@ -2458,6 +2458,9 @@ static int pn533_dev_up(struct nfc_dev *nfc_dev) { struct pn533 *dev = nfc_get_drvdata(nfc_dev); + if (dev->phy_ops->dev_up) + dev->phy_ops->dev_up(dev); + if (dev->device_type == PN533_DEVICE_PN532) { int rc = pn532_sam_configuration(nfc_dev); @@ -2470,7 +2473,14 @@ static int pn533_dev_up(struct nfc_dev *nfc_dev) static int pn533_dev_down(struct nfc_dev *nfc_dev) { - return pn533_rf_field(nfc_dev, 0); + struct pn533 *dev = nfc_get_drvdata(nfc_dev); + int ret; + + ret = pn533_rf_field(nfc_dev, 0); + if (dev->phy_ops->dev_down && !ret) + dev->phy_ops->dev_down(dev); + + return ret; } static struct nfc_ops pn533_nfc_ops = { diff --git a/drivers/nfc/pn533/pn533.h b/drivers/nfc/pn533/pn533.h index 8bf9d6ece0f5..570ee0a3e832 100644 --- a/drivers/nfc/pn533/pn533.h +++ b/drivers/nfc/pn533/pn533.h @@ -207,6 +207,15 @@ struct pn533_phy_ops { struct sk_buff *out); int (*send_ack)(struct pn533 *dev, gfp_t flags); void (*abort_cmd)(struct pn533 *priv, gfp_t flags); + /* + * dev_up and dev_down are optional. + * They are used to inform the phy layer that the nfc chip + * is going to be really used very soon. The phy layer can then + * bring up it's interface to the chip and have it suspended for power + * saving reasons otherwise. + */ + void (*dev_up)(struct pn533 *priv); + void (*dev_down)(struct pn533 *priv); }; -- 2.23.0