2023-12-08 15:16:52 +08:00
|
|
|
#pragma once
|
|
|
|
|
2024-03-10 17:27:45 -05:00
|
|
|
#ifdef USE_ROCM
|
2024-05-22 03:18:41 -04:00
|
|
|
#include <hip/hip_runtime.h>
|
2024-03-10 17:27:45 -05:00
|
|
|
#endif
|
|
|
|
|
|
|
|
#ifndef USE_ROCM
|
|
|
|
#define WARP_SIZE 32
|
|
|
|
#else
|
|
|
|
#define WARP_SIZE warpSize
|
|
|
|
#endif
|
|
|
|
|
2023-12-08 15:16:52 +08:00
|
|
|
#ifndef USE_ROCM
|
|
|
|
#define VLLM_LDG(arg) __ldg(arg)
|
|
|
|
#else
|
|
|
|
#define VLLM_LDG(arg) *(arg)
|
|
|
|
#endif
|
|
|
|
|
|
|
|
#ifndef USE_ROCM
|
2024-05-22 03:18:41 -04:00
|
|
|
#define VLLM_SHFL_XOR_SYNC(var, lane_mask) \
|
|
|
|
__shfl_xor_sync(uint32_t(-1), var, lane_mask)
|
2023-12-08 15:16:52 +08:00
|
|
|
#else
|
|
|
|
#define VLLM_SHFL_XOR_SYNC(var, lane_mask) __shfl_xor(var, lane_mask)
|
|
|
|
#endif
|
|
|
|
|
|
|
|
#ifndef USE_ROCM
|
|
|
|
#define VLLM_SHFL_SYNC(var, src_lane) __shfl_sync(uint32_t(-1), var, src_lane)
|
|
|
|
#else
|
|
|
|
#define VLLM_SHFL_SYNC(var, src_lane) __shfl(var, src_lane)
|
|
|
|
#endif
|
|
|
|
|
2024-05-10 00:19:50 +08:00
|
|
|
#ifndef USE_ROCM
|
2024-05-22 03:18:41 -04:00
|
|
|
#define VLLM_SHFL_DOWN_SYNC(var, lane_delta) \
|
|
|
|
__shfl_down_sync(uint32_t(-1), var, lane_delta)
|
2024-05-10 00:19:50 +08:00
|
|
|
#else
|
|
|
|
#define VLLM_SHFL_DOWN_SYNC(var, lane_delta) __shfl_down(var, lane_delta)
|
|
|
|
#endif
|
|
|
|
|
2023-12-08 15:16:52 +08:00
|
|
|
#ifndef USE_ROCM
|
|
|
|
#define VLLM_DevFuncAttribute_SET_MaxDynamicSharedMemorySize(FUNC, VAL) \
|
|
|
|
cudaFuncSetAttribute(FUNC, cudaFuncAttributeMaxDynamicSharedMemorySize, VAL)
|
|
|
|
#else
|
|
|
|
#define VLLM_DevFuncAttribute_SET_MaxDynamicSharedMemorySize(FUNC, VAL) \
|
|
|
|
hipFuncSetAttribute(FUNC, hipFuncAttributeMaxDynamicSharedMemorySize, VAL)
|
|
|
|
#endif
|