| /* 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 |