diff options
author | Alon Zakai <azakai@google.com> | 2024-02-26 14:22:55 -0800 |
---|---|---|
committer | GitHub <noreply@github.com> | 2024-02-26 14:22:55 -0800 |
commit | df0d283e38ee9ef1359e6f80f178944a928cadca (patch) | |
tree | e809e3d5b4ecd971cfccb8f4305b29eeeb2d77ef | |
parent | 999781ae38f47f20e2dda962abc851e6846ad950 (diff) | |
download | binaryen-df0d283e38ee9ef1359e6f80f178944a928cadca.tar.gz binaryen-df0d283e38ee9ef1359e6f80f178944a928cadca.tar.bz2 binaryen-df0d283e38ee9ef1359e6f80f178944a928cadca.zip |
[Emscripten port] Improve emcc flags (#6349)
No changes here to binaryen.js/wasm builds.
1. Add a flag to enable pthreads.
2. Use SINGLE_FILE on binaryen.js/.wasm as before, which is nice for library users
as they want just a single file to distribute for Binaryen support. For other builds
like wasm-opt.js etc. no longer set SINGLE_FILE, as that type of build wants to be
a replacement for a normal wasm-opt build as much as possible, so avoid the
overhead of SINGLE_FILE.
(Previously we disabled SINGLE_FILE also in the case of BUILD_FOR_BROWSER
but I don't think we need to special-case that any more.)
-rw-r--r-- | CMakeLists.txt | 19 |
1 files changed, 18 insertions, 1 deletions
diff --git a/CMakeLists.txt b/CMakeLists.txt index def330b27..cda32f3d9 100644 --- a/CMakeLists.txt +++ b/CMakeLists.txt @@ -52,6 +52,9 @@ option(BUILD_FOR_BROWSER "Build binaryen toolchain utilities for the browser" OF # Turn this on to use the Wasm EH feature instead of emscripten EH in the wasm/BinaryenJS builds option(EMSCRIPTEN_ENABLE_WASM_EH "Enable Wasm EH feature in emscripten build" OFF) +# Turn this on to use pthreads feature in the wasm/BinaryenJS builds +option(EMSCRIPTEN_ENABLE_PTHREADS "Enable pthreads in emscripten build" OFF) + # For git users, attempt to generate a more useful version string if(EXISTS ${CMAKE_CURRENT_SOURCE_DIR}/.git) find_package(Git QUIET REQUIRED) @@ -342,6 +345,17 @@ if(EMSCRIPTEN) add_compile_flag("-sDISABLE_EXCEPTION_CATCHING=0") add_link_flag("-sDISABLE_EXCEPTION_CATCHING=0") endif() + if(EMSCRIPTEN_ENABLE_PTHREADS) + add_compile_flag("-pthread") + add_link_flag("-pthread") + # Use mimalloc to avoid a 5x slowdown: + # https://github.com/emscripten-core/emscripten/issues/15727#issuecomment-1960295018 + add_link_flag("-sMALLOC=mimalloc") + # Disable the warning on pthreads+memory growth (we are not much affected by + # it as there is little wasm-JS transfer of data, almost all work is inside + # the wasm). + add_link_flag("-Wno-pthreads-mem-growth") + endif() # In the browser, there is no natural place to provide commandline arguments # for a commandline tool, so let the user run the main entry point themselves # and pass in the arguments there. @@ -356,7 +370,6 @@ if(EMSCRIPTEN) else() # On Node.js, make the tools immediately usable. add_link_flag("-sNODERAWFS") - add_link_flag("-sSINGLE_FILE") endif() # in opt builds, LTO helps so much (>20%) it's worth slow compile times add_nondebug_compile_flag("-flto") @@ -461,6 +474,9 @@ if(EMSCRIPTEN) target_link_libraries(binaryen_wasm "-sFILESYSTEM") target_link_libraries(binaryen_wasm "-sEXPORT_NAME=Binaryen") target_link_libraries(binaryen_wasm "-sNODERAWFS=0") + # Emit a single file for convenience of people using binaryen.js as a library, + # so they only need to distribute a single file. + target_link_libraries(binaryen_wasm "-sSINGLE_FILE") target_link_libraries(binaryen_wasm "-sEXPORT_ES6") target_link_libraries(binaryen_wasm "-sEXPORTED_RUNTIME_METHODS=stringToUTF8OnStack,stringToAscii") target_link_libraries(binaryen_wasm "-sEXPORTED_FUNCTIONS=_malloc,_free") @@ -493,6 +509,7 @@ if(EMSCRIPTEN) target_link_libraries(binaryen_js "-sFILESYSTEM=1") endif() target_link_libraries(binaryen_js "-sNODERAWFS=0") + target_link_libraries(binaryen_js "-sSINGLE_FILE") target_link_libraries(binaryen_js "-sEXPORT_NAME=Binaryen") # Currently, js_of_ocaml can only process ES5 code if(JS_OF_OCAML) |