Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

verify shlib errors on partial upgrade bypassed by multilib #580

Open
oreo639 opened this issue Jan 4, 2024 · 0 comments
Open

verify shlib errors on partial upgrade bypassed by multilib #580

oreo639 opened this issue Jan 4, 2024 · 0 comments

Comments

@oreo639
Copy link
Member

oreo639 commented Jan 4, 2024

When performing shlib checks before upgrading, libraries provided by 32bit packages are treated the same as libraries provided by 64bit packages. This can result in system breakage on partial upgrades without warning as noticed on the r/voidlinux subreddit: https://www.reddit.com/r/voidlinux/comments/18r0swm/psa_libxcrypt_updates/

I verified this behavior using the following:

  1. Download testpkgs.zip
  2. Run ./setup.sh
  3. In the cloned void-packages repo run:
./xbps-src binary-bootstrap
./xbps-src -m masterdir-i686 binary-bootstrap i686
./xbps-src pkg libhelloworld
./xbps-src -m masterdir-i686 pkg libhelloworld
./xbps-src pkg test1
xi test1
  1. You can run test1 and it will output hello world 7 as expected.
  2. After that, modify the libhelloworld package to not install libhelloworld.so.1 and build it as version=2 (do not build the 32bit package with this change).
  3. When doing xi -u, you will receive a shlibs error as expected. test1-1_1: broken, unresolvable shlib 'libhelloworld.so.1'
  4. Run xi libhelloworld-32bit
  5. Now run xi -u again, you will not receive any warnings and the upgrade will proceed as normal.
  6. Confirm the breakage of test1 as running it now outputs test1: error while loading shared libraries: libhelloworld.so.1: cannot open shared object file: No such file or directory

Ideally, xbps should be able to detect that the libraries provided by 32bit packages are not applicable to 64bit applications and visa-versa.

@oreo639 oreo639 changed the title shlib errors on partial upgrade bypassed by multilib verify shlib errors on partial upgrade bypassed by multilib Jan 4, 2024
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

No branches or pull requests

1 participant