rust-lang / rust

Empowering everyone to build reliable and efficient software.
https://www.rust-lang.org
Other
96.24k stars 12.45k forks source link

error: found unstable fingerprints for evaluate_obligation #83291

Open AurevoirXavier opened 3 years ago

AurevoirXavier commented 3 years ago

Code

Meta

rustc --version --verbose:

xavier on xavier.zone in common at  rococo-v1 <!?> via 𝓡 v1.52.0-nightly takes 1m6s
Fri Mar 19 13:14:22 2021 - 50%
✗ rustc --version --verbose
rustc 1.52.0-nightly (1705a7d64 2021-03-18)
binary: rustc
commit-hash: 1705a7d64b833d1c4b69958b0627bd054e6d764b
commit-date: 2021-03-18
host: x86_64-unknown-linux-gnu
release: 1.52.0-nightly
LLVM version: 12.0.0

Error output

xavier on xavier.zone in common at  rococo-v1 <!?> via 𝓡 v1.52.0-nightly takes 13ms
Fri Mar 19 13:12:30 2021 - 45%
λ cargo b --release                     
   Compiling darwinia-ethereum-relay v2.0.0 (/home/xavier/Documents/darwinia-network/common/frame/bridge/ethereum/relay)
   Compiling darwinia-ethereum-linear-relay v2.0.0 (/home/xavier/Documents/darwinia-network/common/frame/bridge/ethereum/linear-relay)
   Compiling pangolin-runtime v2.0.0 (/home/xavier/Documents/darwinia-network/common/bin/node/runtime/pangolin)
thread 'rustc' panicked at 'found unstable fingerprints for evaluate_obligation(1746fd5d1304336-c1d2d55e63e10b17)', /rustc/1705a7d64b833d1c4b69958b0627bd054e6d764b/compiler/rustc_query_system/src/query/plumbing.rs:593:5
note: run with `RUST_BACKTRACE=1` environment variable to display a backtrace

error: internal compiler error: unexpected panic

note: the compiler unexpectedly panicked. this is a bug.

note: we would appreciate a bug report: https://github.com/rust-lang/rust/issues/new?labels=C-bug%2C+I-ICE%2C+T-compiler&template=ice.md

note: rustc 1.52.0-nightly (1705a7d64 2021-03-18) running on x86_64-unknown-linux-gnu

note: compiler flags: -C opt-level=3 -C embed-bitcode=no -C incremental --crate-type lib

note: some of the compiler flags provided by cargo are hidden

query stack during panic:
#0 [evaluate_obligation] evaluating trait selection obligation `impls::DealWithFees: sp_api_hidden_includes_construct_runtime::hidden_include::traits::OnUnbalanced<darwinia_balances::NegativeImbalance<Runtime, darwinia_balances::Instance0>>`
#1 [normalize_projection_ty] normalizing `Canonical { max_universe: U0, variables: [], value: ParamEnvAnd { param_env: ParamEnv { caller_bounds: [], reveal: All }, value: ProjectionTy { substs: [pallet_transaction_payment::CurrencyAdapter<darwinia_balances::Module<Runtime, darwinia_balances::Instance0>, impls::DealWithFees>, Runtime], item_def_id: DefId(394:165 ~ pallet_transaction_payment[3044]::payment::OnChargeTransaction::Balance) } } }`
end of query stack
error: could not compile `pangolin-runtime`

To learn more, run the command again with --verbose.
Backtrace

