2021-12-18 10:54:02 -04:00
|
|
|
# Python WebAssembly (WASM) build
|
|
|
|
|
2022-02-05 15:52:01 -04:00
|
|
|
**WARNING: WASM support is highly experimental! Lots of features are not working yet.**
|
|
|
|
|
2021-12-18 10:54:02 -04:00
|
|
|
This directory contains configuration and helpers to facilitate cross
|
2022-02-05 15:52:01 -04:00
|
|
|
compilation of CPython to WebAssembly (WASM). For now we support
|
|
|
|
*wasm32-emscripten* builds for modern browser and for *Node.js*. It's not
|
|
|
|
possible to build for *wasm32-wasi* out-of-the-box yet.
|
2021-12-18 10:54:02 -04:00
|
|
|
|
|
|
|
## wasm32-emscripten build
|
|
|
|
|
|
|
|
Cross compiling to wasm32-emscripten platform needs the [Emscripten](https://emscripten.org/)
|
|
|
|
tool chain and a build Python interpreter.
|
|
|
|
All commands below are relative to a repository checkout.
|
|
|
|
|
|
|
|
### Compile a build Python interpreter
|
|
|
|
|
|
|
|
```shell
|
|
|
|
mkdir -p builddir/build
|
|
|
|
pushd builddir/build
|
|
|
|
../../configure -C
|
|
|
|
make -j$(nproc)
|
|
|
|
popd
|
|
|
|
```
|
|
|
|
|
|
|
|
### Fetch and build additional emscripten ports
|
|
|
|
|
|
|
|
```shell
|
2022-02-05 15:52:01 -04:00
|
|
|
embuilder build zlib bzip2
|
2021-12-18 10:54:02 -04:00
|
|
|
```
|
|
|
|
|
2022-02-05 15:52:01 -04:00
|
|
|
### Cross compile to wasm32-emscripten for browser
|
2022-01-12 11:08:19 -04:00
|
|
|
|
2021-12-18 10:54:02 -04:00
|
|
|
```shell
|
2022-02-05 15:52:01 -04:00
|
|
|
mkdir -p builddir/emscripten-browser
|
|
|
|
pushd builddir/emscripten-browser
|
2021-12-18 10:54:02 -04:00
|
|
|
|
|
|
|
CONFIG_SITE=../../Tools/wasm/config.site-wasm32-emscripten \
|
|
|
|
emconfigure ../../configure -C \
|
|
|
|
--host=wasm32-unknown-emscripten \
|
|
|
|
--build=$(../../config.guess) \
|
2022-01-12 11:08:19 -04:00
|
|
|
--with-emscripten-target=browser \
|
|
|
|
--with-build-python=$(pwd)/../build/python
|
|
|
|
|
|
|
|
emmake make -j$(nproc)
|
2022-02-05 15:52:01 -04:00
|
|
|
popd
|
|
|
|
```
|
|
|
|
|
|
|
|
Serve `python.html` with a local webserver and open the file in a browser.
|
|
|
|
|
|
|
|
```shell
|
|
|
|
emrun builddir/emscripten-browser/python.html
|
|
|
|
```
|
|
|
|
|
|
|
|
or
|
|
|
|
|
|
|
|
```shell
|
|
|
|
python3 -m http.server
|
2022-01-12 11:08:19 -04:00
|
|
|
```
|
|
|
|
|
2022-02-05 15:52:01 -04:00
|
|
|
### Cross compile to wasm32-emscripten for node
|
2022-01-12 11:08:19 -04:00
|
|
|
|
|
|
|
```
|
2022-02-05 15:52:01 -04:00
|
|
|
mkdir -p builddir/emscripten-node
|
|
|
|
pushd builddir/emscripten-node
|
|
|
|
|
2022-01-12 11:08:19 -04:00
|
|
|
CONFIG_SITE=../../Tools/wasm/config.site-wasm32-emscripten \
|
|
|
|
emconfigure ../../configure -C \
|
|
|
|
--host=wasm32-unknown-emscripten \
|
|
|
|
--build=$(../../config.guess) \
|
|
|
|
--with-emscripten-target=node \
|
2021-12-18 10:54:02 -04:00
|
|
|
--with-build-python=$(pwd)/../build/python
|
|
|
|
|
2022-01-12 11:08:19 -04:00
|
|
|
emmake make -j$(nproc)
|
2022-02-05 15:52:01 -04:00
|
|
|
popd
|
2021-12-18 10:54:02 -04:00
|
|
|
```
|
|
|
|
|
|
|
|
```
|
2022-02-05 15:52:01 -04:00
|
|
|
node --experimental-wasm-threads --experimental-wasm-bulk-memory builddir/emscripten-node/python.js
|
2021-12-18 10:54:02 -04:00
|
|
|
```
|
2022-02-05 15:52:01 -04:00
|
|
|
|
|
|
|
## wasm32-emscripten limitations and issues
|
|
|
|
|
|
|
|
- Most stdlib modules with a dependency on external libraries are missing:
|
|
|
|
``ctypes``, ``readline``, ``sqlite3``, ``ssl``, and more.
|
|
|
|
- Shared extension modules are not implemented yet. All extension modules
|
|
|
|
are statically linked into the main binary.
|
|
|
|
- Processes are not supported. System calls like fork, popen, and subprocess
|
|
|
|
fail with ``ENOSYS`` or ``ENOSUP``.
|
|
|
|
- Blocking sockets are not available and non-blocking sockets don't work
|
|
|
|
correctly, e.g. ``socket.accept`` crashes the runtime. ``gethostbyname``
|
|
|
|
does not resolve to a real IP address. IPv6 is not available.
|
|
|
|
- The ``select`` module is limited. ``select.select()`` crashes the runtime
|
|
|
|
due to lack of exectfd support.
|
|
|
|
- The ``*at`` variants of functions (e.g. ``openat``) are not available.
|
|
|
|
The ``dir_fd`` argument of *os* module functions can't be used.
|
|
|
|
- Signal support is limited. ``signal.alarm``, ``itimer``, ``sigaction``
|
|
|
|
are not available or do not work correctly. ``SIGTERM`` exits the runtime.
|
|
|
|
- Most user, group, and permission related function and modules are not
|
|
|
|
supported or don't work as expected, e.g.``pwd`` module, ``grp`` module,
|
|
|
|
``os.setgroups``, ``os.chown``, and so on.
|
|
|
|
- Offset and iovec I/O functions (e.g. ``os.pread``, ``os.preadv``) are not
|
|
|
|
available.
|
|
|
|
- ``os.mknod`` and ``os.mkfifo``
|
|
|
|
[don't work](https://github.com/emscripten-core/emscripten/issues/16158)
|
|
|
|
and are disabled.
|
|
|
|
- Large file support crashes the runtime and is disabled.
|
|
|
|
- ``mmap`` module is unstable. flush (``msync``) can crash the runtime.
|
|
|
|
- Resource-related functions like ``os.nice`` and most functions of the
|
|
|
|
``resource`` module are not available.
|
|
|
|
- Some time and datetime features are broken. ``strftime`` and ``strptime``
|
|
|
|
have known bugs, e.g.
|
|
|
|
[%% quoting](https://github.com/emscripten-core/emscripten/issues/16155),
|
|
|
|
[%U off-by-one](https://github.com/emscripten-core/emscripten/issues/16156).
|
|
|
|
Extended glibc formatting features are not available.
|
|
|
|
- ``locales`` module is affected by musl libc issues,
|
|
|
|
[bpo-46390](https://bugs.python.org/issue46390).
|
|
|
|
- ``uuid`` module is affected by
|
|
|
|
[memory leak](https://github.com/emscripten-core/emscripten/issues/16081)
|
|
|
|
and crasher in Emscripten's ``freeaddrinfo``,
|
|
|
|
- Recursive ``glob`` leaks file descriptors.
|
|
|
|
- Python's object allocator ``obmalloc`` is disabled by default.
|
|
|
|
- ``ensurepip`` is not available.
|
|
|
|
|
|
|
|
### wasm32-emscripten in browsers
|
|
|
|
|
|
|
|
- The bundled stdlib is limited. Network-related modules,
|
|
|
|
distutils, multiprocessing, dbm, tests and similar modules
|
|
|
|
are not shipped. All other modules are bundled as pre-compiled
|
|
|
|
``pyc`` files.
|
|
|
|
- Threading is not supported.
|
|
|
|
|
|
|
|
### wasm32-emscripten in node
|
|
|
|
|
|
|
|
Node builds use ``NODERAWFS``, ``USE_PTHREADS`` and ``PROXY_TO_PTHREAD``
|
|
|
|
linker options.
|
|
|
|
|
|
|
|
- Node RawFS allows direct access to the host file system.
|
|
|
|
- pthread support requires WASM threads and SharedArrayBuffer (bulk memory).
|
|
|
|
The runtime keeps a pool of web workers around. Each web worker uses
|
|
|
|
several file descriptors (eventfd, epoll, pipe).
|