mirror of
https://git.proxmox.com/git/wasi-libc
synced 2025-07-15 05:16:48 +00:00

* Lazy-initialize the environment variables. This is the first in a series of PRs to make it easier to use WASI libc in Wasm modules that don't have a `main` function. By initializing the environment on demand, we avoid depending on having `__wasm_call_ctors` run. This uses weak symbols strategically to ensure that if `environ` is used, it is initialized eagerly, but if only `getenv` and friends are used, the environment is initialized lazily. Eventually, I expect we'll have a convention for wasm modules without main functions which will allow the `__wasm_call_ctors` function to be called automatically, but this helps in simple cases for now. Fixes #180. * Add comments explaining the libc-environ-compat.h header usage.
27 lines
1.0 KiB
C
27 lines
1.0 KiB
C
#include <unistd.h>
|
|
#include <stdlib.h>
|
|
#include <sysexits.h>
|
|
#include <wasi/api.h>
|
|
#include <wasi/libc.h>
|
|
#include <wasi/libc-environ.h>
|
|
|
|
// If the program does use `environ`, it'll get this version of
|
|
// `__wasilibc_environ`, which is initialized with a constructor function, so
|
|
// that it's initialized whenever user code might want to access it.
|
|
char **__wasilibc_environ;
|
|
extern __typeof(__wasilibc_environ) _environ
|
|
__attribute__((weak, alias("__wasilibc_environ")));
|
|
extern __typeof(__wasilibc_environ) environ
|
|
__attribute__((weak, alias("__wasilibc_environ")));
|
|
|
|
// We define this function here in the same source file as
|
|
// `__wasilibc_environ`, so that this function is called in iff environment
|
|
// variable support is used.
|
|
// Concerning the 50 -- levels up to 100 are reserved for the implementation,
|
|
// so we an arbitrary number in the middle of the range to allow other
|
|
// reserved things to go before or after.
|
|
__attribute__((constructor(50)))
|
|
static void __wasilibc_initialize_environ_eagerly(void) {
|
|
__wasilibc_initialize_environ();
|
|
}
|