annotate libsanitizer/merge.sh @ 144:8f4e72ab4e11

fix segmentation fault caused by nothing next cur_op to end
author Takahiro SHIMIZU <anatofuz@cr.ie.u-ryukyu.ac.jp>
date Sun, 23 Dec 2018 21:23:56 +0900
parents 04ced10e8804
children 1830386684a0
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
111
kono
parents:
diff changeset
1 #!/bin/bash
kono
parents:
diff changeset
2
kono
parents:
diff changeset
3 # FIXME: do we need a license (or whatever else) header here?
kono
parents:
diff changeset
4
kono
parents:
diff changeset
5 # This script merges libsanitizer sources from upstream.
kono
parents:
diff changeset
6
kono
parents:
diff changeset
7 get_upstream() {
kono
parents:
diff changeset
8 rm -rf upstream
kono
parents:
diff changeset
9 #cp -rf orig upstream
kono
parents:
diff changeset
10 svn co http://llvm.org/svn/llvm-project/compiler-rt/trunk upstream
kono
parents:
diff changeset
11 }
kono
parents:
diff changeset
12
kono
parents:
diff changeset
13 get_current_rev() {
kono
parents:
diff changeset
14 cd upstream
kono
parents:
diff changeset
15 svn info | grep Revision | grep -o '[0-9]*'
kono
parents:
diff changeset
16 }
kono
parents:
diff changeset
17
kono
parents:
diff changeset
18 list_files() {
kono
parents:
diff changeset
19 (cd $1; ls *.{cc,h,inc,S} 2> /dev/null)
kono
parents:
diff changeset
20
kono
parents:
diff changeset
21 }
kono
parents:
diff changeset
22
kono
parents:
diff changeset
23 change_comment_headers() {
kono
parents:
diff changeset
24 for f in $(list_files $1); do
kono
parents:
diff changeset
25 sed -n 3p $1/$f | grep -q 'The LLVM Compiler Infrastructure' || continue
kono
parents:
diff changeset
26 changed=$(awk 'NR != 2 && NR != 3' < $1/$f)
kono
parents:
diff changeset
27 echo "$changed" > $1/$f
kono
parents:
diff changeset
28 done
kono
parents:
diff changeset
29 }
kono
parents:
diff changeset
30
kono
parents:
diff changeset
31 # ARGUMENTS: upstream_path local_path
kono
parents:
diff changeset
32 # This function merges changes from the directory upstream_path to
kono
parents:
diff changeset
33 # the directory local_path.
kono
parents:
diff changeset
34 merge() {
kono
parents:
diff changeset
35 upstream_path=upstream/$1
kono
parents:
diff changeset
36 local_path=$2
kono
parents:
diff changeset
37 change_comment_headers $upstream_path
kono
parents:
diff changeset
38 echo MERGE: $upstream_path
kono
parents:
diff changeset
39 all=$( (list_files $upstream_path; list_files $local_path) | sort | uniq)
kono
parents:
diff changeset
40 #echo $all
kono
parents:
diff changeset
41 for f in $all; do
kono
parents:
diff changeset
42 if [ -f $upstream_path/$f -a -f $local_path/$f ]; then
kono
parents:
diff changeset
43 echo "FOUND IN BOTH :" $f
kono
parents:
diff changeset
44 # diff -u $local_path/$f $upstream_path/$f
kono
parents:
diff changeset
45 cp -v $upstream_path/$f $local_path
kono
parents:
diff changeset
46 elif [ -f $upstream_path/$f ]; then
kono
parents:
diff changeset
47 echo "FOUND IN UPSTREAM :" $f
kono
parents:
diff changeset
48 cp -v $upstream_path/$f $local_path
kono
parents:
diff changeset
49 svn add $local_path/$f
kono
parents:
diff changeset
50 elif [ -f $local_path/$f ]; then
kono
parents:
diff changeset
51 echo "FOUND IN LOCAL :" $f
kono
parents:
diff changeset
52 svn remove $local_path/$f
kono
parents:
diff changeset
53 fi
kono
parents:
diff changeset
54 done
kono
parents:
diff changeset
55
kono
parents:
diff changeset
56 }
kono
parents:
diff changeset
57
kono
parents:
diff changeset
58 fatal() {
kono
parents:
diff changeset
59 echo "$1"
kono
parents:
diff changeset
60 exit 1;
kono
parents:
diff changeset
61 }
kono
parents:
diff changeset
62
kono
parents:
diff changeset
63 pwd | grep 'libsanitizer$' || \
kono
parents:
diff changeset
64 fatal "Run this script from libsanitizer dir"
kono
parents:
diff changeset
65 get_upstream
kono
parents:
diff changeset
66 CUR_REV=$(get_current_rev)
kono
parents:
diff changeset
67 echo Current upstream revision: $CUR_REV
kono
parents:
diff changeset
68 merge include/sanitizer include/sanitizer
kono
parents:
diff changeset
69 merge lib/asan asan
kono
parents:
diff changeset
70 merge lib/lsan lsan
kono
parents:
diff changeset
71 merge lib/tsan/rtl tsan
kono
parents:
diff changeset
72 merge lib/sanitizer_common sanitizer_common
kono
parents:
diff changeset
73 merge lib/interception interception
kono
parents:
diff changeset
74 merge lib/ubsan ubsan
kono
parents:
diff changeset
75
kono
parents:
diff changeset
76 # Need to merge lib/builtins/assembly.h file:
kono
parents:
diff changeset
77 mkdir -p builtins
kono
parents:
diff changeset
78 cp -v upstream/lib/builtins/assembly.h builtins/assembly.h
kono
parents:
diff changeset
79
kono
parents:
diff changeset
80 rm -rf upstream
kono
parents:
diff changeset
81
kono
parents:
diff changeset
82 # Update the MERGE file.
kono
parents:
diff changeset
83 cat << EOF > MERGE
kono
parents:
diff changeset
84 $CUR_REV
kono
parents:
diff changeset
85
kono
parents:
diff changeset
86 The first line of this file holds the svn revision number of the
kono
parents:
diff changeset
87 last merge done from the master library sources.
kono
parents:
diff changeset
88 EOF