2020-11-26 16:18:48 +01:00
|
|
|
/*
|
|
|
|
* Copyright (C) 2019 Intel Corporation. All rights reserved.
|
|
|
|
* Copyright (C) 2020 TU Bergakademie Freiberg Karl Fessel
|
|
|
|
* SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
|
|
|
|
*/
|
|
|
|
|
2021-09-23 00:17:43 +02:00
|
|
|
#include <stdbool.h>
|
2022-01-21 21:02:23 +01:00
|
|
|
#include <stdint.h>
|
|
|
|
#include <stdio.h>
|
|
|
|
#include <stdlib.h>
|
2020-11-26 16:18:48 +01:00
|
|
|
#include <string.h>
|
|
|
|
|
|
|
|
#include "wasm_export.h"
|
|
|
|
|
|
|
|
/* execs the main function in an instantiated module */
|
|
|
|
static int iwasm_instance_exec_main(wasm_module_inst_t module_inst, int argc, char **argv)
|
|
|
|
{
|
2021-09-23 00:17:43 +02:00
|
|
|
/* exception memory is part of instance -> no buffer need */
|
2020-11-26 16:18:48 +01:00
|
|
|
const char *exception = 0;
|
|
|
|
int ret = 0;
|
|
|
|
wasm_application_execute_main(module_inst, argc, argv);
|
2022-01-21 21:02:23 +01:00
|
|
|
if ((exception = wasm_runtime_get_exception(module_inst))) {
|
2020-11-26 16:18:48 +01:00
|
|
|
puts(exception);
|
|
|
|
return -1;
|
|
|
|
}
|
2022-01-21 21:02:23 +01:00
|
|
|
if (argc > 0) {
|
|
|
|
ret = *((int*)argv);
|
|
|
|
}
|
2020-11-26 16:18:48 +01:00
|
|
|
return ret;
|
|
|
|
}
|
|
|
|
|
|
|
|
/* execs the main function of a loaded module */
|
2022-01-21 21:02:23 +01:00
|
|
|
int iwasm_module_exec_main(wasm_module_t wasm_module, int argc, char **argv)
|
2020-11-26 16:18:48 +01:00
|
|
|
{
|
|
|
|
wasm_module_inst_t wasm_module_inst = NULL;
|
|
|
|
int ret = 0;
|
|
|
|
|
2021-09-23 00:17:43 +02:00
|
|
|
{ /* instantiate the module */
|
|
|
|
char error_buf[128];
|
|
|
|
if (!(wasm_module_inst = wasm_runtime_instantiate(wasm_module, 8 * 1024,
|
|
|
|
8 * 1024, error_buf, sizeof(error_buf)))) {
|
|
|
|
puts(error_buf);
|
|
|
|
return -1;
|
|
|
|
}
|
2020-11-26 16:18:48 +01:00
|
|
|
}
|
|
|
|
ret = iwasm_instance_exec_main(wasm_module_inst, argc, argv);
|
|
|
|
/* destroy the module instance */
|
|
|
|
wasm_runtime_deinstantiate(wasm_module_inst);
|
|
|
|
return ret;
|
|
|
|
}
|
|
|
|
|
|
|
|
/* bytecode needs to be writeable*/
|
2022-01-21 21:02:23 +01:00
|
|
|
int iwasm_bytecode_exec_main(uint8_t *bytecode, size_t bytecode_len, int argc, char **argv)
|
|
|
|
{
|
2020-11-26 16:18:48 +01:00
|
|
|
int ret = 0;
|
|
|
|
wasm_module_t wasm_module = NULL;
|
|
|
|
|
|
|
|
{ /* load WASM module */
|
|
|
|
char error_buf[128];
|
2021-09-23 00:17:43 +02:00
|
|
|
if (!(wasm_module = wasm_runtime_load(bytecode, bytecode_len,
|
2022-01-21 21:02:23 +01:00
|
|
|
error_buf, sizeof(error_buf)))) {
|
2020-11-26 16:18:48 +01:00
|
|
|
puts(error_buf);
|
|
|
|
return -1;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
ret = iwasm_module_exec_main(wasm_module, argc, argv);
|
|
|
|
/* unload WASM module */
|
|
|
|
wasm_runtime_unload(wasm_module);
|
|
|
|
return ret;
|
|
|
|
}
|
|
|
|
|
|
|
|
/* running this initialises the wamr runtime*/
|
|
|
|
bool iwasm_runtime_init(void)
|
|
|
|
{
|
|
|
|
RuntimeInitArgs init_args;
|
|
|
|
memset(&init_args, 0, sizeof(RuntimeInitArgs));
|
2022-03-02 11:58:56 +01:00
|
|
|
/* using default system allocator, pool allocator and
|
|
|
|
* and allocator function hooks are available
|
|
|
|
* see <wamr>/core/iwasm/include/wasm_export.h l99..*/
|
2020-11-26 16:18:48 +01:00
|
|
|
init_args.mem_alloc_type = Alloc_With_System_Allocator;
|
|
|
|
|
|
|
|
/* initialize runtime environment */
|
|
|
|
if (!wasm_runtime_full_init(&init_args)) {
|
|
|
|
puts("Init runtime environment failed.");
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
|
2022-01-21 21:02:23 +01:00
|
|
|
void iwasm_runtime_destroy(void)
|
2020-11-26 16:18:48 +01:00
|
|
|
{
|
|
|
|
wasm_runtime_destroy();
|
2021-09-23 00:17:43 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
/* this seems to be a very direct interpretation of "i like to have a wamr_run" */
|
2022-01-21 21:02:23 +01:00
|
|
|
int wamr_run(void *bytecode, size_t bytecode_len, int argc, char **argv)
|
|
|
|
{
|
|
|
|
return iwasm_bytecode_exec_main((uint8_t *)bytecode, bytecode_len, argc, argv);
|
2020-11-26 16:18:48 +01:00
|
|
|
}
|
|
|
|
|
2022-01-21 21:02:23 +01:00
|
|
|
/* this creates a copy of bytecode and argv
|
|
|
|
* if argc is 0 it is set to 1 and argv[0] is set to ""
|
|
|
|
* to create some space for a return value */
|
|
|
|
int wamr_run_cp(const void *bytecode, size_t bytecode_len, int argc, char *argv[])
|
|
|
|
{
|
2021-09-23 00:17:43 +02:00
|
|
|
/* we need the bytecode to be writable while loading
|
|
|
|
* loading adds size information to stack POPs */
|
|
|
|
uint8_t * wasm_buf = malloc(bytecode_len);
|
2022-01-21 21:02:23 +01:00
|
|
|
if (!wasm_buf) {
|
|
|
|
return -1;
|
|
|
|
}
|
2021-09-23 00:17:43 +02:00
|
|
|
|
|
|
|
memcpy(wasm_buf, bytecode, bytecode_len);
|
|
|
|
/* no copy need if architecture has const in writable mem */
|
|
|
|
/* wasm_buf = (uint8_t *) main_wasm; */
|
|
|
|
|
|
|
|
unsigned wasm_buf_size = bytecode_len;
|
|
|
|
|
2022-01-21 21:02:23 +01:00
|
|
|
/* iwasm uses argv[0] cast to an int to store mains return value */
|
2021-09-23 00:17:43 +02:00
|
|
|
static char * empty = "";
|
|
|
|
char ** parv;
|
2022-01-21 21:02:23 +01:00
|
|
|
if (argc > 0) {
|
2021-09-23 00:17:43 +02:00
|
|
|
parv = malloc(sizeof(argv[0]) * argc);
|
2022-01-21 21:02:23 +01:00
|
|
|
if (!parv){
|
|
|
|
return -1;
|
|
|
|
}
|
2021-09-23 00:17:43 +02:00
|
|
|
memcpy(parv, argv, sizeof(argv[0]) * argc);
|
2022-01-21 21:02:23 +01:00
|
|
|
}
|
|
|
|
else {
|
2021-09-23 00:17:43 +02:00
|
|
|
argc = 1;
|
|
|
|
parv = malloc(sizeof(argv[0]) * argc);
|
2022-01-21 21:02:23 +01:00
|
|
|
if (!parv) {
|
|
|
|
return -1;
|
|
|
|
}
|
2021-09-23 00:17:43 +02:00
|
|
|
parv[0] = empty;
|
|
|
|
}
|
|
|
|
int ret = wamr_run(wasm_buf, wasm_buf_size, argc, parv);
|
|
|
|
free(parv);
|
|
|
|
free(wasm_buf);
|
|
|
|
|
|
|
|
return ret;
|
2020-11-26 16:18:48 +01:00
|
|
|
}
|