Skip to content
Snippets Groups Projects
  1. Nov 03, 2022
  2. Nov 02, 2022
    • Maria Matejka's avatar
      Memory pages are not munmapped, instead we just madvise() · 9d03c3f5
      Maria Matejka authored
      Memory unmapping causes slow address space fragmentation, leading in
      extreme cases to failing to allocate pages at all. Removing this problem
      by keeping all the pages allocated to us, yet calling madvise() to let
      kernel dispose of them.
      
      This adds a little complexity and overhead as we have to keep the
      pointers to the free pages, therefore to hold e.g. 1 GB of 4K pages with
      8B pointers, we have to store 2 MB of data.
      9d03c3f5
  3. Nov 01, 2022
  4. Oct 18, 2022
  5. Oct 12, 2022
  6. Oct 10, 2022
    • Ondřej Zajíček's avatar
      BGP: Add option 'next hop prefer global' · 8f79e6b9
      Ondřej Zajíček authored
      Add BGP channel option 'next hop prefer global' that modifies BGP
      recursive next hop resolution to use global next hop IPv6 address instead
      of link-local next hop IPv6 address for immediate next hop of received
      routes.
      8f79e6b9
  7. Oct 03, 2022
  8. Sep 27, 2022
    • Alexander Zubkov's avatar
      KRT: Fix setting default preference · 0f2be469
      Alexander Zubkov authored
      Changes in commit eb937358 broke setting of channel preference for alien
      routes learned during scan. The preference was set only for async routes.
      Move common attribute processing part of functions krt_learn_async() and
      krt_learn_async() to a separate function to have only one place for such
      changes.
      0f2be469
  9. Sep 16, 2022
  10. Sep 06, 2022
    • Maria Matejka's avatar
      Better profylaction recursive route loops · 71b3456e
      Maria Matejka authored
      In some specific configurations, it was possible to send BIRD into an
      infinite loop of recursive next hop resolution. This was caused by route
      priority inversion.
      
      To prevent priority inversions affecting other next hops, we simply
      refuse to resolve any next hop if the best route for the matching prefix
      is recursive or any other route with the same preference is recursive.
      
      Next hop resolution doesn't change route priority, therefore it is
      perfectly OK to resolve BGP next hops e.g. by an OSPF route, yet if the
      same (or covering) prefix is also announced by iBGP, by retraction of
      the OSPF route we would get a possible priority inversion.
      71b3456e
  11. Aug 18, 2022
  12. Aug 03, 2022
  13. Jul 27, 2022
  14. Jul 26, 2022
    • Ondřej Zajíček's avatar
      Netlink: Restrict route replace for IPv6 · ddb1bdf2
      Ondřej Zajíček authored
      Seems like the previous patch was too optimistic, as route replace is
      still broken even in Linux 4.19 LTS (but fixed in Linux 5.10 LTS) for:
      
        ip route add 2001:db8::/32 via fe80::1 dev eth0
        ip route replace 2001:db8::/32 dev eth0
      
      It ends with two routes instead of just the second.
      
      The issue is limited to direct and special type (e.g. unreachable)
      routes, the patch restricts route replace for cases when the new route
      is a regular route (with a next hop address).
      ddb1bdf2
  15. Jul 25, 2022
    • Ondřej Zajíček's avatar
      Netlink: Simplify handling of IPv6 ECMP routes · 722daa95
      Ondřej Zajíček authored
      When IPv6 ECMP support first appeared in Linux kernel, it used different
      API than IPv4 ECMP. Individual next hops were updated and announced
      separately, instead of using RTA_MULTIPATH as in IPv4. This has several
      drawbacks and requires complex code to merge received notifications to
      one multipath route.
      
      When Linux came with IPv6 RTA_MULTIPATH support, the initial versions
      were somewhat buggy, so we kept using the old API for updates (splitting
      multipath routes to sequences of route updates), while accepting both
      old-style routes and RTA_MULTIPATH routes in scans / notifications.
      
      As IPv6 RTA_MULTIPATH support is here for a long time, this patch fully
      switches Netlink to the IPv6 RTA_MULTIPATH API and removes old complex
      code for handling individual next hop announces.
      
      The required Linux version is at least 4.11 for reliable operation.
      
      Thanks to Daniel Gröber for the original patch.
      722daa95
  16. Jul 24, 2022
    • Ondřej Zajíček's avatar
      Merge branch 'master' into backport · 2e484f8d
      Ondřej Zajíček authored
      2e484f8d
    • Ondřej Zajíček's avatar
      KRT: Scan routing tables separetely on linux to avoid congestion · 534d0a4b
      Ondřej Zajíček authored
      Remove compile-time sysdep option CONFIG_ALL_TABLES_AT_ONCE, replace it
      with runtime ability to run either separate table scans or shared scan.
      
      On Linux, use separate table scans by default when the netlink socket
      option NETLINK_GET_STRICT_CHK is available, but retreat to shared scan
      when it fails.
      
      Running separate table scans has advantages where some routing tables are
      managed independently, e.g. when multiple routing daemons are running on
      the same machine, as kernel routing table modification performance is
      significantly reduced when the table is modified while it is being
      scanned.
      
      Thanks Daniel Gröber for the original patch and Toke Høiland-Jørgensen
      for suggestions.
      534d0a4b
  17. Jul 22, 2022
  18. Jul 12, 2022
  19. Jul 11, 2022
  20. Jul 10, 2022
  21. Jun 27, 2022
    • Ondřej Zajíček's avatar
      Filter: Implement for loops · cb339a30
      Ondřej Zajíček authored and Ondřej Zajíček's avatar Ondřej Zajíček committed
      For loops allow to iterate over elements in compound data like BGP paths
      or community lists. The syntax is:
      
        for [ <type> ] <variable> in <expr> do <command-body>
      cb339a30
    • Ondřej Zajíček's avatar
      Filter: Implement mixed declarations of local variables · 1ac8e11b
      Ondřej Zajíček authored and Ondřej Zajíček's avatar Ondřej Zajíček committed
      Allow variable declarations mixed with code, also in nested blocks with
      proper scoping, and with variable initializers. E.g:
      
      function fn(int a)
      {
        int b;
        int c = 10;
      
        if a > 20 then
        {
          b = 30;
          int d = c * 2;
          print a, b, c, d;
        }
      
        string s = "Hello";
      }
      1ac8e11b
    • Ondřej Zajíček's avatar
      Filter: Improve handling of stack frames in filter bytecode · a2527ee5
      Ondřej Zajíček authored and Ondřej Zajíček's avatar Ondřej Zajíček committed
      When f_line is done, we have to pop the stack frame. The old code just
      removed nominal number of args/vars. Change it to use stored ventry value
      modified by number of returned values. This allows to allocate variables
      on a stack frame during execution of f_lines instead of just at start.
      
      But we need to know the number of returned values for a f_line. It is 1
      for term, 0 for cmd. Store that to f_line during linearization.
      a2527ee5
    • Ondřej Zajíček's avatar
      Filter: Simplify handling of command sequences · f31f4e6e
      Ondřej Zajíček authored and Ondřej Zajíček's avatar Ondřej Zajíček committed
      Command sequences in curly braces used a separate nonterminal in grammar.
      Handle them as a regular command.
      f31f4e6e
    • Ondřej Zajíček's avatar
      Filter: Fix bug in variable shadowing · 1e6acf34
      Ondřej Zajíček authored and Ondřej Zajíček's avatar Ondřej Zajíček committed
      When a new variable used the same name as an existing symbol in an outer
      scope, then offset number was defined based on a scope of the existing
      symbol ($3) instead of a scope of the new symbol (sym_). That can lead
      to two variables sharing the same memory slot.
      1e6acf34
    • Ondřej Zajíček's avatar
      Filter: Implement soft scopes · 946cedfc
      Ondřej Zajíček authored and Ondřej Zajíček's avatar Ondřej Zajíček committed
      Soft scopes are anonymous scopes that most likely do not contain any
      symbol, so allocating regular scope is postponed when it is really
      needed.
      946cedfc
    • Ondřej Zajíček's avatar
      Filter: Implement direct recursion · 26bc4f99
      Ondřej Zajíček authored and Ondřej Zajíček's avatar Ondřej Zajíček committed
      Direct recursion almost worked, just crashed on function signature check.
      Split function parsing such that function signature is saved before
      function body is processed. Recursive calls are marked so they can be
      avoided during f_same() and similar code walking.
      
      Also, include tower of hanoi solver as a test case.
      26bc4f99
Loading