mirror of
https://github.com/bytecodealliance/wasm-micro-runtime.git
synced 2025-05-08 20:56:13 +00:00
Fix app manager install atomics app issue and optimize workload scripts (#458)
This commit is contained in:
parent
c8b0a1cee1
commit
2f530e67fc
|
@ -45,4 +45,18 @@ uint16 ntohs(uint16 value);
|
||||||
// We are not worried for the WASM world since the sandbox will catch it.
|
// We are not worried for the WASM world since the sandbox will catch it.
|
||||||
#define bh_memcpy_s(dst, dst_len, src, src_len) memcpy(dst, src, src_len)
|
#define bh_memcpy_s(dst, dst_len, src, src_len) memcpy(dst, src, src_len)
|
||||||
|
|
||||||
|
#ifdef NDEBUG
|
||||||
|
#define bh_assert(v) (void)0
|
||||||
|
#else
|
||||||
|
#define bh_assert(v) do { \
|
||||||
|
if (!(v)) { \
|
||||||
|
int _count; \
|
||||||
|
printf("ASSERTION FAILED: %s, at %s, line %d",\
|
||||||
|
#v, __FILE__, __LINE__); \
|
||||||
|
_count = printf("\n"); \
|
||||||
|
printf("%d\n", _count / (_count - 1)); \
|
||||||
|
} \
|
||||||
|
} while (0)
|
||||||
|
#endif
|
||||||
|
|
||||||
#endif /* DEPS_IWASM_APP_LIBS_BASE_BH_PLATFORM_H_ */
|
#endif /* DEPS_IWASM_APP_LIBS_BASE_BH_PLATFORM_H_ */
|
||||||
|
|
|
@ -703,7 +703,11 @@ wasm_app_module_install(request_t * msg)
|
||||||
SECTION_TYPE_GLOBAL,
|
SECTION_TYPE_GLOBAL,
|
||||||
SECTION_TYPE_EXPORT,
|
SECTION_TYPE_EXPORT,
|
||||||
SECTION_TYPE_START,
|
SECTION_TYPE_START,
|
||||||
SECTION_TYPE_ELEM
|
SECTION_TYPE_ELEM,
|
||||||
|
#if WASM_ENABLE_BULK_MEMORY != 0
|
||||||
|
SECTION_TYPE_DATACOUNT
|
||||||
|
#endif
|
||||||
|
|
||||||
};
|
};
|
||||||
/* Sections to be released after instantiating */
|
/* Sections to be released after instantiating */
|
||||||
uint8 sections2[] = { SECTION_TYPE_DATA };
|
uint8 sections2[] = { SECTION_TYPE_DATA };
|
||||||
|
@ -1174,7 +1178,12 @@ wasm_app_module_on_install_request_byte_arrive(uint8 ch,
|
||||||
}
|
}
|
||||||
else if (recv_ctx.phase == Phase_Wasm_Section_Type) {
|
else if (recv_ctx.phase == Phase_Wasm_Section_Type) {
|
||||||
uint8 section_type = ch;
|
uint8 section_type = ch;
|
||||||
if (section_type <= SECTION_TYPE_DATA) {
|
#if WASM_ENABLE_BULK_MEMORY == 0
|
||||||
|
uint8 section_type_max = SECTION_TYPE_DATA;
|
||||||
|
#else
|
||||||
|
uint8 section_type_max = SECTION_TYPE_DATACOUNT;
|
||||||
|
#endif
|
||||||
|
if (section_type <= section_type_max) {
|
||||||
wasm_section_t *new_section;
|
wasm_section_t *new_section;
|
||||||
if (!(new_section = (wasm_section_t *) APP_MGR_MALLOC(sizeof(wasm_section_t)))) {
|
if (!(new_section = (wasm_section_t *) APP_MGR_MALLOC(sizeof(wasm_section_t)))) {
|
||||||
app_manager_printf("Allocate memory failed!\n");
|
app_manager_printf("Allocate memory failed!\n");
|
||||||
|
|
|
@ -8,13 +8,9 @@
|
||||||
|
|
||||||
#define bh_assert(v) do { \
|
#define bh_assert(v) do { \
|
||||||
if (!(v)) { \
|
if (!(v)) { \
|
||||||
int _count; \
|
|
||||||
printf("\nASSERTION FAILED: %s, at %s, line %d\n", \
|
printf("\nASSERTION FAILED: %s, at %s, line %d\n", \
|
||||||
#v, __FILE__, __LINE__); \
|
#v, __FILE__, __LINE__); \
|
||||||
_count = printf(" "); \
|
abort(); \
|
||||||
/* divived by 0 to make it abort */ \
|
|
||||||
printf("%d\n", _count / (_count - 1)); \
|
|
||||||
while (1); \
|
|
||||||
} \
|
} \
|
||||||
} while (0)
|
} while (0)
|
||||||
|
|
||||||
|
|
|
@ -6,6 +6,10 @@ Ubuntu 18.04 as an example.
|
||||||
|
|
||||||
## Installation instructions
|
## Installation instructions
|
||||||
|
|
||||||
|
use [preparation.sh](./preparation.sh) to install all dependencies before compiling any workload.
|
||||||
|
|
||||||
|
for details, the script includes below steps:
|
||||||
|
|
||||||
- **wasi-sdk**. Install
|
- **wasi-sdk**. Install
|
||||||
[latest release](https://github.com/WebAssembly/wasi-sdk/releases/download/wasi-sdk-11/wasi-sdk-11.0-linux.tar.gz)
|
[latest release](https://github.com/WebAssembly/wasi-sdk/releases/download/wasi-sdk-11/wasi-sdk-11.0-linux.tar.gz)
|
||||||
in */opt/wasi-sdk* or */opt/wasi-sdk-11*
|
in */opt/wasi-sdk* or */opt/wasi-sdk-11*
|
||||||
|
|
2
samples/workload/XNNPACK/.gitignore
vendored
Normal file
2
samples/workload/XNNPACK/.gitignore
vendored
Normal file
|
@ -0,0 +1,2 @@
|
||||||
|
xnnpack
|
||||||
|
build
|
1
samples/workload/XNNPACK/docker_build.sh
Symbolic link
1
samples/workload/XNNPACK/docker_build.sh
Symbolic link
|
@ -0,0 +1 @@
|
||||||
|
../docker/docker_build.sh
|
1
samples/workload/bwa/docker_build.sh
Symbolic link
1
samples/workload/bwa/docker_build.sh
Symbolic link
|
@ -0,0 +1 @@
|
||||||
|
../docker/docker_build.sh
|
|
@ -23,7 +23,7 @@ RUN cd /opt \
|
||||||
&& tar zxf ${WASI_SDK_FILE} \
|
&& tar zxf ${WASI_SDK_FILE} \
|
||||||
&& rm ${WASI_SDK_FILE} \
|
&& rm ${WASI_SDK_FILE} \
|
||||||
&& ln -sf /opt/wasi-sdk-${WASI_SDK_VER} /opt/wasi-sdk \
|
&& ln -sf /opt/wasi-sdk-${WASI_SDK_VER} /opt/wasi-sdk \
|
||||||
&& ln -sf /opt/wasi-sdk/lib/clang/10.0.0/lib/wasi/ /usr/lib/llvm-11/lib/clang/11.0.0/lib/
|
&& ln -sf /opt/wasi-sdk/lib/clang/10.0.0/lib/wasi/ /usr/lib/llvm-11/lib/clang/11.0.1/lib/
|
||||||
|
|
||||||
#
|
#
|
||||||
# install wabt
|
# install wabt
|
||||||
|
@ -46,7 +46,8 @@ RUN cd /tmp \
|
||||||
|
|
||||||
#
|
#
|
||||||
# install tools
|
# install tools
|
||||||
RUN apt install -y git tree
|
RUN apt update \
|
||||||
|
&& apt install -y git tree
|
||||||
|
|
||||||
#
|
#
|
||||||
# install emsdk
|
# install emsdk
|
||||||
|
@ -85,4 +86,19 @@ RUN apt-get autoremove -y \
|
||||||
&& rm -rf /tmp/*
|
&& rm -rf /tmp/*
|
||||||
|
|
||||||
VOLUME /data
|
VOLUME /data
|
||||||
WORKDIR /data
|
|
||||||
|
#
|
||||||
|
#
|
||||||
|
RUN touch /build.sh \
|
||||||
|
&& echo "\
|
||||||
|
#!/bin/bash \n\
|
||||||
|
if [[ -d /data/project/build ]]; then \n\
|
||||||
|
rm -r /data/project/build \n\
|
||||||
|
fi \n\
|
||||||
|
mkdir /data/project/build \n\
|
||||||
|
cd /data/project/build \n\
|
||||||
|
source /opt/emsdk/emsdk_env.sh \n\
|
||||||
|
cmake .. \n\
|
||||||
|
make \n\
|
||||||
|
cd - > /dev/null" > /build.sh \
|
||||||
|
&& chmod a+x /build.sh
|
||||||
|
|
|
@ -5,8 +5,10 @@
|
||||||
|
|
||||||
#!/bin/bash
|
#!/bin/bash
|
||||||
|
|
||||||
if [[ ! -d build_scripts ]]; then
|
BUILD_CONTENT="/tmp/build_content"
|
||||||
mkdir build_scripts
|
|
||||||
|
if [[ ! -d ${BUILD_CONTENT} ]]; then
|
||||||
|
mkdir ${BUILD_CONTENT}
|
||||||
fi
|
fi
|
||||||
|
|
||||||
WASI_SDK_VER=11.0
|
WASI_SDK_VER=11.0
|
||||||
|
@ -15,7 +17,7 @@ CMAKE_VER=3.16.2
|
||||||
BINARYEN_VER=version_97
|
BINARYEN_VER=version_97
|
||||||
BAZEL_VER=3.7.0
|
BAZEL_VER=3.7.0
|
||||||
|
|
||||||
cd build_scripts
|
cd ${BUILD_CONTENT}
|
||||||
if [[ ! -f wasi-sdk-${WASI_SDK_VER}-linux.tar.gz ]]; then
|
if [[ ! -f wasi-sdk-${WASI_SDK_VER}-linux.tar.gz ]]; then
|
||||||
wget https://github.com/WebAssembly/wasi-sdk/releases/download/wasi-sdk-11/wasi-sdk-${WASI_SDK_VER}-linux.tar.gz
|
wget https://github.com/WebAssembly/wasi-sdk/releases/download/wasi-sdk-11/wasi-sdk-${WASI_SDK_VER}-linux.tar.gz
|
||||||
fi
|
fi
|
||||||
|
@ -39,16 +41,30 @@ fi
|
||||||
if [[ ! -f bazel-${BAZEL_VER}-installer-linux-x86_64.sh ]]; then
|
if [[ ! -f bazel-${BAZEL_VER}-installer-linux-x86_64.sh ]]; then
|
||||||
wget https://github.com/bazelbuild/bazel/releases/download/${BAZEL_VER}/bazel-${BAZEL_VER}-installer-linux-x86_64.sh
|
wget https://github.com/bazelbuild/bazel/releases/download/${BAZEL_VER}/bazel-${BAZEL_VER}-installer-linux-x86_64.sh
|
||||||
fi
|
fi
|
||||||
cd -
|
cd - > /dev/null
|
||||||
|
|
||||||
|
DOCKERFILE_PATH=$(dirname $(realpath $0))
|
||||||
|
|
||||||
docker build \
|
docker build \
|
||||||
--build-arg http_proxy=${http_proxy} \
|
--build-arg http_proxy=${http_proxy} \
|
||||||
--build-arg https_proxy=${https_proxy} \
|
--build-arg https_proxy=${https_proxy} \
|
||||||
--build-arg HTTP_PROXY=${http_proxy} \
|
--build-arg HTTP_PROXY=${http_proxy} \
|
||||||
--build-arg HTTPS_PROXY=${https_proxy} \
|
--build-arg HTTPS_PROXY=${https_proxy} \
|
||||||
--build-arg WASI_SDK_VER=11.0 \
|
--build-arg WASI_SDK_VER=${WASI_SDK_VER} \
|
||||||
--build-arg WABT_VER=${WABT_VER} \
|
--build-arg WABT_VER=${WABT_VER} \
|
||||||
--build-arg CMAKE_VER=${CMAKE_VER} \
|
--build-arg CMAKE_VER=${CMAKE_VER} \
|
||||||
--build-arg BINARYEN_VER=${BINARYEN_VER} \
|
--build-arg BINARYEN_VER=${BINARYEN_VER} \
|
||||||
--build-arg BAZEL_VER=${BAZEL_VER} \
|
--build-arg BAZEL_VER=${BAZEL_VER} \
|
||||||
-t clang_env:0.1 -f Dockerfile build_scripts
|
-t clang_env:0.1 -f ${DOCKERFILE_PATH}/Dockerfile ${BUILD_CONTENT}
|
||||||
|
|
||||||
|
docker run --rm -it \
|
||||||
|
-e http_proxy=${http_proxy} \
|
||||||
|
-e https_proxy=${https_proxy} \
|
||||||
|
-e HTTP_PROXY=${http_proxy} \
|
||||||
|
-e HTTPS_PROXY=${htpps_proxy} \
|
||||||
|
--name workload_w_clang \
|
||||||
|
--mount type=bind,source=$(pwd),target=/data/project \
|
||||||
|
--mount type=bind,source=$(pwd)/../cmake,target=/data/cmake \
|
||||||
|
-w /data/project \
|
||||||
|
clang_env:0.1 \
|
||||||
|
/bin/bash -c /build.sh
|
|
@ -1,10 +0,0 @@
|
||||||
#!/bin/bash
|
|
||||||
|
|
||||||
docker run --rm -it \
|
|
||||||
-e http_proxy=${http_proxy} \
|
|
||||||
-e https_proxy=${https_proxy} \
|
|
||||||
-e HTTP_PROXY=${http_proxy} \
|
|
||||||
-e HTTPS_PROXY=${htpps_proxy} \
|
|
||||||
--name workload_w_clang \
|
|
||||||
--mount type=bind,source=$(pwd)/..,target=/data \
|
|
||||||
clang_env:0.1
|
|
1
samples/workload/meshoptimizer/docker_build.sh
Symbolic link
1
samples/workload/meshoptimizer/docker_build.sh
Symbolic link
|
@ -0,0 +1 @@
|
||||||
|
../docker/docker_build.sh
|
129
samples/workload/preparation.sh
Executable file
129
samples/workload/preparation.sh
Executable file
|
@ -0,0 +1,129 @@
|
||||||
|
#!/bin/bash
|
||||||
|
|
||||||
|
readonly BUILD_CONTENT="/tmp/build_content"
|
||||||
|
readonly WASI_SDK_VER=11.0
|
||||||
|
readonly WASI_SDK_FILE="wasi-sdk-${WASI_SDK_VER}-linux.tar.gz"
|
||||||
|
readonly WABT_VER=1.0.19
|
||||||
|
readonly WABT_FILE="wabt-${WABT_VER}-ubuntu.tar.gz"
|
||||||
|
readonly CMAKE_VER=3.16.2
|
||||||
|
readonly CMAKE_FILE="cmake-${CMAKE_VER}-Linux-x86_64.sh"
|
||||||
|
readonly BINARYEN_VER=version_97
|
||||||
|
readonly BINARYEN_FILE="binaryen-${BINARYEN_VER}-x86_64-linux.tar.gz"
|
||||||
|
readonly BAZEL_VER=3.7.0
|
||||||
|
readonly BAZEL_FILE=bazel-${BAZEL_VER}-installer-linux-x86_64.sh
|
||||||
|
|
||||||
|
function DEBUG() {
|
||||||
|
[[ -n $(env | grep "\<DEBUG\>") ]]
|
||||||
|
}
|
||||||
|
|
||||||
|
#
|
||||||
|
# install dependency
|
||||||
|
function install_deps() {
|
||||||
|
apt update
|
||||||
|
apt install -y lsb-release wget software-properties-common \
|
||||||
|
build-essential git tree zip unzip
|
||||||
|
}
|
||||||
|
|
||||||
|
#
|
||||||
|
# install clang
|
||||||
|
function install_clang() {
|
||||||
|
if [[ ! -f llvm.sh ]]; then
|
||||||
|
wget https://apt.llvm.org/llvm.sh
|
||||||
|
fi
|
||||||
|
|
||||||
|
chmod a+x llvm.sh
|
||||||
|
./llvm.sh 11
|
||||||
|
}
|
||||||
|
|
||||||
|
#
|
||||||
|
# install wasi-sdk
|
||||||
|
function install_wasi-sdk() {
|
||||||
|
if [[ ! -f ${WASI_SDK_FILE} ]]; then
|
||||||
|
wget https://github.com/WebAssembly/wasi-sdk/releases/download/wasi-sdk-11/${WASI_SDK_FILE}
|
||||||
|
fi
|
||||||
|
|
||||||
|
tar zxf ${WASI_SDK_FILE} -C /opt
|
||||||
|
ln -sf /opt/wasi-sdk-${WASI_SDK_VER} /opt/wasi-sdk
|
||||||
|
ln -sf /opt/wasi-sdk/lib/clang/10.0.0/lib/wasi/ /usr/lib/llvm-11/lib/clang/11.0.1/lib/
|
||||||
|
}
|
||||||
|
|
||||||
|
#
|
||||||
|
# install wabt
|
||||||
|
function install_wabt() {
|
||||||
|
if [[ ! -f ${WABT_FILE} ]]; then
|
||||||
|
wget https://github.com/WebAssembly/wabt/releases/download/${WABT_VER}/${WABT_FILE}
|
||||||
|
fi
|
||||||
|
|
||||||
|
tar zxf ${WABT_FILE} -C /opt
|
||||||
|
ln -sf /opt/wabt-${WABT_VER} /opt/wabt
|
||||||
|
}
|
||||||
|
|
||||||
|
#
|
||||||
|
# install cmake
|
||||||
|
function install_cmake() {
|
||||||
|
if [[ ! -f cmake-${CMAKE_VER}-Linux-x86_64.sh ]]; then
|
||||||
|
wget https://github.com/Kitware/CMake/releases/download/v${CMAKE_VER}/${CMAKE_FILE}
|
||||||
|
fi
|
||||||
|
|
||||||
|
chmod a+x ${CMAKE_FILE}
|
||||||
|
mkdir /opt/cmake
|
||||||
|
./${CMAKE_FILE} --prefix=/opt/cmake --skip-license
|
||||||
|
ln -sf /opt/cmake/bin/cmake /usr/local/bin/cmake
|
||||||
|
}
|
||||||
|
|
||||||
|
#
|
||||||
|
# install emsdk
|
||||||
|
function install_emsdk() {
|
||||||
|
cd /opt
|
||||||
|
git clone https://github.com/emscripten-core/emsdk.git
|
||||||
|
cd emsdk
|
||||||
|
git pull
|
||||||
|
./emsdk install latest
|
||||||
|
./emsdk activate latest
|
||||||
|
echo "source /opt/emsdk/emsdk_env.sh" >> ${HOME}/.bashrc
|
||||||
|
}
|
||||||
|
|
||||||
|
#
|
||||||
|
# install binaryen
|
||||||
|
function install_binaryen() {
|
||||||
|
if [[ ! -f ${BINARYEN_FILE} ]]; then
|
||||||
|
wget https://github.com/WebAssembly/binaryen/releases/download/${BINARYEN_VER}/${BINARYEN_FILE}
|
||||||
|
fi
|
||||||
|
|
||||||
|
tar zxf ${BINARYEN_FILE} -C /opt
|
||||||
|
ln -sf /opt/binaryen-${BINARYEN_VER} /opt/binaryen
|
||||||
|
}
|
||||||
|
|
||||||
|
#
|
||||||
|
# install bazel
|
||||||
|
function install_bazel() {
|
||||||
|
if [[ ! -f ${BAZEL_FILE} ]]; then
|
||||||
|
wget https://github.com/bazelbuild/bazel/releases/download/${BAZEL_VER}/${BAZEL_FILE}
|
||||||
|
fi
|
||||||
|
|
||||||
|
chmod a+x ${BAZEL_FILE}
|
||||||
|
./${BAZEL_FILE}
|
||||||
|
}
|
||||||
|
|
||||||
|
#
|
||||||
|
# MAIN
|
||||||
|
DEBUG && set -xevu
|
||||||
|
if [[ ! -d ${BUILD_CONTENT} ]]; then
|
||||||
|
mkdir ${BUILD_CONTENT}
|
||||||
|
fi
|
||||||
|
|
||||||
|
cd ${BUILD_CONTENT}
|
||||||
|
if DEBUG; then
|
||||||
|
$@
|
||||||
|
else
|
||||||
|
install_deps \
|
||||||
|
&& install_clang \
|
||||||
|
&& install_wasi \
|
||||||
|
&& install_wabt \
|
||||||
|
&& install_cmake \
|
||||||
|
&& install_emsdk \
|
||||||
|
&& install_binaryen \
|
||||||
|
&& install_bazel
|
||||||
|
fi
|
||||||
|
cd - > /dev/null
|
||||||
|
DEBUG && set +xevu
|
1
samples/workload/wasm-av1/docker_build.sh
Symbolic link
1
samples/workload/wasm-av1/docker_build.sh
Symbolic link
|
@ -0,0 +1 @@
|
||||||
|
../docker/docker_build.sh
|
Loading…
Reference in New Issue
Block a user