diff options
Diffstat (limited to 'net/socket.c')
-rw-r--r-- | net/socket.c | 29 |
1 files changed, 29 insertions, 0 deletions
diff --git a/net/socket.c b/net/socket.c index cf18c5eb592e..a7bd0df115b2 100644 --- a/net/socket.c +++ b/net/socket.c | |||
@@ -585,6 +585,35 @@ int kernel_sendmsg(struct socket *sock, struct msghdr *msg, | |||
585 | return result; | 585 | return result; |
586 | } | 586 | } |
587 | 587 | ||
588 | /* | ||
589 | * called from sock_recv_timestamp() if sock_flag(sk, SOCK_RCVTSTAMP) | ||
590 | */ | ||
591 | void __sock_recv_timestamp(struct msghdr *msg, struct sock *sk, | ||
592 | struct sk_buff *skb) | ||
593 | { | ||
594 | ktime_t kt = skb->tstamp; | ||
595 | |||
596 | if (!sock_flag(sk, SOCK_RCVTSTAMPNS)) { | ||
597 | struct timeval tv; | ||
598 | /* Race occurred between timestamp enabling and packet | ||
599 | receiving. Fill in the current time for now. */ | ||
600 | if (kt.tv64 == 0) | ||
601 | kt = ktime_get_real(); | ||
602 | skb->tstamp = kt; | ||
603 | tv = ktime_to_timeval(kt); | ||
604 | put_cmsg(msg, SOL_SOCKET, SCM_TIMESTAMP, sizeof(tv), &tv); | ||
605 | } else { | ||
606 | struct timespec ts; | ||
607 | /* Race occurred between timestamp enabling and packet | ||
608 | receiving. Fill in the current time for now. */ | ||
609 | if (kt.tv64 == 0) | ||
610 | kt = ktime_get_real(); | ||
611 | skb->tstamp = kt; | ||
612 | ts = ktime_to_timespec(kt); | ||
613 | put_cmsg(msg, SOL_SOCKET, SCM_TIMESTAMPNS, sizeof(ts), &ts); | ||
614 | } | ||
615 | } | ||
616 | |||
588 | static inline int __sock_recvmsg(struct kiocb *iocb, struct socket *sock, | 617 | static inline int __sock_recvmsg(struct kiocb *iocb, struct socket *sock, |
589 | struct msghdr *msg, size_t size, int flags) | 618 | struct msghdr *msg, size_t size, int flags) |
590 | { | 619 | { |