Skip to content

Commit

Permalink
Merge pull request #1166 from saethlin/raw-pointer-tagging
Browse files Browse the repository at this point in the history
Avoid Box invalidation to be compatible with tag-raw-pointers
  • Loading branch information
dtolnay authored Apr 29, 2022
2 parents b9b0685 + 95f242c commit 5d7d112
Show file tree
Hide file tree
Showing 2 changed files with 11 additions and 9 deletions.
2 changes: 2 additions & 0 deletions .github/workflows/ci.yml
Original file line number Diff line number Diff line change
Expand Up @@ -113,6 +113,8 @@ jobs:
- uses: actions/checkout@v3
- uses: dtolnay/rust-toolchain@miri
- run: cargo miri test --all-features
env:
MIRIFLAGS: '-Zmiri-tag-raw-pointers'

clippy:
name: Clippy
Expand Down
18 changes: 9 additions & 9 deletions src/buffer.rs
Original file line number Diff line number Diff line change
Expand Up @@ -88,25 +88,25 @@ impl TokenBuffer {
// length of the backing buffer. The backing buffer must remain at a
// constant address after this point, as we are going to store a raw
// pointer into it.
let mut entries = entries.into_boxed_slice();
let entries = entries.into_boxed_slice();
let len = entries.len();
// Convert our boxed slice into a pointer to the first element early,
// to avoid invalidating pointers into this slice when we move the Box
// see https://github.com/rust-lang/unsafe-code-guidelines/issues/326
let entries = Box::into_raw(entries) as *mut Entry;
for (idx, group) in groups {
// We know that this index refers to one of the temporary
// `End(null)` entries, and we know that the last entry is
// `End(up)`, so the next index is also valid.
let group_up = unsafe { entries.as_ptr().add(idx + 1) };
let group_up = unsafe { entries.add(idx + 1) };

// The end entry stored at the end of this Entry::Group should
// point to the Entry which follows the Group in the list.
let inner = Self::inner_new(group.stream(), group_up);
entries[idx] = Entry::Group(group, inner);
unsafe { *entries.add(idx) = Entry::Group(group, inner) };
}

let len = entries.len();
let ptr = Box::into_raw(entries);
TokenBuffer {
ptr: ptr as *const Entry,
len,
}
TokenBuffer { ptr: entries, len }
}

/// Creates a `TokenBuffer` containing all the tokens from the input
Expand Down

0 comments on commit 5d7d112

Please sign in to comment.