Gentoo Websites Logo
Go to: Gentoo Home Documentation Forums Lists Bugs Planet Store Wiki Get Gentoo!
Bug 764623 - Circular dependency with Python 3.9 bluetooth on a default 17.1 install following the AMD64 manual
Summary: Circular dependency with Python 3.9 bluetooth on a default 17.1 install follo...
Status: RESOLVED FIXED
Alias: None
Product: Gentoo Linux
Classification: Unclassified
Component: Profiles (show other bugs)
Hardware: AMD64 Linux
: Normal normal with 1 vote (vote)
Assignee: Gentoo Release Team
URL:
Whiteboard:
Keywords:
: 794058 (view as bug list)
Depends on:
Blocks:
 
Reported: 2021-01-09 14:39 UTC by James Lochhead
Modified: 2022-04-18 00:05 UTC (History)
5 users (show)

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


Attachments
emerge -p -uvDU @world (emerge_output,29.61 KB, text/plain)
2021-01-09 14:47 UTC, James Lochhead
Details

Note You need to log in before you can comment on or make changes to this bug.
Description James Lochhead 2021-01-09 14:39:42 UTC
Hello,

New Gentoo user here. I recently did my first experimental install, following the AMD64 manual to the letter using profile 6 and the latest stable stage 3 tarballs, on a spare SSD. I got an error while trying to do my first `emerge --ask --verbose --update --deep --newuse @world`. I am now on my second install, this time a bit more elaborate, with profile 7 and the latest stage 3 tarballs, and I am getting the same error.

The error is as follows:
```
It might be possible to break this cycle
by applying any of the following changes:
- net-wireless/bluez-5.55 (Change USE: -systemd)
- sys-apps/dbus-1.12.20-r1 (Change USE: -X)
- dev-lang/python-3.9.0-r1 (Change USE: -bluetooth)
```

On my first install, I successfully worked around it by:
```
echo "dev-lang/python -bluetooth" >> /etc/portage/package.use/python
```

