diff --git a/miri b/miri index 161276c52b..337b2a496d 100755 --- a/miri +++ b/miri @@ -1,4 +1,4 @@ -#!/bin/sh +#!/bin/bash set -e USAGE=$(cat <<"EOF" COMMANDS diff --git a/src/diagnostics.rs b/src/diagnostics.rs index 81cd049217..12ad93a528 100644 --- a/src/diagnostics.rs +++ b/src/diagnostics.rs @@ -1,5 +1,6 @@ use std::cell::RefCell; use std::fmt; +use std::num::NonZeroU64; use log::trace; @@ -41,6 +42,7 @@ impl MachineStopType for TerminationInfo {} /// Miri specific diagnostics pub enum NonHaltingDiagnostic { + CreatedPointerTag(NonZeroU64), PoppedPointerTag(Item), CreatedCallId(CallId), CreatedAlloc(AllocId), @@ -266,6 +268,8 @@ pub trait EvalContextExt<'mir, 'tcx: 'mir>: crate::MiriEvalContextExt<'mir, 'tcx for e in diagnostics.drain(..) { use NonHaltingDiagnostic::*; let msg = match e { + CreatedPointerTag(tag) => + format!("created tag {:?}", tag), PoppedPointerTag(item) => format!("popped tracked tag for item {:?}", item), CreatedCallId(id) => diff --git a/src/stacked_borrows.rs b/src/stacked_borrows.rs index 817ed99d2b..257208056d 100644 --- a/src/stacked_borrows.rs +++ b/src/stacked_borrows.rs @@ -168,6 +168,9 @@ impl GlobalState { fn new_ptr(&mut self) -> PtrId { let id = self.next_ptr_id; + if Some(id) == self.tracked_pointer_tag { + register_diagnostic(NonHaltingDiagnostic::CreatedPointerTag(id)); + } self.next_ptr_id = NonZeroU64::new(id.get() + 1).unwrap(); id }