"vscode:/vscode.git/clone" did not exist on "15e876677db667a1d73c430a26500465ceee72b7"
get_id.hpp 724 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
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

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

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

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

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