version.cpp 750 Bytes
Newer Older
limm's avatar
limm committed
1
#ifdef WITH_PYTHON
quyuanhao123's avatar
quyuanhao123 committed
2
#include <Python.h>
limm's avatar
limm committed
3
4
#endif

quyuanhao123's avatar
quyuanhao123 committed
5
#include <torch/script.h>
limm's avatar
limm committed
6
7
#include "scatter.h"
#include "macros.h"
quyuanhao123's avatar
quyuanhao123 committed
8

limm's avatar
limm committed
9
10
11
12
13
14
#ifdef WITH_CUDA
#ifdef USE_ROCM
#include <hip/hip_version.h>
#else
#include <cuda.h>
#endif
quyuanhao123's avatar
quyuanhao123 committed
15
16
17
#endif

#ifdef _WIN32
limm's avatar
limm committed
18
19
#ifdef WITH_PYTHON
#ifdef WITH_CUDA
quyuanhao123's avatar
quyuanhao123 committed
20
21
22
23
24
PyMODINIT_FUNC PyInit__version_cuda(void) { return NULL; }
#else
PyMODINIT_FUNC PyInit__version_cpu(void) { return NULL; }
#endif
#endif
limm's avatar
limm committed
25
#endif
quyuanhao123's avatar
quyuanhao123 committed
26

limm's avatar
limm committed
27
28
29
30
31
32
33
34
namespace scatter {
SCATTER_API int64_t cuda_version() noexcept {
#ifdef WITH_CUDA
#ifdef USE_ROCM
  return HIP_VERSION;
#else
  return CUDA_VERSION;
#endif
quyuanhao123's avatar
quyuanhao123 committed
35
36
37
38
#else
  return -1;
#endif
}
limm's avatar
limm committed
39
} // namespace scatter
quyuanhao123's avatar
quyuanhao123 committed
40

limm's avatar
limm committed
41
42
static auto registry = torch::RegisterOperators().op(
    "torch_scatter::cuda_version", [] { return scatter::cuda_version(); });