diff options
Diffstat (limited to 'include/net/sock.h')
-rw-r--r-- | include/net/sock.h | 18 |
1 files changed, 9 insertions, 9 deletions
diff --git a/include/net/sock.h b/include/net/sock.h index a3366c3c837a..9583639090d2 100644 --- a/include/net/sock.h +++ b/include/net/sock.h | |||
@@ -244,7 +244,7 @@ struct sock { | |||
244 | struct sk_filter *sk_filter; | 244 | struct sk_filter *sk_filter; |
245 | void *sk_protinfo; | 245 | void *sk_protinfo; |
246 | struct timer_list sk_timer; | 246 | struct timer_list sk_timer; |
247 | struct timeval sk_stamp; | 247 | ktime_t sk_stamp; |
248 | struct socket *sk_socket; | 248 | struct socket *sk_socket; |
249 | void *sk_user_data; | 249 | void *sk_user_data; |
250 | struct page *sk_sndmsg_page; | 250 | struct page *sk_sndmsg_page; |
@@ -1307,19 +1307,19 @@ static inline int sock_intr_errno(long timeo) | |||
1307 | static __inline__ void | 1307 | static __inline__ void |
1308 | sock_recv_timestamp(struct msghdr *msg, struct sock *sk, struct sk_buff *skb) | 1308 | sock_recv_timestamp(struct msghdr *msg, struct sock *sk, struct sk_buff *skb) |
1309 | { | 1309 | { |
1310 | struct timeval stamp; | 1310 | ktime_t kt = skb->tstamp; |
1311 | 1311 | ||
1312 | skb_get_timestamp(skb, &stamp); | ||
1313 | if (sock_flag(sk, SOCK_RCVTSTAMP)) { | 1312 | if (sock_flag(sk, SOCK_RCVTSTAMP)) { |
1313 | struct timeval tv; | ||
1314 | /* Race occurred between timestamp enabling and packet | 1314 | /* Race occurred between timestamp enabling and packet |
1315 | receiving. Fill in the current time for now. */ | 1315 | receiving. Fill in the current time for now. */ |
1316 | if (stamp.tv_sec == 0) | 1316 | if (kt.tv64 == 0) |
1317 | do_gettimeofday(&stamp); | 1317 | kt = ktime_get_real(); |
1318 | skb_set_timestamp(skb, &stamp); | 1318 | skb->tstamp = kt; |
1319 | put_cmsg(msg, SOL_SOCKET, SO_TIMESTAMP, sizeof(struct timeval), | 1319 | tv = ktime_to_timeval(kt); |
1320 | &stamp); | 1320 | put_cmsg(msg, SOL_SOCKET, SO_TIMESTAMP, sizeof(tv), &tv); |
1321 | } else | 1321 | } else |
1322 | sk->sk_stamp = stamp; | 1322 | sk->sk_stamp = kt; |
1323 | } | 1323 | } |
1324 | 1324 | ||
1325 | /** | 1325 | /** |