CMakeLists.txt 4.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198
  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.14)
  4. project(xnnpack_wasm)
  5. ################ EMCC ################
  6. include(ExternalProject)
  7. # grep xnnpack_benchmark -A 1 BUILD.bazel \
  8. # | grep "name =" \
  9. # | awk '{print $3}' \
  10. # | sed -e 's/\"//g; s/,//g; s/^/\"/g; s/$/\"/g'
  11. list(APPEND NATIVE_BENCHMARKS
  12. "qs8_dwconv_bench"
  13. "qs8_f32_vcvt_bench"
  14. "qs8_gemm_bench"
  15. "qs8_requantization_bench"
  16. "qs8_vadd_bench"
  17. "qs8_vaddc_bench"
  18. "qs8_vcvt_bench"
  19. "qs16_qs8_vcvt_bench"
  20. "qs8_vlrelu_bench"
  21. "qs8_vmul_bench"
  22. "qs8_vmulc_bench"
  23. "qu8_f32_vcvt_bench"
  24. "qu8_gemm_bench"
  25. "qu8_requantization_bench"
  26. "qu8_vadd_bench"
  27. "qu8_vaddc_bench"
  28. "qu8_vcvt_bench"
  29. "qu8_vlrelu_bench"
  30. "qu8_vmul_bench"
  31. "qu8_vmulc_bench"
  32. "bf16_gemm_bench"
  33. "f16_f32acc_igemm_bench"
  34. "f16_igemm_bench"
  35. "f16_f32acc_gemm_bench"
  36. "f16_gemm_bench"
  37. "f16_raddstoreexpminusmax_bench"
  38. "f16_spmm_bench"
  39. "f16_vsigmoid_bench"
  40. "f16_vtanh_bench"
  41. "f16_f32_vcvt_bench"
  42. "f32_igemm_bench"
  43. "f32_conv_hwc_bench"
  44. "f16_conv_hwc2chw_bench"
  45. "f16_gavgpool_cw_bench"
  46. "f32_gavgpool_cw_bench"
  47. "f32_conv_hwc2chw_bench"
  48. "f16_dwconv_bench"
  49. "f32_dwconv_bench"
  50. "f32_dwconv2d_chw_bench"
  51. "f16_dwconv2d_chw_bench"
  52. "f32_f16_vcvt_bench"
  53. "xx_transpose_bench"
  54. "x8_transpose_bench"
  55. "x16_transpose_bench"
  56. "x24_transpose_bench"
  57. "x32_transpose_bench"
  58. "x64_transpose_bench"
  59. "f32_bgemm_bench"
  60. "f32_gemm_bench"
  61. "f32_qs8_vcvt_bench"
  62. "f32_qu8_vcvt_bench"
  63. "f32_raddexpminusmax_bench"
  64. "f32_raddextexp_bench"
  65. "f32_raddstoreexpminusmax_bench"
  66. "f32_rmax_bench"
  67. "f32_spmm_bench"
  68. "f32_softmax_bench"
  69. "f16_velu_bench"
  70. "f32_velu_bench"
  71. "f32_vhswish_bench"
  72. "f32_vlrelu_bench"
  73. "f32_vrelu_bench"
  74. "f32_vscaleexpminusmax_bench"
  75. "f32_vscaleextexp_bench"
  76. "f32_vsigmoid_bench"
  77. "f16_vsqrt_bench"
  78. "f32_vsqrt_bench"
  79. "f32_vtanh_bench"
  80. "f32_im2col_gemm_bench"
  81. "rounding_bench"
  82. "s16_rmaxabs_bench"
  83. "s16_window_bench"
  84. "u32_filterbank_accumulate_bench"
  85. "u32_filterbank_subtract_bench"
  86. "u32_vlog_bench"
  87. "u64_u32_vsqrtshift_bench"
  88. "i16_vlshift_bench"
  89. "cs16_vsquareabs_bench"
  90. "cs16_bfly4_bench"
  91. "cs16_fftr_bench"
  92. "x8_lut_bench"
  93. "x32_packw_bench"
  94. "x16_packw_bench"
  95. "abs_bench"
  96. "average_pooling_bench"
  97. "bankers_rounding_bench"
  98. "ceiling_bench"
  99. "channel_shuffle_bench"
  100. "convert_bench"
  101. "convolution_bench"
  102. "deconvolution_bench"
  103. "elu_bench"
  104. "floor_bench"
  105. "global_average_pooling_bench"
  106. "hardswish_bench"
  107. "leaky_relu_bench"
  108. "max_pooling_bench"
  109. "negate_bench"
  110. "prelu_bench"
  111. "sigmoid_bench"
  112. "softmax_bench"
  113. "square_bench"
  114. "square_root_bench"
  115. "tanh_bench"
  116. "truncation_bench"
  117. "f16_dwconv_e2e_bench"
  118. "f16_gemm_e2e_bench"
  119. "f32_dwconv_e2e_bench"
  120. "f32_gemm_e2e_bench"
  121. "qs8_dwconv_e2e_bench"
  122. "qs8_gemm_e2e_bench"
  123. "qu8_gemm_e2e_bench"
  124. "qu8_dwconv_e2e_bench"
  125. "end2end_bench"
  126. "f16_exp_ulp_eval"
  127. "f16_expminus_ulp_eval"
  128. "f16_expm1minus_ulp_eval"
  129. "f16_sigmoid_ulp_eval"
  130. "f16_sqrt_ulp_eval"
  131. "f16_tanh_ulp_eval"
  132. "f32_exp_ulp_eval"
  133. "f32_expminus_ulp_eval"
  134. "f32_expm1minus_ulp_eval"
  135. "f32_extexp_ulp_eval"
  136. "f32_sigmoid_ulp_eval"
  137. "f32_sqrt_ulp_eval"
  138. "f32_tanh_ulp_eval"
  139. )
  140. # Only Download
  141. ExternalProject_Add(xnnpack-download
  142. PREFIX xnnpack
  143. GIT_REPOSITORY https://github.com/google/XNNPACK.git
  144. GIT_TAG b9d4073a6913891ce9cbd8965c8d506075d2a45a
  145. GIT_PROGRESS ON
  146. SOURCE_DIR ${CMAKE_CURRENT_SOURCE_DIR}/xnnpack
  147. UPDATE_COMMAND ""
  148. PATCH_COMMAND git apply ${CMAKE_CURRENT_SOURCE_DIR}/xnnpack.patch
  149. CONFIGURE_COMMAND ""
  150. BUILD_COMMAND ""
  151. INSTALL_COMMAND ""
  152. TEST_COMMAND ""
  153. )
  154. set(WAMRC "${CMAKE_CURRENT_SOURCE_DIR}/../../../wamr-compiler/build/wamrc")
  155. if(EXISTS ${WAMRC})
  156. message("-- Will generate .aot")
  157. else()
  158. message("Will generate .wasm")
  159. endif()
  160. foreach(BENCHMARK IN LISTS NATIVE_BENCHMARKS)
  161. string(CONCAT WASM_BENCHMARK "//:" ${BENCHMARK} "-wasm")
  162. string(CONCAT WASM_OUTPUT ${BENCHMARK} ".wasm")
  163. add_custom_command(
  164. OUTPUT ${WASM_OUTPUT}
  165. COMMAND bazel --output_user_root=build-user-output build -c opt --config=wasm ${WASM_BENCHMARK}
  166. && ${CMAKE_COMMAND} -E copy_if_different ./bazel-bin/${WASM_OUTPUT} ${CMAKE_CURRENT_BINARY_DIR}/${WASM_OUTPUT}
  167. WORKING_DIRECTORY ${CMAKE_CURRENT_SOURCE_DIR}/xnnpack
  168. DEPENDS xnnpack-download
  169. COMMENT "Generating ${WASM_OUTPUT} ..."
  170. )
  171. set_property(DIRECTORY APPEND PROPERTY ADDITIONAL_CLEAN_FILES ${CMAKE_CURRENT_BINARY_DIR}/${WASM_OUTPUT})
  172. if(EXISTS ${WAMRC})
  173. string(CONCAT AOT_OUTPUT ${BENCHMARK} ".aot")
  174. add_custom_command(
  175. OUTPUT ${AOT_OUTPUT}
  176. COMMAND ${WAMRC} -o ${AOT_OUTPUT} ${WASM_OUTPUT}
  177. WORKING_DIRECTORY ${CMAKE_CURRENT_BINARY_DIR}
  178. DEPENDS ${WASM_OUTPUT}
  179. COMMENT "Generating ${AOT_OUTPUT} ..."
  180. )
  181. add_custom_target(${BENCHMARK} ALL DEPENDS ${AOT_OUTPUT})
  182. else()
  183. add_custom_target(${BENCHMARK} ALL DEPENDS ${WASM_OUTPUT})
  184. endif()
  185. endforeach()