if(GPU_TARGETS MATCHES "gfx9|gfx11|gfx12")
    function (add_moe_smoothquant_test TARGET_NAME MAIN_SRC)
        message(DEBUG "adding ${TARGET_NAME}")
        add_gtest_executable(${TARGET_NAME} ${MAIN_SRC})
        target_include_directories(${TARGET_NAME} PRIVATE ${CMAKE_CURRENT_LIST_DIR})

        foreach(source IN LISTS ARGN)
            list(APPEND INSTANCE_SRCS ${source})
        endforeach()

        target_sources(${TARGET_NAME} PRIVATE ${INSTANCE_SRCS})

        set(COMPILE_OPTIONS)
        # NOTE: we turn off undefined-func-template to let source compile without explicit declare function specializations
        list(APPEND COMPILE_OPTIONS -Wno-undefined-func-template -Wno-float-equal)
        # list(APPEND COMPILE_OPTIONS -v --save-temps -Wno-gnu-line-marker)

        target_compile_options(${TARGET_NAME} PRIVATE ${COMPILE_OPTIONS})
    endfunction(add_moe_smoothquant_test TARGET_NAME MAIN_SRC)

    file(GLOB INSTANCE_SRCS instances/*.cpp)

    add_moe_smoothquant_test(test_ck_tile_moe_smoothquant test_moe_smoothquant.cpp ${INSTANCE_SRCS})

else()
    message(DEBUG "Skipping ck_tile MOE smoothquant tests for current target")
endif()