about summary refs log tree commit diff
path: root/src/tools/miri/tests/fail/tree_borrows/fnentry_invalidation.stderr
blob: bfd6854514e574d42281b295019abc1c2737e152 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
error: Undefined Behavior: write access through <TAG> at ALLOC[0x0] is forbidden
  --> tests/fail/tree_borrows/fnentry_invalidation.rs:LL:CC
   |
LL |         *z = 2;
   |         ^^^^^^ Undefined Behavior occurred here
   |
   = help: this indicates a potential bug in the program: it performed an invalid operation, but the Tree Borrows rules it violated are still experimental
   = help: see https://github.com/rust-lang/unsafe-code-guidelines/blob/master/wip/tree-borrows.md for further information
   = help: the accessed tag <TAG> has state Frozen which forbids this child write access
help: the accessed tag <TAG> was created here, in the initial state Reserved
  --> tests/fail/tree_borrows/fnentry_invalidation.rs:LL:CC
   |
LL |     let z = &mut x as *mut i32;
   |             ^^^^^^
help: the accessed tag <TAG> later transitioned to Unique due to a child write access at offsets [0x0..0x4]
  --> tests/fail/tree_borrows/fnentry_invalidation.rs:LL:CC
   |
LL |         *z = 1;
   |         ^^^^^^
   = help: this transition corresponds to the first write to a 2-phase borrowed mutable reference
help: the accessed tag <TAG> later transitioned to Frozen due to a reborrow (acting as a foreign read access) at offsets [0x0..0x4]
  --> tests/fail/tree_borrows/fnentry_invalidation.rs:LL:CC
   |
LL |     x.do_bad();
   |     ^
   = help: this transition corresponds to a loss of write permissions
   = note: BACKTRACE (of the first span):
   = note: inside `main` at tests/fail/tree_borrows/fnentry_invalidation.rs:LL:CC

note: some details are omitted, run with `MIRIFLAGS=-Zmiri-backtrace=full` for a verbose backtrace

error: aborting due to 1 previous error