CMakeLists.txt 6.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147
  1. # Copyright (C) 2019 Intel Corporation. All rights reserved.
  2. # SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
  3. cmake_minimum_required (VERSION 3.0)
  4. project(xnnpack_wasm)
  5. ################ EMCC ################
  6. include(ExternalProject)
  7. ExternalProject_Add(xnnpack
  8. PREFIX xnnpack
  9. GIT_REPOSITORY https://github.com/google/XNNPACK.git
  10. GIT_TAG 4570a7151aa4f3e57eca14a575eeff6bb13e26be
  11. GIT_PROGRESS ON
  12. SOURCE_DIR ${CMAKE_CURRENT_SOURCE_DIR}/xnnpack
  13. UPDATE_COMMAND git restore .
  14. && cmake -E copy ${CMAKE_CURRENT_SOURCE_DIR}/xnnpack/google3/third_party/XNNPACK/microkernels.bzl
  15. ${CMAKE_CURRENT_SOURCE_DIR}/xnnpack/
  16. && git apply ${CMAKE_CURRENT_SOURCE_DIR}/xnnpack.patch
  17. CONFIGURE_COMMAND ""
  18. # grep xnnpack_benchmark -A 1 BUILD.bazel \
  19. # | grep "name =" \
  20. # | awk '{print $3}' \
  21. # | sed -e 's/\"//g' -e 's/,//g' -e 's/^/\/\/:/g'
  22. BUILD_COMMAND cd ${CMAKE_CURRENT_SOURCE_DIR}/xnnpack
  23. && bazel --output_user_root=build-user-output build -c opt --config=wasm
  24. //:qs8_dwconv_bench.wasm
  25. //:qs8_f32_vcvt_bench.wasm
  26. //:qs8_gemm_bench.wasm
  27. //:qs8_requantization_bench.wasm
  28. //:qs8_vadd_bench.wasm
  29. //:qs8_vaddc_bench.wasm
  30. //:qs8_vcvt_bench.wasm
  31. //:qs8_vlrelu_bench.wasm
  32. //:qs8_vmul_bench.wasm
  33. //:qs8_vmulc_bench.wasm
  34. //:qu8_f32_vcvt_bench.wasm
  35. //:qu8_gemm_bench.wasm
  36. //:qu8_requantization_bench.wasm
  37. //:qu8_vadd_bench.wasm
  38. //:qu8_vaddc_bench.wasm
  39. //:qu8_vcvt_bench.wasm
  40. //:qu8_vlrelu_bench.wasm
  41. //:qu8_vmul_bench.wasm
  42. //:qu8_vmulc_bench.wasm
  43. //:bf16_gemm_bench.wasm
  44. //:f16_igemm_bench.wasm
  45. //:f16_gemm_bench.wasm
  46. //:f16_raddstoreexpminusmax_bench.wasm
  47. //:f16_spmm_bench.wasm
  48. //:f16_vsigmoid_bench.wasm
  49. //:f16_f32_vcvt_bench.wasm
  50. //:f32_igemm_bench.wasm
  51. //:f32_conv_hwc_bench.wasm
  52. //:f16_conv_hwc2chw_bench.wasm
  53. //:f16_gavgpool_cw_bench.wasm
  54. //:f32_gavgpool_cw_bench.wasm
  55. //:f32_conv_hwc2chw_bench.wasm
  56. //:f16_dwconv_bench.wasm
  57. //:f32_dwconv_bench.wasm
  58. //:f32_dwconv2d_chw_bench.wasm
  59. //:f16_dwconv2d_chw_bench.wasm
  60. //:f32_f16_vcvt_bench.wasm
  61. //:xx_transpose_bench.wasm
  62. //:x8_transpose_bench.wasm
  63. //:x16_transpose_bench.wasm
  64. //:x24_transpose_bench.wasm
  65. //:x32_transpose_bench.wasm
  66. //:x64_transpose_bench.wasm
  67. //:f32_gemm_bench.wasm
  68. //:f32_qs8_vcvt_bench.wasm
  69. //:f32_qu8_vcvt_bench.wasm
  70. //:f32_raddexpminusmax_bench.wasm
  71. //:f32_raddextexp_bench.wasm
  72. //:f32_raddstoreexpminusmax_bench.wasm
  73. //:f32_rmax_bench.wasm
  74. //:f32_spmm_bench.wasm
  75. //:f32_softmax_bench.wasm
  76. //:f16_velu_bench.wasm
  77. //:f32_velu_bench.wasm
  78. //:f32_vhswish_bench.wasm
  79. //:f32_vlrelu_bench.wasm
  80. //:f32_vrelu_bench.wasm
  81. //:f32_vscaleexpminusmax_bench.wasm
  82. //:f32_vscaleextexp_bench.wasm
  83. //:f32_vsigmoid_bench.wasm
  84. //:f16_vsqrt_bench.wasm
  85. //:f32_vsqrt_bench.wasm
  86. //:f32_im2col_gemm_bench.wasm
  87. //:rounding_bench.wasm
  88. //:s16_rmaxabs_bench.wasm
  89. //:s16_window_bench.wasm
  90. //:u32_filterbank_accumulate_bench.wasm
  91. //:u32_filterbank_subtract_bench.wasm
  92. //:u32_vlog_bench.wasm
  93. //:u64_u32_vsqrtshift_bench.wasm
  94. //:i16_vlshift_bench.wasm
  95. //:cs16_vsquareabs_bench.wasm
  96. //:cs16_bfly4_bench.wasm
  97. //:cs16_fftr_bench.wasm
  98. //:x8_lut_bench.wasm
  99. //:abs_bench.wasm
  100. //:average_pooling_bench.wasm
  101. //:bankers_rounding_bench.wasm
  102. //:ceiling_bench.wasm
  103. //:channel_shuffle_bench.wasm
  104. //:convert_bench.wasm
  105. //:convolution_bench.wasm
  106. //:deconvolution_bench.wasm
  107. //:elu_bench.wasm
  108. //:floor_bench.wasm
  109. //:global_average_pooling_bench.wasm
  110. //:hardswish_bench.wasm
  111. //:leaky_relu_bench.wasm
  112. //:max_pooling_bench.wasm
  113. //:negate_bench.wasm
  114. //:sigmoid_bench.wasm
  115. //:prelu_bench.wasm
  116. //:softmax_bench.wasm
  117. //:square_bench.wasm
  118. //:square_root_bench.wasm
  119. //:truncation_bench.wasm
  120. //:f16_gemm_e2e_bench.wasm
  121. //:f32_dwconv_e2e_bench.wasm
  122. //:f32_gemm_e2e_bench.wasm
  123. //:qs8_dwconv_e2e_bench.wasm
  124. //:qs8_gemm_e2e_bench.wasm
  125. //:qu8_gemm_e2e_bench.wasm
  126. //:qu8_dwconv_e2e_bench.wasm
  127. //:end2end_bench.wasm
  128. //:f16_exp_ulp_eval.wasm
  129. //:f16_expminus_ulp_eval.wasm
  130. //:f16_expm1minus_ulp_eval.wasm
  131. //:f16_sigmoid_ulp_eval.wasm
  132. //:f16_sqrt_ulp_eval.wasm
  133. //:f32_exp_ulp_eval.wasm
  134. //:f32_expminus_ulp_eval.wasm
  135. //:f32_expm1minus_ulp_eval.wasm
  136. //:f32_extexp_ulp_eval.wasm
  137. //:f32_sigmoid_ulp_eval.wasm
  138. //:f32_sqrt_ulp_eval.wasm
  139. //:f32_tanh_ulp_eval.wasm
  140. INSTALL_COMMAND ${CMAKE_COMMAND} -E copy_directory
  141. ${CMAKE_CURRENT_SOURCE_DIR}/xnnpack/bazel-out/wasm-opt/bin/
  142. ${CMAKE_BINARY_DIR}/wasm-opt
  143. )