diff options
-rw-r--r-- | include/uapi/linux/tcp.h | 1 | ||||
-rw-r--r-- | net/ipv4/tcp.c | 9 |
2 files changed, 10 insertions, 0 deletions
diff --git a/include/uapi/linux/tcp.h b/include/uapi/linux/tcp.h index e962faa5ab0d..6b1ead0b0c9d 100644 --- a/include/uapi/linux/tcp.h +++ b/include/uapi/linux/tcp.h | |||
@@ -111,6 +111,7 @@ enum { | |||
111 | #define TCP_QUEUE_SEQ 21 | 111 | #define TCP_QUEUE_SEQ 21 |
112 | #define TCP_REPAIR_OPTIONS 22 | 112 | #define TCP_REPAIR_OPTIONS 22 |
113 | #define TCP_FASTOPEN 23 /* Enable FastOpen on listeners */ | 113 | #define TCP_FASTOPEN 23 /* Enable FastOpen on listeners */ |
114 | #define TCP_TIMESTAMP 24 | ||
114 | 115 | ||
115 | struct tcp_repair_opt { | 116 | struct tcp_repair_opt { |
116 | __u32 opt_code; | 117 | __u32 opt_code; |
diff --git a/net/ipv4/tcp.c b/net/ipv4/tcp.c index 8a90bda96038..801b07b796f0 100644 --- a/net/ipv4/tcp.c +++ b/net/ipv4/tcp.c | |||
@@ -2714,6 +2714,12 @@ static int do_tcp_setsockopt(struct sock *sk, int level, | |||
2714 | else | 2714 | else |
2715 | err = -EINVAL; | 2715 | err = -EINVAL; |
2716 | break; | 2716 | break; |
2717 | case TCP_TIMESTAMP: | ||
2718 | if (!tp->repair) | ||
2719 | err = -EPERM; | ||
2720 | else | ||
2721 | tp->tsoffset = val - tcp_time_stamp; | ||
2722 | break; | ||
2717 | default: | 2723 | default: |
2718 | err = -ENOPROTOOPT; | 2724 | err = -ENOPROTOOPT; |
2719 | break; | 2725 | break; |
@@ -2962,6 +2968,9 @@ static int do_tcp_getsockopt(struct sock *sk, int level, | |||
2962 | case TCP_USER_TIMEOUT: | 2968 | case TCP_USER_TIMEOUT: |
2963 | val = jiffies_to_msecs(icsk->icsk_user_timeout); | 2969 | val = jiffies_to_msecs(icsk->icsk_user_timeout); |
2964 | break; | 2970 | break; |
2971 | case TCP_TIMESTAMP: | ||
2972 | val = tcp_time_stamp + tp->tsoffset; | ||
2973 | break; | ||
2965 | default: | 2974 | default: |
2966 | return -ENOPROTOOPT; | 2975 | return -ENOPROTOOPT; |
2967 | } | 2976 | } |