| Summary: | net-libs/nodejs-18.14.0: build fails with -O1: error: inlining failed in call to 'always_inline' 'int _mm_popcnt_u32(unsigned int)': target specific option mismatch | ||
|---|---|---|---|
| Product: | Gentoo Linux | Reporter: | Matt Whitlock <gentoo> |
| Component: | Current packages | Assignee: | William Hubbs <williamh> |
| Status: | RESOLVED FIXED | ||
| Severity: | normal | CC: | bugs, gentoo, phmagic, sam, ustinov, vityokster |
| Priority: | Normal | ||
| Version: | unspecified | ||
| Hardware: | All | ||
| OS: | Linux | ||
| See Also: | https://bugs.gentoo.org/show_bug.cgi?id=900513 | ||
| Whiteboard: | |||
| Package list: | Runtime testing required: | --- | |
| Attachments: | build.log | ||
|
Description
Matt Whitlock
2023-02-06 04:27:30 UTC
I have the same problem with -O0 and -O2.
emerge --info '=net-libs/nodejs-18.14.0::gentoo'
Portage 3.0.44 (python 3.10.10-final-0, default/linux/amd64/17.1/no-multilib, gcc-12, glibc-2.36-r7, 5.15.94-gentoo-x86_64 x86_64)
=================================================================
System Settings
=================================================================
System uname: Linux-5.15.94-gentoo-x86_64-x86_64-Intel-R-_Core-TM-2_Quad_CPU_Q9550_@_2.83GHz-with-glibc2.36
KiB Mem: 8138680 total, 279968 free
KiB Swap: 8388604 total, 8230992 free
Timestamp of repository gentoo: Mon, 20 Feb 2023 01:02:01 +0000
Head commit of repository gentoo: d792b3ddf55ff1b77f00887f8c6dfc9f515a804f
Timestamp of repository flying: Tue, 26 Jul 2022 08:30:06 +0000
Head commit of repository guru: 47936a0f50468cce092fabcdb2caa18104792835
Head commit of repository mozilla: 7f09fc95b402bdbfaee8156bda2187bdbf634018
Head commit of repository pf4public: daec97311defc251a9bff1aeaeef996f80aca620
Head commit of repository science: 307e9fc6df28cae1f1bb5e53219ae537256c16a9
sh bash 5.2_p15-r2
ld GNU ld (Gentoo 2.40 p2) 2.40.0
ccache version 4.7.4 [enabled]
app-misc/pax-utils: 1.3.7::gentoo
app-shells/bash: 5.2_p15-r2::gentoo
dev-lang/perl: 5.36.0-r2::gentoo
dev-lang/python: 3.10.10_p1::gentoo
dev-lang/rust: 1.67.1::gentoo
dev-util/ccache: 4.7.4::gentoo
dev-util/cmake: 3.25.2::gentoo
dev-util/meson: 1.0.0::gentoo
sys-apps/baselayout: 2.13-r1::gentoo
sys-apps/openrc: 0.46::gentoo
sys-apps/sandbox: 2.30-r1::gentoo
sys-devel/autoconf: 2.13-r7::gentoo, 2.71-r5::gentoo
sys-devel/automake: 1.16.5::gentoo
sys-devel/binutils: 2.40-r1::gentoo
sys-devel/binutils-config: 5.5::gentoo
sys-devel/clang: 15.0.7-r1::gentoo
sys-devel/gcc: 12.2.1_p20230121-r1::gentoo
sys-devel/gcc-config: 2.10::gentoo
sys-devel/libtool: 2.4.7-r1::gentoo
sys-devel/llvm: 15.0.7::gentoo
sys-devel/make: 4.4::gentoo
sys-kernel/linux-headers: 5.15-r3::gentoo (virtual/os-headers)
sys-libs/glibc: 2.36-r7::gentoo
Repositories:
gentoo
location: /var/db/repos/gentoo
sync-type: git
sync-uri: https://anongit.gentoo.org/git/repo/sync/gentoo.git
priority: -1000
volatile: True
flying
location: /var/db/repos/flying
masters: gentoo
volatile: True
guru
location: /var/db/repos/guru
sync-type: git
sync-uri: https://anongit.gentoo.org/git/repo/proj/guru.git
masters: gentoo
priority: 50
volatile: True
mozilla
location: /var/db/repos/mozilla
sync-type: git
sync-uri: https://anongit.gentoo.org/git/proj/mozilla.git
masters: gentoo
priority: 50
volatile: True
pf4public
location: /var/db/repos/pf4public
sync-type: git
sync-uri: https://github.com/PF4Public/gentoo-overlay.git
masters: gentoo
priority: 50
volatile: True
science
location: /var/db/repos/science
sync-type: git
sync-uri: https://anongit.gentoo.org/git/proj/sci.git
masters: gentoo
priority: 50
volatile: True
ACCEPT_KEYWORDS="amd64 ~amd64"
ACCEPT_LICENSE="@FREE"
CBUILD="x86_64-pc-linux-gnu"
CFLAGS="-O2 -pipe -march=native -mtune=native"
CHOST="x86_64-pc-linux-gnu"
CONFIG_PROTECT="/etc /usr/lib64/libreoffice/program/sofficerc /usr/share/config /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 /etc/texmf/language.dat.d /etc/texmf/language.def.d /etc/texmf/updmap.d /etc/texmf/web2c"
CXXFLAGS="-O2 -pipe -march=native -mtune=native"
DISTDIR="/var/cache/distfiles"
EMERGE_DEFAULT_OPTS="--quiet-build=y --with-bdeps=y"
ENV_UNSET="CARGO_HOME DBUS_SESSION_BUS_ADDRESS DISPLAY GDK_PIXBUF_MODULE_FILE GOBIN GOPATH PERL5LIB PERL5OPT PERLPREFIX PERL_CORE PERL_MB_OPT PERL_MM_OPT XAUTHORITY XDG_CACHE_HOME XDG_CONFIG_HOME XDG_DATA_HOME XDG_RUNTIME_DIR XDG_STATE_HOME"
FCFLAGS="-O2 -pipe -march=native -mtune=native"
FEATURES="assume-digests binpkg-docompress binpkg-dostrip binpkg-logs buildpkg buildpkg-live ccache compress-build-logs config-protect-if-modified distlocks ebuild-locks fixlafiles ipc-sandbox merge-sync multilib-strict network-sandbox news parallel-fetch pid-sandbox preserve-libs protect-owned qa-unresolved-soname-deps sandbox sfperms split-elog split-log strict unknown-features-warn unmerge-logs unmerge-orphans userfetch userpriv usersandbox usersync xattr"
FFLAGS="-O2 -pipe -march=native -mtune=native"
GENTOO_MIRRORS="http://mirror.yandex.ru/gentoo-distfiles/ http://gentoo.bloodhost.ru/"
LANG="ru_RU.utf8"
LDFLAGS="-Wl,-O1 -Wl,--as-needed"
LEX="flex"
MAKEOPTS="-j5"
PKGDIR="/var/cache/binpkgs"
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 --exclude=/.git"
PORTAGE_TMPDIR="/var/tmp"
SHELL="/bin/bash"
USE="7zip X acl alsa amd64 avif blake2 branding bzip2 cairo caps cli crypt cups custom-cflags custom-optimization dbus djvu dri drm egl elogind eps exif expat ffmpeg fftw firmware fortran gdbm gegl gif gnuplot heif hwloc iconv icu jpeg jpeg2k kde kwallet latex lcms libglvnd libinput libtirpc lm-sensors lto lz4 lzma lzo mtp ncurses nls nptl opengl openmp osmesa pam pango pcre pdf pgo phonon plasma png policykit postscript pulseaudio qml qt5 readline seccomp sensord spell split-usr ssl svg system-av1 system-bootstrap system-ffmpeg system-harfbuzz system-icu system-jpeg system-libevent system-libvpx system-llvm system-png system-ssl system-webp system-zlib test-rust tiff truetype udev unicode usb v4l vdpau wayland webengine webp wmf x264 x265 xattr xinerama xml xxhash zip zlib zstd" ABI_X86="64" ADA_TARGET="gnat_2021" 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="karbon sheets words" COLLECTD_PLUGINS="df interface irq load memory rrdtool swap syslog" CPU_FLAGS_X86="mmx mmxext sse sse2 sse3 sse4_1 ssse3" ELIBC="glibc" GPSD_PROTOCOLS="ashtech aivdm earthmate evermore fv18 garmin garmintxt gpsclock greis isync itrax mtk3301 nmea ntrip navcom oceanserver oldstyle oncore rtcm104v2 rtcm104v3 sirf skytraq superstar2 timing tsip tripmate tnt ublox ubx" GRUB_PLATFORMS="pc" INPUT_DEVICES="libinput evdev" KERNEL="linux" L10N="ru en" LCD_DEVICES="bayrad cfontz cfontz633 glk hd44780 lb216 lcdm001 mtxorb ncurses text" LIBREOFFICE_EXTENSIONS="presenter-console presenter-minimizer" LLVM_TARGETS="NVPTX" LUA_SINGLE_TARGET="lua5-1" LUA_TARGETS="lua5-1" OFFICE_IMPLEMENTATION="libreoffice" PHP_TARGETS="php7-4 php8-0" POSTGRES_TARGETS="postgres12 postgres13" PYTHON_SINGLE_TARGET="python3_10" PYTHON_TARGETS="python3_10" QEMU_SOFTMMU_TARGETS="x86_64 i386" QEMU_USER_TARGETS="x86_64 i386" RUBY_TARGETS="ruby31" USERLAND="GNU" VIDEO_CARDS="nouveau" XTABLES_ADDONS="quota2 psd pknock lscan length2 ipv4options ipset ipp2p iface geoip fuzzy condition tee tarpit sysrq proto steal rawnat logmark ipmark dhcpmac delude chaos account"
Unset: ADDR2LINE, AR, ARFLAGS, AS, ASFLAGS, CC, CCLD, CONFIG_SHELL, CPP, CPPFLAGS, CTARGET, CXX, CXXFILT, ELFEDIT, EXTRA_ECONF, F77FLAGS, FC, GCOV, GPROF, INSTALL_MASK, LC_ALL, LD, LFLAGS, LIBTOOL, LINGUAS, MAKE, MAKEFLAGS, NM, OBJCOPY, OBJDUMP, PORTAGE_BINHOST, PORTAGE_BUNZIP2_COMMAND, PORTAGE_COMPRESS, PORTAGE_COMPRESS_FLAGS, PORTAGE_RSYNC_EXTRA_OPTS, RANLIB, READELF, RUSTFLAGS, SIZE, STRINGS, STRIP, YACC, YFLAGS
I faced the same problem with nodejs-18.14.2 and -O2. One possible workaround is to replace -march=native and -mtune=native with a concrete target specification (in my case it is opteron-sse3). Then build completes successfully. (In reply to Alexander Bezrukov from comment #3) > One possible workaround is to replace -march=native and -mtune=native with a > concrete target specification (in my case it is opteron-sse3). Then build > completes successfully. Thanks. That did work around the problem for me too. ("-march=core2" in my case.) Does this seem more like a bug in GCC? If my native CPU architecture is "core2", then shouldn't the options "-march=native" and "-march=core2" be indistinguishable from each other, both in the set of defined preprocessor symbols and in the compiled code that they effect? I suspect this was fixed by the change in bug 900513. (In fact, the original report in bug 900513 may have been something else, but I've seen no other instances of it, and other reports in *that* bug ended up being simdutf, so...). (In reply to Matt Whitlock from comment #4) > (In reply to Alexander Bezrukov from comment #3) > > One possible workaround is to replace -march=native and -mtune=native with a > > concrete target specification (in my case it is opteron-sse3). Then build > > completes successfully. > > Thanks. That did work around the problem for me too. ("-march=core2" in my > case.) > > Does this seem more like a bug in GCC? If my native CPU architecture is > "core2", then shouldn't the options "-march=native" and "-march=core2" be > indistinguishable from each other, both in the set of defined preprocessor > symbols and in the compiled code that they effect? I think I must be missing something obvious, but I don't fully get it either. In principle, I get the problem, but then when I try reproduce it on a more capable machine, I can't, even when trying to use exactly the same -march=native-resolved-settings. See e.g. https://github.com/simdutf/simdutf/issues/251#issuecomment-1576796950. If you have some insight, I'd appreciate it. But it does feel like -march=native is surely doing something that isn't visible and it's a GCC bug. |