blob: c68d2887fa89aee86f3c6869e6d5584c32eb4b34 (
plain)
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
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
|
- job:
name: tcwg-buildfarm
project-type: matrix
defaults: global
logrotate:
daysToKeep: 30
numToKeep: 30
properties:
- authorization:
anonymous:
- job-read
- job-extended-read
linaro:
- job-build
- job-cancel
parameters:
- string:
name: gcc_branch
default: 'latest'
description: 'GCC revision to build'
- string:
name: host_x86_64_languages
default: 'default'
description: 'Languages to build for x86_64-hosted toolchains, e.g., "c,c++" or "all" or "default"'
- string:
name: host_aarchXX_languages
default: 'c,c++'
description: 'Languages to build for AArchXX-hosted toolchains, e.g., "c,c++" or "all" or "default"'
- string:
name: runtests
default: 'x86_64-host'
description: 'Run toolchain testsuites: "yes", "no", "x86_64-host"'
- bool:
name: try_bootstrap
default: 'true'
description: 'Attempt to bootstrap GCC for compatible host and target combinations'
- string:
name: excludecheck
default: 'binutils gdb'
description: 'Do not run "make check" on these components'
- bool:
name: rebuild
default: true
description: 'Rebuild the toolchain even if results are already on logserver'
- string:
name: log_name
default: '${JOB_NAME}-${BUILD_NUMBER}/\$(uname -m).\$target'
description: 'Logname directory on logserver'
- bool:
name: dont_fail
default: false
description: 'Do not fail the build'
- string:
name: log_server
default: dev-01.tcwglab:/home/tcwg-buildslave/logs
description: 'Log_Server'
- string:
name: targets
default: 'cross_main cross_aux native_x86'
description: 'Which target toolchains to build: cross_main cross_aux native_x86 native_armv8'
- string:
name: abe_branch
default: refs/remotes/origin/stable
description: 'ABE revision to test'
disabled: false
node: tcwg-x86_64-cam
child-workspace: $target
concurrent: true
display-name: 'TCWG AAA BuildFarm'
scm:
- git:
url: https://git-us.linaro.org/toolchain/abe.git
refspec: +refs/changes/*:refs/remotes/changes/*
branches:
- $abe_branch
skip-tag: true
shallow-clone: true
wipe-workspace: true
axes:
- axis:
type: slave
name: label
values:
- tcwg-x86_64-cam
- tcwg-aarch64-build
- axis:
type: user-defined
name: target
values:
- aarch64-linux-gnu
- armv8l-linux-gnueabihf
- arm-linux-gnueabi
- arm-linux-gnueabihf
- armeb-linux-gnueabihf
- aarch64-none-elf
- aarch64_be-none-elf
- native
- schroot-i386-native
- schroot-armhf-native
execution-strategy:
combination-filter: |
(label=="tcwg-x86_64-cam" && target!="schroot-armhf-native") || (label=="tcwg-aarch64-build" && (target=="native" || target=="schroot-armhf-native"))
sequential: false
wrappers:
- timeout:
timeout: 600
- timestamps
- ssh-agent-credentials:
# tcwg-buildslave user id
users:
- 'e0958a95-204f-4c14-a66c-5e2be6c5d50a'
- build-name:
name: '#${BUILD_NUMBER}-${ENV,var="gcc_branch"}'
builders:
- shell: |
#!/bin/bash
set -e
set -x
case "$target--$(uname -m)" in
native--aarch64|schroot-armhf-native--*) target_kind=native_armv8 ;;
native--x86_64|schroot-i386-native--*) target_kind=native_x86 ;;
armeb-linux-gnueabihf--*|*-none-elf--*) target_kind=cross_aux ;;
*-linux-gnu*--*) target_kind=cross_main ;;
*) echo "ERROR: Cannot handle target: $target"; exit 1 ;;
esac
if ! echo "$targets" | grep -q "$target_kind"; then
echo "NOTE: Skipping target $target because $target_kind is not in list: $targets"
exit 0
fi
case ${target} in
schroot-*)
schroot_arch=$(echo ${target} | sed -e "s/^schroot-\([^-]*\)-\(.*\)/\1/")
target=$(echo ${target} | sed -e "s/^schroot-\([^-]*\)-\(.*\)/\2/")
;;
*)
case $(uname -m) in
x86_64) schroot_arch="amd64" ;;
aarch64) schroot_arch="arm64" ;;
*) echo "Unexpected architecture $(uname -m)"; exit 1 ;;
esac
;;
esac
schroot_image="tcwg-build-${schroot_arch}-trusty"
case $(uname -m) in
x86_64) languages="$host_x86_64_languages" ;;
*) languages="$host_aarchXX_languages" ;;
esac
case "$runtests-$(uname -m)" in
"yes"-*) runtests_opt="--runtests" ;;
"x86_64-host"-x86_64) runtests_opt="--runtests" ;;
*) runtests_opt="" ;;
esac
if $try_bootstrap; then
bootstrap="--bootstrap"
else
bootstrap=""
fi
if [ x"$log_name" != x"" ]; then
eval "logname_opt=\"--logname $log_name\""
fi
if $rebuild; then
norebuild=""
else
norebuild="--norebuild"
fi
excludecheck_opt=""
for testsuite in $excludecheck; do
excludecheck_opt="$excludecheck_opt --excludecheck $testsuite"
done
ulimit -u 5000
session_id=$(schroot -b -c chroot:$schroot_image --preserve-environment)
BUILD_SHELL="schroot -r -c session:$session_id --preserve-environment -- bash"
$BUILD_SHELL -c "echo \"Build session is up; ulimit config:\"; ulimit -a"
# Sometimes /dev/pts can't get unmounted on the first try.
# Workaround by retrying.
trap "{ schroot -f -e -c session:$session_id || { sleep 60 ; schroot -f -e -c session:$session_id; } }" 0
result="0"
${BUILD_SHELL} -x ./jenkins.sh --target ${target} --gcc-branch ${gcc_branch} --languages ${languages} $bootstrap $runtests_opt $excludecheck_opt --fileserver ex40-01.tcwglab.linaro.org/snapshots-ref --logserver $log_server $logname_opt $norebuild || result=$?
echo "Result of jenkins.sh: $result"
if $dont_fail; then
result="0"
fi
exit $result
|