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

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
#ifndef CK_NOGPU
9
namespace ck {
Chao Liu's avatar
Chao Liu committed
10

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

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

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

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

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

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

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

Chao Liu's avatar
Chao Liu committed
29
} // namespace ck
30
#endif