summaryrefslogtreecommitdiffstats
Commit message (Collapse)AuthorAgeFilesLines
...
| * | | bgpd: add bgp_mpath_test.cJosh Bailey2011-07-202-1/+312
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | * tests/bgp_mpath_test.c * New file with test framework for testing BGP multipath * Add test for CLI support functions * tests/Makefile.am * Add new testbgpmpath target
| * | | bgpd: Add new configuration cli for eBGP and iBGP multipath.Josh Bailey2011-07-207-2/+294
| | |/ | |/| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | There is support to configure this for each (AFI,SAFI), but currently this configuration is only present for IPv4 unicast: maximum-paths [ibgp] <1-255> no maximum-paths [ibgp] [<1-255>] * bgpd/Makefile.am * Add bgp_mpath.h and bgp_mpath.c to build * bgpd/bgp_mpath.h * New file for bgp multipath declarations * define BGP_DEFAULT_MAXPATHS * bgpd/bgp_mpath.c * bgp_maximum_paths_set(): Configure maximum paths for the given afi, safi and bgp instance * bgp_maximum_paths_unset(): Return maximum paths configuration to the default setting for the given afi, safi and bgp instance * bgpd/bgp_vty.c * Define command strings for above CLI * bgp_config_write_maxpaths(): Outputs configuration for the given afi, safi and bgp instance * Install command elements for IPv4 unicast * bgpd/bgp_zebra.h * bgp_config_write_maxpaths(): External declaration * bgpd/bgpd.c * bgp_create(): Initialize bgp instance to default maximum paths setting * bgp_config_write_family(): Output maximum paths configuration for the given address family * bgp_config_write(): Output maximum paths configuration for IPv4 unicast address family * bgpd/bgpd.h * struct bgp: Add storage for maximum paths configuration for each afi, safi
* | | ospfd: adjust OSPF_ROUTER_LSA_MIN_SIZE for VL caseDenis Ovsienko2012-04-111-1/+8
| |/ |/|
* | lib: pretty ip_masklen and masklen2ipDavid Lamparter2012-04-041-109/+19
| | | | | | | | | | | | | | | | | | | | | | | | | | | | nonwithstanding any desire for optimisation, these versions are shorter and more concise. reading the comments, they might even be easier to understand. I've tested them on i686 and x86_64, and checked that correct assembler code is emitted for ARM, MIPS and PowerPC. IPv6 is left as an exercise for another day, none of the ideas I had led to a "yes, this is the one to go with" solution. Signed-off-by: David Lamparter <equinox@diac24.net>
* | Revert "lib: optimize ip_masklen()" (BZ#720)David Lamparter2012-04-041-2081/+25
| | | | | | | | | | | | | | | | | | | | | | This reverts commit d171bf58ef12ace43d48565e6870722dece1e6ed. There are multiple reasons for this revert, including bug #720, but also quite simply the unreadability of having 2000 lines of an autogenerated table in the middle of a source file. Signed-off-by: David Lamparter <equinox@diac24.net> Reported-by: Martin Winter <mwinter@opensourcerouting.org>
* | bgpd: bgp_attr_flags_diagnose shouldn't assertPaul Jakma2012-03-271-1/+8
| | | | | | | | | | | | * bgpd/bgp_attr.c: (bgp_attr_flags_diagnose) debug code for error-handling paths probably shouldn't assert, instead it should just log that there was no problem.
* | bgpd: attr_parse call to attr_malformed should deal with PROCEED error casePaul Jakma2012-03-271-8/+14
| | | | | | | | | | | | * bgpd/bgp_attr.c: (bgp_attr_parse) the invalid flag check call to bgp_attr_malformed is pretty useless if it doesn't actually allow for the PROCEED non-error case.
* | bgpd: Fix silly mistake in bgp_attr_flag_invalidPaul Jakma2012-03-271-1/+1
| | | | | | | | | | * bgp_attr.c: (bgp_attr_flag_invalid) flags is meant to be masked off with the mask variable...
* | bgpd: malformed attribute error that can still proceed should fixup getpPaul Jakma2012-03-251-3/+10
| | | | | | | | | | | | | | | | | | * bgp_attr.c: (bgp_attr_malformed) When a malformed attribute error can be ignored, and BGP message processing may still proceed, the stream getp should be adjusted to the end of the attribute - the caller may not have consumed all the attribute. Problem noted by Martin Winter in bug 678. Also, rename the 'startp' local to 'notify_datap', for clarity.
* | Merge branch 'babeld-merge' into master-copyPaul Jakma2012-03-2562-171/+9168
|\ \
| * | babeld: remove "parasitic" mode.Juliusz Chroboczek2012-03-255-56/+5
| | | | | | | | | | | | | | | | | | | | | | | | | | | This is the functionality described in Appendix C of RFC 6126. Its main purpose is to avoid keeping a full source table, which makes it possible to implement a subset of Babel in just a few hundred lines of code. However, in Quagga the code for maintaining the source table is already there, and a parasitic implementation can be simulated using filtering -- so it makes little sense to keep the functionality.
| * | babeld: 3 more timing statements in config textDenis Ovsienko2012-03-253-2/+15
| | | | | | | | | | | | | | | | | | | | | | | | | | | This commit makes the following lines visible in running-config text, when respective intervals are configured to non-default values: * babel hello-interval * babel update-interval * babel resend-delay
| * | babeld: consolidate zebra interface into fewer functions.Juliusz Chroboczek2012-03-251-124/+29
| | |
| * | babeld: fix typo in kernel_route_add_v6.Juliusz Chroboczek2012-03-251-0/+1
| | |
| * | babeld: set interface flags eagerly, not at interface up.Juliusz Chroboczek2012-03-251-11/+22
| | |
| * | babeld: more helpful sample conf file.Juliusz Chroboczek2012-03-251-2/+11
| | |
| * | babeld: fix documentation.Juliusz Chroboczek2012-03-251-16/+15
| | |
| * | babeld: remove remains of standalone babeld's configuration code.Juliusz Chroboczek2012-03-255-23/+8
| | | | | | | | | | | | | | | | | | Standalone babeld has a configuration interface that is not used in Quagga. This removes a few bits of this code that survived the port to Quagga.
| * | babeld: drive interface_config_write() forwardDenis Ovsienko2012-03-251-9/+17
| | |
| * | babeld: justify "running-config" meaning in CLIDenis Ovsienko2012-03-259-53/+111
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | The primary focus of this commit is to make "show running-config" command display more current configuration, including some of the bits previously seen in the output of "show babel running-config". Besides that, the following commands were renamed for consistency with the syntax of other components: "debug *" to "debug babel *" (and moved to top level) "show babel running-config" to "show babel parameters" * babel_interface.c * show_babel_running_config(): rename to show_babel_parameters(), update syntax pattern, don't call show_babeld_configuration() * babel_if_init(): update respectively * babel_enable_if_config_write(): new VTY helper for static babel_enable_if * babel_interface.h: add extern declaration * babel_main.c: unset all debug options by default * show_babel_main_configuration(): remove debug options decoder * babel_zebra.c * babel_debug(): rename to debug_babel(), update syntax pattern * no_babel_debug(): rename to no_debug_babel(), update syntax pattern * babelz_zebra_init(): update respectively * debug_babel_config_write() new VTY helper for static debug_type * babel_zebra.h: add extern declaration * babeld.c * babel_config_write(): add the code to output "debug babel *", "router babel", "redistribute *" and "network *" statements * show_babeld_configuration(): dismiss * babeld.h: remove extern declaration * babeld.texi: update for renamed commands * babeld.conf.sample: idem, add debug statements block
| * | Remove dead variable reboot_time.Juliusz Chroboczek2012-03-251-5/+0
| | | | | | | | | | | | Thanks to Denis Ovsienko.
| * | doc: fix typo.Matthieu Boutier2012-03-251-1/+1
| | |
| * | doc: update babeld documentation.Juliusz Chroboczek2012-03-251-11/+23
| | |
| * | doc: fix Makefile dependencies for babeld.Juliusz Chroboczek2012-03-251-5/+5
| | |
| * | babeld: display update-interval and resend-delay in show commands"Juliusz Chroboczek2012-03-252-2/+3
| | |
| * | babeld: vty commands (hello-interval, update-interval, resend-delay).Juliusz Chroboczek2012-03-252-23/+61
| | |
| * | babeld: remove port and group setting commands.Juliusz Chroboczek2012-03-251-47/+0
| | | | | | | | | | | | They didn't work anyway, since they're called too late.
| * | Resynchronise with babeld-1.3.1.Juliusz Chroboczek2012-03-258-96/+32
| | |
| * | babeld: dismiss babel_redistribute_unset()Denis Ovsienko2012-03-251-18/+3
| | | | | | | | | | | | | | | | | | The function was effectively duplicating existing zclient_redistribute(). This makes no_babel_redistribute_type() consistent with babel_redistribute_type()
| * | babeld: fix wire{d,less} commands name.Matthieu Boutier2012-03-252-5/+5
| | |
| * | ripd: add babel for redistribution.Matthieu Boutier2012-03-251-1/+2
| | |
| * | ripngd: Replace redistribution strings with route_types.h defines.Matthieu Boutier2012-03-251-124/+74
| | |
| * | babeld: Add support for blackhole routes.Juliusz Chroboczek2012-03-251-21/+43
| | | | | | | | | | | | | | | | | | | | | Babel makes use of blackhole routes to prevent routing loops between overlapping prefixes shortly after a route is retracted (see RFC 6126 sections 2.8 and 3.5.5). This patch adds support for installing such blackhole routes.
| * | babeld: refactor filtering stubs.Juliusz Chroboczek2012-03-253-166/+56
| | | | | | | | | | | | | | | | | | Factorise the common parts of the in/out filtering functions. This also fixes a bug with filtered out routes, which in babeld are signalled by a filter returing INFINITY, not -1.
| * | zebra: Display uptime of Babel routes in show ip[v6] route.Juliusz Chroboczek2012-03-251-0/+4
| | |
| * | babeld: Use quagga_gettime.Juliusz Chroboczek2012-03-251-38/+1
| | |
| * | babeld: Don't use an ifindex when installing IPv4 routes.Juliusz Chroboczek2012-03-251-8/+9
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Stand-alone babeld installs routes using both a next-hop gateway and an interface index. Unfortunately, this doesn't work for IPv4 under Quagga. We now ignore the ifindex when installing IPv4 routes, which makes Babel work for IPv4 in prefix-based networks. Of course this breaks IPv4 mesh networks, unless you play some tricks with your interfaces' netmasks.
| * | babeld: remove some unused functions' arguments.Matthieu Boutier2012-03-251-58/+26
| | |
| * | doc: fix typo in babeld.Matthieu Boutier2012-03-251-6/+5
| | |
| * | doc: Document babeld.Juliusz Chroboczek2012-03-253-1/+119
| | |
| * | babeld: Indentation fix.Juliusz Chroboczek2012-03-251-3/+3
| | |
| * | babeld: Error handling and tweaks for babeld commands.Juliusz Chroboczek2012-03-253-8/+11
| | |
| * | babeld: Fix typo in hello interval command.Juliusz Chroboczek2012-03-251-1/+1
| | |
| * | vtysh: Vtysh support for babeld.Juliusz Chroboczek2012-03-255-3/+31
| | |
| * | babeld: Replace the babeld.conf.sample file by one that actually works.Juliusz Chroboczek2012-03-251-31/+13
| | |
| * | babeld: fix interface bug, simplify code.Matthieu Boutier2012-03-252-16/+30
| | | | | | | | | | | | | | | | | | | | | | | | Perhaps could it be able to free already free memory (so free(NULL)), in function interface_reset(). On other hand, it initiated untracked interfaces, raising (at least) inappropriate messages. Finally, I remove the BABEL_IF_IS_ENABLE flag, witch was not really usefull. Note the test if_up isn't weaker, because (...IS_UP => ...IS_ENABLE).
| * | babeld: state-file was loaded too early. Initial seqno too.Matthieu Boutier2012-03-253-5/+4
| | |
| * | babeld: fix eui64 features.Matthieu Boutier2012-03-252-6/+3
| | | | | | | | | | | | We are interested by eui64 with at least 6 octets.
| * | babeld: "return CMD_SUCCESS" was missing for command 'no debug'.Matthieu Boutier2012-03-251-0/+1
| | |
| * | babeld: Replace redistribution strings with route_types.h defines.Matthieu Boutier2012-03-251-47/+27
| | |