make[2]: Entering directory '/var/tmp/portage/dev-lang/ruby-2.1.0/work/ruby-2.1.0/ext/digest/bubblebabble' x86_64-pc-linux-gnu-gcc -shared -o ../../.ext/x86_64-linux/dbm.so dbm.o -L. -L../.. -L. -Wl,-O1 -Wl,--as-needed -fstack-protector -rdynamic -Wl,-export-dynamic -Wl,--no-undefined -lruby21 -ldb -lpthread -lgmp -ldl -lcrypt -lm -lc x86_64-pc-linux-gnu-gcc -I. -I../../../.ext/include/x86_64-linux -I../../.././include -I../../.././ext/digest/bubblebabble -I../../.././ext/digest/bubblebabble/.. -DRUBY_EXTCONF_H=\"extconf.h\" -fPIC -O2 -pipe -fno-strict-aliasing -fPIC -o bubblebabble.o -c bubblebabble.c /usr/lib/gcc/x86_64-pc-linux-gnu/4.8.2/../../../../x86_64-pc-linux-gnu/bin/ld: /usr/lib/gcc/x86_64-pc-linux-gnu/4.8.2/../../../../lib64/libdb.a(dbm.o): relocation R_X86_64_32 against `.rodata.str1.1' can not be used when making a shared object; recompile with -fPIC /usr/lib/gcc/x86_64-pc-linux-gnu/4.8.2/../../../../lib64/libdb.a: error adding symbols: Bad value collect2: error: ld returned 1 exit status Makefile:236: recipe for target '../../.ext/x86_64-linux/dbm.so' failed make[2]: *** [../../.ext/x86_64-linux/dbm.so] Error 1 make[2]: Leaving directory '/var/tmp/portage/dev-lang/ruby-2.1.0/work/ruby-2.1.0/ext/dbm' exts.mk:139: recipe for target 'ext/dbm/all' failed make[1]: *** [ext/dbm/all] Error 2 make[1]: *** Waiting for unfinished jobs.... /bin/mkdir -p ../../../.ext/.timestamp ../../../.ext/x86_64-linux/digest exit > ../../../.ext/.timestamp/.RUBYARCHDIR.-.digest.time x86_64-pc-linux-gnu-gcc -I. -I../../.ext/include/x86_64-linux -I../.././include -I../.././ext/date -DRUBY_EXTCONF_H=\"extconf.h\" -fPIC -O2 -pipe -fno-strict-aliasing -fPIC -o date_parse.o -c date_parse.c rm -f ../../../.ext/x86_64-linux/digest/bubblebabble.so x86_64-pc-linux-gnu-gcc -shared -o ../../../.ext/x86_64-linux/digest/bubblebabble.so bubblebabble.o -L. -L../../.. -L. -Wl,-O1 -Wl,--as-needed -fstack-protector -rdynamic -Wl,-export-dynamic -Wl,--no-undefined -lruby21 -lpthread -lgmp -ldl -lcrypt -lm -lc make[2]: Leaving directory '/var/tmp/portage/dev-lang/ruby-2.1.0/work/ruby-2.1.0/ext/digest/bubblebabble' x86_64-pc-linux-gnu-gcc -I. -I../../.ext/include/x86_64-linux -I../.././include -I../.././ext/date -DRUBY_EXTCONF_H=\"extconf.h\" -fPIC -O2 -pipe -fno-strict-aliasing -fPIC -o date_core.o -c date_core.c /bin/mkdir -p ../../.ext/.timestamp ../../.ext/common/date exit > ../../.ext/.timestamp/.RUBYLIBDIR.-.date.time cp ../.././ext/date/lib/date.rb ../../.ext/common cp ../.././ext/date/lib/date/format.rb ../../.ext/common/date /bin/mkdir -p ../../.ext/.timestamp ../../.ext/common/bigdecimal exit > ../../.ext/.timestamp/.RUBYLIBDIR.-.bigdecimal.time cp ../.././ext/bigdecimal/lib/bigdecimal/newton.rb ../../.ext/common/bigdecimal cp ../.././ext/bigdecimal/lib/bigdecimal/util.rb ../../.ext/common/bigdecimal cp ../.././ext/bigdecimal/lib/bigdecimal/math.rb ../../.ext/common/bigdecimal cp ../.././ext/bigdecimal/lib/bigdecimal/ludcmp.rb ../../.ext/common/bigdecimal cp ../.././ext/bigdecimal/lib/bigdecimal/jacobian.rb ../../.ext/common/bigdecimal rm -f ../../.ext/x86_64-linux/bigdecimal.so x86_64-pc-linux-gnu-gcc -shared -o ../../.ext/x86_64-linux/bigdecimal.so bigdecimal.o -L. -L../.. -L. -Wl,-O1 -Wl,--as-needed -fstack-protector -rdynamic -Wl,-export-dynamic -Wl,--no-undefined -lruby21 -lpthread -lgmp -ldl -lcrypt -lm -lc make[2]: Leaving directory '/var/tmp/portage/dev-lang/ruby-2.1.0/work/ruby-2.1.0/ext/bigdecimal' rm -f ../../.ext/x86_64-linux/date_core.so x86_64-pc-linux-gnu-gcc -shared -o ../../.ext/x86_64-linux/date_core.so date_strftime.o date_strptime.o date_parse.o date_core.o -L. -L../.. -L. -Wl,-O1 -Wl,--as-needed -fstack-protector -rdynamic -Wl,-export-dynamic -Wl,--no-undefined -lruby21 -lpthread -lgmp -ldl -lcrypt -lm -lc make[2]: Leaving directory '/var/tmp/portage/dev-lang/ruby-2.1.0/work/ruby-2.1.0/ext/date' make[1]: Leaving directory '/var/tmp/portage/dev-lang/ruby-2.1.0/work/ruby-2.1.0' uncommon.mk:180: recipe for target 'build-ext' failed make: *** [build-ext] Error 2 * ERROR: dev-lang/ruby-2.1.0::gentoo failed (compile phase): * emake failed Portage 2.2.8 (default/linux/amd64/13.0/desktop/kde, gcc-4.8.2, glibc-2.17, 3.12.5-gentoo x86_64) ================================================================= System uname: Linux-3.12.5-gentoo-x86_64-AMD_Phenom-tm-_II_X4_965_Processor-with-gentoo-2.2 KiB Mem: 7919324 total, 1435500 free KiB Swap: 25165812 total, 25079492 free Timestamp of tree: Unknown ld GNU ld (GNU Binutils) 2.24 app-shells/bash: 4.2_p45-r1 dev-lang/python: 2.7.6, 3.3.3 dev-util/cmake: 2.8.12.1-r3 dev-util/pkgconfig: 0.28 sys-apps/baselayout: 2.2 sys-apps/openrc: 0.12.4 sys-apps/sandbox: 2.6-r1 sys-devel/autoconf: 2.13, 2.69 sys-devel/automake: 1.12.6, 1.14.1 sys-devel/binutils: 2.24-r1 sys-devel/gcc: 4.8.2 sys-devel/gcc-config: 1.8 sys-devel/libtool: 2.4.2 sys-devel/make: 4.0-r1 sys-kernel/linux-headers: 3.12 (virtual/os-headers) sys-libs/glibc: 2.17 Repositories: gentoo qt x-overlay ACCEPT_KEYWORDS="amd64 ~amd64" ACCEPT_LICENSE="*" CBUILD="x86_64-pc-linux-gnu" CFLAGS="-O2 -pipe" CHOST="x86_64-pc-linux-gnu" CONFIG_PROTECT="/etc /usr/share/config /usr/share/gnupg/qualified.txt /usr/share/themes/oxygen-gtk/gtk-2.0 /var/lib/hsqldb" CONFIG_PROTECT_MASK="/etc/ca-certificates.conf /etc/dconf /etc/env.d /etc/fonts/fonts.conf /etc/gconf /etc/gentoo-release /etc/revdep-rebuild /etc/sandbox.d /etc/terminfo /etc/texmf/language.dat.d /etc/texmf/language.def.d /etc/texmf/updmap.d /etc/texmf/web2c" CXXFLAGS="-O2 -pipe" DISTDIR="/usr/portage/distfiles" FCFLAGS="-O2 -pipe" FEATURES="assume-digests binpkg-logs buildpkg config-protect-if-modified distlocks ebuild-locks fixlafiles merge-sync news parallel-fetch preserve-libs protect-owned sandbox sfperms split-elog strict test unknown-features-warn unmerge-logs unmerge-orphans userfetch userpriv usersandbox usersync" FFLAGS="-O2 -pipe" GENTOO_MIRRORS="http://distfiles.gentoo.org" LANG="en_US.utf8" LDFLAGS="-Wl,-O1 -Wl,--as-needed" MAKEOPTS="-j4" PKGDIR="/usr/portage/packages" PORTAGE_CONFIGROOT="/" PORTAGE_RSYNC_OPTS="--recursive --links --safe-links --perms --times --omit-dir-times --compress --force --whole-file --delete --stats --human-readable --timeout=180 --exclude=/distfiles --exclude=/local --exclude=/packages" PORTAGE_TMPDIR="/var/tmp" PORTDIR="/usr/portage" PORTDIR_OVERLAY="/var/lib/layman/qt /overlay" USE="X a52 aac acl acpi alsa amd64 berkdb bluetooth branding bzip2 cairo cdda cdr cli consolekit cracklib crypt cups cxx dbus declarative dri dts dvd dvdr egl emboss encode exif fam firefox flac fortran gdbm gif gpm gtk iconv ipv6 jpeg kde kipi lcms ldap libnotify mad mmx mng modules mp3 mp4 mpeg multilib ncurses nls nptl ogg opengl openmp openvg pam pango pcre pdf phonon plasma png policykit ppds qt3support qt4 readline sdl semantic-desktop session spell sqlite sse sse2 ssl startup-notification svg tcpd tiff truetype udev udisks unicode upower usb vorbis wxwidgets x264 xa xcb xcomposite xinerama xml xscreensaver xv xvfb xvid zlib" ABI_X86="64" 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" APACHE2_MODULES="authn_core authz_core socache_shmcb unixd 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 cache cgi cgid dav dav_fs dav_lock deflate dir disk_cache env expires ext_filter file_cache filter headers include info log_config logio mem_cache mime mime_magic negotiation rewrite setenvif speling status unique_id userdir usertrack vhost_alias" CALLIGRA_FEATURES="kexi words flow plan sheets stage tables krita karbon braindump author" CAMERAS="ptp2" 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 ublox ubx" INPUT_DEVICES="keyboard mouse evdev" KERNEL="linux" LCD_DEVICES="bayrad cfontz cfontz633 glk hd44780 lb216 lcdm001 mtxorb ncurses text" LIBREOFFICE_EXTENSIONS="presenter-console presenter-minimizer" OFFICE_IMPLEMENTATION="libreoffice" PHP_TARGETS="php5-5" PYTHON_SINGLE_TARGET="python2_7" PYTHON_TARGETS="python2_7 python3_3" RUBY_TARGETS="ruby21" USERLAND="GNU" VIDEO_CARDS="vesa" 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, INSTALL_MASK, LC_ALL, PORTAGE_BUNZIP2_COMMAND, PORTAGE_COMPRESS, PORTAGE_COMPRESS_FLAGS, PORTAGE_RSYNC_EXTRA_OPTS, SYNC, USE_PYTHON
sys-devel/gcc: 4.8.2 Please test with stable gcc, to check if it is related to gcc.
Also, attach config.log - it would be interesting to see why the static lib is used instead of shared (though it's more likely to fall on binutils than gcc).
cd ext/digest && exec make -w -j --jobserver-fds=4,5 V=1 all /usr/lib/gcc/x86_64-pc-linux-gnu/4.7.3/../../../../x86_64-pc-linux-gnu/bin/ld: /usr/lib/gcc/x86_64-pc-linux-gnu/4.7.3/../../../../lib64/libdb.a(dbm.o): relocation R_X86_64_32 against `.rodata.str1.1' can not be used when making a shared object; recompile with -fPIC /usr/lib/gcc/x86_64-pc-linux-gnu/4.7.3/../../../../lib64/libdb.a: error adding symbols: Bad value collect2: error: ld returned 1 exit status Makefile:236: recipe for target '../../.ext/x86_64-linux/dbm.so' failed make[2]: *** [../../.ext/x86_64-linux/dbm.so] Error 1 happens the same with 4.7
Created attachment 368608 [details] config.log of ruby 2.1.0
I can't reproduce this with gcc 4.7 or 4.8. Which version(s) of sys-libs/db do you have installed?
(In reply to Hans de Graaff from comment #5) > I can't reproduce this with gcc 4.7 or 4.8. Which version(s) of sys-libs/db > do you have installed? I can here, using sys-libs/db-4.8.30 and sys-dev/gcc-4.8.2. Denis.
Created attachment 410362 [details] emerge -v --info Making a note that I successfully emerged all below packages (multiple ruby versions) with gentoo hardened and gcc 5.2.0(hardened) and I have noticed -fPIC present in their CFLAGS as I searched back in my scroll buffer. These packages emerged successfully: [ebuild N ] dev-libs/libyaml-0.1.6::gentoo USE="-doc -examples -static-libs {-test}" 492 KiB [ebuild N ] app-eselect/eselect-ruby-20141227::gentoo 2 KiB [ebuild N ] dev-util/ragel-6.9::gentoo USE="-vim-syntax" 1,199 KiB [ebuild N ] dev-lang/ruby-2.2.3:2.2::gentoo USE="berkdb gdbm ncurses rdoc readline ssl -debug -doc -examples -ipv6 -jemalloc -rubytests -socks5 -xemacs" 10,211 KiB [ebuild N ] dev-lang/ruby-2.0.0_p647:2.0::gentoo USE="berkdb gdbm ncurses rdoc readline ssl -debug -doc -examples -ipv6 -rubytests -socks5 -xemacs" CPU_FLAGS_X86="sse2" 8,110 KiB [ebuild N ] dev-lang/ruby-1.9.3_p551-r1:1.9::gentoo USE="berkdb gdbm ncurses rdoc readline ssl yaml -debug -doc -examples -ipv6 -rubytests -socks5 -xemacs" 9,818 KiB [ebuild N ] dev-ruby/rubygems-2.4.8::gentoo USE="-server {-test}" RUBY_TARGETS="ruby19 ruby20 ruby22 -ruby21" 438 KiB [ebuild N ] virtual/rubygems-11::gentoo RUBY_TARGETS="ruby19 ruby20 ruby22 (-rbx) -ruby21" 0 KiB [ebuild N ] dev-ruby/minitest-5.8.0:5::gentoo USE="-doc {-test}" RUBY_TARGETS="ruby19 ruby20 ruby22 -ruby21" 70 KiB [ebuild N ] dev-ruby/rake-10.4.2::gentoo USE="-doc {-test}" RUBY_TARGETS="ruby19 ruby20 ruby22 -ruby21" 128 KiB [ebuild N ] dev-ruby/power_assert-0.2.4::gentoo USE="-doc {-test}" RUBY_TARGETS="ruby20 ruby22 -ruby21" 13 KiB [ebuild N ] dev-ruby/test-unit-3.1.3:2::gentoo USE="-doc {-test}" RUBY_TARGETS="ruby19 ruby20 ruby22 -ruby21" 119 KiB [ebuild N ] dev-ruby/json-1.8.3::gentoo USE="-doc {-test}" RUBY_TARGETS="ruby19 ruby20 ruby22 -ruby21" 149 KiB [ebuild N ] dev-ruby/racc-1.4.12::gentoo USE="-doc {-test}" RUBY_TARGETS="ruby19 ruby20 ruby22 -ruby21" 113 KiB [ebuild N ] dev-ruby/rdoc-4.1.2-r1::gentoo USE="-doc {-test}" RUBY_TARGETS="ruby19 ruby20 ruby22 -ruby21" 713 KiB Total: 15 packages (15 new), Size of downloads: 31,570 KiB Here's emerge --info and attached is emerge -v --info if in any case useful for any reason. (eg. DEBUG=1 is set in env. and no packages failed like media-sound/gsm-1.0.13-r1 does) # emerge --info Portage 2.2.20.1 (python 3.4.3-final-0, hardened/linux/amd64/no-multilib, gcc-5.2.0, glibc-2.21-r1, 4.1.6-hardened-r1-g45b4b78 x86_64) ================================================================= System uname: Linux-4.1.6-hardened-r1-g45b4b78-x86_64-AMD_A6-3400M_APU_with_Radeon-tm-_HD_Graphics-with-gentoo-2.2 KiB Mem: 10223268 total, 3183748 free KiB Swap: 0 total, 0 free Timestamp of repository gentoo: Tue, 25 Aug 2015 00:45:01 +0000 sh bash 4.3_p42 ld GNU ld (Gentoo 2.25.1 p1.0) 2.25.1 ccache version 3.2.3 [enabled] app-shells/bash: 4.3_p42::gentoo dev-lang/perl: 5.22.0::gentoo dev-lang/python: 2.7.10::gentoo, 3.4.3::gentoo dev-util/ccache: 3.2.3::gentoo dev-util/cmake: 3.3.1-r1::gentoo dev-util/pkgconfig: 0.28-r3::gentoo sys-apps/baselayout: 2.2::gentoo sys-apps/openrc: 0.17::gentoo sys-apps/sandbox: 2.6-r1::gentoo sys-devel/autoconf: 2.13::gentoo, 2.69-r1::gentoo sys-devel/automake: 1.13.4::gentoo, 1.14.1::gentoo, 1.15::gentoo sys-devel/binutils: 2.25.1::gentoo sys-devel/gcc: 4.8.5::gentoo, 5.2.0::gentoo sys-devel/gcc-config: 1.8::gentoo sys-devel/libtool: 2.4.6-r1::gentoo sys-devel/make: 4.1-r1::gentoo sys-kernel/linux-headers: 4.1::gentoo (virtual/os-headers) sys-libs/glibc: 2.21-r1::gentoo Repositories: gentoo location: /usr/portage priority: -1000 ACCEPT_KEYWORDS="amd64 ~amd64" ACCEPT_LICENSE="@FREE" CBUILD="x86_64-pc-linux-gnu" CFLAGS="-O2 -pipe -march=native -ggdb -fvar-tracking-assignments -fno-omit-frame-pointer -ftrack-macro-expansion=2 -fstack-protector-all" CHOST="x86_64-pc-linux-gnu" CONFIG_PROTECT="/etc /usr/share/gnupg/qualified.txt" CONFIG_PROTECT_MASK="/etc/ca-certificates.conf /etc/dconf /etc/env.d /etc/fonts/fonts.conf /etc/gconf /etc/gentoo-release /etc/revdep-rebuild /etc/sandbox.d /etc/terminfo" CXXFLAGS="-O2 -pipe -march=native -ggdb -fvar-tracking-assignments -fno-omit-frame-pointer -ftrack-macro-expansion=2 -fstack-protector-all" DISTDIR="/usr/portage/distfiles" FCFLAGS="-O2 -pipe" FEATURES="assume-digests binpkg-logs ccache cgroup collision-protect config-protect-if-modified distlocks downgrade-backup ebuild-locks fakeroot fixlafiles force-mirror installsources ipc-sandbox merge-sync multilib-strict network-sandbox news nostrip parallel-fetch parallel-install prelink-checksums preserve-libs sandbox sfperms split-elog split-log strict unknown-features-warn unmerge-backup unmerge-logs userfetch userpriv usersandbox webrsync-gpg" FFLAGS="-O2 -pipe" GENTOO_MIRRORS="http://ftp.romnet.org/gentoo/ http://tux.rainside.sk/gentoo/ http://de-mirror.org/gentoo/ http://gd.tuwien.ac.at/opsys/linux/gentoo/ http://www.las.ic.unicamp.br/pub/gentoo/" INSTALL_MASK="/lib/systemd /lib32/systemd /lib64/systemd /usr/lib/systemd /usr/lib32/systemd /usr/lib64/systemd /etc/systemd" LANG="en_US.utf8" LDFLAGS="-Wl,-O1 -Wl,--as-needed" MAKEOPTS="-j4" PKGDIR="/usr/portage/packages" PORTAGE_CONFIGROOT="/" PORTAGE_RSYNC_OPTS="--recursive --links --safe-links --perms --times --omit-dir-times --compress --force --whole-file --delete --stats --human-readable --timeout=180 --exclude=/distfiles --exclude=/local --exclude=/packages" PORTAGE_TMPDIR="/var/tmp" USE="3dnow 3dnowext X acl amd64 berkdb bindist btrfs bzip2 cli consolekit cracklib crypt cryptsetup cscope cxx dbus device-mapper dri egl extensions gdbm git gpg gpm gtk3 hardened iconv jpeg justify lock mmx mmxext modules mosh-hardening ncurses nptl openmp pam pax_kernel pcre pie policykit pulseaudio qt4 readline seccomp session sse sse2 sse3 ssl ssp startup-notification strong-security system-icu system-jpeg system-libvpx system-sqlite urandom xattr xcomposite xtpax zlib" ABI_X86="64" 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" APACHE2_MODULES="authn_core authz_core socache_shmcb unixd 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 cache cgi cgid dav dav_fs dav_lock deflate dir disk_cache env expires ext_filter file_cache filter headers include info log_config logio mem_cache mime mime_magic negotiation rewrite setenvif speling status unique_id userdir usertrack vhost_alias" CALLIGRA_FEATURES="kexi words flow plan sheets stage tables krita karbon braindump author" CAMERAS="ptp2" COLLECTD_PLUGINS="df interface irq load memory rrdtool swap syslog" CPU_FLAGS_X86="3dnow 3dnowext mmx mmxext sse sse2 sse3" 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 ublox ubx" GRUB_PLATFORMS="pc" INPUT_DEVICES="keyboard virtualbox evdev" KERNEL="linux" LCD_DEVICES="bayrad cfontz cfontz633 glk hd44780 lb216 lcdm001 mtxorb ncurses text" LIBREOFFICE_EXTENSIONS="presenter-console presenter-minimizer" OFFICE_IMPLEMENTATION="libreoffice" PHP_TARGETS="php5-5" PYTHON_SINGLE_TARGET="python2_7" PYTHON_TARGETS="python2_7 python3_4" RUBY_TARGETS="ruby19 ruby20" USERLAND="GNU" VIDEO_CARDS="virtualbox" XFCE_PLUGINS="brightness clock trash battery power" 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" USE_PYTHON="2.7" Unset: CC, CPPFLAGS, CTARGET, CXX, EMERGE_DEFAULT_OPTS, LC_ALL, PORTAGE_BUNZIP2_COMMAND, PORTAGE_COMPRESS, PORTAGE_COMPRESS_FLAGS, PORTAGE_RSYNC_EXTRA_OPTS
This bug report is for an old version of dev-lang/ruby. Please re-open if this is still an issue with a recent version of dev-lang/ruby (e.g. ruby 2.1.9).