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

Since 1.32.0 compiler cannot run with libfaketime 0.9.7 (jemalloc stack overflow) #60461

Closed
apoelstra opened this issue May 1, 2019 · 6 comments

Comments

@apoelstra
Copy link
Contributor

When running

LD_PRELOAD=/usr/lib64/faketime/libfaketime.so.1 rustc +1.32.0

I get a segfault. This does not happen with 1.31.0. In gdb I see

<snip 89000 lines of repeats, everything between the calloc calls is repeated>
#89781 calloc (num=1, size=32) at /rustc/9fda7c2237db910e41d6a712e9a2139b352e558b/obj/build/x86_64-unknown-linux-gnu/stage1-rustc/x86_64-unknown-linux-gnu/release/build/jemalloc-sys-3e3e6fccf9d297a1/out/jemalloc/src/jemalloc.c:2138
#89782 0x00007ffff722497c in ?? () from /usr/lib/libdl.so.2
#89783 0x00007ffff7224333 in dlsym () from /usr/lib/libdl.so.2
#89784 0x00007ffff7dc3640 in ftpl_init () from /usr/lib64/faketime/libfaketime.so.1
#89785 0x00007ffff7dc7456 in clock_gettime () from /usr/lib64/faketime/libfaketime.so.1
#89786 0x00007ffff78d0a5c in nstime_get (time=0x7fffffffd078) at /rustc/9fda7c2237db910e41d6a712e9a2139b352e558b/obj/build/x86_64-unknown-linux-gnu/stage1-rustc/x86_64-unknown-linux-gnu/release/build/jemalloc-sys-3e3e6fccf9d297a1/out/jemalloc/src/nstime.c:128
#89787 nstime_update_impl (time=0x7fffffffd078) at /rustc/9fda7c2237db910e41d6a712e9a2139b352e558b/obj/build/x86_64-unknown-linux-gnu/stage1-rustc/x86_64-unknown-linux-gnu/release/build/jemalloc-sys-3e3e6fccf9d297a1/out/jemalloc/src/nstime.c:160
#89788 0x00007ffff78d0612 in _rjem_je_malloc_mutex_lock_slow (mutex=0x7ffff7bb21e8 <init_lock>) at /rustc/9fda7c2237db910e41d6a712e9a2139b352e558b/obj/build/x86_64-unknown-linux-gnu/stage1-rustc/x86_64-unknown-linux-gnu/release/build/jemalloc-sys-3e3e6fccf9d297a1/out/jemalloc/src/mutex.c:70
#89789 0x00007ffff789d3d1 in malloc_mutex_lock (tsdn=<optimized out>, mutex=<optimized out>) at /rustc/9fda7c2237db910e41d6a712e9a2139b352e558b/obj/build/x86_64-unknown-linux-gnu/stage1-rustc/x86_64-unknown-linux-gnu/release/build/jemalloc-sys-3e3e6fccf9d297a1/out/jemalloc/include/jemalloc/internal/mutex.h:205
#89790 malloc_init_hard () at /rustc/9fda7c2237db910e41d6a712e9a2139b352e558b/obj/build/x86_64-unknown-linux-gnu/stage1-rustc/x86_64-unknown-linux-gnu/release/build/jemalloc-sys-3e3e6fccf9d297a1/out/jemalloc/src/jemalloc.c:1506
#89791 malloc_init () at /rustc/9fda7c2237db910e41d6a712e9a2139b352e558b/obj/build/x86_64-unknown-linux-gnu/stage1-rustc/x86_64-unknown-linux-gnu/release/build/jemalloc-sys-3e3e6fccf9d297a1/out/jemalloc/src/jemalloc.c:217
#89792 imalloc (sopts=<optimized out>, dopts=<optimized out>) at /rustc/9fda7c2237db910e41d6a712e9a2139b352e558b/obj/build/x86_64-unknown-linux-gnu/stage1-rustc/x86_64-unknown-linux-gnu/release/build/jemalloc-sys-3e3e6fccf9d297a1/out/jemalloc/src/jemalloc.c:1986
#89793 calloc (num=1, size=32) at /rustc/9fda7c2237db910e41d6a712e9a2139b352e558b/obj/build/x86_64-unknown-linux-gnu/stage1-rustc/x86_64-unknown-linux-gnu/release/build/jemalloc-sys-3e3e6fccf9d297a1/out/jemalloc/src/jemalloc.c:2138
#89794 0x00007ffff722497c in ?? () from /usr/lib/libdl.so.2
#89795 0x00007ffff7224333 in dlsym () from /usr/lib/libdl.so.2
#89796 0x00007ffff7dc3640 in ftpl_init () from /usr/lib64/faketime/libfaketime.so.1
#89797 0x00007ffff7dc7456 in clock_gettime () from /usr/lib64/faketime/libfaketime.so.1
#89798 0x00007ffff78d0a5c in nstime_get (time=0x7ffff0e03b18) at /rustc/9fda7c2237db910e41d6a712e9a2139b352e558b/obj/build/x86_64-unknown-linux-gnu/stage1-rustc/x86_64-unknown-linux-gnu/release/build/jemalloc-sys-3e3e6fccf9d297a1/out/jemalloc/src/nstime.c:128
#89799 nstime_update_impl (time=0x7ffff0e03b18) at /rustc/9fda7c2237db910e41d6a712e9a2139b352e558b/obj/build/x86_64-unknown-linux-gnu/stage1-rustc/x86_64-unknown-linux-gnu/release/build/jemalloc-sys-3e3e6fccf9d297a1/out/jemalloc/src/nstime.c:160
#89800 0x00007ffff78aca7a in arena_decay_reinit (decay=0x7ffff0e03a98, decay_ms=<optimized out>) at /rustc/9fda7c2237db910e41d6a712e9a2139b352e558b/obj/build/x86_64-unknown-linux-gnu/stage1-rustc/x86_64-unknown-linux-gnu/release/build/jemalloc-sys-3e3e6fccf9d297a1/out/jemalloc/src/arena.c:572
#89801 arena_decay_init (decay=0x7ffff0e03a98, decay_ms=<optimized out>, stats=0x7ffff0e009a0) at /rustc/9fda7c2237db910e41d6a712e9a2139b352e558b/obj/build/x86_64-unknown-linux-gnu/stage1-rustc/x86_64-unknown-linux-gnu/release/build/jemalloc-sys-3e3e6fccf9d297a1/out/jemalloc/src/arena.c:593
#89802 _rjem_je_arena_new (tsdn=0x0, ind=0, extent_hooks=<optimized out>) at /rustc/9fda7c2237db910e41d6a712e9a2139b352e558b/obj/build/x86_64-unknown-linux-gnu/stage1-rustc/x86_64-unknown-linux-gnu/release/build/jemalloc-sys-3e3e6fccf9d297a1/out/jemalloc/src/arena.c:1858
#89803 0x00007ffff78a7b7c in arena_init_locked (ind=0, extent_hooks=0x0, tsdn=<optimized out>) at /rustc/9fda7c2237db910e41d6a712e9a2139b352e558b/obj/build/x86_64-unknown-linux-gnu/stage1-rustc/x86_64-unknown-linux-gnu/release/build/jemalloc-sys-3e3e6fccf9d297a1/out/jemalloc/src/jemalloc.c:334
#89804 _rjem_je_arena_init (ind=0, tsdn=<optimized out>, extent_hooks=<optimized out>) at /rustc/9fda7c2237db910e41d6a712e9a2139b352e558b/obj/build/x86_64-unknown-linux-gnu/stage1-rustc/x86_64-unknown-linux-gnu/release/build/jemalloc-sys-3e3e6fccf9d297a1/out/jemalloc/src/jemalloc.c:362
#89805 malloc_init_hard_a0_locked () at /rustc/9fda7c2237db910e41d6a712e9a2139b352e558b/obj/build/x86_64-unknown-linux-gnu/stage1-rustc/x86_64-unknown-linux-gnu/release/build/jemalloc-sys-3e3e6fccf9d297a1/out/jemalloc/src/jemalloc.c:1324
#89806 0x00007ffff78a648b in malloc_init_hard () at /rustc/9fda7c2237db910e41d6a712e9a2139b352e558b/obj/build/x86_64-unknown-linux-gnu/stage1-rustc/x86_64-unknown-linux-gnu/release/build/jemalloc-sys-3e3e6fccf9d297a1/out/jemalloc/src/jemalloc.c:1517
#89807 malloc_init () at /rustc/9fda7c2237db910e41d6a712e9a2139b352e558b/obj/build/x86_64-unknown-linux-gnu/stage1-rustc/x86_64-unknown-linux-gnu/release/build/jemalloc-sys-3e3e6fccf9d297a1/out/jemalloc/src/jemalloc.c:217
#89808 jemalloc_constructor () at /rustc/9fda7c2237db910e41d6a712e9a2139b352e558b/obj/build/x86_64-unknown-linux-gnu/stage1-rustc/x86_64-unknown-linux-gnu/release/build/jemalloc-sys-3e3e6fccf9d297a1/out/jemalloc/src/jemalloc.c:3184
#89809 0x00007ffff7fe354a in call_init.part () from /lib64/ld-linux-x86-64.so.2
#89810 0x00007ffff7fe364a in _dl_init () from /lib64/ld-linux-x86-64.so.2
#89811 0x00007ffff7fd503a in _dl_start_user () from /lib64/ld-linux-x86-64.so.2
#89812 0x0000000000000002 in ?? ()
#89813 0x00007fffffffe91a in ?? ()
#89814 0x00007fffffffe967 in ?? ()
#89815 0x0000000000000000 in ?? ()

