runtime.cu 3.09 KB
Newer Older
lijian6's avatar
lijian6 committed
1
#include "hip/hip_runtime.h"
Chenggang Zhao's avatar
Chenggang Zhao committed
2
3
4
5
6
7
#include <cstring>

#include "configs.cuh"
#include "exception.cuh"
#include "launch.cuh"
#include "utils.cuh"
8
#include "shmem_wrapper.cuh"
9

Chenggang Zhao's avatar
Chenggang Zhao committed
10
11
12
13
namespace deep_ep {

namespace intranode {

lijian6's avatar
lijian6 committed
14
15
template <int kNumRanks> 
__global__ void barrier(int **barrier_signal_ptrs, int rank) {
16
    barrier_block<kNumRanks>(barrier_signal_ptrs, rank);
Chenggang Zhao's avatar
Chenggang Zhao committed
17
18
}

lijian6's avatar
lijian6 committed
19
20
21
void barrier(int **barrier_signal_ptrs, int rank, int num_ranks, hipStream_t stream) {
#define BARRIER_LAUNCH_CASE(ranks)                                                                 \
    LAUNCH_KERNEL(&cfg, barrier<ranks>, barrier_signal_ptrs, rank);                                \
Chenggang Zhao's avatar
Chenggang Zhao committed
22
23
    break

lijian6's avatar
lijian6 committed
24
    SETUP_LAUNCH_CONFIG(1, kWarpSize, stream);
Chenggang Zhao's avatar
Chenggang Zhao committed
25
26
27
28
29
30
31
32
    SWITCH_RANKS(BARRIER_LAUNCH_CASE);
#undef BARRIER_LAUNCH_CASE
}

} // namespace intranode

namespace internode {

lijian6's avatar
lijian6 committed
33
#ifndef DISABLE_ROCSHMEM
34
35
shmem_team_t        cpu_rdma_team = EP_SHMEM_TEAM_INVALID;
shmem_team_config_t cpu_rdma_team_config;
Chenggang Zhao's avatar
Chenggang Zhao committed
36
37

std::vector<uint8_t> get_unique_id() {
38
39
40
41
    shmemx_uniqueid_t unique_id;
    shmemx_get_uniqueid(&unique_id);
    std::vector<uint8_t> result(sizeof(shmemx_uniqueid_t));
    std::memcpy(result.data(), &unique_id, sizeof(shmemx_uniqueid_t));
Chenggang Zhao's avatar
Chenggang Zhao committed
42
43
44
    return result;
}

45
46
47
48
49
50
int init(const std::vector<uint8_t> &root_unique_id_val, int rank, int num_ranks, bool low_latency_mode) {
    shmemx_uniqueid_t  root_unique_id;
    shmemx_init_attr_t attr;
    std::memcpy(&root_unique_id, root_unique_id_val.data(), sizeof(shmemx_uniqueid_t));
    shmemx_set_attr_uniqueid_args(rank, num_ranks, &root_unique_id, &attr);
    shmemx_init_attr(EP_SHMEMX_INIT_WITH_UNIQUEID, &attr);
Chenggang Zhao's avatar
Chenggang Zhao committed
51
52
53
54

    // Create sub-RDMA teams
    // NOTES: if `num_ranks <= NUM_MAX_NVL_PEERS` then only low-latency kernels are used
    if (low_latency_mode and num_ranks > NUM_MAX_NVL_PEERS) {
55
56
        shmem_barrier_all();
        EP_HOST_ASSERT(cpu_rdma_team == EP_SHMEM_TEAM_INVALID);
Chenggang Zhao's avatar
Chenggang Zhao committed
57
        EP_HOST_ASSERT(num_ranks % NUM_MAX_NVL_PEERS == 0);
58
59
        EP_HOST_ASSERT(shmem_team_split_strided(
                               EP_SHMEM_TEAM_WORLD, rank % NUM_MAX_NVL_PEERS,
lijian6's avatar
lijian6 committed
60
61
                               NUM_MAX_NVL_PEERS, num_ranks / NUM_MAX_NVL_PEERS,
                               &cpu_rdma_team_config, 0, &cpu_rdma_team) == 0);
62
63
        EP_HOST_ASSERT(cpu_rdma_team != EP_SHMEM_TEAM_INVALID);

lijian6's avatar
lijian6 committed
64
65
66
#ifdef FORCE_DUSHMEM_API
        dushmemi_device_host_state_t* dev_state_ptr = nullptr;
        CUDA_CHECK(hipGetSymbolAddress(reinterpret_cast<void**>(&dev_state_ptr), dushmemi_device_state_d));
67
68
69
        bool ibgda_is_initialized = false;
        CUDA_CHECK(hipMemcpy(&dev_state_ptr->ibgda_is_initialized, &ibgda_is_initialized, sizeof(bool), hipMemcpyHostToDevice));
#endif
Chenggang Zhao's avatar
Chenggang Zhao committed
70
71
    }

72
73
    shmem_barrier_all();
    return shmem_my_pe();
Chenggang Zhao's avatar
Chenggang Zhao committed
74
75
}

lijian6's avatar
lijian6 committed
76
void *alloc(size_t size, size_t alignment) {
77
    return shmem_align(size, alignment);
Chenggang Zhao's avatar
Chenggang Zhao committed
78
79
}

lijian6's avatar
lijian6 committed
80
void free(void *ptr) {
81
    shmem_free(ptr);
Chenggang Zhao's avatar
Chenggang Zhao committed
82
83
84
}

void barrier() {
85
    shmem_barrier_all();
Chenggang Zhao's avatar
Chenggang Zhao committed
86
87
88
}

void finalize() {
89
90
91
    if (cpu_rdma_team != EP_SHMEM_TEAM_INVALID) {
        shmem_team_destroy(cpu_rdma_team);
        cpu_rdma_team = EP_SHMEM_TEAM_INVALID;
Chenggang Zhao's avatar
Chenggang Zhao committed
92
    }
93
    shmem_finalize();
Chenggang Zhao's avatar
Chenggang Zhao committed
94
}
95
#endif
Chenggang Zhao's avatar
Chenggang Zhao committed
96
97
98
99

} // namespace internode

} // namespace deep_ep