diff options
Diffstat (limited to 'include/net/tcp.h')
| -rw-r--r-- | include/net/tcp.h | 35 | 
1 files changed, 15 insertions, 20 deletions
| diff --git a/include/net/tcp.h b/include/net/tcp.h index d4ef5bf94168..78d13c88720f 100644 --- a/include/net/tcp.h +++ b/include/net/tcp.h @@ -322,6 +322,7 @@ void tcp_shutdown(struct sock *sk, int how);  int tcp_v4_early_demux(struct sk_buff *skb);  int tcp_v4_rcv(struct sk_buff *skb); +void tcp_remove_empty_skb(struct sock *sk, struct sk_buff *skb);  int tcp_v4_tw_remember_stamp(struct inet_timewait_sock *tw);  int tcp_sendmsg(struct sock *sk, struct msghdr *msg, size_t size);  int tcp_sendmsg_locked(struct sock *sk, struct msghdr *msg, size_t size); @@ -329,6 +330,8 @@ int tcp_sendpage(struct sock *sk, struct page *page, int offset, size_t size,  		 int flags);  int tcp_sendpage_locked(struct sock *sk, struct page *page, int offset,  			size_t size, int flags); +struct sk_buff *tcp_build_frag(struct sock *sk, int size_goal, int flags, +			       struct page *page, int offset, size_t *size);  ssize_t do_tcp_sendpages(struct sock *sk, struct page *page, int offset,  		 size_t size, int flags);  int tcp_send_mss(struct sock *sk, int *size_goal, int flags); @@ -386,12 +389,13 @@ struct sock *tcp_check_req(struct sock *sk, struct sk_buff *skb,  int tcp_child_process(struct sock *parent, struct sock *child,  		      struct sk_buff *skb);  void tcp_enter_loss(struct sock *sk); -void tcp_cwnd_reduction(struct sock *sk, int newly_acked_sacked, int flag); +void tcp_cwnd_reduction(struct sock *sk, int newly_acked_sacked, int newly_lost, int flag);  void tcp_clear_retrans(struct tcp_sock *tp);  void tcp_update_metrics(struct sock *sk);  void tcp_init_metrics(struct sock *sk);  void tcp_metrics_init(void);  bool tcp_peer_is_proven(struct request_sock *req, struct dst_entry *dst); +void __tcp_close(struct sock *sk, long timeout);  void tcp_close(struct sock *sk, long timeout);  void tcp_init_sock(struct sock *sk);  void tcp_init_transfer(struct sock *sk, int bpf_op, struct sk_buff *skb); @@ -406,6 +410,7 @@ void tcp_syn_ack_timeout(const struct request_sock *req);  int tcp_recvmsg(struct sock *sk, struct msghdr *msg, size_t len, int nonblock,  		int flags, int *addr_len);  int tcp_set_rcvlowat(struct sock *sk, int val); +int tcp_set_window_clamp(struct sock *sk, int val);  void tcp_data_ready(struct sock *sk);  #ifdef CONFIG_MMU  int tcp_mmap(struct file *file, struct socket *sock, @@ -606,7 +611,7 @@ void tcp_skb_collapse_tstamp(struct sk_buff *skb,  /* tcp_input.c */  void tcp_rearm_rto(struct sock *sk);  void tcp_synack_rtt_meas(struct sock *sk, struct request_sock *req); -void tcp_reset(struct sock *sk); +void tcp_reset(struct sock *sk, struct sk_buff *skb);  void tcp_skb_mark_lost_uncond_verify(struct tcp_sock *tp, struct sk_buff *skb);  void tcp_fin(struct sock *sk); @@ -1321,7 +1326,9 @@ static inline unsigned long tcp_probe0_base(const struct sock *sk)  static inline unsigned long tcp_probe0_when(const struct sock *sk,  					    unsigned long max_when)  { -	u64 when = (u64)tcp_probe0_base(sk) << inet_csk(sk)->icsk_backoff; +	u8 backoff = min_t(u8, ilog2(TCP_RTO_MAX / TCP_RTO_MIN) + 1, +			   inet_csk(sk)->icsk_backoff); +	u64 when = (u64)tcp_probe0_base(sk) << backoff;  	return (unsigned long)min_t(u64, when, max_when);  } @@ -1965,18 +1972,7 @@ static inline u32 tcp_notsent_lowat(const struct tcp_sock *tp)  	return tp->notsent_lowat ?: net->ipv4.sysctl_tcp_notsent_lowat;  } -/* @wake is one when sk_stream_write_space() calls us. - * This sends EPOLLOUT only if notsent_bytes is half the limit. - * This mimics the strategy used in sock_def_write_space(). - */ -static inline bool tcp_stream_memory_free(const struct sock *sk, int wake) -{ -	const struct tcp_sock *tp = tcp_sk(sk); -	u32 notsent_bytes = READ_ONCE(tp->write_seq) - -			    READ_ONCE(tp->snd_nxt); - -	return (notsent_bytes << wake) < tcp_notsent_lowat(tp); -} +bool tcp_stream_memory_free(const struct sock *sk, int wake);  #ifdef CONFIG_PROC_FS  int tcp4_proc_init(void); @@ -2014,15 +2010,14 @@ struct tcp_request_sock_ops {  					  const struct sock *sk,  					  const struct sk_buff *skb);  #endif -	void (*init_req)(struct request_sock *req, -			 const struct sock *sk_listener, -			 struct sk_buff *skb);  #ifdef CONFIG_SYN_COOKIES  	__u32 (*cookie_init_seq)(const struct sk_buff *skb,  				 __u16 *mss);  #endif -	struct dst_entry *(*route_req)(const struct sock *sk, struct flowi *fl, -				       const struct request_sock *req); +	struct dst_entry *(*route_req)(const struct sock *sk, +				       struct sk_buff *skb, +				       struct flowi *fl, +				       struct request_sock *req);  	u32 (*init_seq)(const struct sk_buff *skb);  	u32 (*init_ts_off)(const struct net *net, const struct sk_buff *skb);  	int (*send_synack)(const struct sock *sk, struct dst_entry *dst, | 
