forked from mirrors/linux
		
	net: introduce and use custom sockopt socket flag
We will soon introduce custom setsockopt for UDP sockets, too. Instead of doing even more complex arbitrary checks inside sock_use_custom_sol_socket(), add a new socket flag and set it for the relevant socket types (currently only MPTCP). Reviewed-by: Matthieu Baerts <matthieu.baerts@tessares.net> Signed-off-by: Paolo Abeni <pabeni@redhat.com> Reviewed-by: Eric Dumazet <edumazet@google.com> Acked-by: Kuniyuki Iwashima <kuniyu@amazon.com> Signed-off-by: David S. Miller <davem@davemloft.net>
This commit is contained in:
		
							parent
							
								
									ea5ed0f00b
								
							
						
					
					
						commit
						a5ef058dc4
					
				
					 3 changed files with 6 additions and 7 deletions
				
			
		|  | @ -41,6 +41,7 @@ struct net; | ||||||
| #define SOCK_NOSPACE		2 | #define SOCK_NOSPACE		2 | ||||||
| #define SOCK_PASSCRED		3 | #define SOCK_PASSCRED		3 | ||||||
| #define SOCK_PASSSEC		4 | #define SOCK_PASSSEC		4 | ||||||
|  | #define SOCK_CUSTOM_SOCKOPT	5 | ||||||
| 
 | 
 | ||||||
| #ifndef ARCH_HAS_SOCKET_TYPES | #ifndef ARCH_HAS_SOCKET_TYPES | ||||||
| /**
 | /**
 | ||||||
|  |  | ||||||
|  | @ -2708,6 +2708,8 @@ static int mptcp_init_sock(struct sock *sk) | ||||||
| 	if (ret) | 	if (ret) | ||||||
| 		return ret; | 		return ret; | ||||||
| 
 | 
 | ||||||
|  | 	set_bit(SOCK_CUSTOM_SOCKOPT, &sk->sk_socket->flags); | ||||||
|  | 
 | ||||||
| 	/* fetch the ca name; do it outside __mptcp_init_sock(), so that clone will
 | 	/* fetch the ca name; do it outside __mptcp_init_sock(), so that clone will
 | ||||||
| 	 * propagate the correct value | 	 * propagate the correct value | ||||||
| 	 */ | 	 */ | ||||||
|  | @ -3684,6 +3686,8 @@ static int mptcp_stream_accept(struct socket *sock, struct socket *newsock, | ||||||
| 		struct mptcp_subflow_context *subflow; | 		struct mptcp_subflow_context *subflow; | ||||||
| 		struct sock *newsk = newsock->sk; | 		struct sock *newsk = newsock->sk; | ||||||
| 
 | 
 | ||||||
|  | 		set_bit(SOCK_CUSTOM_SOCKOPT, &newsock->flags); | ||||||
|  | 
 | ||||||
| 		lock_sock(newsk); | 		lock_sock(newsk); | ||||||
| 
 | 
 | ||||||
| 		/* PM/worker can now acquire the first subflow socket
 | 		/* PM/worker can now acquire the first subflow socket
 | ||||||
|  |  | ||||||
|  | @ -2199,13 +2199,7 @@ SYSCALL_DEFINE4(recv, int, fd, void __user *, ubuf, size_t, size, | ||||||
| 
 | 
 | ||||||
| static bool sock_use_custom_sol_socket(const struct socket *sock) | static bool sock_use_custom_sol_socket(const struct socket *sock) | ||||||
| { | { | ||||||
| 	const struct sock *sk = sock->sk; | 	return test_bit(SOCK_CUSTOM_SOCKOPT, &sock->flags); | ||||||
| 
 |  | ||||||
| 	/* Use sock->ops->setsockopt() for MPTCP */ |  | ||||||
| 	return IS_ENABLED(CONFIG_MPTCP) && |  | ||||||
| 	       sk->sk_protocol == IPPROTO_MPTCP && |  | ||||||
| 	       sk->sk_type == SOCK_STREAM && |  | ||||||
| 	       (sk->sk_family == AF_INET || sk->sk_family == AF_INET6); |  | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| /*
 | /*
 | ||||||
|  |  | ||||||
		Loading…
	
		Reference in a new issue
	
	 Paolo Abeni
						Paolo Abeni