diff options
author | Eric Dumazet <edumazet@google.com> | 2014-08-06 05:49:29 -0400 |
---|---|---|
committer | David S. Miller <davem@davemloft.net> | 2014-08-06 15:38:07 -0400 |
commit | 140c55d4b59581680dc8963612bdc79d19f7bef6 (patch) | |
tree | e04f86ce3087eff5aaf325031b1632d39e83a7f9 /net/socket.c | |
parent | 85417aef44fc58b08773117ceb1bc6ca5684e973 (diff) |
net-timestamp: sock_tx_timestamp() fix
sock_tx_timestamp() should not ignore initial *tx_flags value, as TCP
stack can store SKBTX_SHARED_FRAG in it.
Also first argument (struct sock *) can be const.
Signed-off-by: Eric Dumazet <edumazet@google.com>
Fixes: 4ed2d765dfac ("net-timestamp: TCP timestamping")
Cc: Willem de Bruijn <willemb@google.com>
Acked-by: Willem de Bruijn <willemb@google.com>
Signed-off-by: David S. Miller <davem@davemloft.net>
Diffstat (limited to 'net/socket.c')
-rw-r--r-- | net/socket.c | 20 |
1 files changed, 13 insertions, 7 deletions
diff --git a/net/socket.c b/net/socket.c index ae89569a2db5..95ee7d8682e7 100644 --- a/net/socket.c +++ b/net/socket.c | |||
@@ -610,20 +610,26 @@ void sock_release(struct socket *sock) | |||
610 | } | 610 | } |
611 | EXPORT_SYMBOL(sock_release); | 611 | EXPORT_SYMBOL(sock_release); |
612 | 612 | ||
613 | void sock_tx_timestamp(struct sock *sk, __u8 *tx_flags) | 613 | void sock_tx_timestamp(const struct sock *sk, __u8 *tx_flags) |
614 | { | 614 | { |
615 | *tx_flags = 0; | 615 | u8 flags = *tx_flags; |
616 | |||
616 | if (sk->sk_tsflags & SOF_TIMESTAMPING_TX_HARDWARE) | 617 | if (sk->sk_tsflags & SOF_TIMESTAMPING_TX_HARDWARE) |
617 | *tx_flags |= SKBTX_HW_TSTAMP; | 618 | flags |= SKBTX_HW_TSTAMP; |
619 | |||
618 | if (sk->sk_tsflags & SOF_TIMESTAMPING_TX_SOFTWARE) | 620 | if (sk->sk_tsflags & SOF_TIMESTAMPING_TX_SOFTWARE) |
619 | *tx_flags |= SKBTX_SW_TSTAMP; | 621 | flags |= SKBTX_SW_TSTAMP; |
622 | |||
620 | if (sk->sk_tsflags & SOF_TIMESTAMPING_TX_SCHED) | 623 | if (sk->sk_tsflags & SOF_TIMESTAMPING_TX_SCHED) |
621 | *tx_flags |= SKBTX_SCHED_TSTAMP; | 624 | flags |= SKBTX_SCHED_TSTAMP; |
625 | |||
622 | if (sk->sk_tsflags & SOF_TIMESTAMPING_TX_ACK) | 626 | if (sk->sk_tsflags & SOF_TIMESTAMPING_TX_ACK) |
623 | *tx_flags |= SKBTX_ACK_TSTAMP; | 627 | flags |= SKBTX_ACK_TSTAMP; |
624 | 628 | ||
625 | if (sock_flag(sk, SOCK_WIFI_STATUS)) | 629 | if (sock_flag(sk, SOCK_WIFI_STATUS)) |
626 | *tx_flags |= SKBTX_WIFI_STATUS; | 630 | flags |= SKBTX_WIFI_STATUS; |
631 | |||
632 | *tx_flags = flags; | ||
627 | } | 633 | } |
628 | EXPORT_SYMBOL(sock_tx_timestamp); | 634 | EXPORT_SYMBOL(sock_tx_timestamp); |
629 | 635 | ||