summaryrefslogtreecommitdiffstats
path: root/fluent-bit/lib/wasm-micro-runtime-WAMR-1.2.2/samples/workload/XNNPACK
diff options
context:
space:
mode:
Diffstat (limited to 'fluent-bit/lib/wasm-micro-runtime-WAMR-1.2.2/samples/workload/XNNPACK')
-rw-r--r--fluent-bit/lib/wasm-micro-runtime-WAMR-1.2.2/samples/workload/XNNPACK/.gitignore2
-rw-r--r--fluent-bit/lib/wasm-micro-runtime-WAMR-1.2.2/samples/workload/XNNPACK/CMakeLists.txt147
-rw-r--r--fluent-bit/lib/wasm-micro-runtime-WAMR-1.2.2/samples/workload/XNNPACK/README.md48
-rw-r--r--fluent-bit/lib/wasm-micro-runtime-WAMR-1.2.2/samples/workload/XNNPACK/benchmark.patch14
-rw-r--r--fluent-bit/lib/wasm-micro-runtime-WAMR-1.2.2/samples/workload/XNNPACK/xnnpack.patch141
5 files changed, 352 insertions, 0 deletions
diff --git a/fluent-bit/lib/wasm-micro-runtime-WAMR-1.2.2/samples/workload/XNNPACK/.gitignore b/fluent-bit/lib/wasm-micro-runtime-WAMR-1.2.2/samples/workload/XNNPACK/.gitignore
new file mode 100644
index 000000000..09f3fe927
--- /dev/null
+++ b/fluent-bit/lib/wasm-micro-runtime-WAMR-1.2.2/samples/workload/XNNPACK/.gitignore
@@ -0,0 +1,2 @@
+xnnpack
+build
diff --git a/fluent-bit/lib/wasm-micro-runtime-WAMR-1.2.2/samples/workload/XNNPACK/CMakeLists.txt b/fluent-bit/lib/wasm-micro-runtime-WAMR-1.2.2/samples/workload/XNNPACK/CMakeLists.txt
new file mode 100644
index 000000000..aef138d5e
--- /dev/null
+++ b/fluent-bit/lib/wasm-micro-runtime-WAMR-1.2.2/samples/workload/XNNPACK/CMakeLists.txt
@@ -0,0 +1,147 @@
+# Copyright (C) 2019 Intel Corporation. All rights reserved.
+# SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
+
+cmake_minimum_required (VERSION 3.0)
+
+project(xnnpack_wasm)
+
+################ EMCC ################
+include(ExternalProject)
+
+ExternalProject_Add(xnnpack
+ PREFIX xnnpack
+ GIT_REPOSITORY https://github.com/google/XNNPACK.git
+ GIT_TAG 4570a7151aa4f3e57eca14a575eeff6bb13e26be
+ GIT_PROGRESS ON
+ SOURCE_DIR ${CMAKE_CURRENT_SOURCE_DIR}/xnnpack
+ UPDATE_COMMAND git restore .
+ && cmake -E copy ${CMAKE_CURRENT_SOURCE_DIR}/xnnpack/google3/third_party/XNNPACK/microkernels.bzl
+ ${CMAKE_CURRENT_SOURCE_DIR}/xnnpack/
+ && git apply ${CMAKE_CURRENT_SOURCE_DIR}/xnnpack.patch
+ CONFIGURE_COMMAND ""
+ # grep xnnpack_benchmark -A 1 BUILD.bazel \
+ # | grep "name =" \
+ # | awk '{print $3}' \
+ # | sed -e 's/\"//g' -e 's/,//g' -e 's/^/\/\/:/g'
+ BUILD_COMMAND cd ${CMAKE_CURRENT_SOURCE_DIR}/xnnpack
+ && bazel --output_user_root=build-user-output build -c opt --config=wasm
+ //:qs8_dwconv_bench.wasm
+ //:qs8_f32_vcvt_bench.wasm
+ //:qs8_gemm_bench.wasm
+ //:qs8_requantization_bench.wasm
+ //:qs8_vadd_bench.wasm
+ //:qs8_vaddc_bench.wasm
+ //:qs8_vcvt_bench.wasm
+ //:qs8_vlrelu_bench.wasm
+ //:qs8_vmul_bench.wasm
+ //:qs8_vmulc_bench.wasm
+ //:qu8_f32_vcvt_bench.wasm
+ //:qu8_gemm_bench.wasm
+ //:qu8_requantization_bench.wasm
+ //:qu8_vadd_bench.wasm
+ //:qu8_vaddc_bench.wasm
+ //:qu8_vcvt_bench.wasm
+ //:qu8_vlrelu_bench.wasm
+ //:qu8_vmul_bench.wasm
+ //:qu8_vmulc_bench.wasm
+ //:bf16_gemm_bench.wasm
+ //:f16_igemm_bench.wasm
+ //:f16_gemm_bench.wasm
+ //:f16_raddstoreexpminusmax_bench.wasm
+ //:f16_spmm_bench.wasm
+ //:f16_vsigmoid_bench.wasm
+ //:f16_f32_vcvt_bench.wasm
+ //:f32_igemm_bench.wasm
+ //:f32_conv_hwc_bench.wasm
+ //:f16_conv_hwc2chw_bench.wasm
+ //:f16_gavgpool_cw_bench.wasm
+ //:f32_gavgpool_cw_bench.wasm
+ //:f32_conv_hwc2chw_bench.wasm
+ //:f16_dwconv_bench.wasm
+ //:f32_dwconv_bench.wasm
+ //:f32_dwconv2d_chw_bench.wasm
+ //:f16_dwconv2d_chw_bench.wasm
+ //:f32_f16_vcvt_bench.wasm
+ //:xx_transpose_bench.wasm
+ //:x8_transpose_bench.wasm
+ //:x16_transpose_bench.wasm
+ //:x24_transpose_bench.wasm
+ //:x32_transpose_bench.wasm
+ //:x64_transpose_bench.wasm
+ //:f32_gemm_bench.wasm
+ //:f32_qs8_vcvt_bench.wasm
+ //:f32_qu8_vcvt_bench.wasm
+ //:f32_raddexpminusmax_bench.wasm
+ //:f32_raddextexp_bench.wasm
+ //:f32_raddstoreexpminusmax_bench.wasm
+ //:f32_rmax_bench.wasm
+ //:f32_spmm_bench.wasm
+ //:f32_softmax_bench.wasm
+ //:f16_velu_bench.wasm
+ //:f32_velu_bench.wasm
+ //:f32_vhswish_bench.wasm
+ //:f32_vlrelu_bench.wasm
+ //:f32_vrelu_bench.wasm
+ //:f32_vscaleexpminusmax_bench.wasm
+ //:f32_vscaleextexp_bench.wasm
+ //:f32_vsigmoid_bench.wasm
+ //:f16_vsqrt_bench.wasm
+ //:f32_vsqrt_bench.wasm
+ //:f32_im2col_gemm_bench.wasm
+ //:rounding_bench.wasm
+ //:s16_rmaxabs_bench.wasm
+ //:s16_window_bench.wasm
+ //:u32_filterbank_accumulate_bench.wasm
+ //:u32_filterbank_subtract_bench.wasm
+ //:u32_vlog_bench.wasm
+ //:u64_u32_vsqrtshift_bench.wasm
+ //:i16_vlshift_bench.wasm
+ //:cs16_vsquareabs_bench.wasm
+ //:cs16_bfly4_bench.wasm
+ //:cs16_fftr_bench.wasm
+ //:x8_lut_bench.wasm
+ //:abs_bench.wasm
+ //:average_pooling_bench.wasm
+ //:bankers_rounding_bench.wasm
+ //:ceiling_bench.wasm
+ //:channel_shuffle_bench.wasm
+ //:convert_bench.wasm
+ //:convolution_bench.wasm
+ //:deconvolution_bench.wasm
+ //:elu_bench.wasm
+ //:floor_bench.wasm
+ //:global_average_pooling_bench.wasm
+ //:hardswish_bench.wasm
+ //:leaky_relu_bench.wasm
+ //:max_pooling_bench.wasm
+ //:negate_bench.wasm
+ //:sigmoid_bench.wasm
+ //:prelu_bench.wasm
+ //:softmax_bench.wasm
+ //:square_bench.wasm
+ //:square_root_bench.wasm
+ //:truncation_bench.wasm
+ //:f16_gemm_e2e_bench.wasm
+ //:f32_dwconv_e2e_bench.wasm
+ //:f32_gemm_e2e_bench.wasm
+ //:qs8_dwconv_e2e_bench.wasm
+ //:qs8_gemm_e2e_bench.wasm
+ //:qu8_gemm_e2e_bench.wasm
+ //:qu8_dwconv_e2e_bench.wasm
+ //:end2end_bench.wasm
+ //:f16_exp_ulp_eval.wasm
+ //:f16_expminus_ulp_eval.wasm
+ //:f16_expm1minus_ulp_eval.wasm
+ //:f16_sigmoid_ulp_eval.wasm
+ //:f16_sqrt_ulp_eval.wasm
+ //:f32_exp_ulp_eval.wasm
+ //:f32_expminus_ulp_eval.wasm
+ //:f32_expm1minus_ulp_eval.wasm
+ //:f32_extexp_ulp_eval.wasm
+ //:f32_sigmoid_ulp_eval.wasm
+ //:f32_sqrt_ulp_eval.wasm
+ //:f32_tanh_ulp_eval.wasm
+ INSTALL_COMMAND ${CMAKE_COMMAND} -E copy_directory
+ ${CMAKE_CURRENT_SOURCE_DIR}/xnnpack/bazel-out/wasm-opt/bin/
+ ${CMAKE_BINARY_DIR}/wasm-opt
+)
diff --git a/fluent-bit/lib/wasm-micro-runtime-WAMR-1.2.2/samples/workload/XNNPACK/README.md b/fluent-bit/lib/wasm-micro-runtime-WAMR-1.2.2/samples/workload/XNNPACK/README.md
new file mode 100644
index 000000000..7984d9cee
--- /dev/null
+++ b/fluent-bit/lib/wasm-micro-runtime-WAMR-1.2.2/samples/workload/XNNPACK/README.md
@@ -0,0 +1,48 @@
+"XNNPACK" sample introduction
+==============
+
+This sample demonstrates how to build [XNNPACK](https://github.com/google/XNNPACK) benchmarks into WebAssembly with emsdk toolchain and run them with iwasm.
+
+## Installation toolchains
+
+please refer to [installation instructions](../README.md).
+
+## Build XNNPACK
+
+```bash
+cd <wamr-dir>/samples/workload/XNNPACK
+mkdir build
+cd build
+cmake ..
+```
+The wasm files are generated under folder samples/workload/XNNPACK/xnnpack/bazel-bin.
+
+## Run benchmarks
+
+Firstly please build iwasm with simd, libc-emcc and lib-pthread support:
+
+``` bash
+$ cd <wamr-dir>/product-mini/platforms/linux/
+$ mkdir build && cd build
+$ cmake .. -DWAMR_BUILD_LIBC_EMCC=1 -DWAMR_BUILD_LIB_PTHREAD=1
+$ make
+```
+
+And please build wamrc:
+
+``` bash
+cd <wamr-dir>/wamr-compiler
+./build_llvm.sh
+mkdir build && cd build
+cmake ..
+make
+```
+
+Then compile wasm file to aot file and run:
+
+``` shell
+$ cd <wamr-dir>/samples/workload/XNNPACK/xnnpack/bazel-bin
+$ wamrc -o average_pooling_bench.aot average_pooling_bench.wasm (or other wasm files)
+$ iwasm average_pooling_bench.aot
+```
+
diff --git a/fluent-bit/lib/wasm-micro-runtime-WAMR-1.2.2/samples/workload/XNNPACK/benchmark.patch b/fluent-bit/lib/wasm-micro-runtime-WAMR-1.2.2/samples/workload/XNNPACK/benchmark.patch
new file mode 100644
index 000000000..713b476d2
--- /dev/null
+++ b/fluent-bit/lib/wasm-micro-runtime-WAMR-1.2.2/samples/workload/XNNPACK/benchmark.patch
@@ -0,0 +1,14 @@
+diff --git include/benchmark/benchmark.h include/benchmark/benchmark.h
+index 9b54802..baa5938 100755
+--- include/benchmark/benchmark.h
++++ include/benchmark/benchmark.h
+@@ -364,7 +364,9 @@ template <class Tp>
+ inline BENCHMARK_ALWAYS_INLINE void DoNotOptimize(Tp const& value) {
+ internal::UseCharPointer(&reinterpret_cast<char const volatile&>(value));
+ }
++
+ // FIXME Add ClobberMemory() for non-gnu and non-msvc compilers
++inline BENCHMARK_ALWAYS_INLINE void ClobberMemory() { }
+ #endif
+
+ // This class is used for user-defined counters.
diff --git a/fluent-bit/lib/wasm-micro-runtime-WAMR-1.2.2/samples/workload/XNNPACK/xnnpack.patch b/fluent-bit/lib/wasm-micro-runtime-WAMR-1.2.2/samples/workload/XNNPACK/xnnpack.patch
new file mode 100644
index 000000000..3fb6b230b
--- /dev/null
+++ b/fluent-bit/lib/wasm-micro-runtime-WAMR-1.2.2/samples/workload/XNNPACK/xnnpack.patch
@@ -0,0 +1,141 @@
+diff --git a/.bazelrc b/.bazelrc
+index 688279da1..376996885 100644
+--- a/.bazelrc
++++ b/.bazelrc
+@@ -53,4 +53,9 @@ build:ios_fat --watchos_cpus=armv7k
+ build:macos --apple_platform_type=macos
+
+ build:macos_arm64 --config=macos
+-build:macos_arm64 --cpu=darwin_arm64
+\ No newline at end of file
++build:macos_arm64 --cpu=darwin_arm64
++
++build:wasm --cpu=wasm
++build:wasm --features=wasm_simd
++build:wasm --crosstool_top=@emsdk//emscripten_toolchain:everything
++build:wasm --host_crosstool_top=@bazel_tools//tools/cpp:toolchain
+diff --git a/WORKSPACE b/WORKSPACE
+index cd8960ffa..787e03ca8 100644
+--- a/WORKSPACE
++++ b/WORKSPACE
+@@ -29,8 +29,9 @@ http_archive(
+ # Google Benchmark library, used in micro-benchmarks.
+ http_archive(
+ name = "com_google_benchmark",
+- strip_prefix = "benchmark-main",
+- urls = ["https://github.com/google/benchmark/archive/main.zip"],
++ sha256 = "1ba14374fddcd9623f126b1a60945e4deac4cdc4fb25a5f25e7f779e36f2db52",
++ strip_prefix = "benchmark-d2a8a4ee41b923876c034afb939c4fc03598e622",
++ urls = ["https://github.com/google/benchmark/archive/d2a8a4ee41b923876c034afb939c4fc03598e622.zip"],
+ )
+
+ # FP16 library, used for half-precision conversions
+@@ -92,8 +93,25 @@ http_archive(
+ ],
+ )
+
++load("@bazel_tools//tools/build_defs/repo:http.bzl", "http_archive")
++http_archive(
++ name = "emsdk",
++ # Use emsdk-3.0.0 since the larger version may:
++ # - compress the wasm file into a tar file but not directly generate wasm file
++ # - generate incomplete implementation of libc API, e.g. throw exception in getentropy
++ strip_prefix = "emsdk-3.0.0/bazel",
++ url = "https://github.com/emscripten-core/emsdk/archive/refs/tags/3.0.0.tar.gz",
++ sha256 = "a41dccfd15be9e85f923efaa0ac21943cbab77ec8d39e52f25eca1ec61a9ac9e"
++)
++
++load("@emsdk//:deps.bzl", emsdk_deps = "deps")
++emsdk_deps()
++
++load("@emsdk//:emscripten_deps.bzl", emsdk_emscripten_deps = "emscripten_deps")
++emsdk_emscripten_deps()
++
+ # Android NDK location and version is auto-detected from $ANDROID_NDK_HOME environment variable
+-android_ndk_repository(name = "androidndk")
++#android_ndk_repository(name = "androidndk")
+
+ # Android SDK location and API is auto-detected from $ANDROID_HOME environment variable
+-android_sdk_repository(name = "androidsdk")
++#android_sdk_repository(name = "androidsdk")
+diff --git a/build_defs.bzl b/build_defs.bzl
+index b8217a18d..6f2d1675e 100644
+--- a/build_defs.bzl
++++ b/build_defs.bzl
+@@ -380,7 +380,7 @@ def xnnpack_benchmark(name, srcs, copts = [], deps = [], tags = []):
+ explicitly specified.
+ """
+ native.cc_binary(
+- name = name,
++ name = name + ".wasm",
+ srcs = srcs,
+ copts = xnnpack_std_cxxopts() + [
+ "-Iinclude",
+@@ -405,5 +405,5 @@ def xnnpack_benchmark(name, srcs, copts = [], deps = [], tags = []):
+ ":emscripten": xnnpack_emscripten_deps(),
+ "//conditions:default": [],
+ }),
+- tags = tags,
++ tags = tags,
+ )
+diff --git a/emscripten.bzl b/emscripten.bzl
+index f1557a7b1..7f964a094 100644
+--- a/emscripten.bzl
++++ b/emscripten.bzl
+@@ -25,12 +25,19 @@ def xnnpack_emscripten_benchmark_linkopts():
+ """Emscripten-specific linkopts for benchmarks."""
+ return [
+ "-s ASSERTIONS=1",
+- "-s ENVIRONMENT=node,shell,web",
+- "-s ERROR_ON_UNDEFINED_SYMBOLS=1",
+- "-s EXIT_RUNTIME=1",
++ "-s ERROR_ON_UNDEFINED_SYMBOLS=0",
+ "-s ALLOW_MEMORY_GROWTH=1",
+ "-s TOTAL_MEMORY=536870912", # 512M
+- "--pre-js $(location :preamble.js.lds)",
++ "-s USE_PTHREADS=0",
++ "-s STANDALONE_WASM=1",
++ "-Wno-unused",
++ "-Wno-unused-variable",
++ "-Wno-unused-command-line-argument",
++ "-Wl,--export=__heap_base",
++ "-Wl,--export=__data_end",
++ "-Wl,--export=malloc",
++ "-Wl,--export=free",
++ "--oformat=wasm",
+ ]
+
+ def xnnpack_emscripten_deps():
+diff --git a/src/log.c b/src/log.c
+index 5715f2f85..4b3e4261b 100644
+--- a/src/log.c
++++ b/src/log.c
+@@ -55,7 +55,7 @@
+ #endif
+
+ #if XNN_LOG_TO_STDIO
+-static void xnn_vlog(int output_handle, const char* prefix, size_t prefix_length, const char* format, va_list args) {
++void xnn_vlog(int output_handle, const char* prefix, size_t prefix_length, const char* format, va_list args) {
+ char stack_buffer[XNN_LOG_STACK_BUFFER_SIZE];
+ char* heap_buffer = NULL;
+ char* out_buffer = &stack_buffer[0];
+diff --git a/third_party/cpuinfo.BUILD b/third_party/cpuinfo.BUILD
+index 1997f4e3a..5e03c43af 100644
+--- a/third_party/cpuinfo.BUILD
++++ b/third_party/cpuinfo.BUILD
+@@ -150,7 +150,7 @@ cc_library(
+ "src/arm/midr.h",
+ ],
+ deps = [
+- "@clog",
++ "//deps/clog"
+ ],
+ )
+
+@@ -352,5 +352,5 @@ config_setting(
+
+ config_setting(
+ name = "emscripten",
+- values = {"crosstool_top": "//toolchain:emscripten"},
++ values = {"crosstool_top": "@emsdk//emscripten_toolchain:everything"},
+ )