Further info:
```
(chroot) livecd / # emerge --info
Portage 3.0.12 (python 3.8.6-final-0, default/linux/amd64/17.1/desktop/gnome/systemd, gcc-9.3.0, glibc-2.32-r3, 5.4.80-gentoo-r1-x86_64 x86_64)
=================================================================
System uname: Linux-5.4.80-gentoo-r1-x86_64-x86_64-Intel-R-_Core-TM-_i7-2700K_CPU_@_3.50GHz-with-glibc2.2.5
KiB Mem:     8142804 total,   4080436 free
KiB Swap:    8388604 total,   8388604 free
Timestamp of repository gentoo: Sat, 09 Jan 2021 13:30:01 +0000
Head commit of repository gentoo: 549bf053ad89f5f65eb925b7d6fb5c6b5d890933
sh bash 5.0_p18
ld GNU ld (Gentoo 2.34 p6) 2.34.0
app-shells/bash:          5.0_p18::gentoo
dev-lang/perl:            5.30.3::gentoo
dev-lang/python:          3.8.6-r1::gentoo
dev-util/cmake:           3.17.4-r1::gentoo
sys-apps/baselayout:      2.7::gentoo
sys-apps/sandbox:         2.20::gentoo
sys-devel/autoconf:       2.69-r5::gentoo
sys-devel/automake:       1.16.2-r1::gentoo
sys-devel/binutils:       2.34-r2::gentoo
sys-devel/gcc:            9.3.0-r2::gentoo
sys-devel/gcc-config:     2.3.2-r1::gentoo
sys-devel/libtool:        2.4.6-r6::gentoo
sys-devel/make:           4.3::gentoo
sys-kernel/linux-headers: 5.4-r1::gentoo (virtual/os-headers)
sys-libs/glibc:           2.32-r3::gentoo
Repositories:

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

ACCEPT_KEYWORDS="amd64"
ACCEPT_LICENSE="@FREE @GPL-COMPATIBLE @BINARY-REDISTRIBUTABLE @EULA"
CBUILD="x86_64-pc-linux-gnu"
CFLAGS=""
CHOST="x86_64-pc-linux-gnu"
CONFIG_PROTECT="/etc /usr/share/gnupg/qualified.txt"
CONFIG_PROTECT_MASK="/etc/ca-certificates.conf /etc/env.d /etc/gconf /etc/gentoo-release /etc/sandbox.d /etc/terminfo"
CXXFLAGS=""
DISTDIR="/var/cache/distfiles"
ENV_UNSET="CARGO_HOME DBUS_SESSION_BUS_ADDRESS DISPLAY 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"
FCFLAGS=""
FEATURES="assume-digests binpkg-docompress binpkg-dostrip binpkg-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 strict unknown-features-warn unmerge-logs unmerge-orphans userfetch userpriv usersandbox usersync xattr"
FFLAGS=""
GENTOO_MIRRORS="https://mirror.bytemark.co.uk/gentoo/ https://mirrors.gethosted.online/gentoo"
LANG="C.UTF8"
LDFLAGS="-Wl,-O1 -Wl,--as-needed"
MAKEOPTS="-j4"
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"
USE="X a52 aac acl acpi alsa amd64 berkdb bluetooth branding bzip2 cairo cdda cdr cli colord crypt cups dbus dri dts dvd dvdr eds emboss encode evo exif flac fortran gdbm gif gnome gnome-keyring gnome-online-accounts gpm gstreamer gtk gui iconv icu introspection ipv6 jpeg lcms libglvnd libnotify libsecret libtirpc mad mng mp3 mp4 mpeg multilib nautilus ncurses networkmanager nls nptl nvidia ogg opengl openmp pam pango pcre pdf png policykit ppds pulseaudio qt5 readline sdl seccomp spell split-usr ssl startup-notification svg sysprof systemd tcpd tiff tracker truetype udev udisks unicode upower usb vorbis wayland wxwidgets x264 xattr xcb xml xv xvid zlib" ABI_X86="64" ADA_TARGET="gnat_2018" 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="karbon sheets words" COLLECTD_PLUGINS="df interface irq load memory rrdtool swap syslog" CPU_FLAGS_X86="mmx mmxext sse sse2" 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" INPUT_DEVICES="libinput" KERNEL="linux" LCD_DEVICES="bayrad cfontz cfontz633 glk hd44780 lb216 lcdm001 mtxorb ncurses text" LIBREOFFICE_EXTENSIONS="presenter-console presenter-minimizer" LUA_SINGLE_TARGET="lua5-1" LUA_TARGETS="lua5-1" OFFICE_IMPLEMENTATION="libreoffice" PHP_TARGETS="php7-3 php7-4" POSTGRES_TARGETS="postgres10 postgres11" PYTHON_SINGLE_TARGET="python3_8" PYTHON_TARGETS="python2_7 python3_8" RUBY_TARGETS="ruby25 ruby26" USERLAND="GNU" VIDEO_CARDS="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:  CC, CPPFLAGS, CTARGET, CXX, EMERGE_DEFAULT_OPTS, INSTALL_MASK, LC_ALL, LINGUAS, PORTAGE_BINHOST, PORTAGE_BUNZIP2_COMMAND, PORTAGE_COMPRESS, PORTAGE_COMPRESS_FLAGS, PORTAGE_RSYNC_EXTRA_OPTS
```
Comment 1 Sam James archtester Gentoo Infrastructure gentoo-dev Security 2021-01-09 14:40:48 UTC
This is a frustrating one that seems to have become more common recently.

The full emerge output would be helpful if you could get it, with emerge -p -uvDU @world, just to see what is actually being pulled in.

