Commit Graph

655 Commits

Author SHA1 Message Date
Tim Ledbetter
884a0140aa LibCore: Allow zero-size AnonymousBuffer creation
Previously, `AnonymousBuffer::create_with_size(0)` returned an error
because POSIX `mmap` rejects a zero length with `EINVAL`, and Windows
`CreateFileMapping` rejects a zero maximum size for an anonymous
mapping. This caused a crash when using `--headless=text` with zero
size pages like `about:blank`.
2026-04-22 09:08:39 -04:00
ayeteadoe
4cb7743915 LibCore: Expose register_process and implement for Windows event loop
This is the closest Windows equivalent to integrating process exit
handlers into the event loop.

Linux could also integrate register_process() into the poll() based
Unix event loop via the SYS_pidfd_open syscall; however, macOS requires
a kqueue. So for now register_process will only be used by Windows to
implement WebView::ProcessMonitor.

Co-authored-by: Aliaksandr Kalenik <kalenik.aliaksandr@gmail.com>
2026-04-12 16:08:07 +02:00
Tim Ledbetter
2f82040cb1 LibCore: Add a CORE_API annotation to log_timing_info()
This is required to use the `REPORT_TIME` and `REPORT_TIME_EVERY`
macros.
2026-04-02 20:00:06 -04:00
sideshowbarker
d7053a8eb8 LibCore: Don’t pass O_CLOEXEC to shm_open
Bug: Ladybird crashes on launch on macOS 26.4+ with “UNEXPECTED ERROR:
close: Bad file descriptor” in SharedVersion.cpp — because
AnonymousBuffer creation fails.

Cause: anon_create() passed O_CLOEXEC in the oflag argument to shm_open.
macOS 26.4+ rejects that with EINVAL. POSIX only specifies O_RDONLY,
O_RDWR, O_CREAT, O_EXCL, and O_TRUNC as valid shm_open flags; on earlier
macOS versions, O_CLOEXEC just happened to also be silently accepted.

Fix: Filter O_CLOEXEC from the oflag argument we pass to shm_open flags,
and instead set FD_CLOEXEC via fcntl — after opening.
2026-03-31 17:21:17 +01:00
Shannon Booth
3beeb11e74 LibCore: Remove unneeded is_null checks on StringView 2026-03-31 13:48:50 +01:00
Aliaksandr Kalenik
1d025620e3 Everywhere: Move Mach bootstrap listener into LibIPC
Move MachPortServer from LibWebView into LibIPC as MachBootstrapListener
and move the Mach message structs from MachMessageTypes.h into LibIPC.

These types are IPC infrastructure, not UI or platform concerns.
Consolidating them in LibIPC keeps the Mach bootstrap handshake
self-contained in a single library and removes LibWebView's dependency
on LibThreading.
2026-03-24 19:51:52 +01:00
Aliaksandr Kalenik
3cb644500e Everywhere: Send IOSurface backing stores via main IPC route on macOS
Now that LibIPC uses Mach ports for transport on macOS, IOSurface port
rights can be sent as regular IPC message attachments instead of through
a separate ad-hoc Mach message side-channel. Introduce
Web::SharedBackingStore that wraps either a MachPort (macOS) or
ShareableBitmap (other platforms) with IPC encode/decode support,
unifying backing store allocation into the existing
did_allocate_backing_stores IPC message.
2026-03-23 23:22:38 +01:00
Aliaksandr Kalenik
4ea4d63008 Everywhere: Replace Unix socket IPC transport with Mach ports on macOS
On macOS, use Mach port messaging instead of Unix domain sockets for
all IPC transport. This makes the transport capable of carrying Mach
port rights as message attachments, which is a prerequisite for sending
IOSurface handles over the main IPC channel (currently sent via a
separate out-of-band path). It also avoids the need for the FD
acknowledgement protocol that TransportSocket requires, since Mach port
right transfers are atomic in the kernel.

Three connection establishment patterns:

- Spawned helper processes (WebContent, RequestServer, etc.) use the
  existing MachPortServer: the child sends its task port with a reply
  port, and the parent responds with a pre-created port pair.

- Socket-bootstrapped connections (WebDriver, BrowserProcess) exchange
  Mach port names over the socket, then drop the socket.

- Pre-created pairs for IPC tests and in-message transport transfer.

Attachment on macOS now wraps a MachPort instead of a file descriptor,
converting between the two via fileport_makeport()/fileport_makefd().

The LibIPC socket transport tests are disabled on macOS since they are
socket-specific.
2026-03-23 18:50:48 +01:00
Andreas Kling
a25fc5ad8a LibCore+LibWeb: Add ScopedAutoreleasePool and use it on macOS
On macOS, Objective-C methods frequently return autoreleased objects
that accumulate until an autorelease pool is drained. Our event loop
(Core::EventLoop) and rendering thread both lacked autorelease pools,
causing unbounded accumulation of autoreleased objects.

