diff options
Diffstat (limited to 'net/ipv6/route.c')
-rw-r--r-- | net/ipv6/route.c | 107 |
1 files changed, 0 insertions, 107 deletions
diff --git a/net/ipv6/route.c b/net/ipv6/route.c index f52cf83bb1e0..7296af144d6c 100644 --- a/net/ipv6/route.c +++ b/net/ipv6/route.c | |||
@@ -1633,92 +1633,6 @@ static int ip6_route_del(struct fib6_config *cfg) | |||
1633 | return err; | 1633 | return err; |
1634 | } | 1634 | } |
1635 | 1635 | ||
1636 | /* | ||
1637 | * Handle redirects | ||
1638 | */ | ||
1639 | struct ip6rd_flowi { | ||
1640 | struct flowi6 fl6; | ||
1641 | struct in6_addr gateway; | ||
1642 | }; | ||
1643 | |||
1644 | static struct rt6_info *__ip6_route_redirect(struct net *net, | ||
1645 | struct fib6_table *table, | ||
1646 | struct flowi6 *fl6, | ||
1647 | int flags) | ||
1648 | { | ||
1649 | struct ip6rd_flowi *rdfl = (struct ip6rd_flowi *)fl6; | ||
1650 | struct rt6_info *rt; | ||
1651 | struct fib6_node *fn; | ||
1652 | |||
1653 | /* | ||
1654 | * Get the "current" route for this destination and | ||
1655 | * check if the redirect has come from approriate router. | ||
1656 | * | ||
1657 | * RFC 2461 specifies that redirects should only be | ||
1658 | * accepted if they come from the nexthop to the target. | ||
1659 | * Due to the way the routes are chosen, this notion | ||
1660 | * is a bit fuzzy and one might need to check all possible | ||
1661 | * routes. | ||
1662 | */ | ||
1663 | |||
1664 | read_lock_bh(&table->tb6_lock); | ||
1665 | fn = fib6_lookup(&table->tb6_root, &fl6->daddr, &fl6->saddr); | ||
1666 | restart: | ||
1667 | for (rt = fn->leaf; rt; rt = rt->dst.rt6_next) { | ||
1668 | /* | ||
1669 | * Current route is on-link; redirect is always invalid. | ||
1670 | * | ||
1671 | * Seems, previous statement is not true. It could | ||
1672 | * be node, which looks for us as on-link (f.e. proxy ndisc) | ||
1673 | * But then router serving it might decide, that we should | ||
1674 | * know truth 8)8) --ANK (980726). | ||
1675 | */ | ||
1676 | if (rt6_check_expired(rt)) | ||
1677 | continue; | ||
1678 | if (!(rt->rt6i_flags & RTF_GATEWAY)) | ||
1679 | continue; | ||
1680 | if (fl6->flowi6_oif != rt->dst.dev->ifindex) | ||
1681 | continue; | ||
1682 | if (!ipv6_addr_equal(&rdfl->gateway, &rt->rt6i_gateway)) | ||
1683 | continue; | ||
1684 | break; | ||
1685 | } | ||
1686 | |||
1687 | if (!rt) | ||
1688 | rt = net->ipv6.ip6_null_entry; | ||
1689 | BACKTRACK(net, &fl6->saddr); | ||
1690 | out: | ||
1691 | dst_hold(&rt->dst); | ||
1692 | |||
1693 | read_unlock_bh(&table->tb6_lock); | ||
1694 | |||
1695 | return rt; | ||
1696 | }; | ||
1697 | |||
1698 | static struct rt6_info *ip6_route_redirect(const struct in6_addr *dest, | ||
1699 | const struct in6_addr *src, | ||
1700 | const struct in6_addr *gateway, | ||
1701 | struct net_device *dev) | ||
1702 | { | ||
1703 | int flags = RT6_LOOKUP_F_HAS_SADDR; | ||
1704 | struct net *net = dev_net(dev); | ||
1705 | struct ip6rd_flowi rdfl = { | ||
1706 | .fl6 = { | ||
1707 | .flowi6_oif = dev->ifindex, | ||
1708 | .daddr = *dest, | ||
1709 | .saddr = *src, | ||
1710 | }, | ||
1711 | }; | ||
1712 | |||
1713 | rdfl.gateway = *gateway; | ||
1714 | |||
1715 | if (rt6_need_strict(dest)) | ||
1716 | flags |= RT6_LOOKUP_F_IFACE; | ||
1717 | |||
1718 | return (struct rt6_info *)fib6_rule_lookup(net, &rdfl.fl6, | ||
1719 | flags, __ip6_route_redirect); | ||
1720 | } | ||
1721 | |||
1722 | static void rt6_do_redirect(struct dst_entry *dst, struct sk_buff *skb) | 1636 | static void rt6_do_redirect(struct dst_entry *dst, struct sk_buff *skb) |
1723 | { | 1637 | { |
1724 | struct net *net = dev_net(skb->dev); | 1638 | struct net *net = dev_net(skb->dev); |
@@ -1848,27 +1762,6 @@ out: | |||
1848 | neigh_release(neigh); | 1762 | neigh_release(neigh); |
1849 | } | 1763 | } |
1850 | 1764 | ||
1851 | void rt6_redirect(struct sk_buff *skb) | ||
1852 | { | ||
1853 | const struct in6_addr *target; | ||
1854 | const struct in6_addr *dest; | ||
1855 | const struct in6_addr *src; | ||
1856 | const struct in6_addr *saddr; | ||
1857 | struct icmp6hdr *icmph; | ||
1858 | struct rt6_info *rt; | ||
1859 | |||
1860 | icmph = icmp6_hdr(skb); | ||
1861 | target = (const struct in6_addr *) (icmph + 1); | ||
1862 | dest = target + 1; | ||
1863 | |||
1864 | src = &ipv6_hdr(skb)->daddr; | ||
1865 | saddr = &ipv6_hdr(skb)->saddr; | ||
1866 | |||
1867 | rt = ip6_route_redirect(dest, src, saddr, skb->dev); | ||
1868 | rt6_do_redirect(&rt->dst, skb); | ||
1869 | dst_release(&rt->dst); | ||
1870 | } | ||
1871 | |||
1872 | /* | 1765 | /* |
1873 | * Misc support functions | 1766 | * Misc support functions |
1874 | */ | 1767 | */ |