Received: by 2002:a05:7412:f690:b0:e2:908c:2ebd with SMTP id ej16csp391909rdb; Thu, 19 Oct 2023 07:30:03 -0700 (PDT) X-Google-Smtp-Source: AGHT+IFJZRIFJBokKdjQeMtdK+wvf99L/6wxt12ErOqnowtLJ90Xod10iINSbJUA47vSobO7yE2g X-Received: by 2002:a05:6a21:3b48:b0:137:23f1:4281 with SMTP id zy8-20020a056a213b4800b0013723f14281mr2255977pzb.12.1697725803600; Thu, 19 Oct 2023 07:30:03 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1697725803; cv=none; d=google.com; s=arc-20160816; b=Ytq37v65EiqBtbE81Zz4u3petscbuoesaqnk7V4dDr6PaObKNSOAdScmWK96f566/G MCGLxf41uorXT8VlQBIGYsMGBR+Q4E26YwpLcx/1zYjleXZTkLi/Nm6NDnqkgncUTtnR Mgrms45dW4jzF5ydtGJzi/gmS5t/PDfG/1rWJr+N54Jds5jzmh/cJ+BfVVN+7z408dCZ mtTeZoL2JnVfdKUMQf/mvzXvjk7tDcA0b6ZpnUAxF0sxR287KkZt2jUUvVzCdJnwE+Fh 3nuXDgH9VbcNbfCawZSA+0IweZmFvAQkfi4T/lOHCnPJMz5ggtTuRhCCUfLryyedhQRn Ojbg== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:cc:to:content-transfer-encoding:mime-version :message-id:date:subject:from:dkim-signature; bh=cfZt1pVD+n+YiXYZj/guFFs0HNUEP9/MpCXNPUVK5KU=; fh=oy3X2PWLw23jHPkfJpWDCk03+UzuARh4FsrJgw5D9Kg=; b=hYrPN2k4l+ai0vN34eD9X3EW8sG1Y2g28CZrn52hcbk0zcTQ55vwhMIgAyxkXvjqYP 5Fu7gFk2xhVP4Ph8nUwCbQA6vPpchgewO8ykcwi0QiL9YB5KPVtWp45UepVWM1DSCYHq JYhnWSTIiK0lm0QcDkEDXaPcKNdggAw1hu963LWPpHTtwMTV8HTkPdQ4JYFL5D5b+yIT 3RqABOR/LtxEUSxX8SSv5GwN+JP42eOLfMDIEhiEC6YgKPvSH+jctqsrMhU2o3y/GUcg exii9g3LTi2PtHFb6iCuVQz/4vE0PFSamfDLbaa71W7UIu46jAHV5BFYGIP/Kyk0dwUY d+sw== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@bootlin.com header.s=gm1 header.b=dQ7PyXUg; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.32 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=REJECT sp=REJECT dis=NONE) header.from=bootlin.com Return-Path: Received: from agentk.vger.email (agentk.vger.email. [23.128.96.32]) by mx.google.com with ESMTPS id cb15-20020a056a02070f00b00578ac88e239si5117291pgb.595.2023.10.19.07.30.03 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Thu, 19 Oct 2023 07:30:03 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.32 as permitted sender) client-ip=23.128.96.32; Authentication-Results: mx.google.com; dkim=pass header.i=@bootlin.com header.s=gm1 header.b=dQ7PyXUg; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.32 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=REJECT sp=REJECT dis=NONE) header.from=bootlin.com Received: from out1.vger.email (depot.vger.email [IPv6:2620:137:e000::3:0]) by agentk.vger.email (Postfix) with ESMTP id A9CE4819D73E; Thu, 19 Oct 2023 07:29:56 -0700 (PDT) X-Virus-Status: Clean X-Virus-Scanned: clamav-milter 0.103.10 at agentk.vger.email Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1346047AbjJSO3q (ORCPT + 99 others); Thu, 19 Oct 2023 10:29:46 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:47410 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S233192AbjJSO3p (ORCPT ); Thu, 19 Oct 2023 10:29:45 -0400 Received: from relay3-d.mail.gandi.net (relay3-d.mail.gandi.net [IPv6:2001:4b98:dc4:8::223]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 99EF19F; Thu, 19 Oct 2023 07:29:41 -0700 (PDT) Received: by mail.gandi.net (Postfix) with ESMTPSA id E0FF960003; Thu, 19 Oct 2023 14:29:37 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=bootlin.com; s=gm1; t=1697725780; h=from:from:reply-to:subject:subject:date:date:message-id:message-id: to:to:cc:cc:mime-version:mime-version:content-type:content-type: content-transfer-encoding:content-transfer-encoding; bh=cfZt1pVD+n+YiXYZj/guFFs0HNUEP9/MpCXNPUVK5KU=; b=dQ7PyXUg56d/+IHXLscrh+ob7A5pD7/aM7hfxM0/7/bqPoRX8FncQmg+kYQrE80yEeZjUU U3gcARhGgiOicN6voOQNz3hJGGWcZE3KbZB9xaxBjouPxvMgsocqycM06NjqqSo8vquBVi 0S1Hs2oYn6iPmRRp26Q596QdSVqveYeMmHKcinXApUgqfUZ9kobYYTX9ZqVDoCyETcft3o zTt5XQq7gQHshbmbfNWE312vjQbDv+fV0vQElQYQ1fFtQrhEKgVh1PcV0NEDfAjshUlu7L e4OHUkZK7qAC4VOmD60FbP9yLkufp3VRWrJQ4qBG2e3EKEegwoX9HRTFMHj21Q== From: Kory Maincent Subject: [PATCH net-next v6 00/16] net: Make timestamping selectable Date: Thu, 19 Oct 2023 16:29:15 +0200 Message-Id: <20231019-feature_ptp_netnext-v6-0-71affc27b0e5@bootlin.com> MIME-Version: 1.0 Content-Type: text/plain; charset="utf-8" Content-Transfer-Encoding: 8bit X-B4-Tracking: v=1; b=H4sIADs9MWUC/x2M3QqEIBQGXyXOdULan/QqEVG7n3VuTNQWIXr3t S4HZuaiAM8INBQXefw48GEzdGVBn32xGwR/M5OqVC0rKYXBEk+P2UU3W0SLFEVtVK/bXkM3K+X SeRhO73WkLInHoum+/6AcXohvAAAA To: Florian Fainelli , Broadcom internal kernel review list , Andrew Lunn , Heiner Kallweit , Russell King , "David S. Miller" , Eric Dumazet , Jakub Kicinski , Paolo Abeni , Richard Cochran , Radu Pirea , Jay Vosburgh , Andy Gospodarek , Nicolas Ferre , Claudiu Beznea , Willem de Bruijn , Jonathan Corbet , Horatiu Vultur , UNGLinuxDriver@microchip.com, Simon Horman , Vladimir Oltean Cc: Thomas Petazzoni , netdev@vger.kernel.org, linux-kernel@vger.kernel.org, linux-doc@vger.kernel.org, Maxime Chevallier , Kory Maincent , Jay Vosburgh X-Mailer: b4 0.12.3 X-GND-Sasl: kory.maincent@bootlin.com X-Spam-Status: No, score=-0.8 required=5.0 tests=DKIM_SIGNED,DKIM_VALID, DKIM_VALID_AU,HEADER_FROM_DIFFERENT_DOMAINS,MAILING_LIST_MULTI, SPF_HELO_NONE,SPF_PASS autolearn=unavailable autolearn_force=no version=3.4.6 X-Spam-Checker-Version: SpamAssassin 3.4.6 (2021-04-09) on agentk.vger.email Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org X-Greylist: Sender passed SPF test, not delayed by milter-greylist-4.6.4 (agentk.vger.email [0.0.0.0]); Thu, 19 Oct 2023 07:29:56 -0700 (PDT) Up until now, there was no way to let the user select the layer at which time stamping occurs. The stack assumed that PHY time stamping is always preferred, but some MAC/PHY combinations were buggy. This series updates the default MAC/PHY default timestamping and aims to allow the user to select the desired layer administratively. Changes in v2: - Move selected_timestamping_layer variable of the concerned patch. - Use sysfs_streq instead of strmcmp. - Use the PHY timestamp only if available. Changes in v3: - Expose the PTP choice to ethtool instead of sysfs. You can test it with the ethtool source on branch feature_ptp of: https://github.com/kmaincent/ethtool - Added a devicetree binding to select the preferred timestamp. Changes in v4: - Move on to ethtool netlink instead of ioctl. - Add a netdev notifier to allow packet trapping by the MAC in case of PHY time stamping. - Add a PHY whitelist to not break the old PHY default time-stamping preference API. Change in v5: - Update to ndo_hwstamp_get/set. This bring several new patches. - Add few patches to make the glue. - Convert macb to ndo_hwstamp_get/set. - Add netlink specs description of new ethtool commands. - Removed netdev notifier. - Split the patches that expose the timestamping to userspace to separate the core and ethtool development. - Add description of software timestamping. - Convert PHYs hwtstamp callback to use kernel_hwtstamp_config. Change in v6: - Few fixes from the reviews. - Replace the allowlist to default_timestamp flag to know which phy is using old API behavior. - Rename the timestamping layer enum values. - Move to a simple enum instead of the mix between enum and bitfield. - Update ts_info and ts-set in software timestamping case. Signed-off-by: Kory Maincent --- Kory Maincent (15): net: Convert PHYs hwtstamp callback to use kernel_hwtstamp_config net: phy: Remove the call to phy_mii_ioctl in phy_hwstamp_get/set net: macb: Convert to ndo_hwtstamp_get() and ndo_hwtstamp_set() net: Make dev_set_hwtstamp_phylib accessible net: phy: micrel: fix ts_info value in case of no phc net_tstamp: Add TIMESTAMPING SOFTWARE and HARDWARE mask net: ethtool: Add a command to expose current time stamping layer netlink: specs: Introduce new netlink command to get current timestamp net: ethtool: Add a command to list available time stamping layers netlink: specs: Introduce new netlink command to list available time stamping layers net: Replace hwtstamp_source by timestamping layer net: Change the API of PHY default timestamp to MAC net: ethtool: ts: Update GET_TS to reply the current selected timestamp net ethtool: net: Let the active time stamping layer be selectable netlink: specs: Introduce time stamping set command Richard Cochran (1): net: ethtool: Refactor identical get_ts_info implementations. Documentation/netlink/specs/ethtool.yaml | 57 +++++ Documentation/networking/ethtool-netlink.rst | 63 ++++++ drivers/net/bonding/bond_main.c | 29 +-- drivers/net/ethernet/cadence/macb.h | 15 +- drivers/net/ethernet/cadence/macb_main.c | 42 +++- drivers/net/ethernet/cadence/macb_ptp.c | 28 +-- .../net/ethernet/microchip/lan966x/lan966x_main.c | 6 +- drivers/net/macvlan.c | 14 +- drivers/net/phy/bcm-phy-ptp.c | 18 +- drivers/net/phy/dp83640.c | 27 +-- drivers/net/phy/micrel.c | 50 ++--- drivers/net/phy/mscc/mscc_ptp.c | 20 +- drivers/net/phy/nxp-c45-tja11xx.c | 20 +- drivers/net/phy/phy.c | 28 ++- drivers/net/phy/phy_device.c | 37 ++++ drivers/ptp/ptp_ines.c | 16 +- include/linux/ethtool.h | 8 + include/linux/mii_timestamper.h | 4 +- include/linux/net_tstamp.h | 11 +- include/linux/netdevice.h | 8 + include/linux/phy.h | 10 +- include/uapi/linux/ethtool_netlink.h | 29 +++ include/uapi/linux/net_tstamp.h | 18 ++ net/8021q/vlan_dev.c | 15 +- net/core/dev.c | 3 + net/core/dev_ioctl.c | 43 ++-- net/core/timestamping.c | 10 + net/ethtool/Makefile | 2 +- net/ethtool/common.c | 25 ++- net/ethtool/common.h | 1 + net/ethtool/netlink.c | 28 +++ net/ethtool/netlink.h | 4 + net/ethtool/ts.c | 244 +++++++++++++++++++++ 33 files changed, 732 insertions(+), 201 deletions(-) --- base-commit: 2b2cd9f2c53ea51bdb28203b91b6d518d88b7e03 change-id: 20231011-feature_ptp_netnext-3f278578e84b Best regards, -- Köry Maincent, Bootlin Embedded Linux and kernel engineering https://bootlin.com