2019-03-22 21:06:09 +08:00
|
|
|
/* SPDX-License-Identifier: GPL-2.0 */
|
|
|
|
#ifndef _IPV6_STUBS_H
|
|
|
|
#define _IPV6_STUBS_H
|
|
|
|
|
|
|
|
#include <linux/in6.h>
|
|
|
|
#include <linux/netdevice.h>
|
|
|
|
#include <linux/skbuff.h>
|
|
|
|
#include <net/dst.h>
|
|
|
|
#include <net/flow.h>
|
|
|
|
#include <net/neighbour.h>
|
|
|
|
#include <net/sock.h>
|
|
|
|
|
|
|
|
/* structs from net/ip6_fib.h */
|
|
|
|
struct fib6_info;
|
2019-04-06 07:30:24 +08:00
|
|
|
struct fib6_nh;
|
|
|
|
struct fib6_config;
|
2019-04-17 05:35:59 +08:00
|
|
|
struct fib6_result;
|
2019-03-22 21:06:09 +08:00
|
|
|
|
|
|
|
/* This is ugly, ideally these symbols should be built
|
|
|
|
* into the core kernel.
|
|
|
|
*/
|
|
|
|
struct ipv6_stub {
|
|
|
|
int (*ipv6_sock_mc_join)(struct sock *sk, int ifindex,
|
|
|
|
const struct in6_addr *addr);
|
|
|
|
int (*ipv6_sock_mc_drop)(struct sock *sk, int ifindex,
|
|
|
|
const struct in6_addr *addr);
|
2019-12-04 22:35:53 +08:00
|
|
|
struct dst_entry *(*ipv6_dst_lookup_flow)(struct net *net,
|
|
|
|
const struct sock *sk,
|
|
|
|
struct flowi6 *fl6,
|
|
|
|
const struct in6_addr *final_dst);
|
2019-03-22 21:06:09 +08:00
|
|
|
int (*ipv6_route_input)(struct sk_buff *skb);
|
|
|
|
|
|
|
|
struct fib6_table *(*fib6_get_table)(struct net *net, u32 id);
|
2019-04-17 05:36:10 +08:00
|
|
|
int (*fib6_lookup)(struct net *net, int oif, struct flowi6 *fl6,
|
|
|
|
struct fib6_result *res, int flags);
|
|
|
|
int (*fib6_table_lookup)(struct net *net, struct fib6_table *table,
|
|
|
|
int oif, struct flowi6 *fl6,
|
|
|
|
struct fib6_result *res, int flags);
|
2019-04-17 05:35:59 +08:00
|
|
|
void (*fib6_select_path)(const struct net *net, struct fib6_result *res,
|
|
|
|
struct flowi6 *fl6, int oif, bool oif_match,
|
|
|
|
const struct sk_buff *skb, int strict);
|
2019-04-17 05:36:06 +08:00
|
|
|
u32 (*ip6_mtu_from_fib6)(const struct fib6_result *res,
|
|
|
|
const struct in6_addr *daddr,
|
|
|
|
const struct in6_addr *saddr);
|
2019-03-22 21:06:09 +08:00
|
|
|
|
2019-04-06 07:30:24 +08:00
|
|
|
int (*fib6_nh_init)(struct net *net, struct fib6_nh *fib6_nh,
|
|
|
|
struct fib6_config *cfg, gfp_t gfp_flags,
|
|
|
|
struct netlink_ext_ack *extack);
|
|
|
|
void (*fib6_nh_release)(struct fib6_nh *fib6_nh);
|
2021-11-22 23:15:12 +08:00
|
|
|
void (*fib6_nh_release_dsts)(struct fib6_nh *fib6_nh);
|
2019-05-23 03:04:40 +08:00
|
|
|
void (*fib6_update_sernum)(struct net *net, struct fib6_info *rt);
|
2020-04-28 04:56:45 +08:00
|
|
|
int (*ip6_del_rt)(struct net *net, struct fib6_info *rt, bool skip_notify);
|
2019-05-23 03:04:41 +08:00
|
|
|
void (*fib6_rt_update)(struct net *net, struct fib6_info *rt,
|
|
|
|
struct nl_info *info);
|
|
|
|
|
2019-03-22 21:06:09 +08:00
|
|
|
void (*udpv6_encap_enable)(void);
|
|
|
|
void (*ndisc_send_na)(struct net_device *dev, const struct in6_addr *daddr,
|
|
|
|
const struct in6_addr *solicited_addr,
|
|
|
|
bool router, bool solicited, bool override, bool inc_opt);
|
2020-04-27 23:59:34 +08:00
|
|
|
#if IS_ENABLED(CONFIG_XFRM)
|
2020-05-04 16:06:06 +08:00
|
|
|
void (*xfrm6_local_rxpmtu)(struct sk_buff *skb, u32 mtu);
|
2020-04-27 23:59:34 +08:00
|
|
|
int (*xfrm6_udp_encap_rcv)(struct sock *sk, struct sk_buff *skb);
|
2023-10-04 21:05:44 +08:00
|
|
|
struct sk_buff *(*xfrm6_gro_udp_encap_rcv)(struct sock *sk,
|
|
|
|
struct list_head *head,
|
|
|
|
struct sk_buff *skb);
|
2020-04-27 23:59:35 +08:00
|
|
|
int (*xfrm6_rcv_encap)(struct sk_buff *skb, int nexthdr, __be32 spi,
|
|
|
|
int encap_type);
|
2020-04-27 23:59:34 +08:00
|
|
|
#endif
|
2019-03-22 21:06:09 +08:00
|
|
|
struct neigh_table *nd_tbl;
|
2020-08-28 23:14:31 +08:00
|
|
|
|
|
|
|
int (*ipv6_fragment)(struct net *net, struct sock *sk, struct sk_buff *skb,
|
|
|
|
int (*output)(struct net *, struct sock *, struct sk_buff *));
|
2021-03-30 09:45:43 +08:00
|
|
|
struct net_device *(*ipv6_dev_find)(struct net *net, const struct in6_addr *addr,
|
|
|
|
struct net_device *dev);
|
2019-03-22 21:06:09 +08:00
|
|
|
};
|
|
|
|
extern const struct ipv6_stub *ipv6_stub __read_mostly;
|
|
|
|
|
|
|
|
/* A stub used by bpf helpers. Similarly ugly as ipv6_stub */
|
|
|
|
struct ipv6_bpf_stub {
|
|
|
|
int (*inet6_bind)(struct sock *sk, struct sockaddr *uaddr, int addr_len,
|
2020-05-09 01:46:10 +08:00
|
|
|
u32 flags);
|
2019-03-22 21:06:09 +08:00
|
|
|
struct sock *(*udp6_lib_lookup)(struct net *net,
|
|
|
|
const struct in6_addr *saddr, __be16 sport,
|
|
|
|
const struct in6_addr *daddr, __be16 dport,
|
|
|
|
int dif, int sdif, struct udp_table *tbl,
|
|
|
|
struct sk_buff *skb);
|
2022-08-17 14:18:34 +08:00
|
|
|
int (*ipv6_setsockopt)(struct sock *sk, int level, int optname,
|
|
|
|
sockptr_t optval, unsigned int optlen);
|
2022-09-02 08:29:31 +08:00
|
|
|
int (*ipv6_getsockopt)(struct sock *sk, int level, int optname,
|
|
|
|
sockptr_t optval, sockptr_t optlen);
|
2023-10-07 16:14:14 +08:00
|
|
|
int (*ipv6_dev_get_saddr)(struct net *net,
|
|
|
|
const struct net_device *dst_dev,
|
|
|
|
const struct in6_addr *daddr,
|
|
|
|
unsigned int prefs,
|
|
|
|
struct in6_addr *saddr);
|
2019-03-22 21:06:09 +08:00
|
|
|
};
|
|
|
|
extern const struct ipv6_bpf_stub *ipv6_bpf_stub __read_mostly;
|
|
|
|
|
|
|
|
#endif
|