Gentoo Websites Logo
Go to: Gentoo Home Documentation Forums Lists Bugs Planet Store Wiki Get Gentoo!
Bug 932192 - dev-qt/qtdeclarative-6.7.0 fails to build on X32 ABI, implement USE=-jit to workaround
Summary: dev-qt/qtdeclarative-6.7.0 fails to build on X32 ABI, implement USE=-jit to w...
Status: RESOLVED FIXED
Alias: None
Product: Gentoo Linux
Classification: Unclassified
Component: Current packages (show other bugs)
Hardware: All Linux
: Normal normal
Assignee: Qt Bug Alias
URL:
Whiteboard:
Keywords:
Depends on:
Blocks: x32
  Show dependency tree
 
Reported: 2024-05-19 11:42 UTC by Andrii Batyiev
Modified: 2024-05-20 08:48 UTC (History)
3 users (show)

See Also:
Package list:
Runtime testing required: ---


Attachments
Ebuild with a proposed fix (qtdeclarative-6.7.0-r1.ebuild,1.15 KB, text/plain)
2024-05-19 11:43 UTC, Andrii Batyiev
Details

Note You need to log in before you can comment on or make changes to this bug.
Description Andrii Batyiev 2024-05-19 11:42:21 UTC
In file included from /var/tmp/portage/dev-qt/qtdeclarative-6.7.0/work/qtdeclarative-everywhere-src-6.7.0_build/src/qml/CMakeFiles/Qml.dir/Unity/unity_5_cxx.c
xx:73:
/var/tmp/portage/dev-qt/qtdeclarative-6.7.0/work/qtdeclarative-everywhere-src-6.7.0/src/qml/jit/qv4baselineassembler.cpp: In member function ‘void QV4::JIT::P
latformAssembler32::saveReturnValueInAccumulator()’:
/var/tmp/portage/dev-qt/qtdeclarative-6.7.0/work/qtdeclarative-everywhere-src-6.7.0/src/qml/jit/qv4baselineassembler.cpp:371:14: error: ‘ReturnValueRegisterTa
g’ was not declared in this scope; did you mean ‘ReturnValueRegister’?
  371 |         move(ReturnValueRegisterTag, AccumulatorRegisterTag);
      |              ^~~~~~~~~~~~~~~~~~~~~~
      |              ReturnValueRegister
/var/tmp/portage/dev-qt/qtdeclarative-6.7.0/work/qtdeclarative-everywhere-src-6.7.0/src/qml/jit/qv4baselineassembler.cpp:371:38: error: ‘AccumulatorRegisterTa
g’ was not declared in this scope; did you mean ‘AccumulatorRegister’?
  371 |         move(ReturnValueRegisterTag, AccumulatorRegisterTag);
      |                                      ^~~~~~~~~~~~~~~~~~~~~~
      |                                      AccumulatorRegister
/var/tmp/portage/dev-qt/qtdeclarative-6.7.0/work/qtdeclarative-everywhere-src-6.7.0/src/qml/jit/qv4baselineassembler.cpp: In member function ‘void QV4::JIT::P
latformAssembler32::loadUndefined()’:
/var/tmp/portage/dev-qt/qtdeclarative-6.7.0/work/qtdeclarative-everywhere-src-6.7.0/src/qml/jit/qv4baselineassembler.cpp:377:31: error: ‘AccumulatorRegisterTa
g’ was not declared in this scope; did you mean ‘AccumulatorRegister’?
  377 |         move(TrustedImm32(0), AccumulatorRegisterTag);
      |                               ^~~~~~~~~~~~~~~~~~~~~~
      |                               AccumulatorRegister
