3397d6
From 13e8c7b8c8537488bc7612c11c429cec274db1f9 Mon Sep 17 00:00:00 2001
3397d6
From: Miroslav Lichvar <mlichvar@redhat.com>
3397d6
Date: Tue, 23 May 2017 16:29:29 +0200
3397d6
Subject: [PATCH 6/7] net_tstamp.h: sync with net-next
3397d6
3397d6
This covers kernel changes up to:
3397d6
3397d6
commit b50a5c70ffa4fd6b6da324ab54c84adf48fb17d9
3397d6
Author: Miroslav Lichvar <mlichvar@redhat.com>
3397d6
Date:   Fri May 19 17:52:40 2017 +0200
3397d6
3397d6
    net: allow simultaneous SW and HW transmit timestamping
3397d6
3397d6
    Add SOF_TIMESTAMPING_OPT_TX_SWHW option to allow an outgoing packet to
3397d6
    be looped to the socket's error queue with a software timestamp even
3397d6
    when a hardware transmit timestamp is expected to be provided by the
3397d6
    driver.
3397d6
3397d6
    Applications using this option will receive two separate messages from
3397d6
    the error queue, one with a software timestamp and the other with a
3397d6
    hardware timestamp. As the hardware timestamp is saved to the shared skb
3397d6
    info, which may happen before the first message with software timestamp
3397d6
    is received by the application, the hardware timestamp is copied to the
3397d6
    SCM_TIMESTAMPING control message only when the skb has no software
3397d6
    timestamp or it is an incoming packet.
3397d6
3397d6
    While changing sw_tx_timestamp(), inline it in skb_tx_timestamp() as
3397d6
    there are no other users.
3397d6
3397d6
    CC: Richard Cochran <richardcochran@gmail.com>
3397d6
    CC: Willem de Bruijn <willemb@google.com>
3397d6
    Signed-off-by: Miroslav Lichvar <mlichvar@redhat.com>
3397d6
    Acked-by: Willem de Bruijn <willemb@google.com>
3397d6
    Signed-off-by: David S. Miller <davem@davemloft.net>
3397d6
3397d6
CC: Richard Cochran <richardcochran@gmail.com>
3397d6
Signed-off-by: Miroslav Lichvar <mlichvar@redhat.com>
3397d6
Signed-off-by: John W. Linville <linville@tuxdriver.com>
3397d6
(cherry picked from commit ba800e3b4acd0692fc16013acbab2c3ac1ecfe66)
3397d6
---
3397d6
 net_tstamp-copy.h | 52 +++++++++++++++++++++++++++++++++++++++++-----------
3397d6
 1 file changed, 41 insertions(+), 11 deletions(-)
3397d6
3397d6
diff --git a/net_tstamp-copy.h b/net_tstamp-copy.h
3397d6
index ae5df12..3d421d9 100644
3397d6
--- a/net_tstamp-copy.h
3397d6
+++ b/net_tstamp-copy.h
3397d6
@@ -9,6 +9,7 @@
3397d6
 #ifndef _NET_TIMESTAMPING_H
3397d6
 #define _NET_TIMESTAMPING_H
3397d6
 
3397d6
+#include <linux/types.h>
3397d6
 #include <linux/socket.h>   /* for SO_TIMESTAMPING */
3397d6
 
3397d6
 /* SO_TIMESTAMPING gets an integer bit field comprised of these values */
