blob: 4fe88f408b0ea35fd84601456509cfcd30bbfd6c (
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
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
339
340
341
342
|
# Maintainer: Natanael Copa <ncopa@alpinelinux.org>
pkgname=qemu
pkgver=2.1.3
pkgrel=3
pkgdesc="QEMU is a generic machine emulator and virtualizer"
url="http://qemu.org/"
arch="all"
license="GPL-2 LGPL-2"
makedepends="zlib-dev alsa-lib-dev gnutls-dev ncurses-dev glib-dev
libjpeg-turbo-dev libpng-dev vde2-dev spice-dev paxctl curl-dev
libcap-dev libcap-ng-dev libaio-dev usbredir-dev util-linux-dev
libusb-dev flex bison linux-headers"
depends=
install="qemu.pre-install"
subpackages="
$pkgname-aarch64:aarch64
$pkgname-alpha:alpha
$pkgname-arm:arm
$pkgname-armeb:armeb
$pkgname-cris:cris
$pkgname-i386:i386
$pkgname-m68k:m68k
$pkgname-microblaze:microblaze
$pkgname-microblazeel:microblazeel
$pkgname-mips:mips
$pkgname-mips64:mips64
$pkgname-mips64el:mips64el
$pkgname-mipsel:mipsel
$pkgname-mipsn32:mipsn32
$pkgname-mipsn32el:mipsn32el
$pkgname-or32:or32
$pkgname-ppc:ppc
$pkgname-ppc64:ppc64
$pkgname-ppc64abi32:ppc64abi32
$pkgname-ppc64le:ppc64le
$pkgname-s390x:s390x
$pkgname-sh4:sh4
$pkgname-sh4eb:sh4eb
$pkgname-sparc:sparc
$pkgname-sparc32plus:sparc32plus
$pkgname-sparc64:sparc64
$pkgname-system-aarch64:system_aarch64
$pkgname-system-alpha:system_alpha
$pkgname-system-arm:system_arm
$pkgname-system-cris:system_cris
$pkgname-system-i386:system_i386
$pkgname-system-lm32:system_lm32
$pkgname-system-m68k:system_m68k
$pkgname-system-microblaze:system_microblaze
$pkgname-system-microblazeel:system_microblazeel
$pkgname-system-mips:system_mips
$pkgname-system-mips64:system_mips64
$pkgname-system-mips64el:system_mips64el
$pkgname-system-mipsel:system_mipsel
$pkgname-system-moxie:system_moxie
$pkgname-system-or32:system_or32
$pkgname-system-ppc:system_ppc
$pkgname-system-ppc64:system_ppc64
$pkgname-system-ppcemb:system_ppcemb
$pkgname-system-s390x:system_s390x
$pkgname-system-sh4:system_sh4
$pkgname-system-sh4eb:system_sh4eb
$pkgname-system-sparc:system_sparc
$pkgname-system-sparc64:system_sparc64
$pkgname-system-unicore32:system_unicore32
$pkgname-system-x86_64:system_x86_64
$pkgname-system-xtensa:system_xtensa
$pkgname-system-xtensaeb:system_xtensaeb
$pkgname-unicore32:unicore32
$pkgname-x86_64:x86_64
$pkgname-img
$pkgname-guest-agent:guest
"
source="http://wiki.qemu-project.org/download/qemu-$pkgver.tar.bz2
0001-elfload-load-PIE-executables-to-right-address.patch
0006-linux-user-signal.c-define-__SIGRTMIN-MAX-for-non-GN.patch
musl-F_SHLCK-and-F_EXLCK.patch
CVE-2014-8106.patch
CVE-2014-9718.patch
CVE-2015-1779.patch
CVE-2015-3456.patch
CVE-2015-4037.patch
CVE-2015-5154.patch
CVE-2015-5165.1.patch
CVE-2015-5165.2.patch
CVE-2015-5165.3.patch
CVE-2015-5165.4.patch
CVE-2015-5165.5.patch
CVE-2015-5165.6.patch
CVE-2015-5165.7.patch
CVE-2015-5225.patch
CVE-2015-5278.patch
CVE-2015-5279.patch
CVE-2015-6815.patch
qemu-guest-agent.confd
qemu-guest-agent.initd
80-kvm.rules"
prepare() {
cd "$srcdir"/$pkgname-$pkgver
for i in $source; do
case $i in
*.patch) msg $i; patch -p1 -i "$srcdir"/$i || return 1;;
esac
done
# avoid fdt till an updated release appears
sed -i -e 's:fdt="yes":fdt="no":' configure
# prevent docs to get automatically installed
sed -i '/$(DESTDIR)$(docdir)/d' Makefile
# Alter target makefiles to accept CFLAGS
sed -i 's/^\(C\|OP_C\|HELPER_C\)FLAGS=/\1FLAGS+=/' \
Makefile Makefile.target tests/Makefile
sed -i 's/^VL_LDFLAGS=$/VL_LDFLAGS=-Wl,-z,execheap/' \
Makefile.target
}
_compile() {
./configure \
--prefix=/usr \
--localstatedir=/var \
--sysconfdir=/etc \
--libexecdir=/usr/lib/qemu \
--enable-vde \
--enable-vnc \
--enable-spice \
--enable-virtfs \
--enable-curl \
--enable-cap-ng \
--enable-linux-aio \
--enable-usb-redir \
--enable-guest-agent \
--enable-uuid \
--disable-bsd-user \
--enable-linux-user \
--disable-werror \
--disable-smartcard-nss \
--cc="${CC:-gcc}" \
"$@" \
|| return 1
make ARFLAGS="rc" || return 1
}
build() {
cd "$srcdir"/$pkgname-$pkgver
_compile \
--audio-drv-list=oss,alsa \
--disable-sdl \
--disable-gtk \
|| return 1
# tests fails on x86
# http://lists.gnu.org/archive/html/qemu-devel/2012-11/msg01429.html
# http://web.archiveorange.com/archive/v/21oVv8wOfpQGkyy8EK0N
# make check || return 1
# cp -al "$srcdir"/$pkgname-$pkgver "$srcdir"/build-gtk
# cd "$srcdir"/build-gtk
# _compile \
# --audio-drv-list=oss,alsa,sdl \
# --enable-sdl \
# --enable-gtk \
# || return 1
}
package() {
cd "$srcdir"/$pkgname-$pkgver
make DESTDIR="$pkgdir" install || return 1
install -Dm644 "$srcdir"/80-kvm.rules \
"$pkgdir"/lib/udev/rules.d/80-kvm.rules || return 1
paxctl -c -m "$pkgdir"/usr/bin/qemu-system-* || return 1
}
_subsys() {
pkgdesc="Qemu ${1/-/ } emulator"
depends="qemu"
mkdir -p "$subpkgdir"/usr/bin
mv "$pkgdir"/usr/bin/qemu-$1 "$subpkgdir"/usr/bin/ || return 1
}
aarch64() { _subsys aarch64; }
alpha() { _subsys alpha; }
arm() { _subsys arm; }
armeb() { _subsys armeb; }
cris() { _subsys cris; }
i386() { _subsys i386; }
m68k() { _subsys m68k; }
microblaze() { _subsys microblaze; }
microblazeel() { _subsys microblazeel; }
mips() { _subsys mips; }
mips64() { _subsys mips64; }
mips64el() { _subsys mips64el; }
mipsel() { _subsys mipsel; }
mipsn32() { _subsys mipsn32; }
mipsn32el() { _subsys mipsn32el; }
or32() { _subsys or32; }
ppc() { _subsys ppc; }
ppc64() { _subsys ppc64; }
ppc64abi32() { _subsys ppc64abi32; }
ppc64le() { _subsys ppc64le; }
s390x() { _subsys s390x; }
sh4() { _subsys sh4; }
sh4eb() { _subsys sh4eb; }
sparc() { _subsys sparc; }
sparc32plus() { _subsys sparc32plus; }
sparc64() { _subsys sparc64; }
system_aarch64() { _subsys system-aarch64; }
system_alpha() { _subsys system-alpha; }
system_arm() { _subsys system-arm; }
system_cris() { _subsys system-cris; }
system_i386() { _subsys system-i386; }
system_lm32() { _subsys system-lm32; }
system_m68k() { _subsys system-m68k; }
system_microblaze() { _subsys system-microblaze; }
system_microblazeel() { _subsys system-microblazeel; }
system_mips() { _subsys system-mips; }
system_mips64() { _subsys system-mips64; }
system_mips64el() { _subsys system-mips64el; }
system_mipsel() { _subsys system-mipsel; }
system_moxie() { _subsys system-moxie; }
system_or32() { _subsys system-or32; }
system_ppc() { _subsys system-ppc; }
system_ppc64() { _subsys system-ppc64; }
system_ppcemb() { _subsys system-ppcemb; }
system_s390x() { _subsys system-s390x; }
system_sh4() { _subsys system-sh4; }
system_sh4eb() { _subsys system-sh4eb; }
system_sparc() { _subsys system-sparc; }
system_sparc64() { _subsys system-sparc64; }
system_unicore32() { _subsys system-unicore32; }
system_x86_64() { _subsys system-x86_64; }
system_xtensa() { _subsys system-xtensa; }
system_xtensaeb() { _subsys system-xtensaeb; }
unicore32() { _subsys unicore32; }
x86_64() { _subsys x86_64; }
img() {
pkgdesc="QEMU command line tool for manipulating disk images"
replaces="qemu"
mkdir -p "$subpkgdir"/usr/bin
mv "$pkgdir"/usr/bin/qemu-img \
"$pkgdir"/usr/bin/qemu-io \
"$subpkgdir"/usr/bin/
# we exploit the fact that -img subpackage are created last
# and check that we done have new systems that belongs in
# subpackage
local _bins= _ret=0
for i in "$pkgdir"/usr/bin/qemu-system-*; do
if [ -r "$i" ]; then
error "Please create a subpackage for ${i##*/}"
_ret=1
fi
done
return $_ret
}
guest() {
pkgdesc="QEMU guest agent"
mkdir -p "$subpkgdir"/usr/bin
mv "$pkgdir"/usr/bin/qemu-ga "$subpkgdir"/usr/bin/
install -Dm755 "$srcdir"/qemu-guest-agent.initd \
"$subpkgdir"/etc/init.d/qemu-guest-agent || return 1
install -Dm644 "$srcdir"/qemu-guest-agent.confd \
"$subpkgdir"/etc/conf.d/qemu-guest-agent || return 1
}
md5sums="950706eda86044446c536514b44934fa qemu-2.1.3.tar.bz2
672727bb1d8c8ab7b5def65dd1793c33 0001-elfload-load-PIE-executables-to-right-address.patch
d364208c4847ad2baeb237900befecd1 0006-linux-user-signal.c-define-__SIGRTMIN-MAX-for-non-GN.patch
bc5f2e41ed3b6d6d30b672adab82e3e1 musl-F_SHLCK-and-F_EXLCK.patch
39bd2ae6aa6a45519fc5f76138ec8a8b CVE-2014-8106.patch
822717a977a9d82d63da00512713f50e CVE-2014-9718.patch
89a81ed58683fcc0323741c873dfad95 CVE-2015-1779.patch
5e8a68940c4e0267e795a6ddd144e00e CVE-2015-3456.patch
97045abdf8d0543691e52f9fdf0c8d52 CVE-2015-4037.patch
311d3845dda4795bf63107c3dcbf2bea CVE-2015-5154.patch
2cb289d5071f4dd93235fb7d89e178be CVE-2015-5165.1.patch
da48557667d23bd2cbe115735b8c3034 CVE-2015-5165.2.patch
4a33d5a280ed5e847353a9c5e4b90184 CVE-2015-5165.3.patch
6127b15957145fa1feeeb457573cf86f CVE-2015-5165.4.patch
e42ef3d3840db18ae172513bf14c7dbd CVE-2015-5165.5.patch
53b14f33b64137e37366478b76e46843 CVE-2015-5165.6.patch
52a6193bc3371e81e3eaab4db8689d85 CVE-2015-5165.7.patch
f813943846bcca68eeb61478c70b7872 CVE-2015-5225.patch
86a63ff69fe5b8af150cd1c082a75b43 CVE-2015-5278.patch
3e3adef433cd25e650815b0506c2c73b CVE-2015-5279.patch
a5bf6747adf6b50bdd5ef8dc540a475c CVE-2015-6815.patch
1663bc6977f6886a58394155b1bf3676 qemu-guest-agent.confd
2035cd781ea810e94bda250c609d8d90 qemu-guest-agent.initd
66660f143235201249dc0648b39b86ee 80-kvm.rules"
sha256sums="9b68fd0e6f6c401939bd1c9c6ab7052d84962007bb02919623474e9269f60a40 qemu-2.1.3.tar.bz2
af35304b165622a53f7557b59ffd8da5030f5fd444e669c862f9410131f3b987 0001-elfload-load-PIE-executables-to-right-address.patch
6af6cf9044997710a6d0fbdba30a35c8d775e30d30c032ec97db672f75ec88ac 0006-linux-user-signal.c-define-__SIGRTMIN-MAX-for-non-GN.patch
eefd597197223899d3b12d8274af493153e270fd06ea8622e33d6eaeae063d40 musl-F_SHLCK-and-F_EXLCK.patch
de64781b2ef71e53c94f3f411bc26ad39e2b6cb581217dbb2739c251e253996f CVE-2014-8106.patch
87165dd0fa774b8a61bd9d10c1929d43ddf7213790644e57433cf74c1fb66664 CVE-2014-9718.patch
512f8847606b4031bec605bad56e420cd723e79df5713839ae2c9431637317fe CVE-2015-1779.patch
de69a47daf292fd0cc01c925a23c9fadbac0fb60c322bf89260cccceb47ca204 CVE-2015-3456.patch
6bb3f4bb71716bdde8ff417b76ceb4cee336ae93a65b2ae1db15406f382c0299 CVE-2015-4037.patch
fe575c51bae7da9ea10bd16c953bafd24c69f57a3fb28878dffc2b85f9a475d2 CVE-2015-5154.patch
12d0dc1a31449288ed5e562a1e9415c437b7a2799e8afa0b251e3957a0d8ab23 CVE-2015-5165.1.patch
c91a60b7d7e18ea95b31eca0ba940d53c14730fae1e50802375c9e5ab7d0f109 CVE-2015-5165.2.patch
99062a9cbf4b96de8f0aa8555291cf6e296a9dbdf22ad4e9285912ba02de9261 CVE-2015-5165.3.patch
82d2214a0bd42b03b72b26170e4c80699d74bc691b6e223780a693ad2e9c267a CVE-2015-5165.4.patch
b728ae69e4a1d838bb1b4c5e6135e84fe8f6fc7e97fdc99915e7fc908edb4fd2 CVE-2015-5165.5.patch
6fb23646e05ef9a4b010d2a2c0235b6ee58a293f39ed40b6b1611115c948a79a CVE-2015-5165.6.patch
ebcadb69110ea4672795b52472222ed1ffe67a83e37c5b7d401530f43137c587 CVE-2015-5165.7.patch
eed8aa723558c3f4a9263ecf96222373430399d57ad3ee04a59041be2073d50f CVE-2015-5225.patch
0ceeaeec1ed46bff0a1a6580d9744ff3615eae55689cd3254ec7d187758b7758 CVE-2015-5278.patch
39ebcd2f3690e241354f9c06716e3f88966baee65907da425c4dc90006281390 CVE-2015-5279.patch
2a67392d648c3e0b5e65eb7c51bc0ab1a3040cdbc4decb3daef391472b3b13e1 CVE-2015-6815.patch
d84e53a94584f37f3bd1b21f44077b5de0d07094c6729f26ae20ab1f7b9cc298 qemu-guest-agent.confd
982fa8ba67c728405305e4cf5a36a41a780b3d1f388ebd6377e7964c271a1c92 qemu-guest-agent.initd
37f666f1cdb7d8a62171de69b531681dcb0fba74236729dac8b6c019232eba84 80-kvm.rules"
sha512sums="119d89d85a54a4225716f7d1b20dc624705c1893e782b6f75e8a31ec11d4ba0ed60b78dd59322c2acc7f132c2f167461cf354d6a5f18925cf594746375b7b8fa qemu-2.1.3.tar.bz2
405008589cad1c8b609eca004d520bf944366e8525f85a19fc6e283c95b84b6c2429822ba064675823ab69f1406a57377266a65021623d1cd581e7db000134fd 0001-elfload-load-PIE-executables-to-right-address.patch
ec84b27648c01c6e58781295dcd0c2ff8e5a635f9836ef50c1da5d0ed125db1afc4cb5b01cb97606d6dd8f417acba93e1560d9a32ca29161a4bb730b302440ea 0006-linux-user-signal.c-define-__SIGRTMIN-MAX-for-non-GN.patch
5de10f7e8abae16d1d7521e5ca1bfb62a8f295b324bea84f122f882b7b9354c21e5a00b20a1c5484c1b737b937e53c4ca6979e55705522f0779a5669725369f5 musl-F_SHLCK-and-F_EXLCK.patch
afa6643a1a474a609f2c7446c3cf13cd89ecc3a6a0192ba967503a569512ad043f6e6fbaef1e5cc6b235b439612de55986a9d83b0a6fb689dfa726369cfbda64 CVE-2014-8106.patch
4b0e6e3e335d1fc0b43740946cba423f663b5ac5076f03d65b0d2f19ef9fef2b1b6fadfd085a6828eb77f86d97161e2f8db32d001166fb0d55a8b5d141a13513 CVE-2014-9718.patch
62f106d4b0927851e0a0ec74a82936245cbc3824f17585007cc37d02517d19607cf024541b1f6be36e0ac79c6fcaa90272276761ec9f6fd0e33b6fa23f529b84 CVE-2015-1779.patch
81485e26e30314b075a154cbce841fa3b803b70d8539a5ce00e57ec2020ab801d88c35631805811d003505dfd1909a5b70307fdbd8a192986f53143669465bd8 CVE-2015-3456.patch
8dc68c2f511a28b0c1896b89922fab8e31dea4eefe18a69e6c068dd799cfc5a5a8b2ed8c3f5d17584932ddb9a2bf72d72fdaaf19c2129babf9a8e8f4ce150659 CVE-2015-4037.patch
47c85d671562fef9000b277f9ae5b10d426952fa36dbe64e1835aa4c592669737b73180730ede79e39dfc19ee4f125cc6d197f6c81a2f7d87db6c223df4f6f4c CVE-2015-5154.patch
1df1ff1044542c4a0b040cb7fe5bbe002ee95782277f50f2bea86fbb34d4c5404a6c1f467a4cc224020882fe8c2f113e6b44d762129bd79ae04e139494a90ddc CVE-2015-5165.1.patch
eb332382898e0450bc6a6297e5977579a05f7b2ad304659aff37a7eed040b28013a982cdff2a1d669e968cea2aefef183081db1f6f9ae2baf64865ef2dbfa283 CVE-2015-5165.2.patch
664ce64538441b0eeb93d1b5642acf3a1bd8c9c8b4cb5578d49e8226b967c9bef816caee41a429365ff0c5f982991f25483fc14db6c0a27d14626febaf8f8bcd CVE-2015-5165.3.patch
a7dba1a26f33c2a65ee84fd0d3e5606cd17f623bea0c33438247e1f8d6cd72217d02bd00c28a24f54506480b12092b7351551af5f9cdcf863157cddaa461b606 CVE-2015-5165.4.patch
7476649c099b363632b158b691f8ec2704590ec6e671f9bb013c7ffe50e593dc7c97278b6d09b5021605071a23b528875f024f5617a019954efac9c4055f6a83 CVE-2015-5165.5.patch
a1a38fdbc3f3cebb557ae00c3764bb268019b2c9f15731bb829b3b73a87856c5d51d65cc3ff712b28601298afb2aa82e83789bab867c8fb2816f23d515af8be7 CVE-2015-5165.6.patch
d174df707dabbaf49fadda0db9b551abef0e4c2045287bfb78ded69c7b8e6a59333d7aa1459ac7a81c0f3f711ec225157d8dabcd63d6eed10bb5755cea608fbb CVE-2015-5165.7.patch
f637a66c3cdeb5970253756eb42d5d8e095918b5c29ff912c01f6cb7dfc4aa8ac0fb96c2f6ea8d64d956855727895299a4ce78887fee3dd8c488e6635108827d CVE-2015-5225.patch
62cc1f05decad3c48bf9246659c4de14862aaba6b8bbf41724ae0e0b45ef5c9e0e0ae163da0f097ba0c3b2a8dd356b3bfe4f2de8de63b22b30ad6b8364cd8cc4 CVE-2015-5278.patch
a435101af6881993bcaf58409b167d1fbe39aa97eac6b77dc48d37f75bb902b945bb01d23931ea44b6634dbff71ff735b54bd55822393163732ef5d8ae346d64 CVE-2015-5279.patch
b7f9c48ca74351d7553f6c9c647bdeafa73bfb71f56cb4f812b55ea99db9e7e58c30854c0a4e9ad202de9a83b694f883c9eb7cd05f80288dc87f98870b3ee541 CVE-2015-6815.patch
d90c034cae3f9097466854ed1a9f32ab4b02089fcdf7320e8f4da13b2b1ff65067233f48809911485e4431d7ec1a22448b934121bc9522a2dc489009e87e2b1f qemu-guest-agent.confd
761b4e2397569dae45ae3bb9e46e28746275297f629af9e9065525497fd26a48b65d8abcf4282727afd35309e338967acf6a1b14c3169577bdc16c1f42e618b3 qemu-guest-agent.initd
9b7a89b20fcf737832cb7b4d5dc7d8301dd88169cbe5339eda69fbb51c2e537d8cb9ec7cf37600899e734209e63410d50d0821bce97e401421db39c294d97be2 80-kvm.rules"
|