Age | Commit message (Collapse) | Author |
|
RTM_CHANGE. Until now it was not possible to get rid of these flags.
Until now a fib decouple, fib couple combo was needed to get rid from
blackholed routes. OK henning@
|
|
Sure henning@
|
|
not a C string and strlcpy() only works on C strings -- returns length of
the source. Found by tedu@ OK deraadt@ tedu@
|
|
is invalid. add check for these flags. shows up with v6, many reject routes
there. claudio ok
|
|
|
|
are e.g. created by the PMTU code and are removed after some time.
OK henning@
|
|
rtlabel_id2name() so call rtlable_unref() after that.
OK henning@
|
|
interface changes. support in the filter language and rde to come. claudio ok
|
|
bgpctl show fib output more logical, especially for INET6 because many
prfixes have the reject flag set. OK henning@
|
|
an own AF independent radix tree. So the passed sockaddrs are often smaller
than the actual AF specific struct, especially sockaddr_in6. So the crap
Henning saw in the mask was acctually the next struct sockaddr that was passed
in the routing message. So pass the struct sockaddr_in6 and compare only the
specified number of bytes (minus the offset of sin6_addr in the struct
sockaddr_in6). Amazing!..
OK henning@
|
|
|
|
|
|
the routing socket have crap in the lower bytes, so instead of
using a straightforward and rather simple algorithm to convert them to prefix
lengths we have to do quite some ugly manual fiddling... disgusting.
|
|
|
|
|
|
do it once and handle both families. claudio ok
|
|
|
|
up more. OK henning@
|
|
the buffer. While RTM_IFINFO starts with a struct if_msghdr RTM_NEWADDR
does not. In other words (struct sockaddr *)(next + sizeof(ifm)) is only
correct for RTM_IFINFO and not for RTM_NEWADDR. So move the ifm_type check
up else get_rtaddrs() would access memory outside of buf.
OK henning@
|
|
directly connected respectively all static routes. The list is auto-
matically adjusted as soon as a route changes.
OK henning@
|
|
OK henning@
|
|
from the kernel. That's what F_KERNEL is for. OK henning@
|
|
(that is a rare corner case in that context, but still)
|
|
there's some nastiness in the interface validation.
clean up by centralizing the checks in kif_validate().
claudio ok
|
|
|
|
|
|
Use IN_CLASSA_NET instead of hard coded 0xff000000
OK henning@
|
|
ok markus claudio
|
|
with the "show nexthop" messages, claudio ok
|
|
was unplugged from the beginning on...
correctly take interfaces' link state into account for nexthop verification
in all cases.
add a new function kroute_validate() that looks up the interface for a given
kroute via the ifindex and check its link state. use it in all cases instead
of hand-rolling the test. claudio ok
|
|
just for AF_LINK
|
|
|
|
RB_* macros I could fix the RB_HEAD calls there too... useless extra define,
nothingthat hurts much. stumbled over while hacking on, eh, something new,
claudio ok
|
|
places where needed. OK henning@
|
|
with this, if a neighbor is configured as dependent on carp0 for example,
the neighbor will remain in state IDLE as long as carp0 is not master.
once carp0 becomes master the session(s) depending on it immediately
go to CONNECT (or ACTIVE, if they're configured passive), reducing failover
time. claudio ok, with some input from ryan as well
|
|
|
|
|
|
always notify the RDE and not only if the nexthop was previously unreachable,
i.e. its validity changed.
found the hard way by Arvid Grtting <arvidg@netfonds.no>, claudio ok
|
|
similar to memcmp() and all other compare functions in bgpd. OK henning@
|
|
|
|
ok henning otto
|
|
blackhole/reject routes will be entered to the kernel for matching ones.
this is intended to be used with the Cymru Bogon Route Server Project
(http://www.cymru.com/BGP/bogon-rs.html) and similar services, claudio ok
|
|
|
|
within 127/8. inspired by a very bad example for bogon filters at the
cymru site, claudio ok
|
|
|
|
times I am getting this in now sow I don't do it a 7th time...
|
|
prefix tree changed form a hash table to a per AF RB tree.
OK henning@ some ideas are from Brent Graveland.
|
|
(smashing them into the v4 table would raise the memory requirements far too
much), and make kroute_nexthop (where we are not under such memory pressure,
you don't have a hundred thousand nexthops) v4/v6. change existing callers
to use the v4 part, claudio ok
|
|
maybe one day we come up with a good reason for bgpd to use multipath
routes, but for now it doesn't make any sense - bgpd inserts the "best"
path fr a prefix, there's no point in inserting more than one. one is
always the "best" one by bgp metrics.
with claudio
|
|
|