Received: by 2002:a25:7ec1:0:0:0:0:0 with SMTP id z184csp1040130ybc; Tue, 12 Nov 2019 13:15:55 -0800 (PST) X-Google-Smtp-Source: APXvYqw0w2WlmlZsn+gpaZvk2qLkjRmJ7H0EGPHcUxtOMKCLmbe7sjnNccMk66XF+YFJKTFq1a23 X-Received: by 2002:a05:6402:4c7:: with SMTP id n7mr34966961edw.263.1573593355690; Tue, 12 Nov 2019 13:15:55 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1573593355; cv=none; d=google.com; s=arc-20160816; b=LbH1voY8IDHbEzhaeGxQEpcV2WKc7LzBzJ9Qb/7Sx+1AC3MkS4NFOfdpxEUdQgXo81 XQ7SrBKdmA6mQb4hB/RR8qPVQ85RI7qEtxhrMHy7XZlGY6mpRX7swW2Aw+SxUW4dylhb TjTiKgMuvBFw9XJJffo5VtmcvnLNild2fwb2g6ZQrrWhxl5JqiVuiXn6nYf1KnGx+knq jcXLgEVCynohs6RcPC1fHBblkL0tfTh5Q8B4hAuiD0RSj3I2zvh9IB7EcZMpTPk/d70y hngYJ+LSbMN56el3H6djMZR+m8enV/D2HRGKrLZ5SxjlFy0rM8cX1ObhnQFClon0xdXH DASQ== 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=KUC7J4Z1p0sgj+EpPwiyunVDslQ1dGWO2DsH/y8eRmQ=; b=Ji4w12wsv+gG4/SMAw5Nc2mRKocz+9XOdRp91ip9GlRQE+vnZZkYg6Yg2VFwVxcon7 +Z0AEMyVFJTc6UEKz5aEcE9fFWATESJfAWG8V8PMrR/qItzPN22dQWCEoHZnYgR0Nh6n AYSDBBOCde9P99efvsVzJLK8QrETWCQY7SJu19XHr/U5vDxeQIU543HpHKJM2IeCoony vzvXSNWhL2BmXZxEk1hn29xB8Wx+5Iu6NQsB5/nyQaldKShRK8s0PZluXF5fPXMeMaNn frg4QAkZpkUS+j+toxwf2dMhqtqF0XjqP9GwSz1DqJOJs3hevlxxozFTf7swLZLDaYCf CJZA== 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 a4si716822ejy.439.2019.11.12.13.15.29; Tue, 12 Nov 2019 13:15:55 -0800 (PST) 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 S1727385AbfKLVMc (ORCPT + 99 others); Tue, 12 Nov 2019 16:12:32 -0500 Received: from orthanc.universe-factory.net ([104.238.176.138]:40922 "EHLO orthanc.universe-factory.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1726910AbfKLVMc (ORCPT ); Tue, 12 Nov 2019 16:12:32 -0500 Received: from localhost.localdomain (unknown [IPv6:2001:19f0:6c01:100::2]) (using TLSv1.2 with cipher ECDHE-RSA-AES128-GCM-SHA256 (128/128 bits)) (No client certificate requested) by orthanc.universe-factory.net (Postfix) with ESMTPSA id 6220F1F56F; Tue, 12 Nov 2019 22:12:30 +0100 (CET) From: Matthias Schiffer To: netdev@vger.kernel.org Cc: linux-kernel@vger.kernel.org, davem@davemloft.net, roopa@cumulusnetworks.com, nikolay@cumulusnetworks.com, Matthias Schiffer Subject: [PATCH net-next v2 1/2] vxlan: implement get_link_ksettings ethtool method Date: Tue, 12 Nov 2019 22:12:24 +0100 Message-Id: <781196ab30ea44163e662e705cf661a1378c2cae.1573591594.git.mschiffer@universe-factory.net> X-Mailer: git-send-email 2.24.0 In-Reply-To: References: 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 Similar to VLAN and similar drivers, we can forward get_link_ksettings to the lower dev if we have one to get meaningful speed/duplex data. Signed-off-by: Matthias Schiffer --- v2: no changes drivers/net/vxlan.c | 24 ++++++++++++++++++++++-- 1 file changed, 22 insertions(+), 2 deletions(-) diff --git a/drivers/net/vxlan.c b/drivers/net/vxlan.c index 11f5776affb1..bf04bc2e68c2 100644 --- a/drivers/net/vxlan.c +++ b/drivers/net/vxlan.c @@ -3175,9 +3175,29 @@ static void vxlan_get_drvinfo(struct net_device *netdev, strlcpy(drvinfo->driver, "vxlan", sizeof(drvinfo->driver)); } +static int vxlan_get_link_ksettings(struct net_device *dev, + struct ethtool_link_ksettings *cmd) +{ + struct vxlan_dev *vxlan = netdev_priv(dev); + struct vxlan_rdst *dst = &vxlan->default_dst; + struct net_device *lowerdev = __dev_get_by_index(vxlan->net, + dst->remote_ifindex); + + if (!lowerdev) { + cmd->base.duplex = DUPLEX_UNKNOWN; + cmd->base.port = PORT_OTHER; + cmd->base.speed = SPEED_UNKNOWN; + + return 0; + } + + return __ethtool_get_link_ksettings(lowerdev, cmd); +} + static const struct ethtool_ops vxlan_ethtool_ops = { - .get_drvinfo = vxlan_get_drvinfo, - .get_link = ethtool_op_get_link, + .get_drvinfo = vxlan_get_drvinfo, + .get_link = ethtool_op_get_link, + .get_link_ksettings = vxlan_get_link_ksettings, }; static struct socket *vxlan_create_sock(struct net *net, bool ipv6, -- 2.24.0