You also left out the actual cycle bit, I believe.
Comment 2 James Lochhead 2021-01-09 14:42:08 UTC
Noticed I missed some of the error text:
```
 * Error: circular dependencies:

(sys-apps/dbus-1.12.20-r1:0/0::gentoo, ebuild scheduled for merge) depends on
 (x11-libs/libX11-1.7.0:0/0::gentoo, ebuild scheduled for merge) (buildtime)
  (x11-libs/libxcb-1.14:0/1.12::gentoo, ebuild scheduled for merge) (buildtime)
   (dev-lang/python-3.9.0-r1:3.9/3.9::gentoo, ebuild scheduled for merge) (buildtime)
    (net-wireless/bluez-5.55:0/3::gentoo, ebuild scheduled for merge) (buildtime)
     (sys-apps/dbus-1.12.20-r1:0/0::gentoo, ebuild scheduled for merge) (buildtime_slot_op)

It might be possible to break this cycle
by applying any of the following changes:
- net-wireless/bluez-5.55 (Change USE: -systemd)
- sys-apps/dbus-1.12.20-r1 (Change USE: -X)
- dev-lang/python-3.9.0-r1 (Change USE: -bluetooth)
```
Comment 3 James Lochhead 2021-01-09 14:47:09 UTC
Created attachment 682099 [details]
emerge -p -uvDU @world

Please find the requested output of `emerge -p -uvDU @world` attached.
Comment 4 Sam James archtester Gentoo Infrastructure gentoo-dev Security 2021-01-09 14:49:28 UTC
Perfect, thank you!

(Assigned to releng and CCed python@ to see if we can do anything about included packages, but I'm not sure how likely that is.

There is another Python one I've seen more recently which may be fixable (involving CMake?)).
Comment 5 Ben Kohler gentoo-dev 2021-01-09 15:05:37 UTC
I wonder if we should just put "dev-lang/python -bluetooth" into desktop profiles' package.use
Comment 6 Brian Evans (RETIRED) gentoo-dev 2021-01-09 15:10:48 UTC
This is profile selection issue possibly combined with bug 702806.

The base profile will not have any issue.

With the X and bluetooth USE being enabled in the desktop target, this rears its head.

One workaround would be to add 'dev-lang/python -bluetooth' to desktop profile's package.use
Comment 7 Brian Evans (RETIRED) gentoo-dev 2021-01-12 17:49:51 UTC
As discussed in IRC, this will also combine with a circular dep with sqlite on python:3.9.

There was a note that sqlite may become default on python or system in the near future.

Until full decisions are made, the current suggested workaround is to add '--exclude dev-lang/python:3.9' to the emerge command. This removes any circular build dependency related to python from stage3.
Comment 8 James Lochhead 2021-01-14 23:16:18 UTC
Just a note that my original workaround no longer works with the latest stage 3 tarballs.

When using Brian's alternative workaround, I get past emerge complaining about circulars.
Comment 9 Sam James archtester Gentoo Infrastructure gentoo-dev Security 2021-06-03 19:34:01 UTC
*** Bug 794058 has been marked as a duplicate of this bug. ***
Comment 10 Toralf Förster gentoo-dev 2021-06-21 08:51:27 UTC
side note: at my tinderbox I need in addition:

# setup dependency issues
dev-db/sqlite             -icu
Comment 11 Larry the Git Cow gentoo-dev 2022-04-18 00:05:04 UTC
The bug has been closed via the following commit(s):

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

commit 6d175a2178b78d92d044298e24ed41b3155fa9e0
Author:     Andreas K. Hüttel <dilfridge@gentoo.org>
AuthorDate: 2022-04-18 00:03:31 +0000
Commit:     Andreas K. Hüttel <dilfridge@gentoo.org>
CommitDate: 2022-04-18 00:04:53 +0000

    profiles/targets/desktop: default to python[-bluetooth]
    
    This works around a circular dependency on install.
    
    Closes: https://bugs.gentoo.org/764623
    Signed-off-by: Andreas K. Hüttel <dilfridge@gentoo.org>

 profiles/targets/desktop/package.use | 4 ++++
 1 file changed, 4 insertions(+)