build.sh 2 KB
Newer Older
1
2
3
4
5
6
7
8
9
10
11
12
13
14
#!/bin/bash
# Helper script to build graphbolt libraries for PyTorch
set -e

mkdir -p build
mkdir -p $BINDIR/graphbolt
cd build

if [ $(uname) = 'Darwin' ]; then
  CPSOURCE=*.dylib
else
  CPSOURCE=*.so
fi

15
16
17
18
# We build for the same architectures as DGL, thus we hardcode
# TORCH_CUDA_ARCH_LIST and we need to at least compile for Volta. Until
# https://github.com/NVIDIA/cccl/issues/1083 is resolved, we need to compile the
# cuda/extension folder with Volta+ CUDA architectures.
19
20
21
22
23
24
25
26
27
28
29
30
31
32
#TORCH_CUDA_ARCH_LIST="Volta"
#if ! [[ -z "${CUDAARCHS}" ]]; then
#  # The architecture list is passed as an environment variable, we set
#  # TORCH_CUDA_ARCH_LIST to the latest architecture.
#  CUDAARCHSARR=(${CUDAARCHS//;/ })
#  LAST_ARCHITECTURE=${CUDAARCHSARR[-1]}
#  # TORCH_CUDA_ARCH_LIST has to be at least 70 to override Volta default.
#  if (( $LAST_ARCHITECTURE >= 70 )); then
#    # Convert "75" to "7.5".
#    TORCH_CUDA_ARCH_LIST=${LAST_ARCHITECTURE:0:-1}'.'${LAST_ARCHITECTURE: -1}
#  fi
#fi
#CMAKE_FLAGS="-DCUDA_TOOLKIT_ROOT_DIR=$CUDA_TOOLKIT_ROOT_DIR -DUSE_CUDA=$USE_CUDA -DGPU_CACHE_BUILD_DIR=$BINDIR -DTORCH_CUDA_ARCH_LIST=$TORCH_CUDA_ARCH_LIST"
CMAKE_FLAGS=" -DUSE_HIP=$USE_HIP -DGPU_CACHE_BUILD_DIR=$BINDIR "
33
34
echo $CMAKE_FLAGS

sangwzh's avatar
sangwzh committed
35
36
37
38
39
40
41
# add new hipcub
# export C_INCLUDE_PATH=/opt/dgl_dep/hipcub-install-0915/include/:$C_INCLUDE_PATH
# export CPLUS_INCLUDE_PATH=/opt/dgl_dep/hipcub-install-0915/include/:$C_INCLUDE_PATH

# export C_INCLUDE_PATH=/opt/dgl_dep/rocprim-install-0915/include/:$C_INCLUDE_PATH
# export CPLUS_INCLUDE_PATH=/opt/dgl_dep/rocprim-install-0915/include/:$C_INCLUDE_PATH

42
if [ $# -eq 0 ]; then
sangwzh's avatar
sangwzh committed
43
44
  CC=hipcc CXX=hipcc $CMAKE_COMMAND $CMAKE_FLAGS ..
  make -j VERBOSE=1
45
46
47
48
49
50
  cp -v $CPSOURCE $BINDIR/graphbolt
else
  for PYTHON_INTERP in $@; do
    TORCH_VER=$($PYTHON_INTERP -c 'import torch; print(torch.__version__.split("+")[0])')
    mkdir -p $TORCH_VER
    cd $TORCH_VER
sangwzh's avatar
sangwzh committed
51
52
    CC=hipcc CXX=hipcc $CMAKE_COMMAND $CMAKE_FLAGS -DPYTHON_INTERP=$PYTHON_INTERP ../..
    make -j VERBOSE=1
53
54
55
56
    cp -v $CPSOURCE $BINDIR/graphbolt
    cd ..
  done
fi