mpls: validate L2 via address length
If an L2 via address for an mpls nexthop is specified, the length of the L2 address must match that expected by the output device, otherwise it could access memory beyond the end of the via address buffer in the route. This check was present prior to commitf8efb73c97
("mpls: multipath route support"), but got lost in the refactoring, so add it back, applying it to all nexthops in multipath routes. Fixes:f8efb73c97
("mpls: multipath route support") Signed-off-by: Robert Shearman <rshearma@brocade.com> Acked-by: Roopa Prabhu <roopa@cumulusnetworks.com> Signed-off-by: David S. Miller <davem@davemloft.net>
This commit is contained in:
parent
f1c2ef40c6
commit
a3e948e83a
1 changed files with 4 additions and 0 deletions
|
@ -534,6 +534,10 @@ static int mpls_nh_assign_dev(struct net *net, struct mpls_route *rt,
|
|||
if (!mpls_dev_get(dev))
|
||||
goto errout;
|
||||
|
||||
if ((nh->nh_via_table == NEIGH_LINK_TABLE) &&
|
||||
(dev->addr_len != nh->nh_via_alen))
|
||||
goto errout;
|
||||
|
||||
RCU_INIT_POINTER(nh->nh_dev, dev);
|
||||
|
||||
return 0;
|
||||
|
|
Loading…
Reference in a new issue