[<prev] [next>] [thread-next>] [day] [month] [year] [list]
Message-Id: <20221018010733.4765-1-muhammad.husaini.zulkifli@intel.com>
Date: Tue, 18 Oct 2022 09:07:28 +0800
From: Muhammad Husaini Zulkifli <muhammad.husaini.zulkifli@...el.com>
To: intel-wired-lan@...osl.org
Cc: netdev@...r.kernel.org, kuba@...nel.org, davem@...emloft.net,
edumazet@...gle.com, aravindhan.gunasekaran@...el.com,
richardcochran@...il.com, gal@...dia.com, saeed@...nel.org,
leon@...nel.org, michael.chan@...adcom.com, andy@...yhouse.net,
muhammad.husaini.zulkifli@...el.com, vinicius.gomes@...el.com
Subject: [PATCH v2 0/5] Add support for DMA timestamp for non-PTP packets
The HW TX timestamps created by the NIC via socket options can be
requested using the current network timestamps generation capability of
SOF_TIMESTAMPING_TX_HARDWARE. The most common users of this socket flag
is PTP, however other packet applications that require tx timestamps might
also ask for it.
The problem is that, when there is a lot of traffic, there is a high chance
that the timestamps for a PTP packet will be lost if both PTP and Non-PTP
packets use the same SOF TIMESTAMPING TX HARDWARE causing the tx timeout.
DMA timestamps through socket options are not currently available to
the user. Because if the user wants to, they can configure the hwtstamp
config option to use the new introduced DMA Time Stamp flag through the
setsockopt().
With these additional socket options, users can continue to utilise
HW timestamps for PTP while specifying non-PTP packets to use DMA
timestamps if the NIC can support them.
This patch series also add a new HWTSTAMP_FILTER_DMA_TIMESTAMP receive
filters. This filter can be configured for devices that support/allow the
DMA timestamp retrieval on receive side.
Any socket application can be use to verify this.
TSN Ref SW application is been used for testing by changing as below:
int timestamping_flags = SOF_TIMESTAMPING_TX_HARDWARE_DMA_FETCH;
strncpy(hwtstamp.ifr_name, opt->ifname, sizeof(hwtstamp.ifr_name)-1);
hwtstamp.ifr_data = (void *)&hwconfig;
hwconfig.tx_type = HWTSTAMP_TX_ON;
hwconfig.flags = HWTSTAMP_FLAG_DMA_TIMESTAMP;
hwconfig.rx_filter = HWTSTAMP_FILTER_ALL;
if (ioctl(sock, SIOCSHWTSTAMP, &hwtstamp) < 0) {
fprintf(stderr, "%s: %s\n", "ioctl", strerror(errno));
exit(1);
}
if (setsockopt(sock, SOL_SOCKET, SO_TIMESTAMPING, ×tamping_flags,
sizeof(timestamping_flags)) < 0)
exit_with_error("setsockopt SO_TIMESTAMPING");
v1 -> v2:
- Move to the end for the new enum.
- Add new HWTSTAMP_FILTER_DMA_TIMESTAMP receive filters.
Muhammad Husaini Zulkifli (4):
ethtool: Add new hwtstamp flag
net-timestamp: Increase the size of tsflags
net: sock: extend SO_TIMESTAMPING for DMA Fetch
ethtool: Add support for HWTSTAMP_FILTER_DMA_TIMESTAMP
Vinicius Costa Gomes (1):
igc: Add support for DMA timestamp for non-PTP packets
drivers/net/ethernet/intel/igc/igc.h | 10 +++
drivers/net/ethernet/intel/igc/igc_base.h | 2 +-
drivers/net/ethernet/intel/igc/igc_defines.h | 2 +
drivers/net/ethernet/intel/igc/igc_ethtool.c | 5 +-
drivers/net/ethernet/intel/igc/igc_main.c | 24 ++++--
drivers/net/ethernet/intel/igc/igc_ptp.c | 84 ++++++++++++++++++++
include/linux/skbuff.h | 3 +
include/net/sock.h | 12 +--
include/uapi/linux/ethtool.h | 3 +
include/uapi/linux/ethtool_netlink.h | 1 +
include/uapi/linux/net_tstamp.h | 14 +++-
net/core/dev_ioctl.c | 1 +
net/ethtool/common.c | 8 ++
net/ethtool/common.h | 2 +
net/ethtool/strset.c | 5 ++
net/ethtool/tsinfo.c | 17 ++++
net/socket.c | 5 +-
17 files changed, 181 insertions(+), 17 deletions(-)
--
2.17.1
Powered by blists - more mailing lists