/var/tmp/portage/dev-qt/qtdeclarative-6.7.0/work/qtdeclarative-everywhere-src-6.7.0/src/qml/jit/qv4baselineassembler.cpp: In member function ‘void QV4::JIT::P
latformAssembler32::loadAccumulator(JSC::MacroAssembler<JSC::MacroAssemblerX86_64>::Address)’:
/var/tmp/portage/dev-qt/qtdeclarative-6.7.0/work/qtdeclarative-everywhere-src-6.7.0/src/qml/jit/qv4baselineassembler.cpp:410:21: error: ‘AccumulatorRegisterTa
g’ was not declared in this scope; did you mean ‘AccumulatorRegister’?
  410 |         load32(src, AccumulatorRegisterTag);
      |                     ^~~~~~~~~~~~~~~~~~~~~~
      |                     AccumulatorRegister
/var/tmp/portage/dev-qt/qtdeclarative-6.7.0/work/qtdeclarative-everywhere-src-6.7.0/src/qml/jit/qv4baselineassembler.cpp: In member function ‘void QV4::JIT::P
latformAssembler32::storeAccumulator(JSC::MacroAssembler<JSC::MacroAssemblerX86_64>::Address)’:
/var/tmp/portage/dev-qt/qtdeclarative-6.7.0/work/qtdeclarative-everywhere-src-6.7.0/src/qml/jit/qv4baselineassembler.cpp:417:17: error: ‘AccumulatorRegisterTa
g’ was not declared in this scope; did you mean ‘AccumulatorRegister’?
  417 |         store32(AccumulatorRegisterTag, addr);
      |                 ^~~~~~~~~~~~~~~~~~~~~~
      |                 AccumulatorRegister


-----

