get_id.hpp 833 Bytes
Newer Older
Umang Yadav's avatar
Umang Yadav committed
1
2
3

#pragma clang diagnostic push
#pragma clang diagnostic ignored "-Weverything"
Chao Liu's avatar
Chao Liu committed
4
// SPDX-License-Identifier: MIT
Illia Silin's avatar
Illia Silin committed
5
// Copyright (c) 2018-2023, Advanced Micro Devices, Inc. All rights reserved.
Chao Liu's avatar
Chao Liu committed
6

7
#pragma once
Chao Liu's avatar
Chao Liu committed
8
9

#include "ck/ck.hpp"
Chao Liu's avatar
Chao Liu committed
10

11
namespace ck {
Chao Liu's avatar
Chao Liu committed
12

Chao Liu's avatar
Chao Liu committed
13
14
15
16
17
__host__ __device__ constexpr index_t get_warp_size()
{
    // warpSize is defined by HIP
    return warpSize;
}
Chao Liu's avatar
Chao Liu committed
18

Chao Liu's avatar
Chao Liu committed
19
__device__ index_t get_thread_local_1d_id() { return threadIdx.x; }
Chao Liu's avatar
Chao Liu committed
20

rocking5566's avatar
rocking5566 committed
21
22
__device__ index_t get_thread_global_1d_id() { return blockIdx.x * blockDim.x + threadIdx.x; }

Chao Liu's avatar
Chao Liu committed
23
__device__ index_t get_warp_local_1d_id() { return threadIdx.x / get_warp_size(); }
Chao Liu's avatar
Chao Liu committed
24

Chao Liu's avatar
Chao Liu committed
25
__device__ index_t get_block_1d_id() { return blockIdx.x; }
Chao Liu's avatar
Chao Liu committed
26

Jianfeng Yan's avatar
Jianfeng Yan committed
27
28
__device__ index_t get_grid_size() { return gridDim.x; }

rocking5566's avatar
rocking5566 committed
29
30
__device__ index_t get_block_size() { return blockDim.x; }

Chao Liu's avatar
Chao Liu committed
31
} // namespace ck
Umang Yadav's avatar
Umang Yadav committed
32
33

#pragma clang diagnostic pop