-
Notifications
You must be signed in to change notification settings - Fork 2.5k
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
i686-unknown-linux-gnu/bin/cargo: error while loading shared libraries: libatomic.so.1 #13546
Comments
This comment was marked as resolved.
This comment was marked as resolved.
That is an old year in the image name. What's the glibc version? We only support kernel 3.2+, glibc 2.17+ as listed in https://doc.rust-lang.org/nightly/rustc/platform-support.html |
It's a CentOS 7 which has glibc 2.17, since it's running in Docker on Ubuntu 22.04, it should have a newer kernel version than 3.2. # uname -a
Linux 2d9d45df5509 5.19.0-1029-aws rust-lang/rust#30~22.04.1-Ubuntu SMP Thu Jul 13 17:17:32 UTC 2023 i686 i686 i386 GNU/Linux
# rustc -vV
rustc 1.78.0-nightly (d18480b84 2024-03-04)
binary: rustc
commit-hash: d18480b84fdbf1efc34f62070951334aa833d761
commit-date: 2024-03-04
host: i686-unknown-linux-gnu
release: 1.78.0-nightly
LLVM version: 18.1.0
# # cargo
/root/.rustup/toolchains/nightly-i686-unknown-linux-gnu/bin/cargo: error while loading shared libraries: libatomic.so.1: cannot open shared object file: No such file or directory
# # ldd /root/.rustup/toolchains/nightly-i686-unknown-linux-gnu/bin/cargo
linux-gate.so.1 => (0xf7f0e000)
libdl.so.2 => /lib/libdl.so.2 (0xf621c000)
libatomic.so.1 => not found
libgcc_s.so.1 => /lib/libgcc_s.so.1 (0xf6201000)
librt.so.1 => /lib/librt.so.1 (0xf61f7000)
libpthread.so.0 => /lib/libpthread.so.0 (0xf61dc000)
libm.so.6 => /lib/libm.so.6 (0xf619a000)
libc.so.6 => /lib/libc.so.6 (0xf5fcf000)
/lib/ld-linux.so.2 (0xf7f10000)
# ldd --version
ldd (GNU libc) 2.17 |
cc @weihanglo in case you know something about this. |
For comparison, Rust stable (1.76.0 ATM) works fine: # ~/.rustup/toolchains/stable-i686-unknown-linux-gnu/bin/cargo -vV
cargo 1.76.0 (c84b36747 2024-01-18)
release: 1.76.0
commit-hash: c84b367471a2db61d2c2c6aab605b14130b8a31b
commit-date: 2024-01-18
host: i686-unknown-linux-gnu
libgit2: 1.7.1 (sys:0.18.1 vendored)
libcurl: 8.5.0-DEV (sys:0.4.70+curl-8.5.0 vendored ssl:OpenSSL/1.1.1w)
ssl: OpenSSL 1.1.1w 11 Sep 2023
os: CentOS 7.0.0 [32-bit]
# ldd ~/.rustup/toolchains/stable-i686-unknown-linux-gnu/bin/cargo
linux-gate.so.1 => (0xf7f2a000)
libdl.so.2 => /lib/libdl.so.2 (0xf6156000)
libgcc_s.so.1 => /lib/libgcc_s.so.1 (0xf613b000)
librt.so.1 => /lib/librt.so.1 (0xf6132000)
libpthread.so.0 => /lib/libpthread.so.0 (0xf6116000)
libm.so.6 => /lib/libm.so.6 (0xf60d4000)
libc.so.6 => /lib/libc.so.6 (0xf5f09000)
/lib/ld-linux.so.2 (0xf7f2c000) |
This is the bad Cargo submodule update rust-lang/rust#121214. It is very likely that OpenSSL v3 did something differently than v1. |
Probably this openssl/openssl#23376? |
sfackler/rust-openssl#2163 and I mentioned it earlier in #13449 (comment) |
This seems to happen again in
|
chore: downgrade to openssl v1.1.1 (again) Accidentally updated by <#13674> See #13546 (comment)
Seems like this is happening again in See PyO3/maturin-action#283 and https://github.com/Warthunder-Open-Source-Foundation/wt_blk/actions/runs/10321002590/job/28572852583#step:4:196 |
That was me overlooking it again: #14299 |
chore: downgrade to openssl v1.1.1 (again) It happened again in <#14299>. See <#13546 (comment)> and <#13731>.
@messense should have been fixed via #14391 and rust-lang/rust#129066. |
openssl/openssl#23376 has been fixed via openssl/openssl@2fd6c12 and released with OpenSSL v3.4.0. If that is the root cause, the atomic problem should be resolved. The next step will be
|
Reopen this to track the progress of upgrading to OpenSSL v3. |
Let me jot down what I've found so far, for building OpenSSL v3.41 into Cargo with rust-lang CI.
The potential reason is that we set It has been more than one year since OpenSSL v1.1.1 EOL (2023-09-11), we should take action on this, either try harder upgrading to OpenSSL v3, or find an alternative like rustls or aws-lc. See also how rustup struggles to upgrade OpenSSL rust-lang/rustup#3790. Footnotes
|
# This is the 1st commit message: chore: remove x86 support (rust-lang/cargo#13546) # The commit message #2 will be skipped: # ci: try dnf install gcc? # The commit message #3 will be skipped: # ci: try manylinux2014
is it possible to temporarily pin openssl to 1.0.66? openssl has a vulnerability prior to 1.0.66, i don't know if this affect the cargo code base. |
I don't think so. In Cargo we only call |
* feat: init a repo for default use_case template * fix: pr suggestions * feat: create repo after cloning template & commit after tests * chore: remove x86 support (rust-lang/cargo#13546) * ci: uselibgit2-dev only * fix: remove commit * chore: cleanup & test ci without ssl feature * fix: remove openssl and warm user if we can't set a git repo
When running
cargo
in aquay.io/pypa/manylinux2014_i686:latest
Docker container, it gives the following errorIs
libatomic.so.1
a hard requirement for cargo now?Meta
rustc --version --verbose
:The text was updated successfully, but these errors were encountered: