mirror of
https://github.com/bytecodealliance/wasm-micro-runtime.git
synced 2025-02-06 06:55:07 +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.
|
||||
#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_ */
|
||||
|
|
|
@ -703,7 +703,11 @@ wasm_app_module_install(request_t * msg)
|
|||
SECTION_TYPE_GLOBAL,
|
||||
SECTION_TYPE_EXPORT,
|
||||
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 */
|
||||
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) {
|
||||
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;
|
||||
if (!(new_section = (wasm_section_t *) APP_MGR_MALLOC(sizeof(wasm_section_t)))) {
|
||||
app_manager_printf("Allocate memory failed!\n");
|
||||
|
|
|
@ -8,13 +8,9 @@
|
|||
|
||||
#define bh_assert(v) do { \
|
||||
if (!(v)) { \
|
||||
int _count; \
|
||||
printf("\nASSERTION FAILED: %s, at %s, line %d\n", \
|
||||
#v, __FILE__, __LINE__); \
|
||||
_count = printf(" "); \
|
||||
/* divived by 0 to make it abort */ \
|
||||
printf("%d\n", _count / (_count - 1)); \
|
||||
while (1); \
|
||||
abort(); \
|
||||
} \
|
||||
} while (0)
|
||||
|
||||
|
|
|
@ -6,6 +6,10 @@ Ubuntu 18.04 as an example.
|
|||
|
||||
## 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
|
||||
[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*
|
||||
|
|
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} \
|
||||
&& rm ${WASI_SDK_FILE} \
|
||||
&& 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
|
||||
|
@ -46,7 +46,8 @@ RUN cd /tmp \
|
|||
|
||||
#
|
||||
# install tools
|
||||
RUN apt install -y git tree
|
||||
RUN apt update \
|
||||
&& apt install -y git tree
|
||||
|
||||
#
|
||||
# install emsdk
|
||||
|
@ -85,4 +86,19 @@ RUN apt-get autoremove -y \
|
|||
&& rm -rf /tmp/*
|
||||
|
||||
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
|
||||
|
||||
if [[ ! -d build_scripts ]]; then
|
||||
mkdir build_scripts
|
||||
BUILD_CONTENT="/tmp/build_content"
|
||||
|
||||
if [[ ! -d ${BUILD_CONTENT} ]]; then
|
||||
mkdir ${BUILD_CONTENT}
|
||||
fi
|
||||
|
||||
WASI_SDK_VER=11.0
|
||||
|
@ -15,7 +17,7 @@ CMAKE_VER=3.16.2
|
|||
BINARYEN_VER=version_97
|
||||
BAZEL_VER=3.7.0
|
||||
|
||||
cd build_scripts
|
||||
cd ${BUILD_CONTENT}
|
||||
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
|
||||
fi
|
||||
|
@ -39,16 +41,30 @@ fi
|
|||
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
|
||||
fi
|
||||
cd -
|
||||
cd - > /dev/null
|
||||
|
||||
DOCKERFILE_PATH=$(dirname $(realpath $0))
|
||||
|
||||
docker build \
|
||||
--build-arg http_proxy=${http_proxy} \
|
||||
--build-arg https_proxy=${https_proxy} \
|
||||
--build-arg HTTP_PROXY=${http_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 CMAKE_VER=${CMAKE_VER} \
|
||||
--build-arg BINARYEN_VER=${BINARYEN_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