amd_address_space.hpp 1.22 KB
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.

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

Chao Liu's avatar
Chao Liu committed
6
#include "ck/ck.hpp"
Chao Liu's avatar
Chao Liu committed
7
#include "c_style_pointer_cast.hpp"
Chao Liu's avatar
tidy  
Chao Liu committed
8

Chao Liu's avatar
Chao Liu committed
9
10
11
// Address Space for AMDGCN
// https://llvm.org/docs/AMDGPUUsage.html#address-space

Chao Liu's avatar
tidy  
Chao Liu committed
12
13
namespace ck {

14
enum struct AddressSpaceEnum
Chao Liu's avatar
tidy  
Chao Liu committed
15
16
17
18
19
20
21
22
23
{
    Generic,
    Global,
    Lds,
    Sgpr,
    Vgpr,
};

template <typename T>
24
__device__ T* cast_pointer_to_generic_address_space(T CK_CONSTANT_ADDRESS_SPACE* p)
Chao Liu's avatar
tidy  
Chao Liu committed
25
{
Chao Liu's avatar
Chao Liu committed
26
    // cast a pointer in "Constant" address space (4) to "Generic" address space (0)
Chao Liu's avatar
Chao Liu committed
27
    // only c-style pointer cast seems be able to be compiled
Chao Liu's avatar
Chao Liu committed
28
#pragma clang diagnostic push
Chao Liu's avatar
Chao Liu committed
29
#pragma clang diagnostic ignored "-Wold-style-cast"
Chao Liu's avatar
Chao Liu committed
30
31
    return (T*)p; // NOLINT(old-style-cast)
#pragma clang diagnostic pop
Chao Liu's avatar
tidy  
Chao Liu committed
32
33
}

Chao Liu's avatar
tidy  
Chao Liu committed
34
template <typename T>
35
__host__ __device__ T CK_CONSTANT_ADDRESS_SPACE* cast_pointer_to_constant_address_space(T* p)
Chao Liu's avatar
tidy  
Chao Liu committed
36
{
Chao Liu's avatar
Chao Liu committed
37
    // cast a pointer in "Generic" address space (0) to "Constant" address space (4)
Chao Liu's avatar
Chao Liu committed
38
    // only c-style pointer cast seems be able to be compiled
Chao Liu's avatar
Chao Liu committed
39
#pragma clang diagnostic push
Chao Liu's avatar
Chao Liu committed
40
#pragma clang diagnostic ignored "-Wold-style-cast"
41
    return (T CK_CONSTANT_ADDRESS_SPACE*)p; // NOLINT(old-style-cast)
Chao Liu's avatar
Chao Liu committed
42
#pragma clang diagnostic pop
Chao Liu's avatar
tidy  
Chao Liu committed
43
44
}

Chao Liu's avatar
tidy  
Chao Liu committed
45
} // namespace ck