blob: 7cc82d5bd6daeba04bdf7da83a84ec9a55b0a22d (
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
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
|
#!/bin/bash
selected=
usage()
{
cat <<EOF
$0 -- Test packages in crosstool-NG
Verifies that the release tarballs can be downloaded for the packages
available in crosstoo-NG and check that the patches apply cleanly.
Requires crosstool-NG to be configured and built prior to running.
Options:
--help, -?
Display this help message.
--download, -d
Download all packages to the default directory (\$HOME/src).
--digest, -D
Create digests (MD5/SHA-1/...) for all package archives.
--apply-patches, -a
Implies -d. Unpack and apply the bundled patches.
--verify-urls, -u
Check *all* the download URLs for accessibility, without
actually downloading anything.
--select MASK, -s MASK
Specify the package to operate upon. MASK can be either package
name ("-s foo"), or package name + version ("-s foo-1.1").
--signature, -S
When downloading archives (because of any of -D/-d/-u options),
also download/verify signatures.
EOF
}
while [ -n "${1}" ]; do
case "${1}" in
--download|-d)
download_pkgs=y
;;
--digest|-D)
create_digests=y
;;
--verify-urls|-u)
verify_urls=y
;;
--apply-patches|-a)
apply_patches=y
download_pkgs=y
;;
--select|-s)
shift
[ -n "${1}" ] || { echo "argument required for --select" >&2; exit 1; }
selected="${1}"
;;
--signature|-S)
signature=y
;;
--help|-?)
usage
exit 0
;;
*)
echo "Unknown option ${1}" >&2
exit 1
;;
esac
shift
done
if [ -z "${download_pkgs}${create_digests}${verify_urls}" ]; then
echo "No action selected" >&2
exit 1
fi
CT_LIB_DIR=`pwd`
CT_TOP_DIR=`pwd`
CT_TARBALLS_DIR=`pwd`/temp.tarballs
CT_COMMON_SRC_DIR=`pwd`/temp.src
CT_SRC_DIR=`pwd`/temp.src
CT_LOG_LEVEL_MAX=EXTRA
mkdir -p ${CT_TARBALLS_DIR}
# Does not matter, just to make the scripts load
CT_ARCH=arm
CT_KERNEL=bare-metal
CT_BINUTILS=binutils
CT_LIBC=none
CT_CC=gcc
. paths.sh
. scripts/functions
rm -f build.log
CT_LogEnable
check_pkg_urls()
{
local e m mh url
for e in ${archive_formats}; do
local -A mirror_status=( )
CT_DoStep EXTRA "Looking for ${archive_filename}${e}"
for m in ${mirrors}; do
url="${m}/${archive_filename}${e}"
case "${url}" in
# WGET always returns success for FTP URLs in spider mode :(
ftp://*) CT_DoLog DEBUG "Skipping '${url}': FTP not supported"; continue;;
esac
mh="${url#*://}"
mh="${mh%%[:/]*}"
if [ -n "${mirror_status[${mh}]}" ]; then
CT_DoLog DEBUG "Skipping '${url}': already found on this host at '${mirror_status[${mh}]}'"
continue
fi
if CT_DoExecLog ALL wget --spider "${url}"; then
mirror_status[${mh}]="${url}"
else
mirror_status[${mh}]=
fi
done
for mh in "${!mirror_status[@]}"; do
if [ -n "${mirror_status[${mh}]}" ]; then
CT_DoLog EXTRA "OK ${mh} [${archive_filename}${e}]"
else
CT_DoLog ERROR "FAIL ${mh} [${archive_filename}${e}]"
fi
done
CT_EndStep
done
}
create_digests()
{
local e m url alg chksum
local save_archive_formats="${archive_formats}"
# Remove stale digests - we'll create them anew below
CT_DoExecLog ALL rm -f "${CT_LIB_DIR}/packages/${pkg_name}/${version}/chksum"
for e in ${save_archive_formats}; do
CT_DoStep EXTRA "Downloading ${archive_filename}${e}"
archive_formats="${e}"
CT_DoFetch
CT_Pushd "${CT_LOCAL_TARBALLS_DIR}"
for alg in md5 sha1 sha256 sha512; do
CT_DoLog EXTRA "Creating ${alg^^} digest for ${archive_filename}${e}"
chksum=`${alg}sum "${archive_filename}${e}"`
if [ "$?" != 0 ]; then
CT_DoExecLog ALL rm -f "${CT_LIB_DIR}/packages/${pkg_name}/${version}/chksum"
CT_Abort "${alg}sum failed"
fi
echo "${alg} ${archive_filename}${e} ${chksum%%[[:space:]]*}" >> \
"${CT_LIB_DIR}/packages/${pkg_name}/${version}/chksum"
done
CT_Popd
CT_EndStep
done
archive_formats="${save_archive_formats}"
}
run_pkgversion()
{
while [ -n "${1}" ]; do
eval "local ${1}"
shift
done
if [ -n "${selected}" ]; then
case "${selected}" in
${pkg_name}|${pkg_name}-${ver})
;;
*)
return
;;
esac
fi
CT_DoStep INFO "Handling ${pkg_name}-${ver}"
# Create a temporary configuration head file
cat >temp.in <<EOF
config OBSOLETE
def_bool y
config EXPERIMENTAL
def_bool y
config CONFIGURE_has_wget
def_bool y
config CONFIGURE_has_curl
def_bool y
config ${versionlocked}_V_${kcfg}
def_bool y
source "config/global/paths.in"
source "config/global/download.in"
source "config/global/extract.in"
source "config/versions/${master}.in"
EOF
cat >temp.defconfig <<EOF
CT_${masterpfx}_USE_${originpfx}=y
CT_${pfx}_SRC_RELEASE=y
CT_${pfx}_V_${kcfg}=y
CT_SAVE_TARBALLS=y
# CT_VERIFY_DOWNLOAD_DIGEST is not set
${signature+CT_VERIFY_DOWNLOAD_SIGNATURE=y}
EOF
./kconfig/conf --defconfig=temp.defconfig temp.in >/dev/null
CT_LoadConfig
rm -f .config .config.old temp.defconfig temp.in
if [ -n "${verify_urls}" ]; then
CT_DoLog EXTRA "Verifying URLs for ${pkg_name}-${ver}"
CT_PackageRun "${masterpfx}" check_pkg_urls
fi
if [ -n "${create_digests}" ]; then
CT_DoLog EXTRA "Creating digests for ${pkg_name}-${ver}"
CT_PackageRun "${masterpfx}" create_digests
fi
if [ -n "${download_pkgs}" ]; then
CT_DoLog EXTRA "Downloading ${pkg_name}-${ver}"
CT_Fetch "${masterpfx}"
fi
if [ -n "${apply_patches}" ]; then
rm -rf ${CT_COMMON_SRC_DIR}
mkdir -p ${CT_COMMON_SRC_DIR}
CT_ExtractPatch "${masterpfx}"
fi
CT_EndStep
}
[ -r .config ] && mv .config .config-saved
. maintainer/package-versions
[ -r .config-saved ] && mv .config-saved .config
rm -rf ${CT_TARBALLS_DIR} ${CT_COMMON_SRC_DIR}
|