Age | Commit message (Collapse) | Author | |
---|---|---|---|
2021-12-08 | Final version of asynchronous export documentation | Maria Matejka | |
2021-12-08 | Thread documentation: chapter 3, coroutines and locking | Maria Matejka | |
2021-12-08 | Thread documentation: chapters 0, 1 and 2 | Maria Matejka | |
2021-12-07 | Fixed build errors for OpenBSD | Maria Jan Matejka | |
2021-12-07 | Fixed standby memory page counters on shutdown | Maria Matejka | |
Bug introduced by commit 38278d94ba0a179d5eeb061a59850a4e1c150e5b. | |||
2021-12-07 | GDB: io loop printing support in resource dumps, better iterating over ↵ | Maria Matejka | |
linpool chunks | |||
2021-12-07 | Fixed a race condition in channel aux table cleanup | Maria Matejka | |
2021-12-07 | Event list asserts to prevent running into rotten data | Maria Matejka | |
2021-12-07 | Using more Python-ish constructions in BIRD linked-list accessors | Maria Matejka | |
2021-12-07 | Main IO loop shouldn't skip sockets when ping is received | Maria Matejka | |
2021-12-02 | Standby memory pages are accounted for as overhead in show memory command | Maria Matejka | |
2021-12-01 | No memory unmapping when shutting down | Maria Matejka | |
All the memory is just freed implicitly on exit, no need for page-by-page unmapping. | |||
2021-12-01 | Faster shutdown and cleanups by freeing route attributes strictly from main loop | Maria Matejka | |
2021-12-01 | Faster prune on table deletion | Maria Matejka | |
2021-12-01 | Table prune routines request export announcements directly | Maria Matejka | |
2021-12-01 | fixed duplicate routes propagation | Maria Matejka | |
2021-12-01 | Merge branch 'master' into HEAD | Maria Matejka | |
2021-12-01 | Fix of shutdown: premature log cleanup led to use-after-free | Maria Matejka | |
2021-12-01 | Page allocator moved from pools to IO loops. | Maria Matejka | |
The resource pool system is highly hierarchical and keeping spare pages in pools leads to unnecessarily complex memory management. Loops have a flat hiearchy, at least for now, and it is therefore much easier to keep care of pages, especially in cases of excessive virtual memory fragmentation. | |||
2021-11-30 | For safer memory allocations, resources are bound to loops. | Maria Matejka | |
Also all loops have their basic resource pool for allocations which are auto-freed when the loop is stopping. | |||
2021-11-27 | Memory statistics split into Effective and Overhead | Maria Matejka | |
This feature is intended mostly for checking that BIRD's allocation strategies don't consume much memory space. There are some cases where withdrawing routes in a specific order lead to memory fragmentation and this output should give the user at least a notion of how much memory is actually used for data storage and how much memory is "just allocated" or used for overhead. Also raising the "system allocator overhead estimation" from 8 to 16 bytes; it is probably even more. I've found 16 as a local minimum in best scenarios among reachable machines. I couldn't find any reasonable method to estimate this value when BIRD starts up. This commit also fixes the inaccurate computation of memory overhead for slabs where the "system allocater overhead estimation" was improperly added to the size of mmap-ed memory. | |||
2021-11-24 | fixup of table reload bug | Maria Matejka | |
2021-11-24 | Directly mapped pages are kept for future use if temporarily not needed | Maria Matejka | |
2021-11-24 | GDB pretty printer for resource pools | Maria Matejka | |
2021-11-23 | Fixed pipe reload/refeed | Maria Matejka | |
2021-11-23 | Stored pages release routine | Maria Matejka | |
2021-11-23 | Fixed channel export map confusion | Maria Matejka | |
2021-11-22 | BGP: End route refresh before another starts | Maria Matejka | |
2021-11-22 | RPKI has its own loop | Maria Matejka | |
2021-11-22 | RPKI: Use the route refresh mechanism also for the first load | Maria Matejka | |
2021-11-22 | More information on RPKI errors | Maria Matejka | |
2021-11-22 | Higher settle times when route refresh in the source table is running | Maria Matejka | |
2021-11-22 | Corking also feed start to keep BIRD running when refeeds would easily cause ↵ | Maria Matejka | |
congestion | |||
2021-11-22 | Route attribute cache is now lockless on read / clone. | Maria Matejka | |
Lots of time was spent locking when accessing route attribute cache. This overhead should be now reduced to a minimum. | |||
2021-11-22 | Route sources have their separate global lock | Maria Matejka | |
2021-11-22 | Introducing basic RCU primitives for lock-less shared data structures | Maria Matejka | |
2021-11-22 | VRF setting reduced to one argument, using default dummy iface for default vrf | Maria Matejka | |
2021-11-22 | Route table import-to-export announcement indirection to reduce pipe traffic | Maria Matejka | |
2021-11-22 | Keeping un-unmmappable pages until they can be reused | Maria Matejka | |
On Linux, munmap() may fail with ENOMEM when virtual memory is too fragmented. Working this around by just keeping such blocks for future use. | |||
2021-11-22 | Pipe runs in parallel. | Maria Matejka | |
2021-11-22 | Routing tables now have their own loops. | Maria Matejka | |
This basically means that: * there are some more levels of indirection and asynchronicity, mostly in cleanup procedures, requiring correct lock ordering * all the internal table operations (prune, next hop update) are done without blocking the other parts of BIRD * the protocols may get their own loops very soon | |||
2021-11-22 | Route subscription uses events | Maria Matejka | |
2021-11-22 | Global table update pool removed | Maria Matejka | |
2021-11-22 | Locking route attributes cache | Maria Matejka | |
To access route attribute cache from multiple threads at once, we have to lock the cache on writing. The route attributes data structures are safe to read unless somebody tries to tamper with the cache itself. | |||
2021-11-22 | Route sources have an explicit owner | Maria Matejka | |
This commit prevents use-after-free of routes belonging to protocols which have been already destroyed, delaying also all the protocols' shutdown until all of their routes have been finally propagated through all the pipes down to the appropriate exports. The use-after-free was somehow hypothetic yet theoretically possible in rare conditions, when one BGP protocol authors a lot of routes and the user deletes that protocol by reconfiguring in the same time as next hop update is requested, causing rte_better() to be called on a not-yet-pruned network prefix while the owner protocol has been already freed. In parallel execution environments, this would happen an inter-thread use-after-free, causing possible heisenbugs or other nasty problems. | |||
2021-11-22 | Table cork: Stop creating updates when there are too many pending. | Maria Matejka | |
The corked procedure gets a callback when uncorked. Supported by table maintenance routines and also BGP. | |||
2021-11-22 | Split route table event into separate events | Maria Matejka | |
The former rt_event is dropped in favour of separate table events. This allows for selective corking of NHU and prune. | |||
2021-11-22 | Adding a generic cork mechanism for events | Maria Matejka | |
2021-11-22 | Converting the former BFD loop to a universal IO loop and protocol loop. | Maria Matejka | |
There is a simple universal IO loop, taking care of events, timers and sockets. Primarily, one instance of a protocol should use exactly one IO loop to do all its work, as is now done in BFD. Contrary to previous versions, the loop is now launched and cleaned by the nest/proto.c code, allowing for a protocol to just request its own loop by setting the loop's lock order in config higher than the_bird. It is not supported nor checked if any protocol changed the requested lock order in reconfigure. No protocol should do it at all. | |||
2021-11-22 | Moved BFD IO loop out of BFD as we want to use it as socket-io coroutine | Maria Matejka | |