Back to browse
GitHub Repository

Experimental thread-like processes, multiple executables in one address space

50 starsC++

Threadprocs – executables sharing one address space (0-copy pointers)

by jer-irl·Mar 23, 2026·64 points·46 comments

AI Analysis

●●●BangerWizardryBig BrainNiche Gem

Zero-copy pointer sharing between independent binaries via ASLR manipulation.

Strengths
  • ASLR direction at load time enables cross-process pointer validity without code changes.
  • Pass std::string and std::unordered_map directly between executables with no serialization.
  • Blends POSIX process isolation with threading memory model—genuinely novel programming paradigm.
Weaknesses
  • Linux-only (aarch64+x86_64), marked experimental with no production quality guarantee yet.
  • Extremely niche audience—only matters if you're already wrestling with IPC performance.
Target Audience

Systems programmers, performance-critical application developers

Similar To

DPDK · shared memory IPC · dlopen plugin systems

Post Description

This project launches multiple independent programs into a single shared virtual address space, while still behaving like separate processes (independent binaries, globals, and lifetimes). When threadprocs share their address space, pointers are valid across them with no code changes for well-behaved Linux binaries.

Unlike threads, each threadproc is a standalone and semi-isolated process. Unlike dlopen-based plugin systems, threadprocs run traditional executables with a `main()` function. Unlike POSIX processes, pointers remain valid across threadprocs because they share the same address space.

This means that idiomatic pointer-based data structures like `std::string` or `std::unordered_map` can be passed between threadprocs and accessed directly (with the usual data race considerations).

This accomplishes a programming model somewhere between pthreads and multi-process shared memory IPC.

The implementation relies on directing ASLR and virtual address layout at load time and implementing a user-space analogue of `exec()`, as well as careful manipulation of threadproc file descriptors, signals, etc. It is implemented entirely in unprivileged user space code: <https://github.com/jer-irl/threadprocs/blob/main/docs/02-imp...>.

There is a simple demo demonstrating “cross-threadproc” memory dereferencing at <https://github.com/jer-irl/threadprocs/tree/main?tab=readme-...>, including a high-level diagram.

This is relevant to systems of multiple processes with shared memory (often ring buffers or flat tables). These designs often require serialization or copying, and tend away from idiomatic C++ or Rust data structures. Pointer-based data structures cannot be passed directly.

There are significant limitations and edge cases, and it’s not clear this is a practical model, but the project explores a way to relax traditional process memory boundaries while still structuring a system as independently launched components.

Similar Projects