summaryrefslogtreecommitdiffstats
Commit message (Collapse)AuthorAgeFilesLines
* 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
|
* babeld: babelz merge.Matthieu Boutier2012-03-2515-317/+792
| | | | | | Babelz is the last version of the stand-alone babel daemon. In particular, it use multiple channels to diminuate interferences. Please refer to this one for more details.
* babeld: remove unused variable.Matthieu Boutier2012-03-251-1/+0
|
* vtysh: fix regexp for install_element() in babeldAng Way Chuang2012-03-251-1/+1
|
* babeld: add MP-specific zclient API fixDenis Ovsienko2012-03-251-0/+4
| | | | | | | Add proper initialization of SAFI field, which is present in the revisions of zapi_ipv4 and zapi_ipv6 structures specific to MP-BGP patchset. Without this change no Babel routes could make into zebra RIB.
* babeld: change the modify route system.Matthieu Boutier2012-03-251-35/+14
| | | | | | Zebra doesn't set errno to EEXIST if we add a route who was already in the kernel, so we always returned after just doing "add; delete". This patch fix the problem by doing "delete; add" always.
* babeld: fix bug due to v4mapped addresses.Matthieu Boutier2012-03-252-6/+6
|
* babeld: add command (config) to set debug flags.Matthieu Boutier2012-03-251-0/+77
|
* babeld: remove useless variable, make local another.Matthieu Boutier2012-03-252-3/+1
|
* memory: install babel memory informations.Matthieu Boutier2012-03-251-0/+3
|
* babeld: fix commands informations messages.Matthieu Boutier2012-03-252-8/+10
|
* babeld: place the babel-state file in the quagga vars directory.Matthieu Boutier2012-03-251-1/+1
|
* babeld: use zlog_debug instead of do_debugf, for debugf.Matthieu Boutier2012-03-251-2/+2
|
* babeld: add command: "show_babel_running_config".Matthieu Boutier2012-03-257-0/+105
|
* babeld: add command: "show_babel_database".Matthieu Boutier2012-03-252-0/+63
|
* babeld: add command: "show_babel_neighbour".Matthieu Boutier2012-03-251-0/+48
|
* babeld: avoid segfault (bug 706).Matthieu Boutier2012-03-252-1/+14
|
* babeld: change fprintf(stderr) in term of zlog_err.Matthieu Boutier2012-03-254-32/+27
|
* babeld: implement "show babel interface" commandDenis Ovsienko2012-03-251-0/+60
| | | | | | | * babel_interface.c * show_babel_interface_sub(): new function to process one ifp * show_babel_interface(): new function, VTY wrapper * babel_if_init(): update respectively
* babeld: add handling of "-z" cmdline argDenis Ovsienko2012-03-251-1/+6
|
* babeld: bring babel_usage() into focusDenis Ovsienko2012-03-251-23/+26
|
* lib: update proto_redistnum() for BabelDenis Ovsienko2012-03-251-2/+6
|
* babeld: address remaining -Wcast-qual warningsDenis Ovsienko2012-03-253-8/+8
| | | | | | | * net.c * babel_send(): arguments are not treated as "const", justify declaration * babel_main.c: declare constant pointers as such
* babeld: fix bug concerning pidfile.Matthieu Boutier2012-03-251-2/+1
|
* babeld: address some other compilation warnings.Matthieu Boutier2012-03-254-11/+11
|
* babeld: address some compilation warningsDenis Ovsienko2012-03-255-42/+1
| | | | | | | | | | | | | | | | | | | Including system headers is not necessary with zebra.h included and sometimes results in "__ASSERT_FUNCTION redefined" compilation warning. * babeld.c * babel_distribute_update_interface(): make static * babel_interface.c * interface_config_write(): unused 'babel_ifp' * don't include system headers * message.c * send_request(): unused 'babel_ifp' * send_multihop_request(): idem * don't include system headers * route.c: don't include system headers * xroute.c: idem * source.h: newline at EOF * message.h: idem
* babeld: address FreeBSD "struct route" issueDenis Ovsienko2012-03-254-58/+58
| | | | | FreeBSD system headers have their own "struct route", which made it impossible to compile babeld. Switching babeld to "struct babel_route".
* babeld: clean kernel_zebra (old functions, fields...).Matthieu Boutier2012-03-252-73/+0
|
* babeld: Initial import, for Babel routing protocol.Paul Jakma2012-03-2550-34/+8535
| | | | | | | | | | | * Initial import of the Babel routing protocol, ported to Quagga. * LICENCE: Update the original LICENCE file to include all known potentially applicable copyright claims. Ask that any future contributors to babeld/ grant MIT/X11 licence to their work. * *.{c,h}: Add GPL headers, in according with the SFLC guidance on dealing with potentially mixed GPL/other licensed work, at: https://www.softwarefreedom.org/resources/2007/gpl-non-gpl-collaboration.html
* lib: fix endianness bug in prefix.cRenato Westphal2012-03-231-4/+14
| | | | | | | | | | | | While defining two "maskbytes" arrays for the respective endiannesses, the code was unconditionally using one that only worked on little endian systems. Use preprocessor macros to avoid the somewhat expensive htonl/ntohl macros. From: Renato Westphal <renatowestphal@gmail.com> Signed-off-by: David Lamparter <equinox@diac24.net>
* ospfd: reduce ospf_verify_header()Denis Ovsienko2012-03-121-15/+6
| | | | | Protocol version checks fits ospf_packet_examin() better (like it is implemented in ospf6d), and packet type check is already there.
* ospfd: bring ospf_check_auth() into focusDenis Ovsienko2012-03-121-70/+100
| | | | | | | | | | | | | | | | | | The old ospf_check_auth() function did two different jobs depending on AuType. For Null and Simple cases it actually authenticated the packet, but for Cryptographic case it only checked declared packet size (not taking the actual number of bytes on wire into account). The calling function, ospf_verify_header(), had its own set of MD5/checksum checks dispatched depending on AuType. This commit makes the packet size check work against the real number of bytes and moves it to ospf_packet_examine(). All MD5/checksum verification is now performed in ospf_check_auth() function. * ospf_packet.c * ospf_packet_examin(): check length with MD5 bytes in mind * ospf_verify_header(): remove all AuType-specific code * ospf_check_auth(): completely rewrite
* ospfd: introduce ospf_auth_type_str[]Denis Ovsienko2012-03-122-2/+15
|
* ospfd: fix packet length check for auth/LLS casesDenis Ovsienko2012-03-121-5/+5
| | | | | | | | | | An OSPFv2 packet with trailing data blocks (authentication and/or link-local signaling) failed the recently implemented packet length check, because trailing data length isn't counted in the packet header "length" field. This commit fixes respective check conditions. * ospf_packet.c * ospf_packet_examin(): use "bytesdeclared" instead of "bytesonwire"
* ospfd: introduce ospf_lsa_minlen[] (BZ#705)Denis Ovsienko2012-03-123-1/+267
| | | | | | | | | | | | | | | This commit ports more packet checks to OSPFv2, in particular, LSA size verification and Router-LSA link blocks verification. * ospf_lsa.h: add LSA size macros * ospf_packet.h: add struct ospf_ls_update * ospf_packet.c * ospf_lsa_minlen[]: a direct equivalent of ospf6_lsa_minlen[] * ospf_router_lsa_links_examin(): new function, verifies trailing part of a Router-LSA * ospf_lsa_examin(): new function like ospf6_lsa_examin() * ospf_lsaseq_examin(): new function like ospf6_lsaseq_examin() * ospf_packet_examin(): add type-specific deeper level checks
* ospfd: review ospf_check_md5_digest()Denis Ovsienko2012-03-121-15/+5
| | | | | Rewrite some pointer arithmetics without the additional variables and move byte order conversion inside the function.
* ospfd: review ospf_check_auth()Denis Ovsienko2012-03-121-4/+3
| | | | | | | | | 1. The only purpose of "ibuf" argument was to get stream size, which was always equal to OSPF_MAX_PACKET_SIZE + 1, exactly as initialized in ospf_new(). 2. Fix the packet size check condition, which was incorrect for very large packets, at least in theory.
* ospfd: introduce ospf_packet_minlen[] (BZ#705)Denis Ovsienko2012-03-122-9/+60
| | | | | | | | | | | | This commit ports some of the OSPFv3 packet reception checks to OSPFv2. * ospf_packet.c * ospf_packet_minlen[]: a direct equivalent of ospf6_packet_minlen[] * ospf_packet_examin(): new function designed after the first part of ospf6_packet_examin() * ospf_read(): verify received packet with ospf_packet_examin() * ospf_packet.h: add convenience macros
* ospfd: fix ospf_packet_add_top() to use LOOKUP()Denis Ovsienko2012-03-121-1/+1
|
* ospfd: use LOOKUP() for ospf_packet_type_strDenis Ovsienko2012-03-124-17/+20
| | | | | | | | | | | | | | * ospf_packet.h: add proper str/max extern declarations * ospf_packet.c * ospf_packet_type_str: rewrite in "struct message", add max value * ospf_packet_add(): use LOOKUP() * ospf_write(): ditto * ospf_hello(): ditto * ospf_read(): ditto * ospf_dump.h: the declaration does not belong here * ospf_dump.c * ospf_header_dump(): use LOOKUP() * show_debugging_ospf(): ditto
* doc: Fix an apparently no longer legal @itemize @asisPaul Jakma2012-03-081-2/+2
| | | | | * basic.texi: @asis isn't legal with @itemize apparently, should be @w according to docs, but @w{} seems to be needed. Fixes doc build error.
* HACKING.tex: Change to a LaTeX version of HACKINGPaul Jakma2012-03-084-406/+482
| | | | | | | * configure.ac: Check for latexmk and pdflatex * Makefile.am: Add a conditional target to build HACKING.pdf, as a convenience * HACKING.tex: A slightly more structured HACKING, is readable on its own. * HACKING: removed
* HACKING: Typo fixPaul Jakma2012-03-071-1/+1
|