2019-02-09 18:07:05 -06:00
|
|
|
#ifndef WASMER_H
|
|
|
|
#define WASMER_H
|
|
|
|
|
2019-02-04 19:54:12 -06:00
|
|
|
#include <cstdarg>
|
|
|
|
#include <cstdint>
|
|
|
|
#include <cstdlib>
|
|
|
|
|
2019-02-11 19:07:28 -06:00
|
|
|
enum class wasmer_result_t {
|
|
|
|
WASMER_OK = 1,
|
|
|
|
WASMER_ERROR = 2,
|
2019-02-09 13:37:07 -06:00
|
|
|
};
|
|
|
|
|
2019-02-04 19:54:12 -06:00
|
|
|
enum class wasmer_value_tag : uint32_t {
|
|
|
|
WASM_I32,
|
|
|
|
WASM_I64,
|
|
|
|
WASM_F32,
|
|
|
|
WASM_F64,
|
|
|
|
};
|
|
|
|
|
|
|
|
struct wasmer_import_object_t;
|
|
|
|
|
|
|
|
struct wasmer_instance_context_t;
|
|
|
|
|
|
|
|
struct wasmer_instance_t;
|
|
|
|
|
2019-02-09 17:39:15 -06:00
|
|
|
struct wasmer_global_t {
|
|
|
|
|
|
|
|
};
|
|
|
|
|
2019-02-04 19:54:12 -06:00
|
|
|
union wasmer_value {
|
|
|
|
int32_t I32;
|
|
|
|
int64_t I64;
|
|
|
|
float F32;
|
|
|
|
double F64;
|
|
|
|
};
|
|
|
|
|
|
|
|
struct wasmer_value_t {
|
|
|
|
wasmer_value_tag tag;
|
|
|
|
wasmer_value value;
|
|
|
|
};
|
|
|
|
|
2019-02-09 17:39:15 -06:00
|
|
|
struct wasmer_global_descriptor_t {
|
|
|
|
bool mutable_;
|
|
|
|
wasmer_value_tag kind;
|
|
|
|
};
|
|
|
|
|
2019-02-04 21:46:47 -06:00
|
|
|
struct wasmer_memory_t {
|
|
|
|
|
|
|
|
};
|
|
|
|
|
|
|
|
struct wasmer_limits_t {
|
|
|
|
uint32_t min;
|
|
|
|
uint32_t max;
|
|
|
|
};
|
|
|
|
|
2019-02-09 13:37:07 -06:00
|
|
|
struct wasmer_table_t {
|
|
|
|
|
|
|
|
};
|
|
|
|
|
2019-02-04 19:54:12 -06:00
|
|
|
extern "C" {
|
|
|
|
|
2019-02-11 23:14:32 -06:00
|
|
|
/// Frees memory for the given Global
|
2019-02-09 17:39:15 -06:00
|
|
|
void wasmer_global_destroy(wasmer_global_t *global);
|
|
|
|
|
2019-02-11 23:14:32 -06:00
|
|
|
/// Gets the value stored by the given Global
|
2019-02-09 17:39:15 -06:00
|
|
|
wasmer_value_t wasmer_global_get(wasmer_global_t *global);
|
|
|
|
|
2019-02-11 23:14:32 -06:00
|
|
|
/// Returns a descriptor (type, mutability) of the given Global
|
2019-02-09 17:39:15 -06:00
|
|
|
wasmer_global_descriptor_t wasmer_global_get_descriptor(wasmer_global_t *global);
|
|
|
|
|
2019-02-11 23:14:32 -06:00
|
|
|
/// Creates a new Global and returns a pointer to it.
|
|
|
|
/// The caller owns the object and should call `wasmer_global_destroy` to free it.
|
2019-02-09 17:39:15 -06:00
|
|
|
wasmer_global_t *wasmer_global_new(wasmer_value_t value, bool mutable_);
|
|
|
|
|
2019-02-11 23:14:32 -06:00
|
|
|
/// Sets the value stored by the given Global
|
2019-02-09 17:39:15 -06:00
|
|
|
void wasmer_global_set(wasmer_global_t *global, wasmer_value_t value);
|
|
|
|
|
2019-02-11 23:14:32 -06:00
|
|
|
/// Frees memory for the given ImportObject
|
2019-02-04 19:54:12 -06:00
|
|
|
void wasmer_import_object_destroy(wasmer_import_object_t *import_object);
|
|
|
|
|
2019-02-11 23:14:32 -06:00
|
|
|
/// Creates a new ImportObject and returns a pointer to it.
|
|
|
|
/// The caller owns the object and should call `wasmer_import_object_destroy` to free it.
|
2019-02-04 19:54:12 -06:00
|
|
|
wasmer_import_object_t *wasmer_import_object_new();
|
|
|
|
|
2019-02-11 23:14:32 -06:00
|
|
|
/// Registers a `func` with provided `name` and `namespace` into the ImportObject.
|
|
|
|
/// Returns `wasmer_result_t::WASMER_OK` upon success.
|
|
|
|
/// Returns `wasmer_result_t::WASMER_ERROR` upon failure. Use `wasmer_last_error_length`
|
|
|
|
/// and `wasmer_last_error_message` to get an error message.
|
2019-02-04 19:54:12 -06:00
|
|
|
void wasmer_imports_set_import_func(wasmer_import_object_t *import_object,
|
|
|
|
const char *namespace_,
|
|
|
|
const char *name,
|
|
|
|
void (*func)(void *data),
|
|
|
|
const wasmer_value_tag *params,
|
|
|
|
int params_len,
|
|
|
|
const wasmer_value_tag *returns,
|
|
|
|
int returns_len);
|
|
|
|
|
2019-02-11 23:14:32 -06:00
|
|
|
/// Calls an instances exported function by `name` with the provided parameters.
|
|
|
|
/// Results are set using the provided `results` pointer.
|
|
|
|
/// Returns `wasmer_result_t::WASMER_OK` upon success.
|
|
|
|
/// Returns `wasmer_result_t::WASMER_ERROR` upon failure. Use `wasmer_last_error_length`
|
|
|
|
/// and `wasmer_last_error_message` to get an error message.
|
2019-02-11 19:07:28 -06:00
|
|
|
wasmer_result_t wasmer_instance_call(wasmer_instance_t *instance,
|
|
|
|
const char *name,
|
|
|
|
const wasmer_value_t *params,
|
|
|
|
int params_len,
|
|
|
|
wasmer_value_t *results,
|
|
|
|
int results_len);
|
2019-02-04 19:54:12 -06:00
|
|
|
|
2019-02-11 23:14:32 -06:00
|
|
|
/// Gets the memory within the context at the index `memory_idx`.
|
|
|
|
/// The index is always 0 until multiple memories are supported.
|
2019-02-10 14:24:36 -06:00
|
|
|
const wasmer_memory_t *wasmer_instance_context_memory(wasmer_instance_context_t *ctx,
|
|
|
|
uint32_t memory_idx);
|
2019-02-04 19:54:12 -06:00
|
|
|
|
2019-02-11 23:14:32 -06:00
|
|
|
/// Frees memory for the given Instance
|
2019-02-04 19:54:12 -06:00
|
|
|
void wasmer_instance_destroy(wasmer_instance_t *instance);
|
|
|
|
|
2019-02-11 23:14:32 -06:00
|
|
|
/// Creates a new Instance from the given wasm bytes and imports.
|
|
|
|
/// Returns `wasmer_result_t::WASMER_OK` upon success.
|
|
|
|
/// Returns `wasmer_result_t::WASMER_ERROR` upon failure. Use `wasmer_last_error_length`
|
|
|
|
/// and `wasmer_last_error_message` to get an error message.
|
2019-02-11 19:07:28 -06:00
|
|
|
wasmer_result_t wasmer_instantiate(wasmer_instance_t **instance,
|
|
|
|
uint8_t *wasm_bytes,
|
|
|
|
uint32_t wasm_bytes_len,
|
|
|
|
wasmer_import_object_t *import_object);
|
2019-02-04 19:54:12 -06:00
|
|
|
|
2019-02-11 23:14:32 -06:00
|
|
|
/// Gets the length in bytes of the last error.
|
|
|
|
/// This can be used to dynamically allocate a buffer with the correct number of
|
|
|
|
/// bytes needed to store a message.
|
|
|
|
/// # Example
|
|
|
|
/// ```
|
|
|
|
/// int error_len = wasmer_last_error_length();
|
|
|
|
/// char *error_str = malloc(error_len);
|
|
|
|
/// ```
|
2019-02-10 17:57:23 -06:00
|
|
|
int wasmer_last_error_length();
|
|
|
|
|
2019-02-11 23:14:32 -06:00
|
|
|
/// Stores the last error message into the provided buffer up to the given `length`.
|
|
|
|
/// The `length` parameter must be large enough to store the last error message.
|
|
|
|
/// Returns the length of the string in bytes.
|
|
|
|
/// Returns `-1` if an error occurs.
|
|
|
|
/// # Example
|
|
|
|
/// ```
|
|
|
|
/// int error_len = wasmer_last_error_length();
|
|
|
|
/// char *error_str = malloc(error_len);
|
|
|
|
/// wasmer_last_error_message(error_str, error_len);
|
|
|
|
/// printf("Error str: `%s`\n", error_str);
|
|
|
|
/// ```
|
2019-02-10 17:57:23 -06:00
|
|
|
int wasmer_last_error_message(char *buffer, int length);
|
|
|
|
|
2019-02-11 23:14:32 -06:00
|
|
|
/// Gets the start pointer to the bytes within a Memory
|
2019-02-10 15:20:35 -06:00
|
|
|
uint8_t *wasmer_memory_data(wasmer_memory_t *mem);
|
|
|
|
|
2019-02-11 23:14:32 -06:00
|
|
|
/// Gets the size in bytes of a Memory
|
2019-02-10 14:14:42 -06:00
|
|
|
uint32_t wasmer_memory_data_length(wasmer_memory_t *mem);
|
|
|
|
|
2019-02-11 23:14:32 -06:00
|
|
|
/// Frees memory for the given Memory
|
2019-02-04 21:46:47 -06:00
|
|
|
void wasmer_memory_destroy(wasmer_memory_t *memory);
|
|
|
|
|
2019-02-11 23:14:32 -06:00
|
|
|
/// Grows a Memory by the given number of pages.
|
|
|
|
/// Returns `wasmer_result_t::WASMER_OK` upon success.
|
|
|
|
/// Returns `wasmer_result_t::WASMER_ERROR` upon failure. Use `wasmer_last_error_length`
|
|
|
|
/// and `wasmer_last_error_message` to get an error message.
|
2019-02-11 19:07:28 -06:00
|
|
|
wasmer_result_t wasmer_memory_grow(wasmer_memory_t *memory, uint32_t delta);
|
2019-02-09 17:53:03 -06:00
|
|
|
|
2019-02-11 23:14:32 -06:00
|
|
|
/// Returns the current length in pages of the given memory
|
2019-02-04 21:46:47 -06:00
|
|
|
uint32_t wasmer_memory_length(wasmer_memory_t *memory);
|
|
|
|
|
2019-02-11 23:14:32 -06:00
|
|
|
/// Creates a new Memory for the given descriptor and initializes the given
|
|
|
|
/// pointer to pointer to a pointer to the new memory.
|
|
|
|
/// The caller owns the object and should call `wasmer_memory_destroy` to free it.
|
|
|
|
/// Returns `wasmer_result_t::WASMER_OK` upon success.
|
|
|
|
/// Returns `wasmer_result_t::WASMER_ERROR` upon failure. Use `wasmer_last_error_length`
|
|
|
|
/// and `wasmer_last_error_message` to get an error message.
|
2019-02-11 19:07:28 -06:00
|
|
|
wasmer_result_t wasmer_memory_new(wasmer_memory_t **memory, wasmer_limits_t limits);
|
2019-02-04 21:46:47 -06:00
|
|
|
|
2019-02-11 23:14:32 -06:00
|
|
|
/// Frees memory for the given Table
|
2019-02-09 13:37:07 -06:00
|
|
|
void wasmer_table_destroy(wasmer_table_t *table);
|
|
|
|
|
2019-02-11 23:14:32 -06:00
|
|
|
/// Grows a Table by the given number of elements.
|
|
|
|
/// Returns `wasmer_result_t::WASMER_OK` upon success.
|
|
|
|
/// Returns `wasmer_result_t::WASMER_ERROR` upon failure. Use `wasmer_last_error_length`
|
|
|
|
/// and `wasmer_last_error_message` to get an error message.
|
2019-02-11 19:07:28 -06:00
|
|
|
wasmer_result_t wasmer_table_grow(wasmer_table_t *table, uint32_t delta);
|
2019-02-09 13:58:50 -06:00
|
|
|
|
2019-02-11 23:14:32 -06:00
|
|
|
/// Returns the current length of the given Table
|
2019-02-09 13:37:07 -06:00
|
|
|
uint32_t wasmer_table_length(wasmer_table_t *table);
|
|
|
|
|
2019-02-11 23:14:32 -06:00
|
|
|
/// Creates a new Table for the given descriptor and initializes the given
|
|
|
|
/// pointer to pointer to a pointer to the new Table.
|
|
|
|
/// The caller owns the object and should call `wasmer_table_destroy` to free it.
|
|
|
|
/// Returns `wasmer_result_t::WASMER_OK` upon success.
|
|
|
|
/// Returns `wasmer_result_t::WASMER_ERROR` upon failure. Use `wasmer_last_error_length`
|
|
|
|
/// and `wasmer_last_error_message` to get an error message.
|
2019-02-11 19:07:28 -06:00
|
|
|
wasmer_result_t wasmer_table_new(wasmer_table_t **table, wasmer_limits_t limits);
|
2019-02-09 13:37:07 -06:00
|
|
|
|
2019-02-11 23:14:32 -06:00
|
|
|
/// Returns true for valid wasm bytes and false for invalid bytes
|
2019-02-05 00:01:01 -06:00
|
|
|
bool wasmer_validate(uint8_t *wasm_bytes, uint32_t wasm_bytes_len);
|
|
|
|
|
2019-02-04 19:54:12 -06:00
|
|
|
} // extern "C"
|
2019-02-09 18:07:05 -06:00
|
|
|
|
|
|
|
#endif // WASMER_H
|