+
+set(ELEC_DEFS
+ "-DEL_CUTOFF\;-DEELNAME=_ElecCut"
+ "-DEL_RF\;-DEELNAME=_ElecRF"
+ "-DEL_EWALD_TAB\;-DEELNAME=_ElecEwQSTab"
+ "-DEL_EWALD_TAB\;-DVDW_CUTOFF_CHECK\;-DEELNAME=_ElecEwQSTabTwinCut"
+ "-DEL_EWALD_ANA\;-DEELNAME=_ElecEw"
+ "-DEL_EWALD_ANA\;-DVDW_CUTOFF_CHECK\;-DEELNAME=_ElecEwTwinCut")
+set(VDW_DEFS
+ "-DVDWNAME=_VdwLJ"
+ "-DLJ_COMB_GEOM\;-DVDWNAME=_VdwLJCombGeom"
+ "-DLJ_COMB_LB\;-DVDWNAME=_VdwLJCombLB"
+ "-DLJ_FORCE_SWITCH\;-DVDWNAME=_VdwLJFsw"
+ "-DLJ_POT_SWITCH\;-DVDWNAME=_VdwLJPsw"
+ "-DLJ_EWALD_COMB_GEOM\;-DVDWNAME=_VdwLJEwCombGeom"
+ "-DLJ_EWALD_COMB_LB\;-DVDWNAME=_VdwLJEwCombLB")
+if(CLANG_TIDY_EXE)
+ set(OCL_COMPILER "${CLANG_TIDY_EXE}")
+ set(CLANG_TIDY_ARGS "-quiet;-checks=*,-readability-implicit-bool-conversion,-llvm-header-guard,-hicpp-signed-bitwise,-clang-analyzer-deadcode.DeadStores,-google-readability-todo;--;${CMAKE_C_COMPILER}")
+else()
+ set(OCL_COMPILER "${CMAKE_C_COMPILER}")
+endif()
+foreach(ELEC_DEF IN LISTS ELEC_DEFS)
+ foreach(VDW_DEF IN LISTS VDW_DEFS)
+ foreach(VENDOR AMD NVIDIA INTEL)
+ if(VENDOR STREQUAL INTEL)
+ set(CLUSTER_SIZE 4)
+ else()
+ set(CLUSTER_SIZE 8)
+ endif()
+ string(REGEX REPLACE ".*=" "" ELEC_NAME "${ELEC_DEF}")
+ string(REGEX REPLACE ".*=" "" VDW_NAME "${VDW_DEF}")
+ set(OBJ_FILE nbnxn_ocl_kernel${ELEC_NAME}${VDW_NAME}_${VENDOR}.o)
+ add_custom_command(OUTPUT ${OBJ_FILE} COMMAND ${OCL_COMPILER}
+ ${CMAKE_CURRENT_SOURCE_DIR}/nbnxn_ocl_kernels.cl ${CLANG_TIDY_ARGS}
+ -Xclang -finclude-default-header -D_${VENDOR}_SOURCE_
+ -DGMX_OCL_FASTGEN ${ELEC_DEF} ${VDW_DEF}
+ -DNBNXN_GPU_CLUSTER_SIZE=${CLUSTER_SIZE} -DIATYPE_SHMEM
+ -c -I ${CMAKE_SOURCE_DIR}/src -std=cl1.2
+ -Weverything -Wno-conversion -Wno-missing-variable-declarations -Wno-used-but-marked-unused
+ -Wno-cast-align -Wno-incompatible-pointer-types
+ -o${OBJ_FILE}
+ )
+ list(APPEND NBNXN_OCL_KERNELS ${OBJ_FILE})
+ endforeach()
+ endforeach()
+endforeach()
+add_custom_target(ocl_kernel DEPENDS ${NBNXN_OCL_KERNELS})