ipv6: Add fib6_nh_init and release to stubs
authorDavid Ahern <dsahern@gmail.com>
Fri, 5 Apr 2019 23:30:24 +0000 (16:30 -0700)
committerDavid S. Miller <davem@davemloft.net>
Mon, 8 Apr 2019 22:22:40 +0000 (15:22 -0700)
Add fib6_nh_init and fib6_nh_release to ipv6_stubs. If fib6_nh_init fails,
callers should not invoke fib6_nh_release, so there is no reason to have
a dummy stub for the IPv6 is not enabled case.

Signed-off-by: David Ahern <dsahern@gmail.com>
Reviewed-by: Ido Schimmel <idosch@mellanox.com>
Signed-off-by: David S. Miller <davem@davemloft.net>
include/net/ipv6_stubs.h
net/ipv6/addrconf_core.c
net/ipv6/af_inet6.c

index d8d9c0b0e8c0fe6097c011a3cbcca8a8484a25ef..453b55bf6723896262accec9a7ced6ac21872a51 100644 (file)
@@ -12,6 +12,8 @@
 
 /* structs from net/ip6_fib.h */
 struct fib6_info;
+struct fib6_nh;
+struct fib6_config;
 
 /* This is ugly, ideally these symbols should be built
  * into the core kernel.
@@ -40,6 +42,10 @@ struct ipv6_stub {
        u32 (*ip6_mtu_from_fib6)(struct fib6_info *f6i, struct in6_addr *daddr,
                                 struct in6_addr *saddr);
 
+       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);
        void (*udpv6_encap_enable)(void);
        void (*ndisc_send_na)(struct net_device *dev, const struct in6_addr *daddr,
                              const struct in6_addr *solicited_addr,
index 945b66e3008fb42433cf30fad477fa04a095a94c..e37e4c5871f71eaaeb895eb85f790fe01f01062c 100644 (file)
@@ -173,6 +173,14 @@ eafnosupport_ip6_mtu_from_fib6(struct fib6_info *f6i, struct in6_addr *daddr,
        return 0;
 }
 
+static int eafnosupport_fib6_nh_init(struct net *net, struct fib6_nh *fib6_nh,
+                                    struct fib6_config *cfg, gfp_t gfp_flags,
+                                    struct netlink_ext_ack *extack)
+{
+       NL_SET_ERR_MSG(extack, "IPv6 support not enabled in kernel");
+       return -EAFNOSUPPORT;
+}
+
 const struct ipv6_stub *ipv6_stub __read_mostly = &(struct ipv6_stub) {
        .ipv6_dst_lookup   = eafnosupport_ipv6_dst_lookup,
        .ipv6_route_input  = eafnosupport_ipv6_route_input,
@@ -181,6 +189,7 @@ const struct ipv6_stub *ipv6_stub __read_mostly = &(struct ipv6_stub) {
        .fib6_lookup       = eafnosupport_fib6_lookup,
        .fib6_multipath_select = eafnosupport_fib6_multipath_select,
        .ip6_mtu_from_fib6 = eafnosupport_ip6_mtu_from_fib6,
+       .fib6_nh_init      = eafnosupport_fib6_nh_init,
 };
 EXPORT_SYMBOL_GPL(ipv6_stub);
 
index 1789bf99c4196e264f0885c018ff5653b302a5a3..1dac6ea6666abb85674c29e56d9f73aaf90e06bb 100644 (file)
@@ -919,6 +919,8 @@ static const struct ipv6_stub ipv6_stub_impl = {
        .fib6_lookup       = fib6_lookup,
        .fib6_multipath_select = fib6_multipath_select,
        .ip6_mtu_from_fib6 = ip6_mtu_from_fib6,
+       .fib6_nh_init      = fib6_nh_init,
+       .fib6_nh_release   = fib6_nh_release,
        .udpv6_encap_enable = udpv6_encap_enable,
        .ndisc_send_na = ndisc_send_na,
        .nd_tbl = &nd_tbl,