From 7df32882203fdd525156ddb785d171b193e5b282 Mon Sep 17 00:00:00 2001 From: Sebastian Weyer Date: Wed, 8 Feb 2023 12:05:51 +0100 Subject: [PATCH] package/rust: fix bootstrap build The update to v1.67.0 of rust broke the bootstrap build. This patch applies an upstream patch to fix this: https://github.com/rust-lang/rust/commit/3fe64ebbce21e79adb64099984e96dfb79bdd0f9 Fixes: http://autobuild.buildroot.org/results/214/214fcbb3458893784b7f85b60f7ee1edb428c77f/build-end.log Signed-off-by: Sebastian Weyer Cc: Eric Le Bihan Cc: James Hilliard Reviewed-by: Romain Naour Signed-off-by: Peter Korsgaard --- ...-unsoundness-in-bootstrap-cache-code.patch | 43 +++++++++++++++++++ 1 file changed, 43 insertions(+) create mode 100644 package/rust/0001-fix-unsoundness-in-bootstrap-cache-code.patch diff --git a/package/rust/0001-fix-unsoundness-in-bootstrap-cache-code.patch b/package/rust/0001-fix-unsoundness-in-bootstrap-cache-code.patch new file mode 100644 index 0000000000..3eae34642f --- /dev/null +++ b/package/rust/0001-fix-unsoundness-in-bootstrap-cache-code.patch @@ -0,0 +1,43 @@ +From 6bf37780ed49846c78d6707355f1cf44790c4301 Mon Sep 17 00:00:00 2001 +From: Michael Goulet +Date: Mon, 12 Dec 2022 18:29:33 +0000 +Subject: [PATCH] =?UTF-8?q?=F0=9F=9A=A8=20fix=20unsoundness=20in=20bootstr?= + =?UTF-8?q?ap=20cache=20code?= +MIME-Version: 1.0 +Content-Type: text/plain; charset=UTF-8 +Content-Transfer-Encoding: 8bit + +(cherry picked from commit 3fe64ebbce21e79adb64099984e96dfb79bdd0f9) +Signed-off-by: Sebastian Weyer +--- + src/bootstrap/cache.rs | 8 ++++---- + 1 file changed, 4 insertions(+), 4 deletions(-) + +diff --git a/src/bootstrap/cache.rs b/src/bootstrap/cache.rs +index be5c9bb0788..05f25af68ea 100644 +--- a/src/bootstrap/cache.rs ++++ b/src/bootstrap/cache.rs +@@ -89,16 +89,16 @@ fn hash(&self, state: &mut H) { + + impl Deref for Interned { + type Target = T::Target; +- fn deref(&self) -> &'static Self::Target { ++ fn deref(&self) -> &Self::Target { + let l = T::intern_cache().lock().unwrap(); +- unsafe { mem::transmute::<&Self::Target, &'static Self::Target>(l.get(*self)) } ++ unsafe { mem::transmute::<&Self::Target, &Self::Target>(l.get(*self)) } + } + } + + impl, U: ?Sized> AsRef for Interned { +- fn as_ref(&self) -> &'static U { ++ fn as_ref(&self) -> &U { + let l = T::intern_cache().lock().unwrap(); +- unsafe { mem::transmute::<&U, &'static U>(l.get(*self).as_ref()) } ++ unsafe { mem::transmute::<&U, &U>(l.get(*self).as_ref()) } + } + } + +-- +2.25.1 +