From 7e348efd4b9eca39da92d68757d4cda500ee1adf Mon Sep 17 00:00:00 2001 From: Sylvester Hesp Date: Wed, 15 Feb 2023 14:55:27 +0100 Subject: [PATCH 1/4] Update to 2023-01-21 --- crates/rustc_codegen_spirv/build.rs | 4 ++-- crates/rustc_codegen_spirv/src/attr.rs | 2 +- crates/rustc_codegen_spirv/src/lib.rs | 3 ++- .../src/linker/spirt_passes/mod.rs | 2 +- crates/rustc_codegen_spirv/src/linker/test.rs | 12 +++++++++- rust-toolchain | 13 +++++----- .../ui/arch/debug_printf_type_checking.stderr | 24 +++++++++++++++++++ tests/ui/dis/ptr_copy.normal.stderr | 4 ++-- tests/ui/dis/ptr_read.stderr | 2 +- tests/ui/dis/ptr_read_method.stderr | 2 +- tests/ui/dis/ptr_write.stderr | 2 +- tests/ui/dis/ptr_write_method.stderr | 2 +- tests/ui/image/gather_err.stderr | 8 +++---- .../ui/image/query/query_size_lod_err.stderr | 4 ++-- 14 files changed, 59 insertions(+), 25 deletions(-) diff --git a/crates/rustc_codegen_spirv/build.rs b/crates/rustc_codegen_spirv/build.rs index d0f126b65b..4010753b9b 100644 --- a/crates/rustc_codegen_spirv/build.rs +++ b/crates/rustc_codegen_spirv/build.rs @@ -10,9 +10,9 @@ use std::process::{Command, ExitCode}; /// `cargo publish`. We need to figure out a way to do this properly, but let's hardcode it for now :/ //const REQUIRED_RUST_TOOLCHAIN: &str = include_str!("../../rust-toolchain"); const REQUIRED_RUST_TOOLCHAIN: &str = r#"[toolchain] -channel = "nightly-2022-12-18" +channel = "nightly-2023-01-21" components = ["rust-src", "rustc-dev", "llvm-tools-preview"] -# commit_hash = 0468a00ae3fd6ef1a6a0f9eaf637d7aa9e604acc"#; +# commit_hash = 5ce39f42bd2c8bca9c570f0560ebe1fce4eddb14"#; fn get_rustc_commit_hash() -> Result> { let rustc = std::env::var("RUSTC").unwrap_or_else(|_| String::from("rustc")); diff --git a/crates/rustc_codegen_spirv/src/attr.rs b/crates/rustc_codegen_spirv/src/attr.rs index 7667e20d8c..313948816b 100644 --- a/crates/rustc_codegen_spirv/src/attr.rs +++ b/crates/rustc_codegen_spirv/src/attr.rs @@ -302,7 +302,7 @@ impl CheckSpirvAttrVisitor<'_> { | SpirvAttribute::Invariant | SpirvAttribute::InputAttachmentIndex(_) => match target { Target::Param => { - let parent_hir_id = self.tcx.hir().get_parent_node(hir_id); + let parent_hir_id = self.tcx.hir().parent_id(hir_id); let parent_is_entry_point = parse_attrs(self.tcx.hir().attrs(parent_hir_id)) .filter_map(|r| r.ok()) diff --git a/crates/rustc_codegen_spirv/src/lib.rs b/crates/rustc_codegen_spirv/src/lib.rs index 3abc1b1a78..0b5a764553 100644 --- a/crates/rustc_codegen_spirv/src/lib.rs +++ b/crates/rustc_codegen_spirv/src/lib.rs @@ -142,7 +142,8 @@ fn is_blocklisted_fn<'tcx>( Some(assoc) if assoc.ident(tcx).name == sym::fmt => match assoc.container { ty::ImplContainer => { let impl_def_id = assoc.container_id(tcx); - tcx.impl_trait_ref(impl_def_id).map(|tr| tr.def_id) + tcx.impl_trait_ref(impl_def_id) + .map(|tr| tr.subst_identity().def_id) == Some(debug_trait_def_id) } ty::TraitContainer => false, diff --git a/crates/rustc_codegen_spirv/src/linker/spirt_passes/mod.rs b/crates/rustc_codegen_spirv/src/linker/spirt_passes/mod.rs index 183d806f15..335202c137 100644 --- a/crates/rustc_codegen_spirv/src/linker/spirt_passes/mod.rs +++ b/crates/rustc_codegen_spirv/src/linker/spirt_passes/mod.rs @@ -257,7 +257,7 @@ const _: () = { // HACK(eddyb) this works around the accidental lack of `spirt::Value: Hash`. #[derive(Copy, Clone, PartialEq, Eq)] struct HashableValue(Value); -#[allow(clippy::derive_hash_xor_eq)] +#[allow(clippy::derived_hash_with_manual_eq)] impl Hash for HashableValue { fn hash(&self, state: &mut H) { use spirt::*; diff --git a/crates/rustc_codegen_spirv/src/linker/test.rs b/crates/rustc_codegen_spirv/src/linker/test.rs index 1c760956de..a8bd254726 100644 --- a/crates/rustc_codegen_spirv/src/linker/test.rs +++ b/crates/rustc_codegen_spirv/src/linker/test.rs @@ -2,6 +2,8 @@ use super::{link, LinkResult}; use pipe::pipe; use rspirv::dr::{Loader, Module}; use rustc_errors::registry::Registry; +use rustc_session::{config::Input, CompilerIO}; +use rustc_span::FileName; use std::io::Read; // https://github.com/colin-kiegel/rust-pretty-assertions/issues/24 @@ -130,7 +132,15 @@ fn link_with_linker_opts( rustc_span::create_session_globals_then(sopts.edition, || { let mut sess = rustc_session::build_session( sopts, - None, + CompilerIO { + input: Input::Str { + name: FileName::Custom(String::new()), + input: String::new(), + }, + output_dir: None, + output_file: None, + temps_dir: None, + }, None, Registry::new(&[]), Default::default(), diff --git a/rust-toolchain b/rust-toolchain index 930a1f1677..566135c1a5 100644 --- a/rust-toolchain +++ b/rust-toolchain @@ -1,14 +1,13 @@ -# If you see this, run `rustup self update` to get rustup 1.23 or newer. +# If you see this, run `rustup self update` to get rustup 1.23 or newer -# NOTE: above comment is for older `rustup` (before TOML support was added), +# NOTE: above comment is for older `rustup` (before TOML support was added) # which will treat the first line as the toolchain name, and therefore show it -# to the user in the error, instead of "error: invalid channel name '[toolchain]'". +# to the user in the error, instead of "error: invalid channel name '[toolchain]'" [toolchain] -channel = "nightly-2022-12-18" +channel = "nightly-2023-01-21" components = ["rust-src", "rustc-dev", "llvm-tools-preview"] -# commit_hash = 0468a00ae3fd6ef1a6a0f9eaf637d7aa9e604acc +# commit_hash = 5ce39f42bd2c8bca9c570f0560ebe1fce4eddb14 # Whenever changing the nightly channel, update the commit hash above, and make -# sure to change REQUIRED_TOOLCHAIN in crates/rustc_codegen_spirv/src/build.rs also. - +# sure to change REQUIRED_TOOLCHAIN in crates/rustc_codegen_spirv/src/build.rs also diff --git a/tests/ui/arch/debug_printf_type_checking.stderr b/tests/ui/arch/debug_printf_type_checking.stderr index 52409369c3..be13dd2f7a 100644 --- a/tests/ui/arch/debug_printf_type_checking.stderr +++ b/tests/ui/arch/debug_printf_type_checking.stderr @@ -67,11 +67,19 @@ error[E0308]: mismatched types | | expected `f32`, found `u32` | arguments to this function are incorrect | +help: the return type of this call is `u32` due to the type of the argument passed + --> $DIR/debug_printf_type_checking.rs:21:9 + | +21 | debug_printf!("%f", 11_u32); + | ^^^^^^^^^^^^^^^^^^^^------^ + | | + | this argument influences the return type of `spirv_std` note: function defined here --> $SPIRV_STD_SRC/lib.rs:144:8 | 144 | pub fn debug_printf_assert_is_type(ty: T) -> T { | ^^^^^^^^^^^^^^^^^^^^^^^^^^^ + = note: this error originates in the macro `debug_printf` (in Nightly builds, run with -Z macro-backtrace for more info) help: change the type of the numeric literal from `u32` to `f32` | 21 | debug_printf!("%f", 11_f32); @@ -86,11 +94,19 @@ error[E0308]: mismatched types | | expected `u32`, found `f32` | arguments to this function are incorrect | +help: the return type of this call is `f32` due to the type of the argument passed + --> $DIR/debug_printf_type_checking.rs:22:9 + | +22 | debug_printf!("%u", 11.0_f32); + | ^^^^^^^^^^^^^^^^^^^^--------^ + | | + | this argument influences the return type of `spirv_std` note: function defined here --> $SPIRV_STD_SRC/lib.rs:144:8 | 144 | pub fn debug_printf_assert_is_type(ty: T) -> T { | ^^^^^^^^^^^^^^^^^^^^^^^^^^^ + = note: this error originates in the macro `debug_printf` (in Nightly builds, run with -Z macro-backtrace for more info) help: change the type of the numeric literal from `f32` to `u32` | 22 | debug_printf!("%u", 11u32); @@ -130,11 +146,19 @@ error[E0308]: mismatched types | | expected `f32`, found struct `Vec2` | arguments to this function are incorrect | +help: the return type of this call is `Vec2` due to the type of the argument passed + --> $DIR/debug_printf_type_checking.rs:24:9 + | +24 | debug_printf!("%f", Vec2::splat(33.3)); + | ^^^^^^^^^^^^^^^^^^^^-----------------^ + | | + | this argument influences the return type of `spirv_std` note: function defined here --> $SPIRV_STD_SRC/lib.rs:144:8 | 144 | pub fn debug_printf_assert_is_type(ty: T) -> T { | ^^^^^^^^^^^^^^^^^^^^^^^^^^^ + = note: this error originates in the macro `debug_printf` (in Nightly builds, run with -Z macro-backtrace for more info) error: aborting due to 14 previous errors diff --git a/tests/ui/dis/ptr_copy.normal.stderr b/tests/ui/dis/ptr_copy.normal.stderr index 89487413e7..40eb74cbe5 100644 --- a/tests/ui/dis/ptr_copy.normal.stderr +++ b/tests/ui/dis/ptr_copy.normal.stderr @@ -1,7 +1,7 @@ error: Cannot memcpy dynamically sized data - --> $CORE_SRC/intrinsics.rs:2519:9 + --> $CORE_SRC/intrinsics.rs:2458:9 | -2519 | copy(src, dst, count) +2458 | copy(src, dst, count) | ^^^^^^^^^^^^^^^^^^^^^ | = note: Stack: diff --git a/tests/ui/dis/ptr_read.stderr b/tests/ui/dis/ptr_read.stderr index 20cc4ad01d..4a4df10a76 100644 --- a/tests/ui/dis/ptr_read.stderr +++ b/tests/ui/dis/ptr_read.stderr @@ -2,7 +2,7 @@ %4 = OpFunctionParameter %5 %6 = OpFunctionParameter %5 %7 = OpLabel -OpLine %8 1135 8 +OpLine %8 1157 8 %9 = OpLoad %10 %4 OpLine %11 9 13 OpStore %6 %9 diff --git a/tests/ui/dis/ptr_read_method.stderr b/tests/ui/dis/ptr_read_method.stderr index 20cc4ad01d..4a4df10a76 100644 --- a/tests/ui/dis/ptr_read_method.stderr +++ b/tests/ui/dis/ptr_read_method.stderr @@ -2,7 +2,7 @@ %4 = OpFunctionParameter %5 %6 = OpFunctionParameter %5 %7 = OpLabel -OpLine %8 1135 8 +OpLine %8 1157 8 %9 = OpLoad %10 %4 OpLine %11 9 13 OpStore %6 %9 diff --git a/tests/ui/dis/ptr_write.stderr b/tests/ui/dis/ptr_write.stderr index fea253a81a..2556854af5 100644 --- a/tests/ui/dis/ptr_write.stderr +++ b/tests/ui/dis/ptr_write.stderr @@ -4,7 +4,7 @@ %7 = OpLabel OpLine %8 9 35 %9 = OpLoad %10 %4 -OpLine %11 1332 8 +OpLine %11 1354 8 OpStore %6 %9 OpNoLine OpReturn diff --git a/tests/ui/dis/ptr_write_method.stderr b/tests/ui/dis/ptr_write_method.stderr index e42322c5b6..709f86aa5d 100644 --- a/tests/ui/dis/ptr_write_method.stderr +++ b/tests/ui/dis/ptr_write_method.stderr @@ -4,7 +4,7 @@ %7 = OpLabel OpLine %8 9 37 %9 = OpLoad %10 %4 -OpLine %11 1332 8 +OpLine %11 1354 8 OpStore %6 %9 OpNoLine OpReturn diff --git a/tests/ui/image/gather_err.stderr b/tests/ui/image/gather_err.stderr index a6188ee2b4..d4c0db36ec 100644 --- a/tests/ui/image/gather_err.stderr +++ b/tests/ui/image/gather_err.stderr @@ -8,11 +8,11 @@ error[E0277]: the trait bound `Image: HasGather` is not s Image Image Image -note: required by a bound in `Image::::gather` +note: required by a bound in `Image::::gather` --> $SPIRV_STD_SRC/image.rs:163:15 | 163 | Self: HasGather, - | ^^^^^^^^^ required by this bound in `Image::::gather` + | ^^^^^^^^^ required by this bound in `Image::::gather` error[E0277]: the trait bound `Image: HasGather` is not satisfied --> $DIR/gather_err.rs:16:34 @@ -24,11 +24,11 @@ error[E0277]: the trait bound `Image: HasGather` is not s Image Image Image -note: required by a bound in `Image::::gather` +note: required by a bound in `Image::::gather` --> $SPIRV_STD_SRC/image.rs:163:15 | 163 | Self: HasGather, - | ^^^^^^^^^ required by this bound in `Image::::gather` + | ^^^^^^^^^ required by this bound in `Image::::gather` error: aborting due to 2 previous errors diff --git a/tests/ui/image/query/query_size_lod_err.stderr b/tests/ui/image/query/query_size_lod_err.stderr index 7559c5e9d5..0b92123ca8 100644 --- a/tests/ui/image/query/query_size_lod_err.stderr +++ b/tests/ui/image/query/query_size_lod_err.stderr @@ -9,11 +9,11 @@ error[E0277]: the trait bound `Image: HasQuerySizeLod` is Image Image Image -note: required by a bound in `Image::::query_size_lod` +note: required by a bound in `Image::::query_size_lod` --> $SPIRV_STD_SRC/image.rs:903:15 | 903 | Self: HasQuerySizeLod, - | ^^^^^^^^^^^^^^^ required by this bound in `Image::::query_size_lod` + | ^^^^^^^^^^^^^^^ required by this bound in `Image::::query_size_lod` error: aborting due to previous error From e9eff39169f16ec9e187e06f74b2ddc445de691a Mon Sep 17 00:00:00 2001 From: Sylvester Hesp Date: Wed, 15 Feb 2023 15:29:04 +0100 Subject: [PATCH 2/4] Added changelog entry. --- CHANGELOG.md | 1 + 1 file changed, 1 insertion(+) diff --git a/CHANGELOG.md b/CHANGELOG.md index cda594ddee..c4eadd75ec 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -30,6 +30,7 @@ and this project adheres to [Semantic Versioning](https://semver.org/spec/v2.0.0 ## [Unreleased] ### Changed 🛠 +- [PR#991](https://github.com/EmbarkStudios/rust-gpu/pull/991) Updated toolchain to `nightly-2023-01-21`. - [PR#990](https://github.com/EmbarkStudios/rust-gpu/pull/990) Removed return type inference from `Image` API and made `glam` usage mandatory. ## [0.5.0] From 6ec09f9683de84597a6b32182a952d856f4a90a5 Mon Sep 17 00:00:00 2001 From: Sylvester Hesp Date: Thu, 16 Feb 2023 10:38:28 +0100 Subject: [PATCH 3/4] Use `skip_binder` in favor of `subst_identity` Co-authored-by: Eduard-Mihai Burtescu --- crates/rustc_codegen_spirv/src/lib.rs | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/crates/rustc_codegen_spirv/src/lib.rs b/crates/rustc_codegen_spirv/src/lib.rs index 0b5a764553..77b537ac08 100644 --- a/crates/rustc_codegen_spirv/src/lib.rs +++ b/crates/rustc_codegen_spirv/src/lib.rs @@ -143,7 +143,7 @@ fn is_blocklisted_fn<'tcx>( ty::ImplContainer => { let impl_def_id = assoc.container_id(tcx); tcx.impl_trait_ref(impl_def_id) - .map(|tr| tr.subst_identity().def_id) + .map(|tr| tr.skip_binder().def_id) == Some(debug_trait_def_id) } ty::TraitContainer => false, From fe56e993a43e3720eed97afbdb913a9226b72f40 Mon Sep 17 00:00:00 2001 From: Sylvester Hesp Date: Thu, 16 Feb 2023 10:45:10 +0100 Subject: [PATCH 4/4] Put back punctuation in comments --- rust-toolchain | 8 ++++---- 1 file changed, 4 insertions(+), 4 deletions(-) diff --git a/rust-toolchain b/rust-toolchain index 566135c1a5..86f3e30241 100644 --- a/rust-toolchain +++ b/rust-toolchain @@ -1,8 +1,8 @@ -# If you see this, run `rustup self update` to get rustup 1.23 or newer +# If you see this, run `rustup self update` to get rustup 1.23 or newer. -# NOTE: above comment is for older `rustup` (before TOML support was added) +# NOTE: above comment is for older `rustup` (before TOML support was added), # which will treat the first line as the toolchain name, and therefore show it -# to the user in the error, instead of "error: invalid channel name '[toolchain]'" +# to the user in the error, instead of "error: invalid channel name '[toolchain]'". [toolchain] channel = "nightly-2023-01-21" @@ -10,4 +10,4 @@ components = ["rust-src", "rustc-dev", "llvm-tools-preview"] # commit_hash = 5ce39f42bd2c8bca9c570f0560ebe1fce4eddb14 # Whenever changing the nightly channel, update the commit hash above, and make -# sure to change REQUIRED_TOOLCHAIN in crates/rustc_codegen_spirv/src/build.rs also +# sure to change REQUIRED_TOOLCHAIN in crates/rustc_codegen_spirv/src/build.rs also.