get_id.hpp 809 Bytes
Newer Older
Chao Liu's avatar
Chao Liu committed
1
// SPDX-License-Identifier: MIT
Illia Silin's avatar
Illia Silin committed
2
// Copyright (c) 2018-2023, Advanced Micro Devices, Inc. All rights reserved.
Chao Liu's avatar
Chao Liu committed
3

4
#pragma once
Chao Liu's avatar
Chao Liu committed
5
6

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

8
namespace ck {
Chao Liu's avatar
Chao Liu committed
9

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

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

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

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

danyao12's avatar
danyao12 committed
22
23
__device__ index_t get_lane_local_1d_id() { return threadIdx.x % get_warp_size(); }

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

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

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

Chao Liu's avatar
Chao Liu committed
30
} // namespace ck