Received: by 2002:ac0:a5b6:0:0:0:0:0 with SMTP id m51-v6csp3274929imm; Mon, 4 Jun 2018 00:12:29 -0700 (PDT) X-Google-Smtp-Source: ADUXVKL0bFzyeeyzdO0UyNUd62PMcWNYQSmKiZjMFbE9SCKyptiWRbtdrlCRGFJhVFueewoGU3Ei X-Received: by 2002:a17:902:4081:: with SMTP id c1-v6mr20641122pld.60.1528096349507; Mon, 04 Jun 2018 00:12:29 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1528096349; cv=none; d=google.com; s=arc-20160816; b=tBWaGsDjjScF3aJk6LVciJUXmyNXwFcXobO2NuTt1ZFD9+kL6S+eYzfKEGl+gq0Co2 7X5Qi4McJjLIrrqBJtItY8QFjkTpK2GHv/eCP65x8FGWUjZBUT9ql41LjNkbMrWRMDT9 F1WiLcAjC3FxDzgUW7XhrG3PPRv6Ei27C+UPFMyjUGY62YJZ1apQQhqce2MkFKSMsXnD vMAgOMBDDzE4pMCTDGosaZ1GkDkI3SGDeIpxRWHyRmmvsCLg//YSN2/uMgv9Fl5rlYIf IrBw0E0iVhOaxJB3ds6q9cbmO/oRwtP4lt14S5U0o0L/nXV8J++xDU3aPSGX8NjUARiv 7fnQ== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:references:in-reply-to:message-id:date :subject:cc:to:from:arc-authentication-results; bh=J2Uil9H2A+HfNhHL4WxyAkJ64E0DHc23rVwOldQT+iA=; b=ceUPpRPD7z/ekIvCtnWzasA3T8dXbFYU4IaHGOyFmQIN2g3C41IXRKuY9rw1J+DYHt KZ90+iUzj18fI6gLOLgH5IstJ/MHRPat1h7L6JRIvRR1VocZliXvdqRkB5CBJQVrhnH6 XKF/2l5/5tC2dLemg2RbUxCJK3RqImqLHAQZ9oDQ98BG2mI0TvPbN3SlXYV3lE9HH//6 UXvC3Zqk4mAbvbH6CT++LA1mOmYzswzsRDKWCZM1H9g+YBgkCVRuBp9NOh8FcVPxUzWA gLvV7eOUe08hCTwWvUeiVginYYmk5Xlc4qp4pmL+jHIAJYxCm+k5NVnHkGMuPkSE9bG+ CbRw== 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; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=nxp.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id d20-v6si43655448pfn.213.2018.06.04.00.12.15; Mon, 04 Jun 2018 00:12:29 -0700 (PDT) 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; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=nxp.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1754036AbeFDHKy (ORCPT + 99 others); Mon, 4 Jun 2018 03:10:54 -0400 Received: from inva020.nxp.com ([92.121.34.13]:54842 "EHLO inva020.nxp.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1754033AbeFDHKu (ORCPT ); Mon, 4 Jun 2018 03:10:50 -0400 Received: from inva020.nxp.com (localhost [127.0.0.1]) by inva020.eu-rdc02.nxp.com (Postfix) with ESMTP id 148FF1A0030; Mon, 4 Jun 2018 09:10:49 +0200 (CEST) Received: from smtp.na-rdc02.nxp.com (inv1260.us-phx01.nxp.com [134.27.49.11]) by inva020.eu-rdc02.nxp.com (Postfix) with ESMTP id CA6251A0091; Mon, 4 Jun 2018 09:10:48 +0200 (CEST) Received: from az84smr01.freescale.net (az84smr01.freescale.net [10.64.34.197]) by inv1260.na-rdc02.nxp.com (Postfix) with ESMTP id 3932640A59; Mon, 4 Jun 2018 00:10:48 -0700 (MST) Received: from titan.ap.freescale.net ([10.192.208.233]) by az84smr01.freescale.net (8.14.3/8.14.0) with ESMTP id w547ADD2029072; Mon, 4 Jun 2018 00:10:45 -0700 From: Yangbo Lu To: netdev@vger.kernel.org, madalin.bucur@nxp.com, Richard Cochran , Rob Herring , Shawn Guo , "David S . Miller" Cc: devicetree@vger.kernel.org, linuxppc-dev@lists.ozlabs.org, linux-arm-kernel@lists.infradead.org, linux-kernel@vger.kernel.org, Yangbo Lu Subject: [PATCH 10/10] dpaa_eth: add the get_ts_info interface for ethtool Date: Mon, 4 Jun 2018 15:08:37 +0800 Message-Id: <20180604070837.19265-11-yangbo.lu@nxp.com> X-Mailer: git-send-email 2.14.1 In-Reply-To: <20180604070837.19265-1-yangbo.lu@nxp.com> References: <20180604070837.19265-1-yangbo.lu@nxp.com> X-Virus-Scanned: ClamAV using ClamSMTP Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Added the get_ts_info interface for ethtool to check the timestamping capability. Signed-off-by: Yangbo Lu --- drivers/net/ethernet/freescale/dpaa/dpaa_ethtool.c | 44 ++++++++++++++++++++ 1 files changed, 44 insertions(+), 0 deletions(-) diff --git a/drivers/net/ethernet/freescale/dpaa/dpaa_ethtool.c b/drivers/net/ethernet/freescale/dpaa/dpaa_ethtool.c index 2f933b6..a20b434 100644 --- a/drivers/net/ethernet/freescale/dpaa/dpaa_ethtool.c +++ b/drivers/net/ethernet/freescale/dpaa/dpaa_ethtool.c @@ -32,6 +32,9 @@ #define pr_fmt(fmt) KBUILD_MODNAME ": " fmt #include +#include +#include +#include #include "dpaa_eth.h" #include "mac.h" @@ -515,6 +518,46 @@ static int dpaa_set_rxnfc(struct net_device *dev, struct ethtool_rxnfc *cmd) return ret; } +static int dpaa_get_ts_info(struct net_device *net_dev, + struct ethtool_ts_info *info) +{ + struct device *dev = net_dev->dev.parent; + struct device_node *mac_node = dev->of_node; + struct device_node *fman_node = NULL, *ptp_node = NULL; + struct platform_device *ptp_dev = NULL; + struct qoriq_ptp *ptp = NULL; + + fman_node = of_get_parent(mac_node); + if (fman_node) + ptp_node = of_parse_phandle(fman_node, "ptimer-handle", 0); + + if (ptp_node) + ptp_dev = of_find_device_by_node(ptp_node); + + if (ptp_dev) + ptp = platform_get_drvdata(ptp_dev); + + if (ptp) { + info->phc_index = ptp->phc_index; +#ifdef CONFIG_FSL_DPAA_ETH_TS + info->so_timestamping = SOF_TIMESTAMPING_TX_HARDWARE | + SOF_TIMESTAMPING_RX_HARDWARE | + SOF_TIMESTAMPING_RAW_HARDWARE; + info->tx_types = (1 << HWTSTAMP_TX_OFF) | + (1 << HWTSTAMP_TX_ON); + info->rx_filters = (1 << HWTSTAMP_FILTER_NONE) | + (1 << HWTSTAMP_FILTER_ALL); + return 0; +#endif + } else { + info->phc_index = -1; + } + + info->so_timestamping = SOF_TIMESTAMPING_RX_SOFTWARE | + SOF_TIMESTAMPING_SOFTWARE; + return 0; +} + const struct ethtool_ops dpaa_ethtool_ops = { .get_drvinfo = dpaa_get_drvinfo, .get_msglevel = dpaa_get_msglevel, @@ -530,4 +573,5 @@ static int dpaa_set_rxnfc(struct net_device *dev, struct ethtool_rxnfc *cmd) .set_link_ksettings = dpaa_set_link_ksettings, .get_rxnfc = dpaa_get_rxnfc, .set_rxnfc = dpaa_set_rxnfc, + .get_ts_info = dpaa_get_ts_info, }; -- 1.7.1