#![feature(map_first_last)]
#![feature(map_try_insert)]
#![feature(never_type)]
-#![feature(or_patterns)]
#![feature(try_blocks)]
-
+#![feature(let_else)]
+#![feature(io_error_more)]
+#![feature(yeet_expr)]
+#![feature(is_some_with)]
+#![feature(nonzero_ops)]
+#![feature(local_key_cell_methods)]
#![warn(rust_2018_idioms)]
-#![allow(clippy::cast_lossless)]
+#![allow(
+ clippy::collapsible_else_if,
+ clippy::collapsible_if,
+ clippy::comparison_chain,
+ clippy::enum_variant_names,
+ clippy::field_reassign_with_default,
+ clippy::manual_map,
+ clippy::new_without_default,
+ clippy::single_match,
+ clippy::useless_format,
+ clippy::derive_partial_eq_without_eq,
+ clippy::derive_hash_xor_eq,
+ clippy::too_many_arguments
+)]
extern crate rustc_apfloat;
extern crate rustc_ast;
-#[macro_use] extern crate rustc_middle;
+#[macro_use]
+extern crate rustc_middle;
+extern crate rustc_const_eval;
extern crate rustc_data_structures;
extern crate rustc_hir;
extern crate rustc_index;
-extern crate rustc_mir;
+extern crate rustc_session;
extern crate rustc_span;
extern crate rustc_target;
-mod data_race;
+mod concurrency;
mod diagnostics;
mod eval;
mod helpers;
// Establish a "crate-wide prelude": we often import `crate::*`.
// Make all those symbols available in the same place as our own.
-pub use rustc_mir::interpret::*;
+pub use rustc_const_eval::interpret::*;
// Resolve ambiguity.
-pub use rustc_mir::interpret::{self, AllocMap, PlaceTy};
+pub use rustc_const_eval::interpret::{self, AllocMap, PlaceTy, Provenance as _};
pub use crate::shims::dlsym::{Dlsym, EvalContextExt as _};
pub use crate::shims::env::{EnvVars, EvalContextExt as _};
pub use crate::shims::foreign_items::EvalContextExt as _;
pub use crate::shims::intrinsics::EvalContextExt as _;
pub use crate::shims::os_str::EvalContextExt as _;
-pub use crate::shims::time::EvalContextExt as _;
pub use crate::shims::panic::{CatchUnwindData, EvalContextExt as _};
+pub use crate::shims::time::EvalContextExt as _;
pub use crate::shims::tls::{EvalContextExt as _, TlsData};
pub use crate::shims::EvalContextExt as _;
-pub use crate::data_race::{
- AtomicReadOp, AtomicWriteOp, AtomicRwOp, AtomicFenceOp,
- EvalContextExt as DataRaceEvalContextExt
+pub use crate::concurrency::data_race::{
+ AtomicFenceOrd, AtomicReadOrd, AtomicRwOrd, AtomicWriteOrd,
+ EvalContextExt as DataRaceEvalContextExt,
};
pub use crate::diagnostics::{
register_diagnostic, report_error, EvalContextExt as DiagnosticsEvalContextExt,
- TerminationInfo, NonHaltingDiagnostic,
+ NonHaltingDiagnostic, TerminationInfo,
};
-pub use crate::eval::{create_ecx, eval_main, AlignmentCheck, MiriConfig};
-pub use crate::helpers::EvalContextExt as HelpersEvalContextExt;
+pub use crate::eval::{
+ create_ecx, eval_entry, AlignmentCheck, BacktraceStyle, IsolatedOp, MiriConfig, RejectOpWith,
+};
+pub use crate::helpers::{CurrentSpan, EvalContextExt as HelpersEvalContextExt};
+pub use crate::intptrcast::ProvenanceMode;
pub use crate::machine::{
- AllocExtra, Evaluator, FrameData, MemoryExtra, MiriEvalContext, MiriEvalContextExt,
- MiriMemoryKind, NUM_CPUS, PAGE_SIZE, STACK_ADDR, STACK_SIZE,
+ AllocExtra, Evaluator, FrameData, MiriEvalContext, MiriEvalContextExt, MiriMemoryKind,
+ Provenance, ProvenanceExtra, NUM_CPUS, PAGE_SIZE, STACK_ADDR, STACK_SIZE,
};
pub use crate::mono_hash_map::MonoHashMap;
pub use crate::operator::EvalContextExt as OperatorEvalContextExt;
pub use crate::range_map::RangeMap;
pub use crate::stacked_borrows::{
- EvalContextExt as StackedBorEvalContextExt, Item, Permission, CallId, PtrId, Stack, Stacks, Tag,
+ CallId, EvalContextExt as StackedBorEvalContextExt, Item, Permission, SbTag, Stack, Stacks,
};
+pub use crate::sync::{CondvarId, EvalContextExt as SyncEvalContextExt, MutexId, RwLockId};
pub use crate::thread::{
EvalContextExt as ThreadsEvalContextExt, SchedulingAction, ThreadId, ThreadManager, ThreadState,
};
-pub use crate::sync::{
- EvalContextExt as SyncEvalContextExt, CondvarId, MutexId, RwLockId
-};
-pub use crate::vector_clock::{
- VClock, VectorIdx, VTimestamp
-};
+pub use crate::vector_clock::{VClock, VTimestamp, VectorIdx};
/// Insert rustc arguments at the beginning of the argument list that Miri wants to be
/// set per default, for maximal validation power.