Source code
Revision control
Copy as Markdown
Other Tools
# -*- Mode: python; indent-tabs-mode: nil; tab-width: 40 -*-
# vim: set filetype=python:
# This Source Code Form is subject to the terms of the Mozilla Public
# License, v. 2.0. If a copy of the MPL was not distributed with this
@template
def RLBoxLibrary(name, use_segue=True):
WASM_SOURCES += [
"/memory/mozalloc/mozalloc.cpp",
"/third_party/rlbox_wasm2c_sandbox/c_src/wasm2c_sandbox_wrapper.c",
]
if CONFIG["DEVELOPER_OPTIONS"]:
wasm_sources = sorted(f"!{name}.wasm_{n}.c" for n in range(16))
else:
wasm_sources = [f"!{name}.wasm.c"]
SOURCES += wasm_sources
SOURCES += ["/third_party/wasm2c/wasm2c/wasm-rt-impl.c"]
SOURCES += ["/third_party/wasm2c/wasm2c/wasm-rt-mem-impl.c"]
# Configuration for the wasm2c runtime used by RLBox
# Enable SIMD autovectorization
if CONFIG["WASM_CC_VERSION"] and int(CONFIG["WASM_CC_VERSION"].split(".")[0]) >= 11:
WASM_CXXFLAGS += ["-msimd128"]
# Use a mmap style allocation
DEFINES["WASM_RT_USE_MMAP"] = 1
# Don't use internal signal handler as Firefox already provides one
DEFINES["WASM_RT_SKIP_SIGNAL_RECOVERY"] = 1
# We provide a custom trap handler that calls MOZ_CRASH
DEFINES["WASM_RT_TRAP_HANDLER"] = "moz_wasm2c_trap_handler"
# Don't limit the nested call depth
DEFINES["WASM_RT_NONCONFORMING_UNCHECKED_STACK_EXHAUSTION"] = 1
# Configure the wasm runtime to invoke a callback when a Wasm memory growth
# fails inside the sandbox. This information is used to annotate crash reports.
DEFINES["WASM_RT_GROW_FAILED_HANDLER"] = "moz_wasm2c_memgrow_failed"
for source in wasm_sources:
SOURCES[source].flags += ["-Wno-unused"]
# Use Segue optimization. Since this requires passing the "-mfsgsbase", we
# restrict this to compilers and architectures that support this flag.
# Manually exclude android for now due to bug in upstream wasm2c support
if (
use_segue
and CONFIG["CC_TYPE"] in ("clang", "gcc")
and CONFIG["TARGET_CPU"] == "x86_64"
and CONFIG["OS_TARGET"] != "Android"
and not (CONFIG["MOZ_ASAN"] or CONFIG["MOZ_TSAN"])
):
# Setting WASM_RT_ALLOW_SEGUE means Segue is used on supported
# OS/compiler/Arch combinations. For example, it is used for
# Linux/clang/x86_64 but not on Windows
DEFINES["WASM_RT_ALLOW_SEGUE"] = 1
# Segue can assume there is no other use of the segment register by the
# application. This is fine as the System V ABI for x86_64 systems does
# not use the gs register for any other purpose.
DEFINES["WASM_RT_SEGUE_FREE_SEGMENT"] = 1
# Add a compiler flag for the wasm2c produced file to enable use of
# wrgsbase64 instruction via intrinsics. While this instruction is
# available only on CPUs starting Ivybridge, the wasm2c runtime checks for
# support before using this instruction. Thus, enabling this flag does not
# introduce a dependency on newer CPUs to Firefox.
CFLAGS += ["-mfsgsbase"]
WASM_DEFINES["MOZ_IN_WASM_SANDBOX"] = True
if CONFIG["ENABLE_CLANG_PLUGIN"]:
WASM_DEFINES["MOZ_CLANG_PLUGIN"] = True
SANDBOXED_WASM_LIBRARY_NAME = f"{name}.wasm"
# Ideally we'd also list {name}.wasm.h as an output, but that would put the
# generation in export rather than pre-compile, and we prefer the latter.
GeneratedFile(
f"{name}.wasm.c",
script="/config/wasm2c.py",
entry_point="wasm2c",
inputs=["!/dist/host/bin/wasm2c" + CONFIG["HOST_BIN_SUFFIX"], f"!{name}.wasm"],
flags=["--num-outputs", len(wasm_sources)] if len(wasm_sources) > 1 else [],
)