summaryrefslogtreecommitdiff
path: root/src/tools/miri/tests/fail/tree-borrows/write-during-2phase.stderr
blob: f6285bdcf16d4fc49a7a17ce23a79c84361cfe50 (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
34
35
36
37
38
39
40
41
42
43
44
45
error: Undefined Behavior: read access through <TAG> is forbidden
  --> $DIR/write-during-2phase.rs:LL:CC
   |
LL |     fn add(&mut self, n: u64) -> u64 {
   |            ^^^^^^^^^ read access through <TAG> is forbidden
   |
   = 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: the accessed tag <TAG> has state Disabled which forbids child read accesses
help: the accessed tag <TAG> was created here, in the initial state Reserved
  --> $DIR/write-during-2phase.rs:LL:CC
   |
LL |       let _res = f.add(unsafe {
   |  ________________^
LL | |         let n = f.0;
LL | |         // This is the access at fault, but it's not immediately apparent because
LL | |         // the reference that got invalidated is not under a Protector.
LL | |         *inner = 42;
LL | |         n
LL | |     });
   | |______^
help: the accessed tag <TAG> then transitioned from Reserved to Disabled due to a foreign write access at offsets [0x0..0x8]
  --> $DIR/write-during-2phase.rs:LL:CC
   |
LL |         *inner = 42;
   |         ^^^^^^^^^^^
   = help: this corresponds to a loss of read and write permissions
   = note: BACKTRACE (of the first span):
   = note: inside `Foo::add` at $DIR/write-during-2phase.rs:LL:CC
note: inside `main`
  --> $DIR/write-during-2phase.rs:LL:CC
   |
LL |       let _res = f.add(unsafe {
   |  ________________^
LL | |         let n = f.0;
LL | |         // This is the access at fault, but it's not immediately apparent because
LL | |         // the reference that got invalidated is not under a Protector.
LL | |         *inner = 42;
LL | |         n
LL | |     });
   | |______^

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

error: aborting due to previous error