Portage doesn't build libraries in two passes, it's building one library which is copied to usr/lib64/php5.2 and the same library is copied to usr/lib64/php5.3 . Result: /usr/lib/php5.2/bin/php -v PHP Warning: PHP Startup: ssh2: Unable to initialize module Module compiled with module API=20090626, debug=0, thread-safety=1 PHP compiled with module API=20060613, debug=0, thread-safety=1 These options need to match in Unknown on line 0 PHP 5.2.17-pl0-gentoo (cli) (built: Jan 18 2011 13:21:34) Copyright (c) 1997-2010 The PHP Group Zend Engine v2.2.0, Copyright (c) 1998-2010 Zend Technologies pecl-* isn;t working on php-5.2. In build.log there are interesting lines: /var/tmp/portage/dev-php5/pecl-ssh2-0.11.2-r1/temp/environment: line 3181: cd: /var/tmp/portage/dev-php5/pecl-ssh2-0.11.2-r1/work/php5.2: No such file or directory and /var/tmp/portage/dev-php5/pecl-ssh2-0.11.2-r1/temp/environment: line 3181: cd: /var/tmp/portage/dev-php5/pecl-ssh2-0.11.2-r1/work/php5.3: No such file or directory Reproducible: Always emerge --info FEATURES variable contains unknown value(s): Xfail-clean Portage 2.1.9.33 (default/linux/amd64/10.0/desktop/kde, gcc-4.5.2, glibc-2.12.2-r0, 2.6.37-gentoo x86_64) ================================================================= System uname: Linux-2.6.37-gentoo-x86_64-Intel-R-_Celeron-R-_CPU_E1500_@_2.20GHz-with-gentoo-2.0.1 Timestamp of tree: Tue, 18 Jan 2011 06:30:01 +0000 ccache version 3.1.4 [enabled] app-shells/bash: 4.1_p9 dev-java/java-config: 2.1.11-r3 dev-lang/python: 2.7.1, 3.1.3 dev-util/ccache: 3.1.4 dev-util/cmake: 2.8.3-r1 sys-apps/baselayout: 2.0.1-r1 sys-apps/openrc: 0.7.0 sys-apps/sandbox: 2.4 sys-devel/autoconf: 2.13, 2.68 sys-devel/automake: 1.9.6-r3, 1.10.3, 1.11.1 sys-devel/binutils: 2.21 sys-devel/gcc: 4.5.2 sys-devel/gcc-config: 1.4.1 sys-devel/libtool: 2.4-r1 sys-devel/make: 3.82 virtual/os-headers: 2.6.36.1 (sys-kernel/linux-headers) ACCEPT_KEYWORDS="amd64 ~amd64" ACCEPT_LICENSE="* -@EULA AdobeFlash-10.1 PUEL Q3AEULA skype-eula dlj-1.1" CBUILD="x86_64-pc-linux-gnu" CFLAGS="-O2 -march=native -pipe -fpeel-loops -fomit-frame-pointer -frename-registers -fpredictive-commoning -fweb -ftree-vectorize -floop-interchange -ftree-loop-distribution -fivopts -floop-block -floop-strip-mine -fira-loop-pressure -floop-interchange -ftree-loop-linear -s -floop-parallelize-all -fipa-sra" CHOST="x86_64-pc-linux-gnu" CONFIG_PROTECT="/etc /usr/share/config /usr/share/gnupg/qualified.txt /usr/share/openvpn/easy-rsa" CONFIG_PROTECT_MASK="/etc/ca-certificates.conf /etc/env.d /etc/env.d/java/ /etc/eselect/postgresql /etc/fonts/fonts.conf /etc/gconf /etc/gentoo-release /etc/php/apache2-php5.2/ext-active/ /etc/php/apache2-php5.3/ext-active/ /etc/php/cgi-php5.2/ext-active/ /etc/php/cgi-php5.3/ext-active/ /etc/php/cli-php5.2/ext-active/ /etc/php/cli-php5.3/ext-active/ /etc/revdep-rebuild /etc/sandbox.d /etc/terminfo" CXXFLAGS="-O2 -march=native -pipe -fpeel-loops -fomit-frame-pointer -frename-registers -fpredictive-commoning -fweb -ftree-vectorize -floop-interchange -ftree-loop-distribution -fivopts -floop-block -floop-strip-mine -fira-loop-pressure -floop-interchange -ftree-loop-linear -s -floop-parallelize-all -fipa-sra" DISTDIR="/usr/portage/distfiles" FEATURES="Xfail-clean assume-digests binpkg-logs ccache collision-protect distlocks fixlafiles fixpackages keepwork news parallel-fetch protect-owned sandbox sfperms strict unknown-features-warn unmerge-logs unmerge-orphans userfetch" GENTOO_MIRRORS="http://distfiles.gentoo.org" LC_ALL="pl_PL.utf8" LDFLAGS="-Wl,-O1 -Wl,--as-needed" LINGUAS="pl en es es_ES" MAKEOPTS="-j2" PKGDIR="/usr/portage/packages" PORTAGE_CONFIGROOT="/" PORTAGE_RSYNC_EXTRA_OPTS="-O" PORTAGE_RSYNC_OPTS="--recursive --links --safe-links --perms --times --compress --force --whole-file --delete --stats --timeout=180 --exclude=/distfiles --exclude=/local --exclude=/packages" PORTAGE_TMPDIR="/var/tmp" PORTDIR="/usr/portage" PORTDIR_OVERLAY="/usr/local/portage /usr/local/portage/layman/sunrise /usr/local/portage/layman/zugaina /usr/local/portage/layman/sping /usr/local/portage/miro-overlay/portage /usr/local/portage/miro-overlay/in_sunrise /usr/local/portage/miro-overlay/staging" SYNC="rsync://192.168.138.254/gentoo-portage" USE="64bit X a52 aac acl acpi alsa amd64 apm async bash-completion bfq bittorrent branding bzip2 cairo caps cdr chroot cli consolekit cracklib crypt cups cxx dbus dmx dri dts dvd dvdr emboss encode exif fam firefox flac fortran ftp gd gif glibc-omitfp gpm graphite gstreamer iconv idn iproute2 ipv6 ithreads jpeg kde laptop lcms libnotify lightning logrotate mad mikmod mmap mmx mmxext mng modules mp3 mp4 mpeg mudflap multilib ncurses network-cron nls nptl nptlonly nsplugin nspluginwrapper objc ogg opengl openmp openssl optimization optimized-qmake pam pango pch pcre pdf phonon png policykit ppds pppd qt3support qt4 readline samba sdl semantic-desktop session sharedmem smp spell sse sse2 sse3 ssl ssse3 startup-notification svg sysfs threads threadsafe tiff tools truetype udev unicode urandom usb vim vim-pager vim-syntax vorbis x264 xattr xcb xinerama xml xorg xulrunner xv xvid zip zlib" ALSA_CARDS="ali5451 als4000 atiixp atiixp-modem bt87x ca0106 cmipci emu10k1x ens1370 ens1371 es1938 es1968 fm801 hda-intel intel8x0 intel8x0m maestro3 trident usb-audio via82xx via82xx-modem ymfpci" ALSA_PCM_PLUGINS="adpcm alaw asym copy dmix dshare dsnoop empty extplug file hooks iec958 ioplug ladspa lfloat linear meter mmap_emul mulaw multi null plug rate route share shm softvol" APACHE2_MODULES="actions alias auth_basic authn_alias authn_anon authn_dbm authn_default authn_file authz_dbm authz_default authz_groupfile authz_host authz_owner authz_user autoindex cgid dav deflate dir env expires ext_filter filter headers include info log_config logio mime mime_magic negotiation rewrite setenvif speling status unique_id usertrack vhost_alias" APACHE2_MPMS="worker" COLLECTD_PLUGINS="df interface irq load memory rrdtool swap syslog" ELIBC="glibc" GPSD_PROTOCOLS="ashtech aivdm earthmate evermore fv18 garmin garmintxt gpsclock itrax mtk3301 nmea ntrip navcom oceanserver oldstyle oncore rtcm104v2 rtcm104v3 sirf superstar2 timing tsip tripmate tnt ubx" INPUT_DEVICES="keyboard mouse" KERNEL="linux" LCD_DEVICES="bayrad cfontz cfontz633 glk hd44780 lb216 lcdm001 mtxorb ncurses text" LINGUAS="pl en es es_ES" PHP_TARGETS="php5-2 php5-3" RUBY_TARGETS="ruby18" USERLAND="GNU" VIDEO_CARDS="intel nvidia" XTABLES_ADDONS="quota2 psd pknock lscan length2 ipv4options ipset ipp2p iface geoip fuzzy condition tee tarpit sysrq steal rawnat logmark ipmark dhcpmac delude chaos account" Unset: CPPFLAGS, CTARGET, EMERGE_DEFAULT_OPTS, FFLAGS, INSTALL_MASK, LANG, PORTAGE_BUNZIP2_COMMAND, PORTAGE_COMPRESS, PORTAGE_COMPRESS_FLAGS
Created attachment 260174 [details] build.log
Can you retry without FEATURES="keepwork"?
I've noticed problem without keepwork, i set this flag to provide build.log
Please look at bug #352068, the same problem.
Okay. Never mind that then. Thing is that I run this setup on a rather large number of servers and I have done so for some six months now, with a lot of upgrading and downgrading and emerge (-C) of pecl ebuilds without any issues like this. It has also passed through QA and whatnot. I also tried to reproduce, bvut no luck.
*** Bug 352068 has been marked as a duplicate of this bug. ***
I managed to reprocude! The issue seem to be related to USE="threads"
Never mind that. That was just a coincidence. The bug is in the pecl eclass. Fix will hopefully be in CVS in after some testing.
Fix committed to CVS now. Please test and see if it solves this bug.
I've tested only on one host, pecles compiles correctly for me:) In Gentoo we have two branches "stable" and "~ unstable", it's for package. But what about eclasses? One change in it can break compilation of many packages. I don't have idea how to do it, but everyone (every dev) can make mistake and change eclass in unwanted way.
(In reply to comment #10) > I've tested only on one host, pecles compiles correctly for me:) > In Gentoo we have two branches "stable" and "~ unstable", it's for package. But > what about eclasses? One change in it can break compilation of many packages. I > don't have idea how to do it, but everyone (every dev) can make mistake and > change eclass in unwanted way. > You are quite right. Especially for something as complicated as PHP (huge number of USE flags, configuration settings and packages). In this case it was a small change in php-ext-source that affected php-ext-pecl ... It doesn't get any better that the PHP herd is stretched thin. Anyways, thanks for reporting and providing feedback!
> It doesn't get any better that the PHP herd is stretched thin. I think this is one of the bigest problem with gentoo, too few maintainers. > Anyways, thanks for reporting and providing feedback! Thank you for important fix!