Commit 371087aa authored by Florian Westphal's avatar Florian Westphal Committed by David S. Miller

sock: expose so_timestamp options for mptcp

This exports SO_TIMESTAMP_* function for re-use by MPTCP.

Without this there is too much copy & paste needed to support
this from mptcp setsockopt path.
Acked-by: default avatarPaolo Abeni <pabeni@redhat.com>
Signed-off-by: default avatarFlorian Westphal <fw@strlen.de>
Signed-off-by: default avatarMat Martineau <mathew.j.martineau@linux.intel.com>
Signed-off-by: default avatarDavid S. Miller <davem@davemloft.net>
parent ebbf5fcb
...@@ -2743,6 +2743,7 @@ static inline bool sk_dev_equal_l3scope(struct sock *sk, int dif) ...@@ -2743,6 +2743,7 @@ static inline bool sk_dev_equal_l3scope(struct sock *sk, int dif)
void sock_def_readable(struct sock *sk); void sock_def_readable(struct sock *sk);
int sock_bindtoindex(struct sock *sk, int ifindex, bool lock_sk); int sock_bindtoindex(struct sock *sk, int ifindex, bool lock_sk);
void sock_set_timestamp(struct sock *sk, int optname, bool valbool);
void sock_enable_timestamps(struct sock *sk); void sock_enable_timestamps(struct sock *sk);
void sock_no_linger(struct sock *sk); void sock_no_linger(struct sock *sk);
void sock_set_keepalive(struct sock *sk); void sock_set_keepalive(struct sock *sk);
......
...@@ -776,6 +776,24 @@ void sock_enable_timestamps(struct sock *sk) ...@@ -776,6 +776,24 @@ void sock_enable_timestamps(struct sock *sk)
} }
EXPORT_SYMBOL(sock_enable_timestamps); EXPORT_SYMBOL(sock_enable_timestamps);
void sock_set_timestamp(struct sock *sk, int optname, bool valbool)
{
switch (optname) {
case SO_TIMESTAMP_OLD:
__sock_set_timestamps(sk, valbool, false, false);
break;
case SO_TIMESTAMP_NEW:
__sock_set_timestamps(sk, valbool, true, false);
break;
case SO_TIMESTAMPNS_OLD:
__sock_set_timestamps(sk, valbool, false, true);
break;
case SO_TIMESTAMPNS_NEW:
__sock_set_timestamps(sk, valbool, true, true);
break;
}
}
void sock_set_keepalive(struct sock *sk) void sock_set_keepalive(struct sock *sk)
{ {
lock_sock(sk); lock_sock(sk);
...@@ -989,16 +1007,10 @@ int sock_setsockopt(struct socket *sock, int level, int optname, ...@@ -989,16 +1007,10 @@ int sock_setsockopt(struct socket *sock, int level, int optname,
break; break;
case SO_TIMESTAMP_OLD: case SO_TIMESTAMP_OLD:
__sock_set_timestamps(sk, valbool, false, false);
break;
case SO_TIMESTAMP_NEW: case SO_TIMESTAMP_NEW:
__sock_set_timestamps(sk, valbool, true, false);
break;
case SO_TIMESTAMPNS_OLD: case SO_TIMESTAMPNS_OLD:
__sock_set_timestamps(sk, valbool, false, true);
break;
case SO_TIMESTAMPNS_NEW: case SO_TIMESTAMPNS_NEW:
__sock_set_timestamps(sk, valbool, true, true); sock_set_timestamp(sk, valbool, optname);
break; break;
case SO_TIMESTAMPING_NEW: case SO_TIMESTAMPING_NEW:
case SO_TIMESTAMPING_OLD: case SO_TIMESTAMPING_OLD:
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment