Received: by 2002:a05:6a10:9848:0:0:0:0 with SMTP id x8csp3945324pxf; Tue, 6 Apr 2021 04:28:16 -0700 (PDT) X-Google-Smtp-Source: ABdhPJzYxqZbsffx6C5WajvuxT7qrDQWtQtCnudj1Rqs6Bflc/nZHyF+Smxw1BBl5X3D7FlXKWuv X-Received: by 2002:a17:906:a0c2:: with SMTP id bh2mr160941ejb.394.1617708496753; Tue, 06 Apr 2021 04:28:16 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1617708496; cv=none; d=google.com; s=arc-20160816; b=ITrUkHkJ6XB+ZkYku5sPTpMdBZ/7299j4vIeRtCDGHTnbVzE4OkvRye8G4sfE32ch/ GO86CYST4k/uamHpNbF9F6TeWxrhrP9kXPd6HippPaZQxEOEFNHQdqdlhVWI5wVho7un 9XcntYJ3wtFoHanFUl1Z9Le5TMagpJmXrKMjPKYntF4+x5oS/rdBEBR+66nUNmo996dw ruAXxlI3/f4vAHgFT3DfOSMg7DwQxIhoEPRTDqmZvMxjcNfz371CgKcgNbWhiVuwV92l t3RxyNjbPgOA++QbDE8J7h/JniIseZeOqXNpLIdj1A+BPxdMhz5fgxUqz3NMEsfFmDnl q33A== 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 :dkim-signature; bh=2B7CVc4bneBn0+oIH4XJcVlXMfyFNghvu+iRTDeNX6E=; b=bIGh6vApU9p+J70Q9hlb8y2W8kCY3nJl2qy8tQ+Jfial2U6k4PMmgbS1LGL4JKLfEY cAoRpH+72/d6hnidflfGHmMvahnTZkfNyzPzc1B6JwzmA/d43nq7JPD/un4AgYbu9BEK dx48EJLeTjd9QGjdom7GQsyrmPoUaRNaE6qvUeISZHA09F3RWIfk3jODpJMv0lWtiuFT u3GMrAQFbsUGaHm4kpTg041AG8Ff+NEfpW04RPR1iECEHb/fiXf7QmxuDTkLxZlc7DTi yVHtL7/r+u+icqXFdQ6gMgZS/47ViTcQQ6CkvG/8Pn8tn3C+OchlKxlzllTAX5N2Ud32 il+w== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@chromium.org header.s=google header.b=hlR5KlLW; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=chromium.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id r22si15522842eds.172.2021.04.06.04.27.49; Tue, 06 Apr 2021 04:28:16 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) client-ip=23.128.96.18; Authentication-Results: mx.google.com; dkim=pass header.i=@chromium.org header.s=google header.b=hlR5KlLW; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=chromium.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S241622AbhDEXOW (ORCPT + 99 others); Mon, 5 Apr 2021 19:14:22 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:41802 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S241552AbhDEXOQ (ORCPT ); Mon, 5 Apr 2021 19:14:16 -0400 Received: from mail-qt1-x82b.google.com (mail-qt1-x82b.google.com [IPv6:2607:f8b0:4864:20::82b]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 4F4F0C061756 for ; Mon, 5 Apr 2021 16:14:09 -0700 (PDT) Received: by mail-qt1-x82b.google.com with SMTP id j7so9866636qtx.5 for ; Mon, 05 Apr 2021 16:14:09 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=chromium.org; s=google; h=from:to:cc:subject:date:message-id:in-reply-to:references :mime-version:content-transfer-encoding; bh=2B7CVc4bneBn0+oIH4XJcVlXMfyFNghvu+iRTDeNX6E=; b=hlR5KlLWXM3SfaqIji/GJ8Jc+0M4zRkzN+/wAyXllIpop6vWFWlDL8IRGTQF5CUh9j Y8CnUIfxF302XZui5/tCs8DUiP2GnYjcjVdP58xmTb5+XtVz95nnJ542KC9CYWvNAaL+ 0IumAXSH2jXP8pNGHkAUjgzivvUCD5JOIGaqc= 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:in-reply-to :references:mime-version:content-transfer-encoding; bh=2B7CVc4bneBn0+oIH4XJcVlXMfyFNghvu+iRTDeNX6E=; b=rBApNUGUi+gbD5e0d/uXm2i0woKh30K198de9rHifdrCNdSFdTt5qxUUcil45MNhfk bMlFDTBkvMDffpCbnAZUZGMvEVEQ55pp5QrbjGP/UBadQvIgK065vCgJb43LKX9yhYur Xjb12efds86JxnJd/RChebD2ySI52NzEq0DqviSjoepGYxFIHzjXaIVZPy+RuzwwNPB/ GLCpjZSQtQ7W58XkM+pE+L8glYOECsWRTWymS2EAjFjWqnNBlcwhenXaTh5/LM4shkC9 uURPpHFFupjprCZ+67vTNUIXSSGs5ZYbCaAFVSTlgcL9OFe0yVt/XHp4dFzCOcUhuWb2 BXUg== X-Gm-Message-State: AOAM530TkxFAwfBlSsoGRc2c1Mj/Ml1wrRUxuxvztoj/4jha8d5VZt5y KbL0JJ2jjXBQTtCePUHZ421l5w== X-Received: by 2002:aed:3001:: with SMTP id 1mr24888246qte.344.1617664448588; Mon, 05 Apr 2021 16:14:08 -0700 (PDT) Received: from grundler-glapstation.lan ([70.134.62.80]) by smtp.gmail.com with ESMTPSA id b17sm13151650qtp.73.2021.04.05.16.14.07 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Mon, 05 Apr 2021 16:14:08 -0700 (PDT) From: Grant Grundler To: Oliver Neukum , Jakub Kicinski Cc: Roland Dreier , nic_swsd , netdev , "David S . Miller" , LKML , Andrew Lunn , Grant Grundler Subject: [PATCH net-next v4 3/4] net: cdc_ncm: record speed in status method Date: Mon, 5 Apr 2021 16:13:43 -0700 Message-Id: <20210405231344.1403025-4-grundler@chromium.org> X-Mailer: git-send-email 2.31.0.208.g409f899ff0-goog In-Reply-To: <20210405231344.1403025-1-grundler@chromium.org> References: <20210405231344.1403025-1-grundler@chromium.org> MIME-Version: 1.0 Content-Transfer-Encoding: 8bit Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org From: Oliver Neukum Until very recently, the usbnet framework only had support functions for devices which reported the link speed by explicitly querying the PHY over a MDIO interface. However, the cdc_ncm devices send notifications when the link state or link speeds change and do not expose the PHY (or modem) directly. Support funtions (e.g. usbnet_get_link_ksettings_internal()) to directly query state recorded by the cdc_ncm driver were added in a previous patch. So instead of cdc_ncm spewing the link speed into the dmesg buffer, record the link speed encoded in these notifications and tell the usbnet framework to use the new functions to get link speed/state. Link speed/state is now available via ethtool. This is especially useful given all current RTL8156 devices emit a connection/speed status notification every 32ms and this would fill the dmesg buffer. This implementation replaces the one recently submitted in de658a195ee23ca6aaffe197d1d2ea040beea0a2 : "net: usb: cdc_ncm: don't spew notifications" v2: rebased on upstream v3: changed variable names v4: rewrote commit message Signed-off-by: Oliver Neukum Tested-by: Roland Dreier Signed-off-by: Grant Grundler Reviewed-by: Andrew Lunn --- drivers/net/usb/cdc_ncm.c | 55 ++++++++++++--------------------------- 1 file changed, 17 insertions(+), 38 deletions(-) diff --git a/drivers/net/usb/cdc_ncm.c b/drivers/net/usb/cdc_ncm.c index 2644234d4c4d..6f330c7dcad2 100644 --- a/drivers/net/usb/cdc_ncm.c +++ b/drivers/net/usb/cdc_ncm.c @@ -133,17 +133,17 @@ static void cdc_ncm_get_strings(struct net_device __always_unused *netdev, u32 s static void cdc_ncm_update_rxtx_max(struct usbnet *dev, u32 new_rx, u32 new_tx); static const struct ethtool_ops cdc_ncm_ethtool_ops = { - .get_link = usbnet_get_link, - .nway_reset = usbnet_nway_reset, - .get_drvinfo = usbnet_get_drvinfo, - .get_msglevel = usbnet_get_msglevel, - .set_msglevel = usbnet_set_msglevel, - .get_ts_info = ethtool_op_get_ts_info, - .get_sset_count = cdc_ncm_get_sset_count, - .get_strings = cdc_ncm_get_strings, - .get_ethtool_stats = cdc_ncm_get_ethtool_stats, - .get_link_ksettings = usbnet_get_link_ksettings_mii, - .set_link_ksettings = usbnet_set_link_ksettings_mii, + .get_link = usbnet_get_link, + .nway_reset = usbnet_nway_reset, + .get_drvinfo = usbnet_get_drvinfo, + .get_msglevel = usbnet_get_msglevel, + .set_msglevel = usbnet_set_msglevel, + .get_ts_info = ethtool_op_get_ts_info, + .get_sset_count = cdc_ncm_get_sset_count, + .get_strings = cdc_ncm_get_strings, + .get_ethtool_stats = cdc_ncm_get_ethtool_stats, + .get_link_ksettings = usbnet_get_link_ksettings_internal, + .set_link_ksettings = NULL, }; static u32 cdc_ncm_check_rx_max(struct usbnet *dev, u32 new_rx) @@ -1826,33 +1826,9 @@ static void cdc_ncm_speed_change(struct usbnet *dev, struct usb_cdc_speed_change *data) { - uint32_t rx_speed = le32_to_cpu(data->DLBitRRate); - uint32_t tx_speed = le32_to_cpu(data->ULBitRate); - - /* if the speed hasn't changed, don't report it. - * RTL8156 shipped before 2021 sends notification about every 32ms. - */ - if (dev->rx_speed == rx_speed && dev->tx_speed == tx_speed) - return; - - dev->rx_speed = rx_speed; - dev->tx_speed = tx_speed; - - /* - * Currently the USB-NET API does not support reporting the actual - * device speed. Do print it instead. - */ - if ((tx_speed > 1000000) && (rx_speed > 1000000)) { - netif_info(dev, link, dev->net, - "%u mbit/s downlink %u mbit/s uplink\n", - (unsigned int)(rx_speed / 1000000U), - (unsigned int)(tx_speed / 1000000U)); - } else { - netif_info(dev, link, dev->net, - "%u kbit/s downlink %u kbit/s uplink\n", - (unsigned int)(rx_speed / 1000U), - (unsigned int)(tx_speed / 1000U)); - } + /* RTL8156 shipped before 2021 sends notification about every 32ms. */ + dev->rx_speed = le32_to_cpu(data->DLBitRRate); + dev->tx_speed = le32_to_cpu(data->ULBitRate); } static void cdc_ncm_status(struct usbnet *dev, struct urb *urb) @@ -1878,6 +1854,9 @@ static void cdc_ncm_status(struct usbnet *dev, struct urb *urb) * USB_CDC_NOTIFY_NETWORK_CONNECTION notification shall be * sent by device after USB_CDC_NOTIFY_SPEED_CHANGE. */ + /* RTL8156 shipped before 2021 sends notification about + * every 32ms. Don't forward notification if state is same. + */ if (netif_carrier_ok(dev->net) != !!event->wValue) usbnet_link_change(dev, !!event->wValue, 0); break; -- 2.30.1