May be related to wolfcw/libfaketime#130

@jonas-schievink jonas-schievink added the T-compiler Relevant to the compiler team, which will review and decide on the PR/issue. label May 2, 2019
@jonas-schievink
Copy link
Contributor

This is very likely to just be wolfcw/libfaketime#130, so maybe we should close in favor of that? libfaketime has never really been an officially supported environment for rustc

@apoelstra
Copy link
Contributor Author

The libfaketime issue has been open for over a year with no activity. Meanwhile it was only triggered by a recent change in rustc.

Are you aware of any way to achieve deterministic builds without libfaketime? It would be unfortunate to leave users who require determinism stuck on 1.31.

@jonas-schievink
Copy link
Contributor

Perhaps 1.32.0 was the release Rust binaries used the system allocator by default? In that case the compiler would've also started to opt into jemalloc via jemallocator, which probably bumped jemalloc's version to one exposing the issue.

There's a few issues relating to reproducible builds, eg. #34902 for a sort of meta-issue, as well as specific bugs and regressions like #59542 and #57041.

@mati865
Copy link
Contributor

mati865 commented Jul 19, 2019

Rust was using jemalloc before 1.32.0 but an old version. Recent jemalloc versions have additional optimisations that clash with libfaketime.

There is nothing to be done on the Rust front, either libfaketime has to fix the issue or jemalloc could implement workaround.

