diff options
Diffstat (limited to 'net')
-rw-r--r-- | net/core/skbuff.c | 1 | ||||
-rw-r--r-- | net/socket.c | 20 |
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 |
111 | unsigned int sysctl_net_busy_read __read_mostly; | 112 | unsigned 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 | } |
736 | EXPORT_SYMBOL_GPL(__sock_recv_timestamp); | 738 | EXPORT_SYMBOL_GPL(__sock_recv_timestamp); |
737 | 739 | ||