add_custom_target(example_grouped_gemm)

if (DL_KERNELS)
add_example_executable(example_grouped_gemm_multiple_d_dl_fp16 grouped_gemm_multiple_d_dl_fp16.cpp)
add_example_dependencies(example_grouped_gemm example_grouped_gemm_multiple_d_dl_fp16)
endif()

list(APPEND gpu_list gfx90a gfx940 gfx941 gfx942)
set(target 0)
foreach(gpu IN LISTS GPU_TARGETS)
    if(gpu IN_LIST gpu_list AND target EQUAL 0)
        add_example_executable(example_grouped_gemm_xdl_fp32 grouped_gemm_xdl_fp32.cpp)
        add_example_dependencies(example_grouped_gemm example_grouped_gemm_xdl_fp32)

        add_example_executable(example_grouped_gemm_xdl_fp16 grouped_gemm_xdl_fp16.cpp)
        add_example_dependencies(example_grouped_gemm example_grouped_gemm_xdl_fp16)

        add_example_executable(example_grouped_gemm_xdl_splitk_fp16 grouped_gemm_xdl_splitk_fp16.cpp)
        add_example_dependencies(example_grouped_gemm example_grouped_gemm_xdl_splitk_fp16)

        add_example_executable(example_grouped_gemm_xdl_fixed_nk_fp16 grouped_gemm_xdl_fixed_nk_fp16.cpp)
        add_example_dependencies(example_grouped_gemm example_grouped_gemm_xdl_fixed_nk_fp16)

        add_example_executable(example_grouped_gemm_xdl_fixed_nk_bias_fp16 grouped_gemm_xdl_fixed_nk_bias_fp16.cpp)
        add_example_dependencies(example_grouped_gemm example_grouped_gemm_xdl_fixed_nk_bias_fp16)

        add_example_executable(example_grouped_gemm_xdl_bf16 grouped_gemm_xdl_bf16.cpp)
        add_example_dependencies(example_grouped_gemm example_grouped_gemm_xdl_bf16)

        add_example_executable(example_grouped_gemm_xdl_int8 grouped_gemm_xdl_int8.cpp)
        add_example_dependencies(example_grouped_gemm example_grouped_gemm_xdl_int8)

        add_example_executable(example_grouped_gemm_xdl_fixed_nk_fp8 grouped_gemm_xdl_fixed_nk_fp8.cpp)
        add_dependencies(example_grouped_gemm example_grouped_gemm_xdl_fixed_nk_fp8)

        add_example_executable(example_grouped_gemm_multiple_d_splitk_xdl_fp16 grouped_gemm_multiple_d_splitk_xdl_fp16.cpp)
        add_dependencies(example_grouped_gemm example_grouped_gemm_multiple_d_splitk_xdl_fp16)
        
        if(USE_BITINT_EXTENSION_INT4)
            add_example_executable(example_grouped_gemm_xdl_int4 grouped_gemm_xdl_int4.cpp)
            add_example_dependencies(example_grouped_gemm example_grouped_gemm_xdl_int4)
        endif()

        set(target 1)
    endif()
endforeach()

