Received: by 2002:a05:6358:7058:b0:131:369:b2a3 with SMTP id 24csp9547493rwp; Thu, 20 Jul 2023 06:35:58 -0700 (PDT) X-Google-Smtp-Source: APBJJlHlQMeOygVRCONN9lkp/lgmqQIarGjN1p6XnoNMWbFv/w4bxiqm6R1qUBJkA+FD9nApEO7g X-Received: by 2002:a05:6a20:8f0d:b0:137:2d73:707f with SMTP id b13-20020a056a208f0d00b001372d73707fmr5620042pzk.5.1689860158072; Thu, 20 Jul 2023 06:35:58 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1689860158; cv=none; d=google.com; s=arc-20160816; b=imunZzQFPWooYi6+PWglEnJdeWFW8KVUrDWYeF0jMEOOU/Ww9Su+IdnHtoZQdKG4MO rirIZarRgYwno04JrhXOoQpIiE/zr0Q9pQXs4Wrpx5uGY2Bc3EvK9/YyOICr4sGVhU2D ix1MqRr7ib5ddh2mkRDLcpwKT4///MwQsNXvgl1useIEkRwAlvjIahJHm9IBkCNtTbyl eIC3FJVkVasMCmFO8aVxuBO5Rv1qLdh+e/AJx7XMsABSw0mMl+SZB/XlYPcWaIMSG0nC ZeOqhvVOPE0+s1/nR3yD87OIw2AIWKGyocFL7OXf5GE4fyhnt2zqUVA6PNYaOiQTGT1a hTTw== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:content-transfer-encoding:mime-version :references:in-reply-to:message-id:date:subject:cc:to:from; bh=MYsHiiNYq5Uwpy4l+bYI4HJsZ5/PnYrq8ClFTjVJ4uo=; fh=d9XFsL0QiW7mB0yy/Dn7n/CVmKRQqLnFoPiaUGJewck=; b=sIJnbz1KWWfjposKVlUgRCsgKxUf7ZhLWRkuZCcmZrL89Vit4DDb7ZmWAULtlKrsDU dfeSz9A0FJGOcjSesgsc8mTCfjhRTRD0rrK2XgxAuAclkzuJYeKv45hqU5q//kGtVMTs ie5oF6Adfn7a46CNTm5jax0fiPTwqE++ArRiYSkML5JaBYMqQGSmHlXrqZyfJBumaLeg Tlm4Qu9rO2TU8oKTqdgvY7KaoIL1ECfq67wCmDVYjWExZ+Tzxh6Jjp7E8/ahKSQGr5XS A4GNZPVFG4ykLv3XR4d4YMWu85E7MOa8AZl5YxVPcUAmz+w84pAuIgBuVsx6ct8SbkGV Yu/g== ARC-Authentication-Results: i=1; mx.google.com; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Return-Path: Received: from out1.vger.email (out1.vger.email. [2620:137:e000::1:20]) by mx.google.com with ESMTP id r11-20020a65498b000000b00553813c2df0si819363pgs.513.2023.07.20.06.35.43; Thu, 20 Jul 2023 06:35:57 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) client-ip=2620:137:e000::1:20; Authentication-Results: mx.google.com; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S231853AbjGTN0h (ORCPT + 99 others); Thu, 20 Jul 2023 09:26:37 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:45022 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S231847AbjGTN0Z (ORCPT ); Thu, 20 Jul 2023 09:26:25 -0400 Received: from metis.ext.pengutronix.de (metis.ext.pengutronix.de [IPv6:2001:67c:670:201:290:27ff:fe1d:cc33]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 9943E1FD7 for ; Thu, 20 Jul 2023 06:26:18 -0700 (PDT) Received: from drehscheibe.grey.stw.pengutronix.de ([2a0a:edc0:0:c01:1d::a2]) by metis.ext.pengutronix.de with esmtps (TLS1.3:ECDHE_RSA_AES_256_GCM_SHA384:256) (Exim 4.92) (envelope-from ) id 1qMTfL-0007aG-QF; Thu, 20 Jul 2023 15:26:00 +0200 Received: from [2a0a:edc0:0:1101:1d::ac] (helo=dude04.red.stw.pengutronix.de) by drehscheibe.grey.stw.pengutronix.de with esmtp (Exim 4.94.2) (envelope-from ) id 1qMTfJ-000qc3-Vg; Thu, 20 Jul 2023 15:25:57 +0200 Received: from ore by dude04.red.stw.pengutronix.de with local (Exim 4.96) (envelope-from ) id 1qMTfJ-000Ezj-12; Thu, 20 Jul 2023 15:25:57 +0200 From: Oleksij Rempel To: "David S. Miller" , Andrew Lunn , Eric Dumazet , Florian Fainelli , Jakub Kicinski , Paolo Abeni , Vladimir Oltean , Woojung Huh , Arun Ramadoss , Conor Dooley , Krzysztof Kozlowski , Rob Herring Cc: Oleksij Rempel , kernel@pengutronix.de, linux-kernel@vger.kernel.org, netdev@vger.kernel.org, UNGLinuxDriver@microchip.com, "Russell King (Oracle)" , devicetree@vger.kernel.org Subject: [PATCH net-next v1 5/6] net: dsa: microchip: use wakeup-source DT property to enable PME output Date: Thu, 20 Jul 2023 15:25:55 +0200 Message-Id: <20230720132556.57562-6-o.rempel@pengutronix.de> X-Mailer: git-send-email 2.39.2 In-Reply-To: <20230720132556.57562-1-o.rempel@pengutronix.de> References: <20230720132556.57562-1-o.rempel@pengutronix.de> MIME-Version: 1.0 Content-Transfer-Encoding: 8bit X-SA-Exim-Connect-IP: 2a0a:edc0:0:c01:1d::a2 X-SA-Exim-Mail-From: ore@pengutronix.de X-SA-Exim-Scanned: No (on metis.ext.pengutronix.de); SAEximRunCond expanded to false X-PTX-Original-Recipient: linux-kernel@vger.kernel.org X-Spam-Status: No, score=-4.2 required=5.0 tests=BAYES_00,RCVD_IN_DNSWL_MED, SPF_HELO_NONE,SPF_PASS,T_SCC_BODY_TEXT_LINE autolearn=ham autolearn_force=no version=3.4.6 X-Spam-Checker-Version: SpamAssassin 3.4.6 (2021-04-09) on lindbergh.monkeyblade.net Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org KSZ switches with WoL support signals wake event over PME pin. If this pin is attached to some external PMIC or System Controller can't be described as GPIO, the only way to describe it in the devicetree is to use wakeup-source property. So, add support for this property and enable PME switch output if this property is present. Signed-off-by: Oleksij Rempel --- drivers/net/dsa/microchip/ksz9477.c | 3 +++ drivers/net/dsa/microchip/ksz_common.c | 3 +++ drivers/net/dsa/microchip/ksz_common.h | 1 + 3 files changed, 7 insertions(+) diff --git a/drivers/net/dsa/microchip/ksz9477.c b/drivers/net/dsa/microchip/ksz9477.c index 9a531db79f832..1a3d7ae5970e2 100644 --- a/drivers/net/dsa/microchip/ksz9477.c +++ b/drivers/net/dsa/microchip/ksz9477.c @@ -1208,6 +1208,9 @@ int ksz9477_setup(struct dsa_switch *ds) return ret; } + if (dev->wakeup_source) + ksz_write8(dev, REG_SW_PME_CTRL, PME_ENABLE); + return 0; } diff --git a/drivers/net/dsa/microchip/ksz_common.c b/drivers/net/dsa/microchip/ksz_common.c index eb67bb520934d..354cc5333675b 100644 --- a/drivers/net/dsa/microchip/ksz_common.c +++ b/drivers/net/dsa/microchip/ksz_common.c @@ -3717,6 +3717,9 @@ int ksz_switch_register(struct ksz_device *dev) dev_err(dev->dev, "inconsistent synclko settings\n"); return -EINVAL; } + + dev->wakeup_source = of_property_read_bool(dev->dev->of_node, + "wakeup-source"); } ret = dsa_register_switch(dev->ds); diff --git a/drivers/net/dsa/microchip/ksz_common.h b/drivers/net/dsa/microchip/ksz_common.h index 4ec53cf4b30be..b67bb9b4631ea 100644 --- a/drivers/net/dsa/microchip/ksz_common.h +++ b/drivers/net/dsa/microchip/ksz_common.h @@ -158,6 +158,7 @@ struct ksz_device { phy_interface_t compat_interface; bool synclko_125; bool synclko_disable; + bool wakeup_source; struct vlan_table *vlan_cache; -- 2.39.2