Commit c2364199 authored by David Ahern's avatar David Ahern Committed by David S. Miller

ipv4: Change fib_nexthop_info and fib_add_nexthop to take fib_nh_common

With the exception of the nexthop weight, the nexthop attributes used by
fib_nexthop_info and fib_add_nexthop come from the fib_nh_common struct.
Update both to use it and change fib_nexthop_info to check the family
as needed.

nexthop weight comes from the common struct for existing use cases, but
for nexthop groups the weight is outside of the fib_nh_common to allow
the same nexthop definition to be used in multiple groups with different
weights.
Signed-off-by: default avatarDavid Ahern <dsahern@gmail.com>
Acked-by: default avatarMartin KaFai Lau <kafai@fb.com>
Signed-off-by: default avatarDavid S. Miller <davem@davemloft.net>
parent b0f60193
...@@ -1317,35 +1317,44 @@ struct fib_info *fib_create_info(struct fib_config *cfg, ...@@ -1317,35 +1317,44 @@ struct fib_info *fib_create_info(struct fib_config *cfg,
return ERR_PTR(err); return ERR_PTR(err);
} }
static int fib_nexthop_info(struct sk_buff *skb, const struct fib_nh *nh, static int fib_nexthop_info(struct sk_buff *skb, const struct fib_nh_common *nhc,
unsigned int *flags, bool skip_oif) unsigned int *flags, bool skip_oif)
{ {
if (nh->fib_nh_flags & RTNH_F_DEAD) if (nhc->nhc_flags & RTNH_F_DEAD)
*flags |= RTNH_F_DEAD; *flags |= RTNH_F_DEAD;
if (nh->fib_nh_flags & RTNH_F_LINKDOWN) { if (nhc->nhc_flags & RTNH_F_LINKDOWN) {
*flags |= RTNH_F_LINKDOWN; *flags |= RTNH_F_LINKDOWN;
rcu_read_lock(); rcu_read_lock();
if (ip_ignore_linkdown(nh->fib_nh_dev)) switch (nhc->nhc_family) {
case AF_INET:
if (ip_ignore_linkdown(nhc->nhc_dev))
*flags |= RTNH_F_DEAD; *flags |= RTNH_F_DEAD;
break;
}
rcu_read_unlock(); rcu_read_unlock();
} }
if (nh->fib_nh_gw4 && if (nhc->nhc_has_gw) {
nla_put_in_addr(skb, RTA_GATEWAY, nh->fib_nh_gw4)) switch (nhc->nhc_family) {
case AF_INET:
if (nla_put_in_addr(skb, RTA_GATEWAY, nhc->nhc_gw.ipv4))
goto nla_put_failure; goto nla_put_failure;
break;
}
}
*flags |= (nh->fib_nh_flags & RTNH_F_ONLINK); *flags |= (nhc->nhc_flags & RTNH_F_ONLINK);
if (nh->fib_nh_flags & RTNH_F_OFFLOAD) if (nhc->nhc_flags & RTNH_F_OFFLOAD)
*flags |= RTNH_F_OFFLOAD; *flags |= RTNH_F_OFFLOAD;
if (!skip_oif && nh->fib_nh_dev && if (!skip_oif && nhc->nhc_dev &&
nla_put_u32(skb, RTA_OIF, nh->fib_nh_dev->ifindex)) nla_put_u32(skb, RTA_OIF, nhc->nhc_dev->ifindex))
goto nla_put_failure; goto nla_put_failure;
if (nh->fib_nh_lws && if (nhc->nhc_lwtstate &&
lwtunnel_fill_encap(skb, nh->fib_nh_lws) < 0) lwtunnel_fill_encap(skb, nhc->nhc_lwtstate) < 0)
goto nla_put_failure; goto nla_put_failure;
return 0; return 0;
...@@ -1355,9 +1364,10 @@ static int fib_nexthop_info(struct sk_buff *skb, const struct fib_nh *nh, ...@@ -1355,9 +1364,10 @@ static int fib_nexthop_info(struct sk_buff *skb, const struct fib_nh *nh,
} }
#ifdef CONFIG_IP_ROUTE_MULTIPATH #ifdef CONFIG_IP_ROUTE_MULTIPATH
static int fib_add_nexthop(struct sk_buff *skb, const struct fib_nh *nh) static int fib_add_nexthop(struct sk_buff *skb, const struct fib_nh_common *nhc,
int nh_weight)
{ {
const struct net_device *dev = nh->fib_nh_dev; const struct net_device *dev = nhc->nhc_dev;
struct rtnexthop *rtnh; struct rtnexthop *rtnh;
unsigned int flags = 0; unsigned int flags = 0;
...@@ -1365,10 +1375,10 @@ static int fib_add_nexthop(struct sk_buff *skb, const struct fib_nh *nh) ...@@ -1365,10 +1375,10 @@ static int fib_add_nexthop(struct sk_buff *skb, const struct fib_nh *nh)
if (!rtnh) if (!rtnh)
goto nla_put_failure; goto nla_put_failure;
rtnh->rtnh_hops = nh->fib_nh_weight - 1; rtnh->rtnh_hops = nh_weight - 1;
rtnh->rtnh_ifindex = dev ? dev->ifindex : 0; rtnh->rtnh_ifindex = dev ? dev->ifindex : 0;
if (fib_nexthop_info(skb, nh, &flags, true) < 0) if (fib_nexthop_info(skb, nhc, &flags, true) < 0)
goto nla_put_failure; goto nla_put_failure;
rtnh->rtnh_flags = flags; rtnh->rtnh_flags = flags;
...@@ -1381,7 +1391,9 @@ static int fib_add_nexthop(struct sk_buff *skb, const struct fib_nh *nh) ...@@ -1381,7 +1391,9 @@ static int fib_add_nexthop(struct sk_buff *skb, const struct fib_nh *nh)
nla_put_failure: nla_put_failure:
return -EMSGSIZE; return -EMSGSIZE;
} }
#endif
#ifdef CONFIG_IP_ROUTE_MULTIPATH
static int fib_add_multipath(struct sk_buff *skb, struct fib_info *fi) static int fib_add_multipath(struct sk_buff *skb, struct fib_info *fi)
{ {
struct nlattr *mp; struct nlattr *mp;
...@@ -1391,7 +1403,7 @@ static int fib_add_multipath(struct sk_buff *skb, struct fib_info *fi) ...@@ -1391,7 +1403,7 @@ static int fib_add_multipath(struct sk_buff *skb, struct fib_info *fi)
goto nla_put_failure; goto nla_put_failure;
for_nexthops(fi) { for_nexthops(fi) {
if (fib_add_nexthop(skb, nh) < 0) if (fib_add_nexthop(skb, &nh->nh_common, nh->fib_nh_weight) < 0)
goto nla_put_failure; goto nla_put_failure;
#ifdef CONFIG_IP_ROUTE_CLASSID #ifdef CONFIG_IP_ROUTE_CLASSID
if (nh->nh_tclassid && if (nh->nh_tclassid &&
...@@ -1457,7 +1469,7 @@ int fib_dump_info(struct sk_buff *skb, u32 portid, u32 seq, int event, ...@@ -1457,7 +1469,7 @@ int fib_dump_info(struct sk_buff *skb, u32 portid, u32 seq, int event,
struct fib_nh *nh = &fi->fib_nh[0]; struct fib_nh *nh = &fi->fib_nh[0];
unsigned int flags = 0; unsigned int flags = 0;
if (fib_nexthop_info(skb, nh, &flags, false) < 0) if (fib_nexthop_info(skb, &nh->nh_common, &flags, false) < 0)
goto nla_put_failure; goto nla_put_failure;
rtm->rtm_flags = flags; rtm->rtm_flags = flags;
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment