Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Lock-Free Programming #14

Open
ashvardanian opened this issue Dec 31, 2024 · 2 comments
Open

Lock-Free Programming #14

ashvardanian opened this issue Dec 31, 2024 · 2 comments
Labels
enhancement New feature or request good first issue Good for newcomers help wanted Extra attention is needed

Comments

@ashvardanian
Copy link
Owner

Most C++ developers have heard of std::mutex and std::shared_mutex, and some may have implemented their oversimplified versions using std::atomic. However, there have been few attempts to design a scalable shared mutex that works efficiently on modern 100+ core NUMA systems.

To understand the foundational problems causing these limitations, one should study memory contention and profile how the system behaves when many threads attempt to read or modify the same memory address. Before attempting to design high-level STL-like abstractions, one should understand how some key instructions operate:

  • On x86:
    • LOCK XADD, LOCK CMPXCHG, and PAUSE for spinlocks and synchronization.
    • Memory barriers: MFENCE, SFENCE, LFENCE.
    • Transactional memory primitives: XBEGIN / XEND (TSX).
  • On AArch64:
    • Load/store-exclusive: LDXR / STXR and atomic compare-and-swap (CAS).
    • Memory barriers: DMB, DSB, ISB.
    • Spinlock optimization: YIELD.

Once the low-level profiling is complete, the next step could be to explore implementations of advanced concurrency primitives proposed in the Concurrency TS, like the Distributed Counters in P0261 or Byte-wise atomic memcpy in P1478.


This topic could also serve as the foundation for a research paper on concurrency primitives, especially for those pursuing a master’s or PhD in Systems Programming.

@ashvardanian ashvardanian added enhancement New feature or request help wanted Extra attention is needed good first issue Good for newcomers labels Dec 31, 2024
@Cosmin-B
Copy link

Hey @ashvardanian

Thank you for your amazing contributions so far!!

I am reaching out regarding this specific issue as it is a very dear topic for me and ask what a good contribution would look like that will cover these instructions to be accepted by you and what the main goals /objectives should be, as right now the description is a bit broader. Thanks again!

Cheers,
Cosmin

@ashvardanian
Copy link
Owner Author

I don't have a specific task in mind here, but would prefer it to be practical. It can probably be something like concurrent histogram construction, a queue, or else. What do you have in mind?

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
enhancement New feature or request good first issue Good for newcomers help wanted Extra attention is needed
Projects
None yet
Development

No branches or pull requests

2 participants