[INFO] fetching crate mu_uefi_boot_services 2.0.0...
[INFO] testing mu_uefi_boot_services-2.0.0 against master#d98a5da813da67eb189387b8ccfb73cf481275d8+rustflags=-Copt-level=3 for pr-138759
[INFO] extracting crate mu_uefi_boot_services 2.0.0 into /workspace/builds/worker-0-tc1/source
[INFO] started tweaking crates.io crate mu_uefi_boot_services 2.0.0
[INFO] finished tweaking crates.io crate mu_uefi_boot_services 2.0.0
[INFO] tweaked toml for crates.io crate mu_uefi_boot_services 2.0.0 written to /workspace/builds/worker-0-tc1/source/Cargo.toml
[INFO] validating manifest of crates.io crate mu_uefi_boot_services 2.0.0 on toolchain d98a5da813da67eb189387b8ccfb73cf481275d8
[INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+d98a5da813da67eb189387b8ccfb73cf481275d8" "metadata" "--manifest-path" "Cargo.toml" "--no-deps", kill_on_drop: false }`
[INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+d98a5da813da67eb189387b8ccfb73cf481275d8" "generate-lockfile" "--manifest-path" "Cargo.toml", kill_on_drop: false }`
[INFO] [stderr]     Updating crates.io index
[INFO] [stderr]      Locking 15 packages to latest compatible versions
[INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+d98a5da813da67eb189387b8ccfb73cf481275d8" "fetch" "--manifest-path" "Cargo.toml", kill_on_drop: false }`
[INFO] [stderr]  Downloading crates ...
[INFO] [stderr]   Downloaded mockall v0.13.1
[INFO] [stderr]   Downloaded mockall_derive v0.13.1
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-0-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-0-tc1/source:/opt/rustwide/workdir:ro,Z" "-v" "/var/lib/crater-agent-workspace/cargo-home:/opt/rustwide/cargo-home:ro,Z" "-v" "/var/lib/crater-agent-workspace/rustup-home:/opt/rustwide/rustup-home:ro,Z" "-e" "SOURCE_DIR=/opt/rustwide/workdir" "-e" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_HOME=/opt/rustwide/cargo-home" "-e" "RUSTUP_HOME=/opt/rustwide/rustup-home" "-w" "/opt/rustwide/workdir" "-m" "1610612736" "--user" "0:0" "--network" "none" "ghcr.io/rust-lang/crates-build-env/linux@sha256:e90291280db7d1fac5b66fc6dad9f9662629e7365a55743daf9bdf73ebc4ea79" "/opt/rustwide/cargo-home/bin/cargo" "+d98a5da813da67eb189387b8ccfb73cf481275d8" "metadata" "--no-deps" "--format-version=1", kill_on_drop: false }`
[INFO] [stdout] ad88489797e39fc3e7dd88b9401a6c977ae2e46e7a5c8b4ccc1881cd37043470
[INFO] running `Command { std: "docker" "start" "-a" "ad88489797e39fc3e7dd88b9401a6c977ae2e46e7a5c8b4ccc1881cd37043470", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "inspect" "ad88489797e39fc3e7dd88b9401a6c977ae2e46e7a5c8b4ccc1881cd37043470", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "ad88489797e39fc3e7dd88b9401a6c977ae2e46e7a5c8b4ccc1881cd37043470", kill_on_drop: false }`
[INFO] [stdout] ad88489797e39fc3e7dd88b9401a6c977ae2e46e7a5c8b4ccc1881cd37043470
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-0-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-0-tc1/source:/opt/rustwide/workdir:ro,Z" "-v" "/var/lib/crater-agent-workspace/cargo-home:/opt/rustwide/cargo-home:ro,Z" "-v" "/var/lib/crater-agent-workspace/rustup-home:/opt/rustwide/rustup-home:ro,Z" "-e" "SOURCE_DIR=/opt/rustwide/workdir" "-e" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_INCREMENTAL=0" "-e" "RUST_BACKTRACE=full" "-e" "RUSTFLAGS=--cap-lints=forbid -Copt-level=3" "-e" "RUSTDOCFLAGS=--cap-lints=forbid" "-e" "CARGO_HOME=/opt/rustwide/cargo-home" "-e" "RUSTUP_HOME=/opt/rustwide/rustup-home" "-w" "/opt/rustwide/workdir" "-m" "1610612736" "--user" "0:0" "--network" "none" "ghcr.io/rust-lang/crates-build-env/linux@sha256:e90291280db7d1fac5b66fc6dad9f9662629e7365a55743daf9bdf73ebc4ea79" "/opt/rustwide/cargo-home/bin/cargo" "+d98a5da813da67eb189387b8ccfb73cf481275d8" "build" "--frozen" "--message-format=json", kill_on_drop: false }`
[INFO] [stdout] 457bb77bb623cc28bcac2ea8788cb19a9d646c854bd6ca1f059914ec5fcbeeab
[INFO] running `Command { std: "docker" "start" "-a" "457bb77bb623cc28bcac2ea8788cb19a9d646c854bd6ca1f059914ec5fcbeeab", kill_on_drop: false }`
[INFO] [stderr]    Compiling r-efi v5.3.0
[INFO] [stderr]    Compiling mu_uefi_boot_services v2.0.0 (/opt/rustwide/workdir)
[INFO] [stdout] warning: lifetime flowing from input to output with different syntax can be confusing
[INFO] [stdout]     --> src/boot_services.rs:1052:9
[INFO] [stdout]      |
[INFO] [stdout] 1052 |         &self,
[INFO] [stdout]      |         ^^^^^ this lifetime flows to the output
[INFO] [stdout] 1053 |         search_type: HandleSearchType,
[INFO] [stdout] 1054 |     ) -> Result<BootServicesBox<[efi::Handle], Self>, efi::Status> {
[INFO] [stdout]      |                 ------------------------------------ the lifetime gets resolved as `'_`
[INFO] [stdout]      |
[INFO] [stdout]      = note: `#[warn(mismatched_lifetime_syntaxes)]` on by default
[INFO] [stdout] help: one option is to remove the lifetime for references and use the anonymous lifetime for paths
[INFO] [stdout]      |
[INFO] [stdout] 1054 |     ) -> Result<BootServicesBox<'_, [efi::Handle], Self>, efi::Status> {
[INFO] [stdout]      |                                 +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: lifetime flowing from input to output with different syntax can be confusing
[INFO] [stdout]     --> src/boot_services.rs:1163:9
[INFO] [stdout]      |
[INFO] [stdout] 1163 |         &self,
[INFO] [stdout]      |         ^^^^^ this lifetime flows to the output
[INFO] [stdout] ...
[INFO] [stdout] 1166 |     ) -> Result<BootServicesBox<[efi::OpenProtocolInformationEntry], Self>, efi::Status>
[INFO] [stdout]      |                 ---------------------------------------------------------- the lifetime gets resolved as `'_`
[INFO] [stdout]      |
[INFO] [stdout] help: one option is to remove the lifetime for references and use the anonymous lifetime for paths
[INFO] [stdout]      |
[INFO] [stdout] 1166 |     ) -> Result<BootServicesBox<'_, [efi::OpenProtocolInformationEntry], Self>, efi::Status>
[INFO] [stdout]      |                                 +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: lifetime flowing from input to output with different syntax can be confusing
[INFO] [stdout]     --> src/boot_services.rs:1224:9
[INFO] [stdout]      |
[INFO] [stdout] 1224 |         &self,
[INFO] [stdout]      |         ^^^^^ this lifetime flows to the output
[INFO] [stdout] 1225 |         handle: efi::Handle,
[INFO] [stdout] 1226 |     ) -> Result<BootServicesBox<[&'static efi::Guid], Self>, efi::Status> {
[INFO] [stdout]      |                 ------------------------------------------- the lifetime gets resolved as `'_`
[INFO] [stdout]      |
[INFO] [stdout] help: one option is to remove the lifetime for references and use the anonymous lifetime for paths
[INFO] [stdout]      |
[INFO] [stdout] 1226 |     ) -> Result<BootServicesBox<'_, [&'static efi::Guid], Self>, efi::Status> {
[INFO] [stdout]      |                                 +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: lifetime flowing from input to output with different syntax can be confusing
[INFO] [stdout]     --> src/boot_services.rs:1242:9
[INFO] [stdout]      |
[INFO] [stdout] 1242 |         &self,
[INFO] [stdout]      |         ^^^^^ this lifetime flows to the output
[INFO] [stdout] 1243 |         search_type: HandleSearchType,
[INFO] [stdout] 1244 |     ) -> Result<BootServicesBox<[efi::Handle], Self>, efi::Status>
[INFO] [stdout]      |                 ------------------------------------ the lifetime gets resolved as `'_`
[INFO] [stdout]      |
[INFO] [stdout] help: one option is to remove the lifetime for references and use the anonymous lifetime for paths
[INFO] [stdout]      |
[INFO] [stdout] 1244 |     ) -> Result<BootServicesBox<'_, [efi::Handle], Self>, efi::Status>
[INFO] [stdout]      |                                 +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stderr]     Finished `dev` profile [unoptimized + debuginfo] target(s) in 1.27s
[INFO] running `Command { std: "docker" "inspect" "457bb77bb623cc28bcac2ea8788cb19a9d646c854bd6ca1f059914ec5fcbeeab", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "457bb77bb623cc28bcac2ea8788cb19a9d646c854bd6ca1f059914ec5fcbeeab", kill_on_drop: false }`
[INFO] [stdout] 457bb77bb623cc28bcac2ea8788cb19a9d646c854bd6ca1f059914ec5fcbeeab
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-0-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-0-tc1/source:/opt/rustwide/workdir:ro,Z" "-v" "/var/lib/crater-agent-workspace/cargo-home:/opt/rustwide/cargo-home:ro,Z" "-v" "/var/lib/crater-agent-workspace/rustup-home:/opt/rustwide/rustup-home:ro,Z" "-e" "SOURCE_DIR=/opt/rustwide/workdir" "-e" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_INCREMENTAL=0" "-e" "RUST_BACKTRACE=full" "-e" "RUSTFLAGS=--cap-lints=forbid -Copt-level=3" "-e" "RUSTDOCFLAGS=--cap-lints=forbid" "-e" "CARGO_HOME=/opt/rustwide/cargo-home" "-e" "RUSTUP_HOME=/opt/rustwide/rustup-home" "-w" "/opt/rustwide/workdir" "-m" "1610612736" "--user" "0:0" "--network" "none" "ghcr.io/rust-lang/crates-build-env/linux@sha256:e90291280db7d1fac5b66fc6dad9f9662629e7365a55743daf9bdf73ebc4ea79" "/opt/rustwide/cargo-home/bin/cargo" "+d98a5da813da67eb189387b8ccfb73cf481275d8" "test" "--frozen" "--no-run" "--message-format=json", kill_on_drop: false }`
[INFO] [stdout] 302076e6e9e78377f99c809c80a9e6f325acdadf6368b6ee79786fb4fd3f8d64
[INFO] running `Command { std: "docker" "start" "-a" "302076e6e9e78377f99c809c80a9e6f325acdadf6368b6ee79786fb4fd3f8d64", kill_on_drop: false }`
[INFO] [stderr]    Compiling predicates-core v1.0.9
[INFO] [stderr]    Compiling mockall_derive v0.13.1
[INFO] [stderr]    Compiling termtree v0.5.1
[INFO] [stderr]    Compiling fragile v2.0.1
[INFO] [stderr]    Compiling downcast v0.11.0
[INFO] [stdout] warning: lifetime flowing from input to output with different syntax can be confusing
[INFO] [stdout]     --> src/boot_services.rs:1052:9
[INFO] [stdout]      |
[INFO] [stdout] 1052 |         &self,
[INFO] [stdout]      |         ^^^^^ this lifetime flows to the output
[INFO] [stdout] 1053 |         search_type: HandleSearchType,
[INFO] [stdout] 1054 |     ) -> Result<BootServicesBox<[efi::Handle], Self>, efi::Status> {
[INFO] [stdout]      |                 ------------------------------------ the lifetime gets resolved as `'_`
[INFO] [stdout]      |
[INFO] [stdout]      = note: `#[warn(mismatched_lifetime_syntaxes)]` on by default
[INFO] [stdout] help: one option is to remove the lifetime for references and use the anonymous lifetime for paths
[INFO] [stdout]      |
[INFO] [stdout] 1054 |     ) -> Result<BootServicesBox<'_, [efi::Handle], Self>, efi::Status> {
[INFO] [stdout]      |                                 +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: lifetime flowing from input to output with different syntax can be confusing
[INFO] [stdout]     --> src/boot_services.rs:1163:9
[INFO] [stdout]      |
[INFO] [stdout] 1163 |         &self,
[INFO] [stdout]      |         ^^^^^ this lifetime flows to the output
[INFO] [stdout] ...
[INFO] [stdout] 1166 |     ) -> Result<BootServicesBox<[efi::OpenProtocolInformationEntry], Self>, efi::Status>
[INFO] [stdout]      |                 ---------------------------------------------------------- the lifetime gets resolved as `'_`
[INFO] [stdout]      |
[INFO] [stdout] help: one option is to remove the lifetime for references and use the anonymous lifetime for paths
[INFO] [stdout]      |
[INFO] [stdout] 1166 |     ) -> Result<BootServicesBox<'_, [efi::OpenProtocolInformationEntry], Self>, efi::Status>
[INFO] [stdout]      |                                 +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: lifetime flowing from input to output with different syntax can be confusing
[INFO] [stdout]     --> src/boot_services.rs:1224:9
[INFO] [stdout]      |
[INFO] [stdout] 1224 |         &self,
[INFO] [stdout]      |         ^^^^^ this lifetime flows to the output
[INFO] [stdout] 1225 |         handle: efi::Handle,
[INFO] [stdout] 1226 |     ) -> Result<BootServicesBox<[&'static efi::Guid], Self>, efi::Status> {
[INFO] [stdout]      |                 ------------------------------------------- the lifetime gets resolved as `'_`
[INFO] [stdout]      |
[INFO] [stdout] help: one option is to remove the lifetime for references and use the anonymous lifetime for paths
[INFO] [stdout]      |
[INFO] [stdout] 1226 |     ) -> Result<BootServicesBox<'_, [&'static efi::Guid], Self>, efi::Status> {
[INFO] [stdout]      |                                 +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: lifetime flowing from input to output with different syntax can be confusing
[INFO] [stdout]     --> src/boot_services.rs:1242:9
[INFO] [stdout]      |
[INFO] [stdout] 1242 |         &self,
[INFO] [stdout]      |         ^^^^^ this lifetime flows to the output
[INFO] [stdout] 1243 |         search_type: HandleSearchType,
[INFO] [stdout] 1244 |     ) -> Result<BootServicesBox<[efi::Handle], Self>, efi::Status>
[INFO] [stdout]      |                 ------------------------------------ the lifetime gets resolved as `'_`
[INFO] [stdout]      |
[INFO] [stdout] help: one option is to remove the lifetime for references and use the anonymous lifetime for paths
[INFO] [stdout]      |
[INFO] [stdout] 1244 |     ) -> Result<BootServicesBox<'_, [efi::Handle], Self>, efi::Status>
[INFO] [stdout]      |                                 +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stderr]    Compiling syn v2.0.106
[INFO] [stderr]    Compiling predicates v3.1.3
[INFO] [stderr]    Compiling predicates-tree v1.0.12
[INFO] [stderr]    Compiling mockall v0.13.1
[INFO] [stderr]    Compiling mu_uefi_boot_services v2.0.0 (/opt/rustwide/workdir)
[INFO] [stdout] warning: unnecessary `unsafe` block
[INFO] [stdout]     --> src/boot_services.rs:3045:24
[INFO] [stdout]      |
[INFO] [stdout] 3045 |             assert_eq!(unsafe { ptr::addr_of!(B) } as usize, dest as usize);
[INFO] [stdout]      |                        ^^^^^^ unnecessary `unsafe` block
[INFO] [stdout]      |
[INFO] [stdout]      = note: `#[warn(unused_unsafe)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary `unsafe` block
[INFO] [stdout]     --> src/boot_services.rs:3067:24
[INFO] [stdout]      |
[INFO] [stdout] 3067 |             assert_eq!(unsafe { ptr::addr_of!(BUFFER) } as usize, buffer as usize);
[INFO] [stdout]      |                        ^^^^^^ unnecessary `unsafe` block
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary `unsafe` block
[INFO] [stdout]     --> src/boot_services.rs:3109:24
[INFO] [stdout]      |
[INFO] [stdout] 3109 |             assert_eq!(unsafe { ptr::addr_of!(TABLE) } as usize, table as usize);
[INFO] [stdout]      |                        ^^^^^^ unnecessary `unsafe` block
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: lifetime flowing from input to output with different syntax can be confusing
[INFO] [stdout]     --> src/boot_services.rs:1052:9
[INFO] [stdout]      |
[INFO] [stdout] 1052 |         &self,
[INFO] [stdout]      |         ^^^^^ this lifetime flows to the output
[INFO] [stdout] 1053 |         search_type: HandleSearchType,
[INFO] [stdout] 1054 |     ) -> Result<BootServicesBox<[efi::Handle], Self>, efi::Status> {
[INFO] [stdout]      |                 ------------------------------------ the lifetime gets resolved as `'_`
[INFO] [stdout]      |
[INFO] [stdout]      = note: `#[warn(mismatched_lifetime_syntaxes)]` on by default
[INFO] [stdout] help: one option is to remove the lifetime for references and use the anonymous lifetime for paths
[INFO] [stdout]      |
[INFO] [stdout] 1054 |     ) -> Result<BootServicesBox<'_, [efi::Handle], Self>, efi::Status> {
[INFO] [stdout]      |                                 +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: lifetime flowing from input to output with different syntax can be confusing
[INFO] [stdout]     --> src/boot_services.rs:1163:9
[INFO] [stdout]      |
[INFO] [stdout] 1163 |         &self,
[INFO] [stdout]      |         ^^^^^ this lifetime flows to the output
[INFO] [stdout] ...
[INFO] [stdout] 1166 |     ) -> Result<BootServicesBox<[efi::OpenProtocolInformationEntry], Self>, efi::Status>
[INFO] [stdout]      |                 ---------------------------------------------------------- the lifetime gets resolved as `'_`
[INFO] [stdout]      |
[INFO] [stdout] help: one option is to remove the lifetime for references and use the anonymous lifetime for paths
[INFO] [stdout]      |
[INFO] [stdout] 1166 |     ) -> Result<BootServicesBox<'_, [efi::OpenProtocolInformationEntry], Self>, efi::Status>
[INFO] [stdout]      |                                 +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: lifetime flowing from input to output with different syntax can be confusing
[INFO] [stdout]     --> src/boot_services.rs:1224:9
[INFO] [stdout]      |
[INFO] [stdout] 1224 |         &self,
[INFO] [stdout]      |         ^^^^^ this lifetime flows to the output
[INFO] [stdout] 1225 |         handle: efi::Handle,
[INFO] [stdout] 1226 |     ) -> Result<BootServicesBox<[&'static efi::Guid], Self>, efi::Status> {
[INFO] [stdout]      |                 ------------------------------------------- the lifetime gets resolved as `'_`
[INFO] [stdout]      |
[INFO] [stdout] help: one option is to remove the lifetime for references and use the anonymous lifetime for paths
[INFO] [stdout]      |
[INFO] [stdout] 1226 |     ) -> Result<BootServicesBox<'_, [&'static efi::Guid], Self>, efi::Status> {
[INFO] [stdout]      |                                 +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: lifetime flowing from input to output with different syntax can be confusing
[INFO] [stdout]     --> src/boot_services.rs:1242:9
[INFO] [stdout]      |
[INFO] [stdout] 1242 |         &self,
[INFO] [stdout]      |         ^^^^^ this lifetime flows to the output
[INFO] [stdout] 1243 |         search_type: HandleSearchType,
[INFO] [stdout] 1244 |     ) -> Result<BootServicesBox<[efi::Handle], Self>, efi::Status>
[INFO] [stdout]      |                 ------------------------------------ the lifetime gets resolved as `'_`
[INFO] [stdout]      |
[INFO] [stdout] help: one option is to remove the lifetime for references and use the anonymous lifetime for paths
[INFO] [stdout]      |
[INFO] [stdout] 1244 |     ) -> Result<BootServicesBox<'_, [efi::Handle], Self>, efi::Status>
[INFO] [stdout]      |                                 +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: a dangling pointer will be produced because the temporary `MaybeUninit<r_efi::system::BootServices>` will be dropped
[INFO] [stdout]     --> src/boot_services.rs:1529:74
[INFO] [stdout]      |
[INFO] [stdout] 1529 |         let efi_bs = unsafe { MaybeUninit::<efi::BootServices>::zeroed().as_ptr().as_ref().unwrap() };
[INFO] [stdout]      |                               ------------------------------------------ ^^^^^^ this pointer will immediately be invalid
[INFO] [stdout]      |                               |
[INFO] [stdout]      |                               this `MaybeUninit<r_efi::system::BootServices>` is deallocated at the end of the statement, bind it to a variable to extend its lifetime
[INFO] [stdout]      |
[INFO] [stdout]      = note: pointers do not have a lifetime; when calling `as_ptr` the `MaybeUninit<r_efi::system::BootServices>` will be deallocated at the end of the statement because nothing is referencing it as far as the type system is concerned
[INFO] [stdout]      = help: you must make sure that the variable you bind the `MaybeUninit<r_efi::system::BootServices>` to lives at least as long as the pointer returned by the call to `as_ptr`
[INFO] [stdout]      = help: in particular, if this pointer is returned from the current function, binding the `MaybeUninit<r_efi::system::BootServices>` inside the function will not suffice
[INFO] [stdout]      = help: for more information, see <https://doc.rust-lang.org/reference/destructors.html>
[INFO] [stdout]      = note: `#[warn(dangling_pointers_from_temporaries)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function pointer comparisons do not produce meaningful results since their addresses are not guaranteed to be unique
[INFO] [stdout]     --> src/boot_services.rs:1593:13
[INFO] [stdout]      |
[INFO] [stdout] 1593 |             assert_eq!(None, notify_function);
[INFO] [stdout]      |             ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]      |
[INFO] [stdout]      = note: the address of the same function can vary between different codegen units
[INFO] [stdout]      = note: furthermore, different functions could have the same address after being merged together
[INFO] [stdout]      = note: for more information visit <https://doc.rust-lang.org/nightly/core/ptr/fn.fn_addr_eq.html>
[INFO] [stdout]      = note: `#[warn(unpredictable_function_pointer_comparisons)]` on by default
[INFO] [stdout]      = note: this warning originates in the macro `assert_eq` (in Nightly builds, run with -Z macro-backtrace for more info)
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function pointer comparisons do not produce meaningful results since their addresses are not guaranteed to be unique
[INFO] [stdout]     --> src/boot_services.rs:1668:13
[INFO] [stdout]      |
[INFO] [stdout] 1668 |             assert_eq!(None, notify_function);
[INFO] [stdout]      |             ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]      |
[INFO] [stdout]      = note: the address of the same function can vary between different codegen units
[INFO] [stdout]      = note: furthermore, different functions could have the same address after being merged together
[INFO] [stdout]      = note: for more information visit <https://doc.rust-lang.org/nightly/core/ptr/fn.fn_addr_eq.html>
[INFO] [stdout]      = note: this warning originates in the macro `assert_eq` (in Nightly builds, run with -Z macro-backtrace for more info)
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stderr]     Finished `test` profile [unoptimized + debuginfo] target(s) in 1m 09s
[INFO] running `Command { std: "docker" "inspect" "302076e6e9e78377f99c809c80a9e6f325acdadf6368b6ee79786fb4fd3f8d64", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "302076e6e9e78377f99c809c80a9e6f325acdadf6368b6ee79786fb4fd3f8d64", kill_on_drop: false }`
[INFO] [stdout] 302076e6e9e78377f99c809c80a9e6f325acdadf6368b6ee79786fb4fd3f8d64
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-0-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-0-tc1/source:/opt/rustwide/workdir:ro,Z" "-v" "/var/lib/crater-agent-workspace/cargo-home:/opt/rustwide/cargo-home:ro,Z" "-v" "/var/lib/crater-agent-workspace/rustup-home:/opt/rustwide/rustup-home:ro,Z" "-e" "SOURCE_DIR=/opt/rustwide/workdir" "-e" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_INCREMENTAL=0" "-e" "RUST_BACKTRACE=full" "-e" "RUSTFLAGS=--cap-lints=forbid -Copt-level=3" "-e" "RUSTDOCFLAGS=--cap-lints=forbid" "-e" "CARGO_HOME=/opt/rustwide/cargo-home" "-e" "RUSTUP_HOME=/opt/rustwide/rustup-home" "-w" "/opt/rustwide/workdir" "-m" "1610612736" "--user" "0:0" "--network" "none" "ghcr.io/rust-lang/crates-build-env/linux@sha256:e90291280db7d1fac5b66fc6dad9f9662629e7365a55743daf9bdf73ebc4ea79" "/opt/rustwide/cargo-home/bin/cargo" "+d98a5da813da67eb189387b8ccfb73cf481275d8" "test" "--frozen", kill_on_drop: false }`
[INFO] [stdout] 6a7897fa28273221cb7e0cd7454757d514768e098d55688b188bb544f29cbea0
[INFO] running `Command { std: "docker" "start" "-a" "6a7897fa28273221cb7e0cd7454757d514768e098d55688b188bb544f29cbea0", kill_on_drop: false }`
[INFO] [stderr] warning: lifetime flowing from input to output with different syntax can be confusing
[INFO] [stderr]     --> src/boot_services.rs:1052:9
[INFO] [stderr]      |
[INFO] [stderr] 1052 |         &self,
[INFO] [stderr]      |         ^^^^^ this lifetime flows to the output
[INFO] [stderr] 1053 |         search_type: HandleSearchType,
[INFO] [stderr] 1054 |     ) -> Result<BootServicesBox<[efi::Handle], Self>, efi::Status> {
[INFO] [stderr]      |                 ------------------------------------ the lifetime gets resolved as `'_`
[INFO] [stderr]      |
[INFO] [stderr]      = note: `#[warn(mismatched_lifetime_syntaxes)]` on by default
[INFO] [stderr] help: one option is to remove the lifetime for references and use the anonymous lifetime for paths
[INFO] [stderr]      |
[INFO] [stderr] 1054 |     ) -> Result<BootServicesBox<'_, [efi::Handle], Self>, efi::Status> {
[INFO] [stderr]      |                                 +++
[INFO] [stderr] 
[INFO] [stderr] warning: lifetime flowing from input to output with different syntax can be confusing
[INFO] [stderr]     --> src/boot_services.rs:1163:9
[INFO] [stderr]      |
[INFO] [stderr] 1163 |         &self,
[INFO] [stderr]      |         ^^^^^ this lifetime flows to the output
[INFO] [stderr] ...
[INFO] [stderr] 1166 |     ) -> Result<BootServicesBox<[efi::OpenProtocolInformationEntry], Self>, efi::Status>
[INFO] [stderr]      |                 ---------------------------------------------------------- the lifetime gets resolved as `'_`
[INFO] [stderr]      |
[INFO] [stderr] help: one option is to remove the lifetime for references and use the anonymous lifetime for paths
[INFO] [stderr]      |
[INFO] [stderr] 1166 |     ) -> Result<BootServicesBox<'_, [efi::OpenProtocolInformationEntry], Self>, efi::Status>
[INFO] [stderr]      |                                 +++
[INFO] [stderr] 
[INFO] [stderr] warning: lifetime flowing from input to output with different syntax can be confusing
[INFO] [stderr]     --> src/boot_services.rs:1224:9
[INFO] [stderr]      |
[INFO] [stderr] 1224 |         &self,
[INFO] [stderr]      |         ^^^^^ this lifetime flows to the output
[INFO] [stderr] 1225 |         handle: efi::Handle,
[INFO] [stderr] 1226 |     ) -> Result<BootServicesBox<[&'static efi::Guid], Self>, efi::Status> {
[INFO] [stderr]      |                 ------------------------------------------- the lifetime gets resolved as `'_`
[INFO] [stderr]      |
[INFO] [stderr] help: one option is to remove the lifetime for references and use the anonymous lifetime for paths
[INFO] [stderr]      |
[INFO] [stderr] 1226 |     ) -> Result<BootServicesBox<'_, [&'static efi::Guid], Self>, efi::Status> {
[INFO] [stderr]      |                                 +++
[INFO] [stderr] 
[INFO] [stderr] warning: lifetime flowing from input to output with different syntax can be confusing
[INFO] [stderr]     --> src/boot_services.rs:1242:9
[INFO] [stderr]      |
[INFO] [stderr] 1242 |         &self,
[INFO] [stderr]      |         ^^^^^ this lifetime flows to the output
[INFO] [stderr] 1243 |         search_type: HandleSearchType,
[INFO] [stderr] 1244 |     ) -> Result<BootServicesBox<[efi::Handle], Self>, efi::Status>
[INFO] [stderr]      |                 ------------------------------------ the lifetime gets resolved as `'_`
[INFO] [stderr]      |
[INFO] [stderr] help: one option is to remove the lifetime for references and use the anonymous lifetime for paths
[INFO] [stderr]      |
[INFO] [stderr] 1244 |     ) -> Result<BootServicesBox<'_, [efi::Handle], Self>, efi::Status>
[INFO] [stderr]      |                                 +++
[INFO] [stderr] 
[INFO] [stderr] warning: `mu_uefi_boot_services` (lib) generated 4 warnings
[INFO] [stderr] warning: unnecessary `unsafe` block
[INFO] [stderr]     --> src/boot_services.rs:3045:24
[INFO] [stderr]      |
[INFO] [stderr] 3045 |             assert_eq!(unsafe { ptr::addr_of!(B) } as usize, dest as usize);
[INFO] [stderr]      |                        ^^^^^^ unnecessary `unsafe` block
[INFO] [stderr]      |
[INFO] [stderr]      = note: `#[warn(unused_unsafe)]` on by default
[INFO] [stderr] 
[INFO] [stderr] warning: unnecessary `unsafe` block
[INFO] [stderr]     --> src/boot_services.rs:3067:24
[INFO] [stderr]      |
[INFO] [stderr] 3067 |             assert_eq!(unsafe { ptr::addr_of!(BUFFER) } as usize, buffer as usize);
[INFO] [stderr]      |                        ^^^^^^ unnecessary `unsafe` block
[INFO] [stderr] 
[INFO] [stderr] warning: unnecessary `unsafe` block
[INFO] [stderr]     --> src/boot_services.rs:3109:24
[INFO] [stderr]      |
[INFO] [stderr] 3109 |             assert_eq!(unsafe { ptr::addr_of!(TABLE) } as usize, table as usize);
[INFO] [stderr]      |                        ^^^^^^ unnecessary `unsafe` block
[INFO] [stderr] 
[INFO] [stderr] warning: a dangling pointer will be produced because the temporary `MaybeUninit<r_efi::system::BootServices>` will be dropped
[INFO] [stderr]     --> src/boot_services.rs:1529:74
[INFO] [stderr]      |
[INFO] [stderr] 1529 |         let efi_bs = unsafe { MaybeUninit::<efi::BootServices>::zeroed().as_ptr().as_ref().unwrap() };
[INFO] [stderr]      |                               ------------------------------------------ ^^^^^^ this pointer will immediately be invalid
[INFO] [stderr]      |                               |
[INFO] [stderr]      |                               this `MaybeUninit<r_efi::system::BootServices>` is deallocated at the end of the statement, bind it to a variable to extend its lifetime
[INFO] [stderr]      |
[INFO] [stderr]      = note: pointers do not have a lifetime; when calling `as_ptr` the `MaybeUninit<r_efi::system::BootServices>` will be deallocated at the end of the statement because nothing is referencing it as far as the type system is concerned
[INFO] [stderr]      = help: you must make sure that the variable you bind the `MaybeUninit<r_efi::system::BootServices>` to lives at least as long as the pointer returned by the call to `as_ptr`
[INFO] [stderr]      = help: in particular, if this pointer is returned from the current function, binding the `MaybeUninit<r_efi::system::BootServices>` inside the function will not suffice
[INFO] [stderr]      = help: for more information, see <https://doc.rust-lang.org/reference/destructors.html>
[INFO] [stderr]      = note: `#[warn(dangling_pointers_from_temporaries)]` on by default
[INFO] [stderr] 
[INFO] [stderr] warning: function pointer comparisons do not produce meaningful results since their addresses are not guaranteed to be unique
[INFO] [stderr]     --> src/boot_services.rs:1593:13
[INFO] [stderr]      |
[INFO] [stderr] 1593 |             assert_eq!(None, notify_function);
[INFO] [stderr]      |             ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr]      |
[INFO] [stderr]      = note: the address of the same function can vary between different codegen units
[INFO] [stderr]      = note: furthermore, different functions could have the same address after being merged together
[INFO] [stderr]      = note: for more information visit <https://doc.rust-lang.org/nightly/core/ptr/fn.fn_addr_eq.html>
[INFO] [stderr]      = note: `#[warn(unpredictable_function_pointer_comparisons)]` on by default
[INFO] [stderr]      = note: this warning originates in the macro `assert_eq` (in Nightly builds, run with -Z macro-backtrace for more info)
[INFO] [stderr] 
[INFO] [stderr] warning: function pointer comparisons do not produce meaningful results since their addresses are not guaranteed to be unique
[INFO] [stderr]     --> src/boot_services.rs:1668:13
[INFO] [stderr]      |
[INFO] [stderr] 1668 |             assert_eq!(None, notify_function);
[INFO] [stderr]      |             ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr]      |
[INFO] [stderr]      = note: the address of the same function can vary between different codegen units
[INFO] [stderr]      = note: furthermore, different functions could have the same address after being merged together
[INFO] [stderr]      = note: for more information visit <https://doc.rust-lang.org/nightly/core/ptr/fn.fn_addr_eq.html>
[INFO] [stderr]      = note: this warning originates in the macro `assert_eq` (in Nightly builds, run with -Z macro-backtrace for more info)
[INFO] [stderr] 
[INFO] [stderr] warning: `mu_uefi_boot_services` (lib test) generated 10 warnings (4 duplicates)
[INFO] [stderr]     Finished `test` profile [unoptimized + debuginfo] target(s) in 0.06s
[INFO] [stderr]      Running unittests src/boot_services.rs (/opt/rustwide/target/debug/deps/boot_services-188f47aa578110fd)
[INFO] [stdout] 
[INFO] [stdout] running 104 tests
[INFO] [stdout] test c_ptr::test::test_manually_drop ... ok
[INFO] [stdout] test c_ptr::test::test_option ... ok
[INFO] [stderr] error: test failed, to rerun pass `--lib`
[INFO] [stderr] 
[INFO] [stderr] Caused by:
[INFO] [stderr]   process didn't exit successfully: `/opt/rustwide/target/debug/deps/boot_services-188f47aa578110fd` (signal: 11, SIGSEGV: invalid memory reference)
[INFO] running `Command { std: "docker" "inspect" "6a7897fa28273221cb7e0cd7454757d514768e098d55688b188bb544f29cbea0", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "6a7897fa28273221cb7e0cd7454757d514768e098d55688b188bb544f29cbea0", kill_on_drop: false }`
[INFO] [stdout] 6a7897fa28273221cb7e0cd7454757d514768e098d55688b188bb544f29cbea0