The rendering thread was the worst offender: every Skia flush triggers
Metal resource allocation which sets labels on GPU textures via
-[IOGPUMetalResource setLabel:], creating autoreleased CFData objects.
With ~1M+ such objects at 112 bytes each, this leaked ~121MB. Metal
command buffer objects (_MTLCommandBufferEncoderInfo, etc.) also
accumulated, adding another ~128MB.

Add Core::ScopedAutoreleasePool, a RAII wrapper around the ObjC runtime
autorelease pool (no-op on non-macOS), and drain it:
- Every event loop pump (like NSRunLoop does)
- Every compositor loop iteration on the rendering thread
2026-03-15 11:42:43 +01:00
Andreas Kling
643f2884cc LibCore: Fix signal handler deadlock in EventLoopImplementationUnix
handle_signal() called ThreadData::the() which can acquire a write
lock on s_thread_data_lock if the thread hasn't initialized its
ThreadData yet. If the signal interrupts a thread that already holds
a read lock on s_thread_data_lock (e.g. in unregister_notifier()),
this deadlocks — the write lock waits for the read lock, but the
read lock holder is blocked in the signal handler.

Fix by accessing the thread-local s_this_thread_data directly. If
the thread has no ThreadData, there's no wake pipe to write to, so
we just return.
2026-03-07 13:09:50 +01:00
Andreas Kling
656a84e180 LibThreading: Fix data race in RWLock::unlock()
The generic unlock() wrote to m_write_locked from every thread
regardless of whether a read or write lock was held. When multiple
threads held concurrent read locks, their unlock() calls would race
on the non-atomic m_write_locked and m_read_locked_with_write_lock
fields.

Split unlock() into unlock_read() and unlock_write() so that read
unlocks never touch the write-lock tracking fields. The RWLockLocker
template dispatches at compile time based on LockMode.
2026-03-07 13:09:50 +01:00
Zaggy1024
8c96f7b3aa LibCore: Stop atomically ref-counting EventReceiver
Inheriting from AtomicRefCounted and Weakable is asking for misuse of
WeakPtr to result in TOCTOU-caused UAFs.

In order to ensure we're not misusing EventReceiver across threads, I
ran test-web and some sites with a temporary hack to verify that ref()s
and unref()s are always called from the same thread on the class.
2026-03-02 17:06:39 -06:00
Zaggy1024
d6ff027593 LibCore: Remove the pending jobs functionality from ThreadEventQueue
This is no longer used.
2026-03-02 17:06:39 -06:00
Zaggy1024
035b489266 LibCore: Prevent UAF on event loop wake handles on Windows
We were holding a reference to ThreadData, which could be destroyed
earlier than the EventLoop itself, causing other threads to UAF trying
to signal a wake.
2026-03-02 17:06:39 -06:00
Zaggy1024
04e95b7dd1 LibCore: Avoid UAF on the array of wake pipes when exit()ing
If exit() is called on a thread with an EventLoop in the stack, the
ThreadData storing the array of wake pipes will be destroyed first.
Threads can still take a strong reference to the EventLoop after that,
and will read the fds from freed memory.

Instead, take a copy of the write fd, and swallow EBADF when writing to
it, since that only indicates that the thread and event loop are
exiting, so there's nothing to do with the wake.
2026-03-02 17:06:39 -06:00
R-Goc
919f44f3a5 LibCore: Explicitly export symbols from LibCore
This patch adds explicit symbol export to LibCore. This leads to about
350 less symbols being exported.
2026-02-26 18:31:57 +01:00
R-Goc
57b12d3ca0 LibCore: Remove LibCoreMinimal 2026-02-26 18:31:57 +01:00
Ben Wiederhake
1fd672c4c2 LibCore: Remove unused header in File 2026-02-23 12:15:23 +01:00
Ben Wiederhake
7093082d75 LibCore: Remove forward declaration of non-existent type 2026-02-23 12:15:23 +01:00
Ben Wiederhake
0206150b70 LibCore: Remove unused header in TimeZoneWatcherUnix 2026-02-21 19:27:35 +01:00
Ben Wiederhake
08f4cf10ed LibCore: Remove unused header in LocalServer 2026-02-21 19:27:35 +01:00
Ben Wiederhake
084f5ababd LibCore: Remove unused header in EventLoopImplementationUnix 2026-02-21 19:27:35 +01:00
Ben Wiederhake
ee5a6e1b28 LibCore: Remove unused header in AnonymousBuffer 2026-02-21 19:27:35 +01:00
Ben Wiederhake
6a34849238 LibCore: Remove unused header in ThreadEventQueue 2026-02-21 19:27:35 +01:00
Ben Wiederhake
e27bdaafe7 LibCore: Remove unused header in ResourceImplementationFile 2026-02-21 19:27:35 +01:00
Ben Wiederhake
387f378f45 LibCore: Remove unused header in ResourceImplementation 2026-02-21 19:27:35 +01:00
Ben Wiederhake
fb7095ab88 LibCore: Remove unused header in Resource 2026-02-21 19:27:35 +01:00
Ben Wiederhake
6335f4745f LibCore: Remove unused header in MimeData 2026-02-21 19:27:35 +01:00
Ben Wiederhake
b33b08050a LibCore: Remove unused header in EventReceiver 2026-02-21 19:27:35 +01:00
Ben Wiederhake
ca28b98b83 LibCore: Remove unused header in EventLoopImplementation 2026-02-21 19:27:35 +01:00
Ben Wiederhake
a929850fdb LibCore: Remove unused header in EventLoop 2026-02-21 19:27:35 +01:00
Ben Wiederhake
543fb77e5d LibCore: Remove unused header in ConfigFile 2026-02-21 19:27:35 +01:00
Ben Wiederhake
94dee9bea2 LibCore: Remove unused header in System 2026-02-21 19:27:35 +01:00
Ben Wiederhake
e0f39d5114 LibCore: Remove unused header in StandardPaths 2026-02-21 19:27:35 +01:00
Ben Wiederhake
36063f6881 LibCore: Remove unused header in MappedFile 2026-02-21 19:27:35 +01:00
Ben Wiederhake
e6e0bf0136 LibCore: Remove unused header in Environment 2026-02-21 19:27:35 +01:00
Andreas Kling
e87f889e31 Everywhere: Abandon Swift adoption
After making no progress on this for a very long time, let's acknowledge
it's not going anywhere and remove it from the codebase.
2026-02-17 10:48:09 -05:00
Shannon Booth
32c51774ee LibCore: Remove unusued Core::System::mkdtemp
This suffers from TOCTOU issues, and alternatives should probably
be used. Since it is unused, let's just remove it.
2026-02-14 10:25:33 -05:00
Timothy Flynn
4ad9543a65 LibCore: Add helpers to share arbitrary versions between processes
This will allow sharing e.g. document cookie versions between the UI and
WebContent processes, and safely accessing those versions.

