From e82b053f56d11c944c227cefa6d2c2689346d49e Mon Sep 17 00:00:00 2001 From: Ralf Jung Date: Thu, 8 Aug 2019 10:01:41 +0200 Subject: [PATCH 1/2] move of packed fields might or might not occur when they actually are sufficiently aligned --- src/libcore/pin.rs | 3 ++- 1 file changed, 2 insertions(+), 1 deletion(-) diff --git a/src/libcore/pin.rs b/src/libcore/pin.rs index 88a56174629f..251dc4c3b99b 100644 --- a/src/libcore/pin.rs +++ b/src/libcore/pin.rs @@ -188,7 +188,8 @@ //! you do not accidentally use `self`/`this` in a way that is in conflict with pinning. //! //! Moreover, if your type is `#[repr(packed)]`, the compiler will automatically -//! move fields around to be able to drop them. As a consequence, you cannot use +//! move fields around to be able to drop them. In a packed struct, it might even do +//! that for fields that happen to be sufficiently aligned. As a consequence, you cannot use //! pinning with a `#[repr(packed)]` type. //! //! # Projections and Structural Pinning From fa58c278300895aad254342c89aafa7c080877b3 Mon Sep 17 00:00:00 2001 From: Ralf Jung Date: Thu, 8 Aug 2019 21:02:11 +0200 Subject: [PATCH 2/2] remove confusing remark --- src/libcore/pin.rs | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/src/libcore/pin.rs b/src/libcore/pin.rs index 251dc4c3b99b..271ddcc4662c 100644 --- a/src/libcore/pin.rs +++ b/src/libcore/pin.rs @@ -188,7 +188,7 @@ //! you do not accidentally use `self`/`this` in a way that is in conflict with pinning. //! //! Moreover, if your type is `#[repr(packed)]`, the compiler will automatically -//! move fields around to be able to drop them. In a packed struct, it might even do +//! move fields around to be able to drop them. It might even do //! that for fields that happen to be sufficiently aligned. As a consequence, you cannot use //! pinning with a `#[repr(packed)]` type. //!