``` xavier on xavier.zone in common at  rococo-v1 via 𝓡 v1.52.0-nightly takes 62ms Fri Mar 19 13:14:24 2021 - 46% λ RUST_BACKTRACE=1 cargo b --release Compiling librocksdb-sys v6.11.4 Compiling sc-network v0.9.0 (https://github.com/darwinia-network/substrate.git?tag=rococo-v1.1#645299e8) Compiling pangolin-runtime v2.0.0 (/home/xavier/Documents/darwinia-network/common/bin/node/runtime/pangolin) thread 'rustc' panicked at 'found unstable fingerprints for evaluate_obligation(1746fd5d1304336-c1d2d55e63e10b17)', /rustc/1705a7d64b833d1c4b69958b0627bd054e6d764b/compiler/rustc_query_system/src/query/plumbing.rs:593:5 stack backtrace: 0: rust_begin_unwind at /rustc/1705a7d64b833d1c4b69958b0627bd054e6d764b/library/std/src/panicking.rs:493:5 1: std::panicking::begin_panic_fmt at /rustc/1705a7d64b833d1c4b69958b0627bd054e6d764b/library/std/src/panicking.rs:435:5 2: rustc_query_system::query::plumbing::incremental_verify_ich 3: rustc_query_system::query::plumbing::load_from_disk_and_cache_in_memory 4: rustc_data_structures::stack::ensure_sufficient_stack 5: rustc_query_system::query::plumbing::get_query_impl 6: ::evaluate_obligation 7: ::evaluate_obligation 8: ::evaluate_obligation_no_overflow 9: rustc_trait_selection::traits::fulfill::FulfillProcessor::process_trait_obligation 10: rustc_trait_selection::traits::fulfill::FulfillProcessor::progress_changed_obligations 11: rustc_data_structures::obligation_forest::ObligationForest::process_obligations 12: ::select_where_possible 13: ::enter_canonical_trait_query 14: rustc_traits::normalize_projection_ty::normalize_projection_ty 15: rustc_query_impl:: for rustc_query_impl::queries::normalize_projection_ty>::compute 16: rustc_query_system::query::config::QueryVtable::compute 17: rustc_middle::dep_graph::::with_deps 18: rustc_query_system::dep_graph::graph::DepGraph::with_ignore 19: rustc_query_system::query::plumbing::load_from_disk_and_cache_in_memory 20: rustc_data_structures::stack::ensure_sufficient_stack 21: rustc_query_system::query::plumbing::get_query_impl 22: ::normalize_projection_ty 23: ::fold_ty 24: rustc_middle::ty::fold::TypeFoldable::fold_with 25: rustc_middle::ty::structural_impls::::super_fold_with 26: ::fold_ty 27: rustc_middle::ty::fold::TypeFoldable::fold_with 28: rustc_middle::ty::structural_impls::::super_fold_with 29: ::fold_ty 30: ::normalize 31: rustc_infer::infer::InferCtxtBuilder::enter 32: rustc_traits::normalize_erasing_regions::normalize_generic_arg_after_erasing_regions 33: rustc_middle::dep_graph::::with_deps 34: rustc_query_system::dep_graph::graph::DepGraph::with_ignore 35: rustc_query_system::query::plumbing::load_from_disk_and_cache_in_memory 36: rustc_data_structures::stack::ensure_sufficient_stack 37: rustc_query_system::query::plumbing::get_query_impl 38: ::normalize_generic_arg_after_erasing_regions 39: ::fold_ty 40: rustc_middle::ty::instance::Instance::subst_mir_and_normalize_erasing_regions 41: ::visit_terminator 42: rustc_mir::monomorphize::collector::collect_neighbours 43: rustc_mir::monomorphize::collector::collect_items_rec 44: rustc_mir::monomorphize::collector::collect_items_rec 45: rustc_mir::monomorphize::collector::collect_items_rec 46: rustc_mir::monomorphize::collector::collect_items_rec 47: rustc_mir::monomorphize::collector::collect_items_rec 48: rustc_mir::monomorphize::collector::collect_items_rec 49: rustc_mir::monomorphize::collector::collect_items_rec 50: rustc_mir::monomorphize::collector::collect_items_rec 51: rustc_mir::monomorphize::collector::collect_items_rec 52: rustc_mir::monomorphize::collector::collect_items_rec 53: rustc_mir::monomorphize::collector::collect_items_rec 54: rustc_mir::monomorphize::collector::collect_items_rec 55: rustc_mir::monomorphize::collector::collect_crate_mono_items 56: rustc_mir::monomorphize::partitioning::collect_and_partition_mono_items 57: rustc_query_impl:: for rustc_query_impl::queries::collect_and_partition_mono_items>::compute 58: rustc_middle::dep_graph::::with_deps 59: rustc_query_system::dep_graph::graph::DepGraph::with_task_impl 60: rustc_data_structures::stack::ensure_sufficient_stack 61: rustc_query_system::query::plumbing::force_query_with_job 62: rustc_query_system::query::plumbing::get_query_impl 63: ::collect_and_partition_mono_items 64: ::codegen_crate 65: rustc_interface::passes::QueryContext::enter 66: rustc_interface::queries::Queries::ongoing_codegen 67: rustc_interface::queries::::enter 68: rustc_span::with_source_map 69: rustc_interface::interface::create_compiler_and_run 70: scoped_tls::ScopedKey::set note: Some details are omitted, run with `RUST_BACKTRACE=full` for a verbose backtrace. error: internal compiler error: unexpected panic note: the compiler unexpectedly panicked. this is a bug. note: we would appreciate a bug report: https://github.com/rust-lang/rust/issues/new?labels=C-bug%2C+I-ICE%2C+T-compiler&template=ice.md note: rustc 1.52.0-nightly (1705a7d64 2021-03-18) running on x86_64-unknown-linux-gnu note: compiler flags: -C opt-level=3 -C embed-bitcode=no -C incremental --crate-type lib note: some of the compiler flags provided by cargo are hidden query stack during panic: #0 [evaluate_obligation] evaluating trait selection obligation `impls::DealWithFees: sp_api_hidden_includes_construct_runtime::hidden_include::traits::OnUnbalanced>` #1 [normalize_projection_ty] normalizing `Canonical { max_universe: U0, variables: [], value: ParamEnvAnd { param_env: ParamEnv { caller_bounds: [], reveal: All }, value: ProjectionTy { substs: [pallet_transaction_payment::CurrencyAdapter, impls::DealWithFees>, Runtime], item_def_id: DefId(394:165 ~ pallet_transaction_payment[3044]::payment::OnChargeTransaction::Balance) } } }` #2 [normalize_generic_arg_after_erasing_regions] normalizing `for<'r> fn(&'r mut _::_parity_scale_codec::depth_limit::DepthTrackingInput<&[u8]>) -> std::result::Result<<<::OnChargeTransaction as pallet_transaction_payment::OnChargeTransaction>::Balance as _::_parity_scale_codec::HasCompact>::Type, _::_parity_scale_codec::Error> {<<<::OnChargeTransaction as pallet_transaction_payment::OnChargeTransaction>::Balance as _::_parity_scale_codec::HasCompact>::Type as _::_parity_scale_codec::Decode>::decode::<_::_parity_scale_codec::depth_limit::DepthTrackingInput<&[u8]>>}` #3 [collect_and_partition_mono_items] collect_and_partition_mono_items end of query stack error: could not compile `pangolin-runtime` To learn more, run the command again with --verbose. ```