@jonas-schievink jonas-schievink added the A-reproducibility Area: Reproducible / deterministic builds label Aug 19, 2019
dagurval added a commit to dagurval/ElectrsCash that referenced this issue Aug 28, 2019
Rustc with faketime is broken in recent releases, and this check seems
to work fine without.

More about the issue:
rust-lang/rust#60461
dagurval added a commit to dagurval/ElectrsCash that referenced this issue Aug 28, 2019
Rustc with faketime is broken in recent releases, and this check seems
to work fine without.

More about the issue:
rust-lang/rust#60461
@gwillen
Copy link
Contributor

gwillen commented Aug 12, 2020

Just to come back to this for anybody who may read it in the future -- I can't actually tell if it is ever required to use libfaketime with current rustc, in order to get deterministic builds. (I think it's pretty good about not including the time in the output anywhere. It's not totally clear to me whether it was even required at the time we were trying to do it in the first place.) In which case this issue may not actually be an issue?

@jieyouxu
Copy link
Member

Closing as this does not look like anything that rustc can do on our side, and may have to rely on libfaketime and jemalloc to coordinate instead.

@jieyouxu jieyouxu closed this as not planned Won't fix, can't repro, duplicate, stale Aug 14, 2024
@jieyouxu jieyouxu removed A-reproducibility Area: Reproducible / deterministic builds T-compiler Relevant to the compiler team, which will review and decide on the PR/issue. labels Aug 14, 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

5 participants