mirror of
				https://github.com/torvalds/linux.git
				synced 2025-11-01 00:58:39 +02:00 
			
		
		
		
	 92ef0fd55a
			
		
	
	
		92ef0fd55a
		
	
	
	
	
		
			
			Rather than pass in flags, error pointer, and whether this is a kernel invocation or not, add a struct proto_accept_arg struct as the argument. This then holds all of these arguments, and prepares accept for being able to pass back more information. No functional changes in this patch. Acked-by: Jakub Kicinski <kuba@kernel.org> Signed-off-by: Jens Axboe <axboe@kernel.dk>
		
			
				
	
	
		
			84 lines
		
	
	
	
		
			2.8 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			84 lines
		
	
	
	
		
			2.8 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
| /* SPDX-License-Identifier: GPL-2.0 */
 | |
| #ifndef _INET_COMMON_H
 | |
| #define _INET_COMMON_H
 | |
| 
 | |
| #include <linux/indirect_call_wrapper.h>
 | |
| #include <linux/net.h>
 | |
| #include <linux/netdev_features.h>
 | |
| #include <linux/types.h>
 | |
| #include <net/sock.h>
 | |
| 
 | |
| extern const struct proto_ops inet_stream_ops;
 | |
| extern const struct proto_ops inet_dgram_ops;
 | |
| 
 | |
| /*
 | |
|  *	INET4 prototypes used by INET6
 | |
|  */
 | |
| 
 | |
| struct msghdr;
 | |
| struct net;
 | |
| struct page;
 | |
| struct sock;
 | |
| struct sockaddr;
 | |
| struct socket;
 | |
| 
 | |
| int inet_release(struct socket *sock);
 | |
| int inet_stream_connect(struct socket *sock, struct sockaddr *uaddr,
 | |
| 			int addr_len, int flags);
 | |
| int __inet_stream_connect(struct socket *sock, struct sockaddr *uaddr,
 | |
| 			  int addr_len, int flags, int is_sendmsg);
 | |
| int inet_dgram_connect(struct socket *sock, struct sockaddr *uaddr,
 | |
| 		       int addr_len, int flags);
 | |
| int inet_accept(struct socket *sock, struct socket *newsock,
 | |
| 		struct proto_accept_arg *arg);
 | |
| void __inet_accept(struct socket *sock, struct socket *newsock,
 | |
| 		   struct sock *newsk);
 | |
| int inet_send_prepare(struct sock *sk);
 | |
| int inet_sendmsg(struct socket *sock, struct msghdr *msg, size_t size);
 | |
| void inet_splice_eof(struct socket *sock);
 | |
| int inet_recvmsg(struct socket *sock, struct msghdr *msg, size_t size,
 | |
| 		 int flags);
 | |
| int inet_shutdown(struct socket *sock, int how);
 | |
| int inet_listen(struct socket *sock, int backlog);
 | |
| int __inet_listen_sk(struct sock *sk, int backlog);
 | |
| void inet_sock_destruct(struct sock *sk);
 | |
| int inet_bind(struct socket *sock, struct sockaddr *uaddr, int addr_len);
 | |
| int inet_bind_sk(struct sock *sk, struct sockaddr *uaddr, int addr_len);
 | |
| /* Don't allocate port at this moment, defer to connect. */
 | |
| #define BIND_FORCE_ADDRESS_NO_PORT	(1 << 0)
 | |
| /* Grab and release socket lock. */
 | |
| #define BIND_WITH_LOCK			(1 << 1)
 | |
| /* Called from BPF program. */
 | |
| #define BIND_FROM_BPF			(1 << 2)
 | |
| /* Skip CAP_NET_BIND_SERVICE check. */
 | |
| #define BIND_NO_CAP_NET_BIND_SERVICE	(1 << 3)
 | |
| int __inet_bind(struct sock *sk, struct sockaddr *uaddr, int addr_len,
 | |
| 		u32 flags);
 | |
| int inet_getname(struct socket *sock, struct sockaddr *uaddr,
 | |
| 		 int peer);
 | |
| int inet_ioctl(struct socket *sock, unsigned int cmd, unsigned long arg);
 | |
| int inet_ctl_sock_create(struct sock **sk, unsigned short family,
 | |
| 			 unsigned short type, unsigned char protocol,
 | |
| 			 struct net *net);
 | |
| int inet_recv_error(struct sock *sk, struct msghdr *msg, int len,
 | |
| 		    int *addr_len);
 | |
| 
 | |
| struct sk_buff *inet_gro_receive(struct list_head *head, struct sk_buff *skb);
 | |
| int inet_gro_complete(struct sk_buff *skb, int nhoff);
 | |
| struct sk_buff *inet_gso_segment(struct sk_buff *skb,
 | |
| 				 netdev_features_t features);
 | |
| 
 | |
| static inline void inet_ctl_sock_destroy(struct sock *sk)
 | |
| {
 | |
| 	if (sk)
 | |
| 		sock_release(sk->sk_socket);
 | |
| }
 | |
| 
 | |
| #define indirect_call_gro_receive(f2, f1, cb, head, skb)	\
 | |
| ({								\
 | |
| 	unlikely(gro_recursion_inc_test(skb)) ?			\
 | |
| 		NAPI_GRO_CB(skb)->flush |= 1, NULL :		\
 | |
| 		INDIRECT_CALL_2(cb, f2, f1, head, skb);		\
 | |
| })
 | |
| 
 | |
| #endif
 |