aboutsummaryrefslogtreecommitdiffstats
path: root/net
diff options
context:
space:
mode:
Diffstat (limited to 'net')
-rw-r--r--net/core/skbuff.c1
-rw-r--r--net/socket.c20
2 files changed, 12 insertions, 9 deletions
diff --git a/net/core/skbuff.c b/net/core/skbuff.c
index c1a33033cbe2..c9f68802e992 100644
--- a/net/core/skbuff.c
+++ b/net/core/skbuff.c
@@ -3521,6 +3521,7 @@ void skb_tstamp_tx(struct sk_buff *orig_skb,
3521 memset(serr, 0, sizeof(*serr)); 3521 memset(serr, 0, sizeof(*serr));
3522 serr->ee.ee_errno = ENOMSG; 3522 serr->ee.ee_errno = ENOMSG;
3523 serr->ee.ee_origin = SO_EE_ORIGIN_TIMESTAMPING; 3523 serr->ee.ee_origin = SO_EE_ORIGIN_TIMESTAMPING;
3524 serr->ee.ee_info = SCM_TSTAMP_SND;
3524 3525
3525 err = sock_queue_err_skb(sk, skb); 3526 err = sock_queue_err_skb(sk, skb);
3526 3527
diff --git a/net/socket.c b/net/socket.c
index d8222c025061..dc0cc5d95ee5 100644
--- a/net/socket.c
+++ b/net/socket.c
@@ -106,6 +106,7 @@
106#include <linux/sockios.h> 106#include <linux/sockios.h>
107#include <linux/atalk.h> 107#include <linux/atalk.h>
108#include <net/busy_poll.h> 108#include <net/busy_poll.h>
109#include <linux/errqueue.h>
109 110
110#ifdef CONFIG_NET_RX_BUSY_POLL 111#ifdef CONFIG_NET_RX_BUSY_POLL
111unsigned int sysctl_net_busy_read __read_mostly; 112unsigned int sysctl_net_busy_read __read_mostly;
@@ -697,7 +698,7 @@ void __sock_recv_timestamp(struct msghdr *msg, struct sock *sk,
697 struct sk_buff *skb) 698 struct sk_buff *skb)
698{ 699{
699 int need_software_tstamp = sock_flag(sk, SOCK_RCVTSTAMP); 700 int need_software_tstamp = sock_flag(sk, SOCK_RCVTSTAMP);
700 struct timespec ts[3]; 701 struct scm_timestamping tss;
701 int empty = 1; 702 int empty = 1;
702 struct skb_shared_hwtstamps *shhwtstamps = 703 struct skb_shared_hwtstamps *shhwtstamps =
703 skb_hwtstamps(skb); 704 skb_hwtstamps(skb);
@@ -714,24 +715,25 @@ void __sock_recv_timestamp(struct msghdr *msg, struct sock *sk,
714 put_cmsg(msg, SOL_SOCKET, SCM_TIMESTAMP, 715 put_cmsg(msg, SOL_SOCKET, SCM_TIMESTAMP,
715 sizeof(tv), &tv); 716 sizeof(tv), &tv);
716 } else { 717 } else {
717 skb_get_timestampns(skb, &ts[0]); 718 struct timespec ts;
719 skb_get_timestampns(skb, &ts);
718 put_cmsg(msg, SOL_SOCKET, SCM_TIMESTAMPNS, 720 put_cmsg(msg, SOL_SOCKET, SCM_TIMESTAMPNS,
719 sizeof(ts[0]), &ts[0]); 721 sizeof(ts), &ts);
720 } 722 }
721 } 723 }
722 724
723 725 memset(&tss, 0, sizeof(tss));
724 memset(ts, 0, sizeof(ts)); 726 if ((sock_flag(sk, SOCK_TIMESTAMPING_SOFTWARE) ||
725 if (sock_flag(sk, SOCK_TIMESTAMPING_SOFTWARE) && 727 skb_shinfo(skb)->tx_flags & SKBTX_ANY_SW_TSTAMP) &&
726 ktime_to_timespec_cond(skb->tstamp, ts + 0)) 728 ktime_to_timespec_cond(skb->tstamp, tss.ts + 0))
727 empty = 0; 729 empty = 0;
728 if (shhwtstamps && 730 if (shhwtstamps &&
729 sock_flag(sk, SOCK_TIMESTAMPING_RAW_HARDWARE) && 731 sock_flag(sk, SOCK_TIMESTAMPING_RAW_HARDWARE) &&
730 ktime_to_timespec_cond(shhwtstamps->hwtstamp, ts + 2)) 732 ktime_to_timespec_cond(shhwtstamps->hwtstamp, tss.ts + 2))
731 empty = 0; 733 empty = 0;
732 if (!empty) 734 if (!empty)
733 put_cmsg(msg, SOL_SOCKET, 735 put_cmsg(msg, SOL_SOCKET,
734 SCM_TIMESTAMPING, sizeof(ts), &ts); 736 SCM_TIMESTAMPING, sizeof(tss), &tss);
735} 737}
736EXPORT_SYMBOL_GPL(__sock_recv_timestamp); 738EXPORT_SYMBOL_GPL(__sock_recv_timestamp);
737 739