Core::AnonymousBuffer internally creates a minimum buffer of PAGE_SIZE
bytes. This is much more than the size of a single version, but this
affords us the opportunity to share multiple versions in a single buffer
between processes. With a PAGE_SIZE of 4096, we can share up to 512
versions in a single buffer.
2026-02-05 07:28:07 -05:00
Andrew Kaster
643605099e LibCore: Move Core::MappedFile to LibCoreMinimal 2026-02-03 10:29:51 +01:00
R-Goc
3a86e779bd LibCore/LibIPC/Meta: Stop using deprecated Winsock functions
This commit stops using deprecated WSA functions. While the ANSI
versions are most likely not going anywhere, Windows is natively UTF-16
so it has to convert to ANSI internally. All the ANSI functions in
Winsock are marked as deprecated. The macro suppressing the warnings is
no longer defined.
2026-02-02 10:35:11 +01:00
R-Goc
1ac35d19f9 LibCore: Handle long paths in ProcessWindows
This commit handles the case where the process executable has a long
path.
2026-02-02 10:35:11 +01:00
Andreas Kling
5968ff90af LibCore: Add AnonymousBuffer::bytes() getter 2026-02-01 22:46:09 +01:00
Andreas Kling
9ad9c65368 Revert "LibCore: Add thread-safe weak deferred_invoke()"
This reverts commit 96ce468b60.

Appears to have regressed WPT.
2026-01-25 12:20:39 +01:00
Andreas Kling
96ce468b60 LibCore: Add thread-safe weak deferred_invoke()
Add a thread-safe deferred_invoke() API on WeakEventLoopReference that
queues work onto the owning thread's event queue and wakes that thread
via EventLoopManager hooks. This avoids calling wake() from foreign
threads during teardown.

Implement current_thread_handle()/wake_thread() in each backend and
track per-thread data so handles are validated before waking:

- Unix: wake via per-thread wake pipe
- Windows: wake via thread wake event
- macOS: wake via stored CFRunLoopRef
- Qt: wake via event target or QEventLoop::wakeUp()
- Android: wake via stored ALooper
2026-01-25 09:32:51 +01:00
Andreas Kling
2734f72835 LibCore: Fix data race in WeakEventLoopReference::revoke()
This was taking a read lock while modifying m_event_loop, which is a
data race with concurrent calls to take() that also hold read locks.
2026-01-25 09:32:51 +01:00
Andreas Kling
2a6045833c LibCore: Make ProxyData::port a u16
TCP ports are always u16 and this prevents invalid values from getting
into this field somehow.
2026-01-22 17:38:15 +01:00
Zaggy1024
4a5350a2ee LibCore: Use sendfile instead of mmap+write on macOS 2026-01-19 06:53:29 -05:00
Zaggy1024
84c0eb3dbf LibCore+LibHTTP+RequestServer: Send data via sockets instead of pipes
This brings the implementation on Unix in line with Windows, so we can
drop a few ifdefs.
2026-01-19 06:53:29 -05:00
Zaggy1024
a3f0b513b6 LibCore: Remove an unnecessary ifdef from ioctl
Passing argp to ioctl as void* instead of FlatPtr works on Linux, but
Haiku needs a void*, so let's just do that unconditionally.
2026-01-19 06:53:29 -05:00