Received: by 2002:a05:6358:9144:b0:117:f937:c515 with SMTP id r4csp4788438rwr; Mon, 8 May 2023 12:41:32 -0700 (PDT) X-Google-Smtp-Source: ACHHUZ6u2EG8HJX0lURi+mr6P0/wkgpXDc6Pc+9cjug9MnhutEMXZ4dmrSSqlp3TczACf6ZuWC+H X-Received: by 2002:a05:6a00:ccb:b0:63d:315f:560f with SMTP id b11-20020a056a000ccb00b0063d315f560fmr16512361pfv.13.1683574892480; Mon, 08 May 2023 12:41:32 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1683574892; cv=none; d=google.com; s=arc-20160816; b=ezCU+KKB8jQ/UU9wg9AypKpfEuURXV7zFSnRuRC/WqWBAO/Abv8yjncGLTgeRU4AmP Ql/RTmAmhmr+2zIMc9Y+SaZrdfvuU3T/2j096iTqhz8KHaK92CNlrLEn4L/PZHpry/Et yfv7wF8zwRZOxwwYF/t/U6fgXJdEnailNCi85CIv35qYTu/hd1S+IR/oBlYl7DnMVE5p AkCqPhqutu9apQUwkDV5uumGDa8QoHRYY2rcHYP3vhhtxK+EcaoAn9NW98gCRxC9QcXD 9i92YHdPk2A3qbqiSzZwsgj5MiDHdrYWqi9kATmvIDqIKifBs4ePpiMpZATROCOTzMC5 c39g== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:in-reply-to:from:references:cc:to:subject :user-agent:mime-version:date:message-id:dkim-signature; bh=4qD8FYX4YusICqrFcsI+adyMTWlvz4Qtk4KkpJmlAIk=; b=XuXYTXqdEVA/ztfGWQrx2RZ9irKRk8IWmju+QGW5LjvCTgq/ffp3x6t/Mc9toorgeS A3r6g+UmWsJCuxn04avtfXvZd3BBkGep5iL65c7fVot6m4SBl1vm5gm34okpYt0J7Z3g GwmBBDOBOud2lk4ZWj92bbsjDXYSsZ7VO5xh5QYXg6uHfQlzN/2BJ3Lmw3raWsJb8Unp 3vhLMbk+YCBaWw7K2Ha/6VCvSLNJZ4XzZLtqRxTht3nPRMwkwWK9w+y9h/MDs2DVTwwj rmfTbICmPCa4pTViWCpxzI6r0SAX6pQhIV9OUAyNBDlbJA8HxocuT6MOUYPZlzsRp+Xq 7mgA== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@broadcom.com header.s=google header.b=DHVp277J; 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; dmarc=pass (p=QUARANTINE sp=QUARANTINE dis=NONE) header.from=broadcom.com Return-Path: Received: from out1.vger.email (out1.vger.email. [2620:137:e000::1:20]) by mx.google.com with ESMTP id x16-20020aa79ad0000000b006435b08fee8si547135pfp.196.2023.05.08.12.41.14; Mon, 08 May 2023 12:41:31 -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; dkim=pass header.i=@broadcom.com header.s=google header.b=DHVp277J; 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; dmarc=pass (p=QUARANTINE sp=QUARANTINE dis=NONE) header.from=broadcom.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S230032AbjEHTRt (ORCPT + 99 others); Mon, 8 May 2023 15:17:49 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:47330 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S229621AbjEHTRs (ORCPT ); Mon, 8 May 2023 15:17:48 -0400 Received: from mail-qk1-x72c.google.com (mail-qk1-x72c.google.com [IPv6:2607:f8b0:4864:20::72c]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 0EE9849EB for ; Mon, 8 May 2023 12:17:47 -0700 (PDT) Received: by mail-qk1-x72c.google.com with SMTP id af79cd13be357-757720be6abso103580385a.2 for ; Mon, 08 May 2023 12:17:47 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=broadcom.com; s=google; t=1683573466; x=1686165466; h=in-reply-to:from:references:cc:to:subject:user-agent:mime-version :date:message-id:from:to:cc:subject:date:message-id:reply-to; bh=4qD8FYX4YusICqrFcsI+adyMTWlvz4Qtk4KkpJmlAIk=; b=DHVp277JGgZcdZGfy7FrAidVUXte3K+I2POrh7fJ0EpVJkTLjmhAVeFrkX4d8ZB3eF ZPbjj2A+qUGG/YfrvljPt9jzUQ0rBYnmyX2fdmHCnRbWCZZdukP7nGdP9QksRrcKWNFF piD/fqYtXiC3A+YgG4pi6QXiS8G2QqBmlXzZo= X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20221208; t=1683573466; x=1686165466; h=in-reply-to:from:references:cc:to:subject:user-agent:mime-version :date:message-id:x-gm-message-state:from:to:cc:subject:date :message-id:reply-to; bh=4qD8FYX4YusICqrFcsI+adyMTWlvz4Qtk4KkpJmlAIk=; b=YKIP1qSEQt4lPaUkQIu1lYORJd8WU7xFsko1VTCfWIEX2GL1YMGyqHXRz7UCI3Zo1y 83IwpgFFNbt/jApsBydzsRHn9aGHHemXMRFWi07C3vVV8b+mIMbBndjERRAKaR4hCTjw TNzQzpzhcJ8F6ffw4vGFfzRvpcm4dKRZvbc4U0Ois6pcxAIkg8UYzptYW8ce7EN3DCA3 43cthi2coaLechUMDBgUYl/mZBjRZ3eJk/SxVCyDtL6wDsafqK3DQWIRO9ux7BDuhx6f fzdOfPG2L7Vqts9ql+B3aYVU6DquNjz0U2bH4Pj08FfHk5uqzZPg08DmzwmWRInNmNkb dEPw== X-Gm-Message-State: AC+VfDznN8ddDCVghdjzMdmtcqI3HvyMtQKCfc1uFFjyvj7UaJpPCk1h uIrwFgGtEzSNWjRWu0tfecl9YA== X-Received: by 2002:a05:6214:76a:b0:621:fde:7239 with SMTP id f10-20020a056214076a00b006210fde7239mr9680527qvz.42.1683573466108; Mon, 08 May 2023 12:17:46 -0700 (PDT) Received: from [10.67.48.245] ([192.19.223.252]) by smtp.gmail.com with ESMTPSA id p9-20020a0cf549000000b0061a4a93eeadsm185631qvm.127.2023.05.08.12.17.43 (version=TLS1_3 cipher=TLS_AES_128_GCM_SHA256 bits=128/128); Mon, 08 May 2023 12:17:45 -0700 (PDT) Message-ID: <00ef2d9e-2c30-9f13-f702-f692ce0baee9@broadcom.com> Date: Mon, 8 May 2023 12:17:42 -0700 MIME-Version: 1.0 User-Agent: Mozilla/5.0 (X11; Linux x86_64; rv:102.0) Gecko/20100101 Thunderbird/102.10.0 Subject: Re: [PATCH net-next 1/3] net: phy: Let drivers check Wake-on-LAN status To: Andrew Lunn , Florian Fainelli Cc: netdev@vger.kernel.org, Doug Berger , Broadcom internal kernel review list , "David S. Miller" , Eric Dumazet , Jakub Kicinski , Paolo Abeni , Heiner Kallweit , Russell King , =?UTF-8?Q?Marek_Beh=c3=ban?= , Peter Geis , Frank , open list References: <20230508184309.1628108-1-f.fainelli@gmail.com> <20230508184309.1628108-2-f.fainelli@gmail.com> From: Florian Fainelli In-Reply-To: Content-Type: multipart/signed; protocol="application/pkcs7-signature"; micalg=sha-256; boundary="0000000000006bad9b05fb337eca" X-Spam-Status: No, score=-3.9 required=5.0 tests=BAYES_00,DKIMWL_WL_HIGH, DKIM_SIGNED,DKIM_VALID,DKIM_VALID_AU,DKIM_VALID_EF,NICE_REPLY_A, RCVD_IN_DNSWL_NONE,SPF_HELO_NONE,SPF_NONE,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 --0000000000006bad9b05fb337eca Content-Language: en-US Content-Type: text/plain; charset=UTF-8; format=flowed Content-Transfer-Encoding: 7bit On 5/8/23 12:02, Andrew Lunn wrote: > On Mon, May 08, 2023 at 11:43:07AM -0700, Florian Fainelli wrote: >> A few PHY drivers are currently attempting to not suspend the PHY when >> Wake-on-LAN is enabled, however that code is not currently executing at >> all due to an early check in phy_suspend(). >> >> This prevents PHY drivers from making an appropriate decisions and put >> the hardware into a low power state if desired. >> >> In order to allow the PHY framework to always call into the PHY driver's >> ->suspend routine whether Wake-on-LAN is enabled or not, provide a >> phydev::wol_enabled boolean that tracks whether the PHY or the attached >> MAC has Wake-on-LAN enabled. >> >> If phydev::wol_enabled then the PHY shall not prevent its own >> Wake-on-LAN detection logic from working and shall not prevent the >> Ethernet MAC from receiving packets for matching. > > Hi Florian > > Did you look at using late_suspend for this? Then there would not be > any need to change all these drivers which are happy as they are. I did not know its existence until you mentioned it, this would require plumbing all the way from the MDIO bus driver down to the PHY driver level, which could be done, but for a single driver? The way Linux suspends devices currently, and the fact that the interrupt is driven level low, it does not give much room if at all for missing the interrupt AFAICT. phy_suspend() is called both from the system suspend path, but also whenever the PHY is unused, and this is a nice property because we do not really need to differentiate these paths usually, that includes Wake-on-LAN. Besides there are drivers like drivers/net/phy/at803x.c that wish to isolate the PHY if WoL is enabled and which are currently not doing it because this never gets called. -- Florian --0000000000006bad9b05fb337eca Content-Type: application/pkcs7-signature; name="smime.p7s" Content-Transfer-Encoding: base64 Content-Disposition: attachment; filename="smime.p7s" Content-Description: S/MIME Cryptographic Signature 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 riBJ/K1AFUjRAjFhGV64l++td7dkmnq/X8ET75ti+w1s4FRpFqkD2m7pg5NxdsZphYIXAgMBAAGj QjBAMA4GA1UdDwEB/wQEAwIBBjAPBgNVHRMBAf8EBTADAQH/MB0GA1UdDgQWBBSP8Et/qC5FJK5N UPpjmove4t0bvDANBgkqhkiG9w0BAQsFAAOCAQEAS0DbwFCq/sgM7/eWVEVJu5YACUGssxOGhigH M8pr5nS5ugAtrqQK0/Xx8Q+Kv3NnSoPHRHt44K9ubG8DKY4zOUXDjuS5V2yq/BKW7FPGLeQkbLmU Y/vcU2hnVj6DuM81IcPJaP7O2sJTqsyQiunwXUaMld16WCgaLx3ezQA3QY/tRG3XUyiXfvNnBB4V 14qWtNPeTCekTBtzc3b0F5nCH3oO4y0IrQocLP88q1UOD5F+NuvDV0m+4S4tfGCLw0FREyOdzvcy a5QBqJnnLDMfOjsl0oZAzjsshnjJYS8Uuu7bVW/fhO4FCU29KNhyztNiUGUe65KXgzHZs7XKR1g/ XzCCBVgwggRAoAMCAQICDBP8P9hKRVySg3Qv5DANBgkqhkiG9w0BAQsFADBbMQswCQYDVQQGEwJC RTEZMBcGA1UEChMQR2xvYmFsU2lnbiBudi1zYTExMC8GA1UEAxMoR2xvYmFsU2lnbiBHQ0MgUjMg UGVyc29uYWxTaWduIDIgQ0EgMjAyMDAeFw0yMjA5MTAxMjE4MTFaFw0yNTA5MTAxMjE4MTFaMIGW MQswCQYDVQQGEwJJTjESMBAGA1UECBMJS2FybmF0YWthMRIwEAYDVQQHEwlCYW5nYWxvcmUxFjAU BgNVBAoTDUJyb2FkY29tIEluYy4xGTAXBgNVBAMTEEZsb3JpYW4gRmFpbmVsbGkxLDAqBgkqhkiG 9w0BCQEWHWZsb3JpYW4uZmFpbmVsbGlAYnJvYWRjb20uY29tMIIBIjANBgkqhkiG9w0BAQEFAAOC AQ8AMIIBCgKCAQEA+oi3jMmHltY4LMUy8Up5+1zjd1iSgUBXhwCJLj1GJQF+GwP8InemBbk5rjlC UwbQDeIlOfb8xGqHoQFGSW8p9V1XUw+cthISLkycex0AJ09ufePshLZygRLREU0H4ecNPMejxCte KdtB4COST4uhBkUCo9BSy1gkl8DJ8j/BQ1KNUx6oYe0CntRag+EnHv9TM9BeXBBLfmMRnWNhvOSk nSmRX0J3d9/G2A3FIC6WY2XnLW7eAZCQPa1Tz3n2B5BGOxwqhwKLGLNu2SRCPHwOdD6e0drURF7/ Vax85/EqkVnFNlfxtZhS0ugx5gn2pta7bTdBm1IG4TX+A3B1G57rVwIDAQABo4IB3jCCAdowDgYD VR0PAQH/BAQDAgWgMIGjBggrBgEFBQcBAQSBljCBkzBOBggrBgEFBQcwAoZCaHR0cDovL3NlY3Vy ZS5nbG9iYWxzaWduLmNvbS9jYWNlcnQvZ3NnY2NyM3BlcnNvbmFsc2lnbjJjYTIwMjAuY3J0MEEG CCsGAQUFBzABhjVodHRwOi8vb2NzcC5nbG9iYWxzaWduLmNvbS9nc2djY3IzcGVyc29uYWxzaWdu MmNhMjAyMDBNBgNVHSAERjBEMEIGCisGAQQBoDIBKAowNDAyBggrBgEFBQcCARYmaHR0cHM6Ly93 d3cuZ2xvYmFsc2lnbi5jb20vcmVwb3NpdG9yeS8wCQYDVR0TBAIwADBJBgNVHR8EQjBAMD6gPKA6 hjhodHRwOi8vY3JsLmdsb2JhbHNpZ24uY29tL2dzZ2NjcjNwZXJzb25hbHNpZ24yY2EyMDIwLmNy bDAoBgNVHREEITAfgR1mbG9yaWFuLmZhaW5lbGxpQGJyb2FkY29tLmNvbTATBgNVHSUEDDAKBggr BgEFBQcDBDAfBgNVHSMEGDAWgBSWM9HmWBdbNHWKgVZk1b5I3qGPzzAdBgNVHQ4EFgQUUwwfJ6/F KL0fRdVROal/Lp4lAF0wDQYJKoZIhvcNAQELBQADggEBAKBgfteDc1mChZjKBY4xAplC6uXGyBrZ kNGap1mHJ+JngGzZCz+dDiHRQKGpXLxkHX0BvEDZLW6LGOJ83ImrW38YMOo3ZYnCYNHA9qDOakiw 2s1RH00JOkO5SkYdwCHj4DB9B7KEnLatJtD8MBorvt+QxTuSh4ze96Jz3kEIoHMvwGFkgObWblsc 3/YcLBmCgaWpZ3Ksev1vJPr5n8riG3/N4on8gO5qinmmr9Y7vGeuf5dmZrYMbnb+yCBalkUmZQwY NxADYvcRBA0ySL6sZpj8BIIhWiXiuusuBmt2Mak2eEv0xDbovE6Z6hYyl/ZnRadbgK/ClgbY3w+O AfUXEZ0xggJtMIICaQIBATBrMFsxCzAJBgNVBAYTAkJFMRkwFwYDVQQKExBHbG9iYWxTaWduIG52 LXNhMTEwLwYDVQQDEyhHbG9iYWxTaWduIEdDQyBSMyBQZXJzb25hbFNpZ24gMiBDQSAyMDIwAgwT /D/YSkVckoN0L+QwDQYJYIZIAWUDBAIBBQCggdQwLwYJKoZIhvcNAQkEMSIEID3cTMWXmbblM++J FJrew6V6EwCeR9uXD7QcWsn1dPZLMBgGCSqGSIb3DQEJAzELBgkqhkiG9w0BBwEwHAYJKoZIhvcN AQkFMQ8XDTIzMDUwODE5MTc0NlowaQYJKoZIhvcNAQkPMVwwWjALBglghkgBZQMEASowCwYJYIZI AWUDBAEWMAsGCWCGSAFlAwQBAjAKBggqhkiG9w0DBzALBgkqhkiG9w0BAQowCwYJKoZIhvcNAQEH MAsGCWCGSAFlAwQCATANBgkqhkiG9w0BAQEFAASCAQAY4JrHOkWeEV5I5C1WoYUbLGMV16F0QcuD gyEW9FfUfwyHGJybm1gLXjSziwu87Gu5Jost1P0ZGqxpkV0oFAplbp1rsbdQ7DsWqZ/fL5JMlYLQ MO6uX8XErFTCfhEnzriRl6fqY5WeWECbkyTII8nkU2tkHCWUZag6nZ0tUuZEDMsgJZdv0YhdnMWV lqcM4NPZKxzeqJ2JU+ZB4UWFRRVCOcKMOFmddhJ8XQlN7veYC0gq6ADZZLj3u357wWXaFGU+iAjb P+CFj4QZUU0vIww5xLqp7zeUVf+PsTVEumMtjPJXJdp5x6aPqF3aPcLn8vG/L1jSneyEUPec1FCi 3Ia4 --0000000000006bad9b05fb337eca--