• Victor Gomes's avatar
    [heap] Support mprotect off thread · 8a6b7d8b
    Victor Gomes authored
    While compiling concurrently, we change the permissions of the page
    containing the new code object to RWX, so the main thread can continue
    executing a potential code in the same page.
    
    If no thread is compiling the new code, we change the permissions
    of all pages affected back to RX.
    
    We also initialises code object page to immediately RWX by default.
    Otherwise, a new code could be allocated in the same page, it will call
    UnprotectAndRegister, and since write_unprotect_counter_ is now at
    least 2, the code ignores the permission change. We then sigfault
    when trying to run the new code.
    
    Change-Id: Id18bcb9a44843b4ff747b1e4ac91913e80b74d80
    Reviewed-on: https://chromium-review.googlesource.com/c/v8/v8/+/3257606Reviewed-by: 's avatarDominik Inführ <dinfuehr@chromium.org>
    Commit-Queue: Victor Gomes <victorgomes@chromium.org>
    Cr-Commit-Position: refs/heads/main@{#77827}
    8a6b7d8b
Name
Last commit
Last update
..
arm Loading commit data...
arm64 Loading commit data...
ia32 Loading commit data...
loong64 Loading commit data...
mips Loading commit data...
mips64 Loading commit data...
ppc Loading commit data...
riscv64 Loading commit data...
s390 Loading commit data...
x64 Loading commit data...
DEPS Loading commit data...
OWNERS Loading commit data...
baseline-assembler-inl.h Loading commit data...
baseline-assembler.h Loading commit data...
baseline-batch-compiler.cc Loading commit data...
baseline-batch-compiler.h Loading commit data...
baseline-compiler.cc Loading commit data...
baseline-compiler.h Loading commit data...
baseline.cc Loading commit data...
baseline.h Loading commit data...
bytecode-offset-iterator.cc Loading commit data...
bytecode-offset-iterator.h Loading commit data...