lockfree
set-ethernet-max-ring-buffer
Our great sponsors
lockfree | set-ethernet-max-ring-buffer | |
---|---|---|
11 | 1 | |
695 | 2 | |
- | - | |
7.9 | 2.8 | |
20 days ago | 3 months ago | |
C++ | Python | |
MIT License | - |
Stars - the number of stars that a project has on GitHub. Growth - month over month growth in stars.
Activity is a relative number indicating how actively a project is being developed. Recent commits have higher weight than older ones.
For example, an activity of 9.0 indicates that a project is amongst the top 10% of the most actively developed projects that we are tracking.
lockfree
- A lock-free ring-buffer with contiguous reservations (2019)
-
Atomics and Concurrency
If you're interested about lock-free data structures, I wrote [lockfree](https://github.com/DNedic/lockfree) a collection of lock-free data structures meant to be readable and both hosted system and embedded friendly.
-
Optimizing a Ring Buffer for Throughput
If you want more than a spsc queue, I've written `lockfree`, a collection of SPSC and MPMC data structures along the same principles the author here used:https://github.com/DNedic/lockfree.
The library is written in standard C++11 (but additional API's for higher C++ versions have been added), uses no dynamic allocation and is configurable so it is both big metal and deeply embedded friendly.
-
A collection of lock-free data structures written in standard C++11
- A lot of code won't work for types with no default constructors, but that is at least compile error
- Using memcpy[0] for arbitrary types is just wrong, see [1]
[0] https://github.com/DNedic/lockfree/blob/main/lockfree/inc/bi...
[1] https://www.open-std.org/jtc1/sc22/wg21/docs/papers/2023/p11...
-
Lock-free data structures
My friend wrote a few lock-free data structures and he is now looking for some feedback. Here is the link: https://github.com/DNedic/lockfree
- A collection of lock-free data structures written in standard c++11
- A collection of embedded friendly lock-free data structures written in standard C++11
set-ethernet-max-ring-buffer
-
a small tool to maximize ethernet rx/tx ring buffer
Sometimes maximizing RX/TX ring buffer can be a common task on high-throughput servers to avoid packet loss. I wrote a small utility to auto detect the max rx/tx ring buffer and then set them to the max values. This can save time and make it easy when we need to place a command to tune the ring buffer after OS starts.
What are some alternatives?
rc_event_queue - VecDeque-like fast, unbounded, mpmc/spmc concurent FIFO message queue. Lockless reads, write-lock writes.
AQtion - Aquantia AQC multigigabit NIC linux driver (atlantic) - development preview
distortos - object-oriented C++ RTOS for microcontrollers
ge-ethernet-SRTP - Working Demo of Proprietary GE SRTP PLC Communication Protocol (GE Ethernet)
glibc - GNU Libc
Ring-Buffer - A simple ring buffer (circular buffer) designed for embedded systems.
micro-gl - Headers Only C++11 CPU Vector Graphics. no std-lib, no FPU and no GPU required !
lwrb - Lightweight generic ring buffer manager library
tlaplus - TLC is a model checker for specifications written in TLA+. The TLA+Toolbox is an IDE for TLA+.
jemalloc
bounded-spsc-queue - A Bounded SPSC queue for Rust