The problem first appeared in 6.7.0 because qtdeclarative turns JIT on by default now. The workaround is to add `jit' USE flag to the package. Ebuild is (will be) added to this ticket.

Reproducible: Always




Portage 3.0.63 (python 3.11.8-final-0, default/linux/amd64/17.0/x32, gcc-13, glibc-2.38-r10, 6.6.21-gentoo-x64 x86_64)
=================================================================
System uname: Linux-6.6.21-gentoo-x64-x86_64-Intel-R-_Core-TM-2_Duo_CPU_T5670_@_1.80GHz-with-glibc2.38
KiB Mem:     2024900 total,    116356 free
KiB Swap:    2097148 total,   1626616 free
Timestamp of repository gentoo: Thu, 16 May 2024 09:30:00 +0000
Head commit of repository gentoo: 48dc430277044110b90d96a0547d6c1242de2d5a
sh bash 5.1_p16-r6
ld GNU ld (Gentoo 2.41 p5) 2.41.0
distcc 3.4 x86_64-pc-linux-gnux32 [disabled]
app-misc/pax-utils:        1.3.7::gentoo
app-shells/bash:           5.1_p16-r6::gentoo
dev-build/autoconf:        2.71-r6::gentoo
dev-build/automake:        1.16.5-r2::gentoo
dev-build/cmake:           3.28.5::gentoo
dev-build/libtool:         2.4.7-r4::gentoo
dev-build/make:            4.4.1-r1::gentoo
dev-build/meson:           1.4.0-r1::gentoo
dev-java/java-config:      2.3.3-r1::gentoo
dev-lang/perl:             5.38.2-r2::gentoo
dev-lang/python:           2.7.18_p16-r2::gentoo, 3.11.8_p1::gentoo, 3.12.2_p1::gentoo
sys-apps/baselayout:       2.14-r2::gentoo
sys-apps/openrc:           0.54::gentoo
sys-apps/sandbox:          2.38::gentoo
sys-devel/binutils:        2.41-r5::gentoo
sys-devel/binutils-config: 5.5::gentoo
sys-devel/clang:           17.0.6::gentoo
sys-devel/gcc:             13.2.1_p20240210::gentoo
sys-devel/gcc-config:      2.11::gentoo
sys-devel/llvm:            17.0.6::gentoo
sys-kernel/linux-headers:  6.6-r1::gentoo (virtual/os-headers)
sys-libs/glibc:            2.38-r10::gentoo
Repositories:

gentoo
    location: /var/db/repos/gentoo
    sync-type: rsync
    sync-uri: rsync://rsync.gentoo.org/gentoo-portage
    priority: -1000
    volatile: False
    sync-rsync-extra-opts: 
    sync-rsync-verify-max-age: 3
    sync-rsync-verify-metamanifest: yes
    sync-rsync-verify-jobs: 1

local
    location: /var/db/repos/local
    masters: gentoo
    volatile: False

Binary Repositories:

gentoobinhost
    priority: 1
    sync-uri: https://distfiles.gentoo.org/releases/amd64/binpackages/17.0/x32

ACCEPT_KEYWORDS="amd64"
ACCEPT_LICENSE="*"
CBUILD="x86_64-pc-linux-gnux32"
CFLAGS="-O2 -march=core2 -mtune=core2 -pipe -mmmx -msse -msse2 -msse3 -mssse3 -mcx16 -mfpmath=sse -msahf --param l1-cache-size=32 --param l1-cache-line-size=64 --param l2-cache-size=2048 -fno-stack-protector -flto"
CHOST="x86_64-pc-linux-gnux32"
CONFIG_PROTECT="/etc /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 -march=core2 -mtune=core2 -pipe -mmmx -msse -msse2 -msse3 -mssse3 -mcx16 -mfpmath=sse -msahf --param l1-cache-size=32 --param l1-cache-line-size=64 --param l2-cache-size=2048 -fno-stack-protector -flto"
DISTDIR="/var/cache/distfiles"
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 -march=core2 -mtune=core2 -pipe -mmmx -msse -msse2 -msse3 -mssse3 -mcx16 -mfpmath=sse -msahf --param l1-cache-size=32 --param l1-cache-line-size=64 --param l2-cache-size=2048 -fno-stack-protector -flto"
FEATURES="assume-digests binpkg-docompress binpkg-dostrip binpkg-logs binpkg-multi-instance buildpkg-live config-protect-if-modified distlocks ebuild-locks fixlafiles ipc-sandbox merge-sync merge-wait multilib-strict network-sandbox news parallel-fetch pid-sandbox pkgdir-index-trusted preserve-libs protect-owned qa-unresolved-soname-deps sandbox sfperms splitdebug strict unknown-features-warn unmerge-logs unmerge-orphans userfetch userpriv usersandbox usersync xattr"
FFLAGS="-O2 -march=core2 -mtune=core2 -pipe -mmmx -msse -msse2 -msse3 -mssse3 -mcx16 -mfpmath=sse -msahf --param l1-cache-size=32 --param l1-cache-line-size=64 --param l2-cache-size=2048 -fno-stack-protector -flto"
GENTOO_MIRRORS="http://distfiles.gentoo.org"
LANG="uk_UA.UTF-8"
LDFLAGS="-Wl,-O1 -Wl,--as-needed"
LEX="flex"
LINGUAS="en uk"
MAKEOPTS="-j2"
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="X acl alsa amd64 bash-completion bzip2 cli crypt cyrillic dbus dri evdev flac fortran gdbm gpm graphite iconv icu ipv6 jlink-spi libdrm libtirpc lto lvm minizip mp3 mpg123 multilib ncurses nls ogg opengl openh264 openmp opus pam pcre qdbus qml qt6 readline seccomp sixel sndfile split-usr sqlite ssl test-rust theora truetype udev unicode v4l vorbis vpx wavpack xattr xinerama zlib" ABI_X86="x32" ADA_TARGET="gcc_12" APACHE2_MODULES="authn_core authz_core socache_shmcb unixd actions alias auth_basic authn_anon authn_dbm authn_file authz_dbm authz_groupfile authz_host authz_owner authz_user autoindex cache cgi cgid dav dav_fs dav_lock deflate dir env expires ext_filter file_cache filter headers include info log_config logio 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 ssse3" ELIBC="glibc" GPSD_PROTOCOLS="ashtech aivdm earthmate evermore fv18 garmin garmintxt gpsclock greis isync itrax mtk3301 ntrip navcom oceanserver oncore rtcm104v2 rtcm104v3 sirf skytraq superstar2 tsip tripmate tnt ublox" INPUT_DEVICES="evdev synaptics" KERNEL="linux" L10N="en uk" LCD_DEVICES="bayrad cfontz glk hd44780 lb216 lcdm001 mtxorb text" LUA_SINGLE_TARGET="lua5-1" LUA_TARGETS="lua5-1" OFFICE_IMPLEMENTATION="libreoffice" PHP_TARGETS="php8-1" POSTGRES_TARGETS="postgres15" PYTHON_SINGLE_TARGET="python3_11" PYTHON_TARGETS="python3_11" RUBY_TARGETS="ruby31" VIDEO_CARDS="intel i965" XTABLES_ADDONS="quota2 psd pknock lscan length2 ipv4options ipp2p iface geoip fuzzy condition tarpit sysrq proto logmark ipmark dhcpmac delude chaos account"
Unset:  ADDR2LINE, AR, ARFLAGS, AS, ASFLAGS, CC, CCLD, CONFIG_SHELL, CPP, CPPFLAGS, CTARGET, CXX, CXXFILT, ELFEDIT, EMERGE_DEFAULT_OPTS, EXTRA_ECONF, F77FLAGS, FC, GCOV, GPROF, INSTALL_MASK, LC_ALL, LD, LFLAGS, LIBTOOL, MAKE, MAKEFLAGS, NM, OBJCOPY, OBJDUMP, PORTAGE_BINHOST, PORTAGE_BUNZIP2_COMMAND, PORTAGE_COMPRESS, PORTAGE_COMPRESS_FLAGS, PORTAGE_RSYNC_EXTRA_OPTS, PYTHONPATH, RANLIB, READELF, RUSTFLAGS, SIZE, STRINGS, STRIP, YACC, YFLAGS
Comment 1 Andrii Batyiev 2024-05-19 11:43:43 UTC
Created attachment 893369 [details]
Ebuild with a proposed fix
Comment 2 Ionen Wolkens gentoo-dev 2024-05-19 11:51:42 UTC
Sounds good, albeit 6.7.1 is about to release tomorrow (assuming it's not delayed again), may as well add IUSE=+jit only to it to spare most people from having to rebuild 6.7.0.

Will also mask it on x32 profiles.
Comment 3 Ionen Wolkens gentoo-dev 2024-05-19 12:03:23 UTC
(In reply to Ionen Wolkens from comment #2)
> Will also mask it on x32 profiles.
Actually hadn't realized it already is (for Qt5), wonder why USE=jit wasn't kept for Qt6 (maybe just went overlooked, or there was something up with it early on).
Comment 4 Larry the Git Cow gentoo-dev 2024-05-19 12:11:37 UTC
The bug has been referenced in the following commit(s):

https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=a6158554613831c4b7588bf8cd47bb6a6d20bf77

commit a6158554613831c4b7588bf8cd47bb6a6d20bf77
Author:     Ionen Wolkens <ionen@gentoo.org>
AuthorDate: 2024-05-19 12:04:53 +0000
Commit:     Ionen Wolkens <ionen@gentoo.org>
CommitDate: 2024-05-19 12:06:27 +0000

    profiles/arch/amd64/x32: add bugref for qtdeclarative[jit] mask
    
    Bug: https://bugs.gentoo.org/932192
    Signed-off-by: Ionen Wolkens <ionen@gentoo.org>

 profiles/arch/amd64/x32/package.use.mask | 2 +-
 1 file changed, 1 insertion(+), 1 deletion(-)

https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=8ddeae9549b742f100fe46e07f3b50b1c390cae0

commit 8ddeae9549b742f100fe46e07f3b50b1c390cae0
Author:     Ionen Wolkens <ionen@gentoo.org>
AuthorDate: 2024-05-19 11:57:54 +0000
Commit:     Ionen Wolkens <ionen@gentoo.org>
CommitDate: 2024-05-19 12:06:06 +0000

    dev-qt/qtdeclarative: add IUSE=+jit in live (qt6)
    
    Untested, but will be soon for the 6.7.1 release.
    
    Bug: https://bugs.gentoo.org/932192
    Signed-off-by: Ionen Wolkens <ionen@gentoo.org>

 dev-qt/qtdeclarative/qtdeclarative-6.7.9999.ebuild | 3 ++-
 dev-qt/qtdeclarative/qtdeclarative-6.9999.ebuild   | 3 ++-
 2 files changed, 4 insertions(+), 2 deletions(-)
Comment 5 Chiitoo gentoo-dev 2024-05-19 12:50:43 UTC
(In reply to Ionen Wolkens from comment #3)
> (In reply to Ionen Wolkens from comment #2)
> > Will also mask it on x32 profiles.
> Actually hadn't realized it already is (for Qt5), wonder why USE=jit wasn't
> kept for Qt6 (maybe just went overlooked, or there was something up with it
> early on).

Don't think there was any particular reason aside from either it not being there as an option, or I just didn't notice it or something like that.
Comment 6 Larry the Git Cow gentoo-dev 2024-05-19 14:53:24 UTC
The bug has been referenced in the following commit(s):

https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=ad94a24d5dce2ef617a1e716fd57d4499c17d953

commit ad94a24d5dce2ef617a1e716fd57d4499c17d953
Author:     Ionen Wolkens <ionen@gentoo.org>
AuthorDate: 2024-05-19 14:38:17 +0000
Commit:     Ionen Wolkens <ionen@gentoo.org>
CommitDate: 2024-05-19 14:53:07 +0000

    profiles/arch/arm64: unmask >=qtdeclarative-6[jit]
    
    Been looking at existing jit masks given this is not supported
    everywhere, and seen arm64 unmask was missing.
    
    Untested but the configure.cmake should have already have been
    automagic enabling this by default for arm64 w/ 6.7.0 so there
    should be no reason it wouldn't work.
    
    Considered semi-keeping the automagic (aka, either hard-disable
    or let automagic enable if it can), but given USE=jit provides
    some extra headers it *could* be a problem for dependencies that
    use them despite being private.
    
    Limiting to >=6 given have not verified Qt5 (doing >=6 rather
    than :6 given assuming Qt7 will be fine too), and at this
    point would rather not add more worries for 5.
    
    Bug: https://bugs.gentoo.org/932192
    Signed-off-by: Ionen Wolkens <ionen@gentoo.org>

 profiles/arch/arm64/package.use.mask | 4 ++++
 1 file changed, 4 insertions(+)
Comment 7 Larry the Git Cow gentoo-dev 2024-05-20 08:48:57 UTC
The bug has been closed via the following commit(s):

https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=82f78b7280f1572011b2a33cf03e2962f527270c

commit 82f78b7280f1572011b2a33cf03e2962f527270c
Author:     Ionen Wolkens <ionen@gentoo.org>
AuthorDate: 2024-05-20 07:52:47 +0000
Commit:     Ionen Wolkens <ionen@gentoo.org>
CommitDate: 2024-05-20 08:45:27 +0000

    dev-qt/qtdeclarative: add 6.7.1
    
    Closes: https://bugs.gentoo.org/932192
    Signed-off-by: Ionen Wolkens <ionen@gentoo.org>

 dev-qt/qtdeclarative/Manifest                   |  1 +
 dev-qt/qtdeclarative/qtdeclarative-6.7.1.ebuild | 47 +++++++++++++++++++++++++
 2 files changed, 48 insertions(+)