# Maintainer: Natanael Copa 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"