3397d6
@@ -20,23 +21,42 @@ enum {
3397d6
 	SOF_TIMESTAMPING_SOFTWARE = (1<<4),
3397d6
 	SOF_TIMESTAMPING_SYS_HARDWARE = (1<<5),
3397d6
 	SOF_TIMESTAMPING_RAW_HARDWARE = (1<<6),
3397d6
-	SOF_TIMESTAMPING_MASK =
3397d6
-	(SOF_TIMESTAMPING_RAW_HARDWARE - 1) |
3397d6
-	SOF_TIMESTAMPING_RAW_HARDWARE
3397d6
+	SOF_TIMESTAMPING_OPT_ID = (1<<7),
3397d6
+	SOF_TIMESTAMPING_TX_SCHED = (1<<8),
3397d6
+	SOF_TIMESTAMPING_TX_ACK = (1<<9),
3397d6
+	SOF_TIMESTAMPING_OPT_CMSG = (1<<10),
3397d6
+	SOF_TIMESTAMPING_OPT_TSONLY = (1<<11),
3397d6
+	SOF_TIMESTAMPING_OPT_STATS = (1<<12),
3397d6
+	SOF_TIMESTAMPING_OPT_PKTINFO = (1<<13),
3397d6
+	SOF_TIMESTAMPING_OPT_TX_SWHW = (1<<14),
3397d6
+
3397d6
+	SOF_TIMESTAMPING_LAST = SOF_TIMESTAMPING_OPT_TX_SWHW,
3397d6
+	SOF_TIMESTAMPING_MASK = (SOF_TIMESTAMPING_LAST - 1) |
3397d6
+				 SOF_TIMESTAMPING_LAST
3397d6
 };
3397d6
 
3397d6
+/*
3397d6
+ * SO_TIMESTAMPING flags are either for recording a packet timestamp or for
3397d6
+ * reporting the timestamp to user space.
3397d6
+ * Recording flags can be set both via socket options and control messages.
3397d6
+ */
3397d6
+#define SOF_TIMESTAMPING_TX_RECORD_MASK	(SOF_TIMESTAMPING_TX_HARDWARE | \
3397d6
+					 SOF_TIMESTAMPING_TX_SOFTWARE | \
3397d6
+					 SOF_TIMESTAMPING_TX_SCHED | \
3397d6
+					 SOF_TIMESTAMPING_TX_ACK)
3397d6
+
3397d6
 /**
3397d6
- * struct hwtstamp_config - %SIOCSHWTSTAMP parameter
3397d6
+ * struct hwtstamp_config - %SIOCGHWTSTAMP and %SIOCSHWTSTAMP parameter
3397d6
  *
3397d6
- * @flags:	no flags defined right now, must be zero
3397d6
+ * @flags:	no flags defined right now, must be zero for %SIOCSHWTSTAMP
3397d6
  * @tx_type:	one of HWTSTAMP_TX_*
3397d6
- * @rx_type:	one of one of HWTSTAMP_FILTER_*
3397d6
+ * @rx_filter:	one of HWTSTAMP_FILTER_*
3397d6
  *
3397d6
- * %SIOCSHWTSTAMP expects a &struct ifreq with a ifr_data pointer to
3397d6
- * this structure. dev_ifsioc() in the kernel takes care of the
3397d6
- * translation between 32 bit userspace and 64 bit kernel. The
3397d6
- * structure is intentionally chosen so that it has the same layout on
3397d6
- * 32 and 64 bit systems, don't break this!
3397d6
+ * %SIOCGHWTSTAMP and %SIOCSHWTSTAMP expect a &struct ifreq with a
3397d6
+ * ifr_data pointer to this structure.  For %SIOCSHWTSTAMP, if the
3397d6
+ * driver or hardware does not support the requested @rx_filter value,
3397d6
+ * the driver may use a more general filter mode.  In this case
3397d6
+ * @rx_filter will indicate the actual mode on return.
3397d6
  */
3397d6
 struct hwtstamp_config {
3397d6
 	int flags;
3397d6
@@ -108,6 +128,16 @@ enum hwtstamp_rx_filters {
3397d6
 	HWTSTAMP_FILTER_PTP_V2_SYNC,
3397d6
 	/* PTP v2/802.AS1, any layer, Delay_req packet */
3397d6
 	HWTSTAMP_FILTER_PTP_V2_DELAY_REQ,
3397d6
+
3397d6
+	/* NTP, UDP, all versions and packet modes */
3397d6
+	HWTSTAMP_FILTER_NTP_ALL,
3397d6
+};
3397d6
+
3397d6
+/* SCM_TIMESTAMPING_PKTINFO control message */
3397d6
+struct scm_ts_pktinfo {
3397d6
+	__u32 if_index;
3397d6
+	__u32 pkt_length;
3397d6
+	__u32 reserved[2];
3397d6
 };
3397d6
 
3397d6
 #endif /* _NET_TIMESTAMPING_H */
3397d6
-- 
3397d6
1.8.3.1
3397d6