From f1a5a50c880af67e71944740275a60af388151e6 Mon Sep 17 00:00:00 2001 From: Johannes Hostert Date: Fri, 23 Aug 2024 16:50:26 +0200 Subject: [PATCH] Make test ptr::slice_mut compliant with Tree Borrows Tree Borrows is a new aliasing model for Rust, which features more precise tracking of pointer aliasing. The aim is to be more lenient than Stacked Borrows, while also having less dirty hacks than SB had. It turns out that the test ptr::slice_mut here relied on one such gross hack. The problematic code is here: https://github.com/lumol-org/soa-derive/blob/ad918be58f47ee6d38e9c83411180e756a3220c0/tests/ptr.rs#L77-L93 There, a slice is created, and then a reference to it is obtained using `slice::as_mut_ptr()`, which (internally) creates a new mutable reference. This means that the resulting pointer can not be mixed with accesses to the original slice. However, the test does so: It first uses the pointer, then the original slice, and then again the pointer. The proper solution is to re-derive the pointer when it's needed again, which is what this PR does. --- tests/ptr.rs | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/tests/ptr.rs b/tests/ptr.rs index d7e6817..a38549e 100644 --- a/tests/ptr.rs +++ b/tests/ptr.rs @@ -86,7 +86,7 @@ fn slice_mut() { assert_eq!(slice.mass[0], 42.0); unsafe { - let slice = ParticleSliceMut::from_raw_parts_mut(ptr, 2); + let slice = ParticleSliceMut::from_raw_parts_mut(slice.as_mut_ptr(), 2); for mass in slice.mass { *mass = -1.0;