-
Notifications
You must be signed in to change notification settings - Fork 26
/
Copy pathbuild.sh
executable file
·120 lines (106 loc) · 3.58 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
#!/bin/bash
#
# Copyright (C) National University of Singapore
#
# This program is free software: you can redistribute it and/or modify
# it under the terms of the GNU General Public License as published by
# the Free Software Foundation, either version 3 of the License, or
# (at your option) any later version.
#
# This program is distributed in the hope that it will be useful,
# but WITHOUT ANY WARRANTY; without even the implied warranty of
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
# GNU General Public License for more details.
#
# You should have received a copy of the GNU General Public License
# along with this program. If not, see <http://www.gnu.org/licenses/>.
if [ -t 1 ]
then
RED="\033[31m"
GREEN="\033[32m"
YELLOW="\033[33m"
BOLD="\033[1m"
OFF="\033[0m"
else
RED=
GREEN=
YELLOW=
BOLD=
OFF=
fi
set -e
VERSION=70d605e039054ae12ebb9a7d688a5a0d1dcc50ca
# STEP (1): install e9patch if necessary:
if [ "`readlink e9patch`" != "e9patch-$VERSION/e9patch" ]
then
if [ ! -f e9patch-$VERSION.zip ]
then
echo -e "${GREEN}$0${OFF}: downloading e9patch-$VERSION.zip..."
wget -O e9patch-$VERSION.zip \
https://github.com/GJDuck/e9patch/archive/$VERSION.zip
fi
echo -e "${GREEN}$0${OFF}: extracting e9patch-$VERSION.zip..."
unzip e9patch-$VERSION.zip
echo -e "${GREEN}$0${OFF}: building e9patch..."
cd e9patch-$VERSION
./build.sh
cd ..
ln -f -s e9patch-$VERSION/e9patch
ln -f -s e9patch-$VERSION/e9tool
ln -f -s e9patch-$VERSION/e9compile.sh
ln -f -s e9patch-$VERSION/examples/stdlib.c
ln -f -s e9patch-$VERSION/src/e9tool/e9plugin.h
ln -f -s e9patch-$VERSION/src/e9tool/e9tool.h
echo -e "${GREEN}$0${OFF}: e9patch has been built..."
else
echo -e "${GREEN}$0${OFF}: using existing e9patch..."
fi
# STEP (2): build the hook code:
echo -e "${GREEN}$0${OFF}: building hook ($HOOK)..."
if [ "$LIBC" = "" ]
then
LIBC="$(g++ --print-file-name=libc.so.6)"
fi
./e9compile.sh rr_main.cpp -std=c++11 -O2 -I "$PWD"
g++ rr_main.o -o rr_main -pie -nostdlib -Wl,-z -Wl,max-page-size=4096 \
-Wl,-z -Wl,norelro -Wl,-z -Wl,stack-size=0 -Wl,--export-dynamic -Wl,--entry=0x0
# STEP (3): patch libc:
echo -e "${GREEN}$0${OFF}: patching libc ($LIBC)..."
mkdir -p lib/
echo "./e9tool -M 'asm=\"syscall\"' -P 'replace entry(state)@rr_main' "$LIBC" -o "lib/libc.so.6""
./e9tool -CFR \
-M 'asm="syscall"' \
-P 'replace entry(state)@rr_main' \
-M 'asm="rdtsc"' \
-P 'replace rdtsc_hook(state)@rr_main' \
-M 'asm="rdtscp"' \
-P 'replace rdtscp_hook(state)@rr_main' \
-M 'addr=&"abort"' \
-P 'replace abort_hook(%rsp)@rr_main' \
-M 'addr=&"__assert"' \
-P 'assert_hook(%rsp)@rr_main' \
-M 'addr=&"__assert_fail"' \
-P 'assert_hook(%rsp)@rr_main' \
-M 'addr=&"__assert_perror_fail"' \
-P 'assert_hook(%rsp)@rr_main' \
"$LIBC" -o "lib/libc.so.6" | tee "build.log"
# STEP (4): compile env-fuzz:
echo -e "${GREEN}$0${OFF}: building env-fuzz..."
make env-fuzz
# STEP (5): compile extra objects
echo -e "${GREEN}$0${OFF}: building rrCovPlugin.so..."
make rrCovPlugin.so
echo -e "${GREEN}$0${OFF}: building rezzan.so..."
make rezzan
echo -e "${GREEN}$0${OFF}: done!"
echo
echo -e "${YELLOW} _____ _____ "
echo -e "| ____|_ ____ _| ___| _ ________"
echo -e "| _| | '_ \ \ / / |_ | | | |_ /_ /"
echo -e "| |___| | | \ V /| _|| |_| |/ / / / "
echo -e "|_____|_| |_|\_/ |_| \__,_/___/___|${OFF}"
echo
echo "To use, run the following command:"
echo
echo " env-fuzz (record|replay|fuzz) [OPTION] -- PROGRAM [ARG ...]"
echo