jyn514 commented 3 years ago

Could you post the code this crashes on? It doesn't have to be small, but this is hard to fix without a way to replicate the crash.

AurevoirXavier commented 3 years ago

Could you post the code this crashes on? It doesn't have to be small, but this is hard to fix without a way to replicate the crash.

I'm not sure what causes this. Can't give a minimal env to reproduce this, sorry.

I'm compiling a substrate runtime. Really big project.

https://github.com/darwinia-network/darwinia-common/commit/81fb0c538d22111e16f0db8da6acb5b37b99f9d4

The first time it can be compile success. And I do some modifies to code, then it panics.

And cargo clean is a workaround.

Aaron1011 commented 3 years ago

This will be fixed by https://github.com/rust-lang/rust/pull/83220

AurevoirXavier commented 3 years ago

Fixed in 3-23

But in 3-24 panic again

teor2345 commented 3 years ago

I'm also seeing a similar error intermittently, when compiling https://github.com/ZcashFoundation/zebra using clippy --all-targets --all-features. See #83381 for more details.

It seems like nightly-2021-03-13-x86_64-unknown-linux-gnu is unaffected (or the issue is very rare).

2021-03-14 to 2021-03-21 are affected occasionally. (Maybe 1 in 10 runs.)

I haven't tested anything more recent, but I'll do that over the next few days.

AurevoirXavier commented 3 years ago

I'm also seeing a similar error intermittently, when compiling https://github.com/ZcashFoundation/zebra using clippy --all-targets --all-features. See #83381 for more details.

It seems like nightly-2021-03-13-x86_64-unknown-linux-gnu is unaffected (or the issue is very rare).

2021-03-14 to 2021-03-21 are affected occasionally. (Maybe 1 in 10 runs.)

I haven't tested anything more recent, but I'll do that over the next few days.

Now I stay at 03-01

Quite stable

real-felix commented 3 years ago

I'm on 2021-03-24, and I'm getting that bug a lot. Is the source of the bug known?

teor2345 commented 3 years ago

I haven't tested anything more recent, but I'll do that over the next few days.

Recent nightlies are also affected for me.

dhardy commented 3 years ago

Worse yet I've found my builds not updating and cargo test running outdated code (using 1.52.0-beta.2).

Aaron1011 commented 3 years ago

The underlying issue is tracked at https://github.com/rust-lang/rust/issues/83538

If you're running into this issue, you can use cargo clean -p <your_package_name> as a temporary workaround.

carado commented 3 years ago

(for anyone running into this issue often enough that cargo clean -p is annoying to run every time, if you don't mind the recompilation time you can use export CARGO_INCREMENTAL=0 to disable incremental compilation)

a1ph commented 3 years ago

This one reached 1.52.0 stable. Pretty inconvenient.

AurevoirXavier commented 3 years ago

Fixed since nightly-2021-05-10

Sry, still found this in 2021-05-11

jyn514 commented 3 years ago

This is likely https://github.com/rust-lang/rust/issues/85360.

Igosuki commented 2 years ago

Getting this error too

thread 'rustc' panicked at 'Found unstable fingerprints for evaluate_obligation(c9d69c0d5a400ccc-62c332b1848d388e): Ok(EvaluatedToOkModuloRegions)', /rustc/8c2b6ea37d7719a0370bd404030eef9702c1752c/compiler/rustc_query_system/src/query/plumbing.rs:632:13
earthengine commented 1 year ago

I receive this error with

>rustc --version --verbose
rustc 1.63.0 (4b91a6ea7 2022-08-08)
binary: rustc
commit-hash: 4b91a6ea7258a947e59c6522cd5898e7c0a6a88f
commit-date: 2022-08-08
host: x86_64-pc-windows-msvc
release: 1.63.0
LLVM version: 14.0.5

Trying to replicate with simpler code. (But no, the problem is gone when I deleted the target folder and build again)

istankovic commented 10 months ago

@AurevoirXavier is this still relevant?

kpreid commented 8 months ago

Triage: Relabeling issues which don't have a runnable reproduction (as opposed to having a non-minimized one) to the new label S-needs-repro. @rustbot label +S-needs-repro -E-needs-mcve