-
Notifications
You must be signed in to change notification settings - Fork 20
/
Copy pathbuild.sh
executable file
·150 lines (133 loc) · 4.42 KB
/
build.sh
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
set -x
clean="OFF"
# with_platform, to support cuda/x86/arm build
with_platform="${AS_PLATFORM:-cuda}"
# cuda related version, provide a defualt value for cuda 11.4
cuda_version="${AS_CUDA_VERSION:-12.4}"
cuda_sm="${AS_CUDA_SM:-80;86;90a}"
NCCL_VERSION="${AS_NCCL_VERSION:-2.23.4}"
build_folder="${AS_BUILD_FOLDER:-build}"
## NCCL Version Map:
## the corresponding pre-build nccl will download on oss.
# | CUDA Version | NCCL Version |
# | 10.2, 11.8 | 2.15.5 |
# | 11.[3,4,6],12.1 | 2.11.4 |
# | 12.2 | 2.21.5 |
# | 12.4 | 2.23.4 |
system_nv_lib="${AS_SYSTEM_NV_LIB:-OFF}"
build_type="${AS_BUILD_TYPE:-Release}"
cuda_static="${AS_CUDA_STATIC:-OFF}"
build_package="${AS_BUILD_PACKAGE:-ON}"
enable_glibcxx11_abi="${AS_CXX11_ABI:-OFF}"
build_hiednn="${AS_BUILD_HIEDNN:-ON}"
enable_span_attn="${ENABLE_SPAN_ATTENTION:-ON}"
enable_multinuma="${ENABLE_MULTINUMA:-OFF}"
function clone_pull {
GIT_URL=$1
DIRECTORY=$2
GIT_COMMIT=$3
if [ -d "$DIRECTORY" ]; then
pushd "$DIRECTORY"
git remote update
popd
else
git clone "$GIT_URL" "$DIRECTORY"
fi
pushd "$DIRECTORY"
git reset --hard "$GIT_COMMIT"
popd
}
if [ "$clean" == "ON" ]; then
rm -rf ${build_folder}
fi
if [ ! -d "./${build_folder}" ]; then
mkdir ${build_folder} && cd ${build_folder}
conan profile new dashinfer_compiler_profile --detect --force
conanfile=../conan/conanfile.txt
if [ "${enable_multinuma}" == "ON" ]; then
conanfile=../conan/conanfile_openmpi.txt
fi
if [ "${with_platform,,}" == "armclang" ]; then
conanfile=../conan/conanfile_arm.txt
if [ "${enable_multinuma}" == "ON" ]; then
conanfile=../conan/conanfile_openmpi_arm.txt
fi
cp -f ../conan/conanprofile_armclang.aarch64 ~/.conan/profiles/dashinfer_compiler_profile
cp -r ../conan/settings_arm.yml ~/.conan/settings.yml
fi
if [ "$enable_glibcxx11_abi" == "ON" ]; then
conan profile update settings.compiler.libcxx=libstdc++11 dashinfer_compiler_profile
else
conan profile update settings.compiler.libcxx=libstdc++ dashinfer_compiler_profile
fi
conan install ${conanfile} -pr dashinfer_compiler_profile -b missing -b protobuf -b gtest -b glog
cd ../
fi
cd ${build_folder}
source ./activate.sh
export PATH=`pwd`/bin:$PATH
if [ "${with_platform,,}" == "cuda" ]; then
cmake .. \
-DCMAKE_BUILD_TYPE=${build_type} \
-DBUILD_PACKAGE=${build_package} \
-DCONFIG_ACCELERATOR_TYPE=CUDA \
-DCONFIG_HOST_CPU_TYPE=X86 \
-DNCCL_VERSION=${NCCL_VERSION} \
-DCUDA_VERSION=${cuda_version} \
-DCMAKE_CUDA_ARCHITECTURES="${cuda_sm}" \
-DUSE_SYSTEM_NV_LIB=${system_nv_lib} \
-DCMAKE_EXPORT_COMPILE_COMMANDS=ON \
-DENABLE_NV_STATIC_LIB=${cuda_static} \
-DENABLE_GLIBCXX11_ABI=${enable_glibcxx11_abi} \
-DBUILD_PYTHON=OFF \
-DALWAYS_READ_LOAD_MODEL=OFF \
-DENABLE_SPAN_ATTENTION=${enable_span_attn} \
-DBUILD_HIEDNN=${build_hiednn} \
-DENABLE_MULTINUMA=OFF
elif [ "${with_platform,,}" == "x86" ]; then
cmake .. \
-DCMAKE_BUILD_TYPE=${build_type} \
-DBUILD_PACKAGE=${build_package} \
-DCONFIG_ACCELERATOR_TYPE=NONE \
-DCONFIG_HOST_CPU_TYPE=X86 \
-DENABLE_GLIBCXX11_ABI=${enable_glibcxx11_abi} \
-DBUILD_PYTHON=OFF \
-DALLSPARK_CBLAS=MKL \
-DENABLE_CUDA=OFF \
-DENABLE_SPAN_ATTENTION=OFF \
-DALWAYS_READ_LOAD_MODEL=ON \
-DENABLE_MULTINUMA=${enable_multinuma}
elif [ "${with_platform,,}" == "armclang" ]; then
cmake .. \
-DCMAKE_BUILD_TYPE=${build_type} \
-DBUILD_PACKAGE=${build_package} \
-DCONFIG_ACCELERATOR_TYPE=NONE \
-DCONFIG_HOST_CPU_TYPE=ARM \
-DENABLE_BLADE_AUTH=${enable_blade_auth} \
-DENABLE_GLIBCXX11_ABI=${enable_glibcxx11_abi} \
-DBUILD_PYTHON=OFF \
-DCMAKE_EXPORT_COMPILE_COMMANDS=ON \
-DENABLE_ARMCL=ON \
-DALLSPARK_CBLAS=BLIS \
-DENABLE_CUDA=OFF \
-DENABLE_AVX2=OFF \
-DENABLE_AVX512=OFF \
-DENABLE_ARM_V84_V9=ON \
-DENABLE_BF16=ON \
-DENABLE_FP16=ON \
-DCMAKE_C_COMPILER=armclang \
-DCMAKE_CXX_COMPILER=armclang++ \
-DENABLE_SPAN_ATTENTION=OFF \
-DALWAYS_READ_LOAD_MODEL=ON \
-DENABLE_MULTINUMA=${enable_multinuma}
fi
# do the make and package.
# VERBOSE=1 make && make install
make -j16 && make install
if [ $? -eq 0 ]; then
if [ ${build_package} == "ON" ]; then
make package
fi
else
exit $?
fi