blob: 30971ce15f8baefef1105bfa926884feece078a9 (
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
|
# upstream git revision: 6c7254c3d0df797b3e1d6e2ef1b652765da48e67
source_pentium4=('config.pentium4')
source_i686=('config.i686')
source_i486=('config.i486')
# fail if upstream's .config changes
for ((i=0; i<${#sha256sums[@]}; i++)); do
if [ "${sha256sums[${i}]}" = 'f5d3635520c9eb9519629f6df0d9a58091ed4b1ea4ddb1acd5caf5822d91a060' ]; then
sha256sums_pentium4=('7f32ecf54b292b628e33f388a4284344af58dace881a08a63e3174336032523f')
sha256sums_i686=('2e2b94ac357bba826780362b5ebc4d971ee1f6c956660330e585068b695bfc6c')
sha256sums_i486=('937a4d846f2ebb9a9a11bf710f07168261120a07873e75074320d974dd43d946')
fi
done
# copy architecture specific config file, not default 'config'
eval "$(
declare -f prepare | \
sed '
s,\.\./config,../config.$CARCH,
'
)"
# patch architecture when copying the kernel Makefile
eval "$(
declare -f package_linux-headers | \
sed '
\,/tools/objtool" ,d
\,arch/x86/Makefile, {
a \
install -t "${builddir}/arch/x86" -m644 arch/x86/Makefile_32.cpu
}
'
)"
# use our tarballer instead of cloning from git
for ((i=0; i<${#source[@]}; i++)); do
infos=$(
printf '%s\n' "${source[${i}]}" | \
sed '
s@^\(\([^:]\+\)::\)\?\(git\|hg\)+\([^#?]\+\)\(?signed\)\?#\(\(tag\|commit\)=[^?]\+\)$@\3 \2 \4 \5 \6@
t
s@^\(\([^:]\+\)::\)\?\(git\|hg\)+\([^#?]\+\)#\(\(tag\|commit\)=[^?]\+\)\(?signed\)\?$@\3 \2 \4 \7 \5@
t
d
'
)
if [ -n "${infos}" ]; then
source[${i}]=$(
type="${infos%% *}"
infos="${infos#* }"
if [ -n "${infos%% *}" ]; then
prefix="${infos%% *}"
else
prefix=''
fi
infos="${infos#* }"
repo="${infos%% *}"
repo64=$(
printf '%s' "${repo}" | \
base64 -w0 | \
sed 's/=/%3D/g'
)
infos="${infos#* }"
if [ "${infos%% *}" = '?signed' ]; then
key_check=$(
printf '&valid_keys='
printf '%s,' "${validpgpkeys[@]}" | \
sed 's/,$//'
)
else
key_check=''
fi
infos="${infos#* }"
if [ -z "${prefix}" ]; then
prefix="${repo%.git}"
prefix="${prefix##*/}"
fi
prefix_64=$(
printf '%s/' "${prefix}" | \
base64 -w0 | \
sed 's/=/%3D/g'
)
printf '%s-%s.tar.gz::https://archive-server.archlinux32.org/?t=%s&p=%s&r=%s%s&%s\n' \
"${prefix}" \
"${pkgver}" \
"${type}" \
"${prefix_64}" \
"${repo64}" \
"${key_check}" \
"${infos}"
)
fi
done
# avoid using zstd compression in ultra mode (exhausts virtual memory)
source+=('core/linux/no-ultra-zstd.patch')
sha256sums+=('3997ce6033fdf950a9960f1db720b38c47b1a2e06ab75fc6712c154f596e7c47')
# upstream prepare() does already do the *.patch patching
|