aboutsummaryrefslogtreecommitdiffstats
path: root/include
diff options
context:
space:
mode:
authorRichard Cochran <richardcochran@gmail.com>2010-07-17 04:49:36 -0400
committerDavid S. Miller <davem@davemloft.net>2010-07-18 22:15:26 -0400
commitc1f19b51d1d87f3e3bb7e6648f43f7d57ed2da6b (patch)
treed9525359409e3493b48e8676717cc11ed69b640a /include
parent15f0127d1d189fda3294b7823e3e654afca54055 (diff)
net: support time stamping in phy devices.
This patch adds a new networking option to allow hardware time stamps from PHY devices. When enabled, likely candidates among incoming and outgoing network packets are offered to the PHY driver for possible time stamping. When accepted by the PHY driver, incoming packets are deferred for later delivery by the driver. The patch also adds phylib driver methods for the SIOCSHWTSTAMP ioctl and callbacks for transmit and receive time stamping. Drivers may optionally implement these functions. Signed-off-by: Richard Cochran <richard.cochran@omicron.at> Signed-off-by: David S. Miller <davem@davemloft.net>
Diffstat (limited to 'include')
-rw-r--r--include/linux/netdevice.h4
-rw-r--r--include/linux/phy.h22
-rw-r--r--include/linux/skbuff.h31
3 files changed, 57 insertions, 0 deletions
diff --git a/include/linux/netdevice.h b/include/linux/netdevice.h
index c4fedf000541..fdc3f2992230 100644
--- a/include/linux/netdevice.h
+++ b/include/linux/netdevice.h
@@ -54,6 +54,7 @@
54 54
55struct vlan_group; 55struct vlan_group;
56struct netpoll_info; 56struct netpoll_info;
57struct phy_device;
57/* 802.11 specific */ 58/* 802.11 specific */
58struct wireless_dev; 59struct wireless_dev;
59 /* source back-compat hooks */ 60 /* source back-compat hooks */
@@ -1065,6 +1066,9 @@ struct net_device {
1065#endif 1066#endif
1066 /* n-tuple filter list attached to this device */ 1067 /* n-tuple filter list attached to this device */
1067 struct ethtool_rx_ntuple_list ethtool_ntuple_list; 1068 struct ethtool_rx_ntuple_list ethtool_ntuple_list;
1069
1070 /* phy device may attach itself for hardware timestamping */
1071 struct phy_device *phydev;
1068}; 1072};
1069#define to_net_dev(d) container_of(d, struct net_device, dev) 1073#define to_net_dev(d) container_of(d, struct net_device, dev)
1070 1074
diff --git a/include/linux/phy.h b/include/linux/phy.h
index d63736a84002..6b0a782c6224 100644
--- a/include/linux/phy.h
+++ b/include/linux/phy.h
@@ -234,6 +234,8 @@ enum phy_state {
234 PHY_RESUMING 234 PHY_RESUMING
235}; 235};
236 236
237struct sk_buff;
238
237/* phy_device: An instance of a PHY 239/* phy_device: An instance of a PHY
238 * 240 *
239 * drv: Pointer to the driver for this PHY instance 241 * drv: Pointer to the driver for this PHY instance
@@ -402,6 +404,26 @@ struct phy_driver {
402 /* Clears up any memory if needed */ 404 /* Clears up any memory if needed */
403 void (*remove)(struct phy_device *phydev); 405 void (*remove)(struct phy_device *phydev);
404 406
407 /* Handles SIOCSHWTSTAMP ioctl for hardware time stamping. */
408 int (*hwtstamp)(struct phy_device *phydev, struct ifreq *ifr);
409
410 /*
411 * Requests a Rx timestamp for 'skb'. If the skb is accepted,
412 * the phy driver promises to deliver it using netif_rx() as
413 * soon as a timestamp becomes available. One of the
414 * PTP_CLASS_ values is passed in 'type'. The function must
415 * return true if the skb is accepted for delivery.
416 */
417 bool (*rxtstamp)(struct phy_device *dev, struct sk_buff *skb, int type);
418
419 /*
420 * Requests a Tx timestamp for 'skb'. The phy driver promises
421 * to deliver it to the socket's error queue as soon as a
422 * timestamp becomes available. One of the PTP_CLASS_ values
423 * is passed in 'type'.
424 */
425 void (*txtstamp)(struct phy_device *dev, struct sk_buff *skb, int type);
426
405 struct device_driver driver; 427 struct device_driver driver;
406}; 428};
407#define to_phy_driver(d) container_of(d, struct phy_driver, driver) 429#define to_phy_driver(d) container_of(d, struct phy_driver, driver)
diff --git a/include/linux/skbuff.h b/include/linux/skbuff.h
index a1b0400c8d86..f5aa87e1e0c8 100644
--- a/include/linux/skbuff.h
+++ b/include/linux/skbuff.h
@@ -1933,6 +1933,36 @@ static inline ktime_t net_invalid_timestamp(void)
1933 return ktime_set(0, 0); 1933 return ktime_set(0, 0);
1934} 1934}
1935 1935
1936extern void skb_timestamping_init(void);
1937
1938#ifdef CONFIG_NETWORK_PHY_TIMESTAMPING
1939
1940extern void skb_clone_tx_timestamp(struct sk_buff *skb);
1941extern bool skb_defer_rx_timestamp(struct sk_buff *skb);
1942
1943#else /* CONFIG_NETWORK_PHY_TIMESTAMPING */
1944
1945static inline void skb_clone_tx_timestamp(struct sk_buff *skb)
1946{
1947}
1948
1949static inline bool skb_defer_rx_timestamp(struct sk_buff *skb)
1950{
1951 return false;
1952}
1953
1954#endif /* !CONFIG_NETWORK_PHY_TIMESTAMPING */
1955
1956/**
1957 * skb_complete_tx_timestamp() - deliver cloned skb with tx timestamps
1958 *
1959 * @skb: clone of the the original outgoing packet
1960 * @hwtstamps: hardware time stamps
1961 *
1962 */
1963void skb_complete_tx_timestamp(struct sk_buff *skb,
1964 struct skb_shared_hwtstamps *hwtstamps);
1965
1936/** 1966/**
1937 * skb_tstamp_tx - queue clone of skb with send time stamps 1967 * skb_tstamp_tx - queue clone of skb with send time stamps
1938 * @orig_skb: the original outgoing packet 1968 * @orig_skb: the original outgoing packet
@@ -1965,6 +1995,7 @@ static inline void sw_tx_timestamp(struct sk_buff *skb)
1965 */ 1995 */
1966static inline void skb_tx_timestamp(struct sk_buff *skb) 1996static inline void skb_tx_timestamp(struct sk_buff *skb)
1967{ 1997{
1998 skb_clone_tx_timestamp(skb);
1968 sw_tx_timestamp(skb); 1999 sw_tx_timestamp(skb);
1969} 2000}
1970 2001