forked from kdudka/predator
-
Notifications
You must be signed in to change notification settings - Fork 0
/
switch-host-llvm.sh
executable file
·82 lines (63 loc) · 2.66 KB
/
switch-host-llvm.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
#!/bin/bash
export SELF="$0"
export LC_ALL=C
die() {
printf "%s: %s\n" "$SELF" "$*" >&2
exit 1
}
usage() {
printf "Usage: %s LLVM_DIR\n" "$SELF" >&2
cat >&2 << EOF
Use this script to (re)build Predator and/or Forester against an arbitrary
build of host Clang/LLVM. The host Clang/LLVM needs library and header files
for develop native programs that use the LLVM infrastructure. The currently
supported version of host Clang/LLVM is 10.0.0 but Predator can be loaded also
into older versions of LLVM (3.5+, but correct output is guaranteed form 4).
LLVM_DIR is the absolute path to the folder where LLVMConfig.cmake is found.
Can be found using the command 'llvm-config –cmakedir'. The most common
location is /usr/lib/cmake/llvm or /usr/local/share/llvm/cmake.
If you have multiple versions of Clang/LLVM installed on the system, it can
be something like /usr/lib/cmake/llvm-10.0.0. You can also provide a local build,
e.g. <INSTALL_PREFIX>/lib<LIB_SUFFIX>/cmake/llvm.
On some Linux distributions you need to install an optional package (e.g.
llvm-devel on Fedora) in order to be able to build LLVM pass.
EOF
exit 1
}
test 1 = "$#" || usage
status_update() {
printf "\n%s...\n\n" "$*"
tty >/dev/null && printf "\033]0;%s\a" "$*"
}
# number of processor units
NCPU="$(getconf _NPROCESSORS_ONLN 2>/dev/null || echo 1)"
MAKE="make -j${NCPU}"
# check the given LLVM_DIR
LLVM_DIR="$1"
test "/" == "${LLVM_DIR:0:1}" \
|| die "LLVM_DIR is not an absolute path: $LLVM_DIR"
test -r "$LLVM_DIR/LLVMConfig.cmake" \
|| die "LLVM_DIR is not an absolute path to an readable file: $LLVM_DIR/LLVMConfig.cmake"
status_update "Trying to build Code Listener"
$MAKE -C cl CMAKE="cmake -D LLVM_DIR='$LLVM_DIR' -D ENABLE_LLVM=ON" \
|| die "failed to build Code Listener"
status_update "Checking whether Code Listener works"
#$MAKE -C cl check CMAKE="cmake -D ENABLE_LLVM=ON" \
# || die "Code Listener does not work"
status_update "System hopes yes"
status_update "Traying to build LLVM passes"
$MAKE build_passes CMAKE="cmake -D LLVM_DIR='$LLVM_DIR'" \
|| die "failed to build LLVM passes"
build_analyzer() {
test -d $1 || return 0
status_update "Nuking working directory"
$MAKE -C $1 distclean || die "'$MAKE -C $1 distclean' has failed"
status_update "Trying to build $2"
$MAKE -C $1 CMAKE="cmake -D LLVM_DIR='$LLVM_DIR' -D ENABLE_LLVM=ON" \
|| return $?
status_update "Checking whether $2 works"
$MAKE -C $1 check CMAKE="cmake -D ENABLE_LLVM=ON" CTEST="ctest -j${NCPU}"
}
# apply patch
patch -p1 < build-aux/llvm.patch
build_analyzer sl Predator || exit $?