[INFO] fetching crate sys_util 0.1.0...
[INFO] testing sys_util-0.1.0 against 1.95.0 for beta-1.96-2
[INFO] extracting crate sys_util 0.1.0 into /workspace/builds/worker-3-tc1/source
[INFO] started tweaking crates.io crate sys_util 0.1.0
[INFO] finished tweaking crates.io crate sys_util 0.1.0
[INFO] tweaked toml for crates.io crate sys_util 0.1.0 written to /workspace/builds/worker-3-tc1/source/Cargo.toml
[INFO] validating manifest of crates.io crate sys_util 0.1.0 on toolchain 1.95.0
[INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+1.95.0" "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" "+1.95.0" "generate-lockfile" "--manifest-path" "Cargo.toml", kill_on_drop: false }`
[INFO] [stderr]     Updating crates.io index
[INFO] [stderr]      Locking 10 packages to latest compatible versions
[INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+1.95.0" "fetch" "--manifest-path" "Cargo.toml", kill_on_drop: false }`
[INFO] [stderr] warning: the cargo feature `rename-dependency` has been stabilized in the 1.31 release and is no longer necessary to be listed in the manifest
[INFO] [stderr]   See https://doc.rust-lang.org/cargo/reference/specifying-dependencies.html#renaming-dependencies-in-cargotoml for more information about using this feature.
[INFO] [stderr] warning: no edition set: defaulting to the 2015 edition while the latest is 2024
[INFO] [stderr]  Downloading crates ...
[INFO] [stderr]   Downloaded syscall_defines v0.1.0
[INFO] [stderr]   Downloaded sync_panic v0.1.0
[INFO] [stderr]   Downloaded data_model v0.1.0
[INFO] [stderr]   Downloaded poll_token_derive v0.1.0
[INFO] [stderr]   Downloaded assertions v0.1.0
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-3-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-3-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:d429b63d4308055ea97f60fb1d3dfca48854a00942f1bd2ad806beaf015945ec" "/opt/rustwide/cargo-home/bin/cargo" "+1.95.0" "metadata" "--no-deps" "--format-version=1", kill_on_drop: false }`
[INFO] [stdout] 093e63317c2e0b809595b9afc8902efd48ea0f206121d4937a378f94f520bf8e
[INFO] running `Command { std: "docker" "start" "-a" "093e63317c2e0b809595b9afc8902efd48ea0f206121d4937a378f94f520bf8e", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "inspect" "093e63317c2e0b809595b9afc8902efd48ea0f206121d4937a378f94f520bf8e", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "093e63317c2e0b809595b9afc8902efd48ea0f206121d4937a378f94f520bf8e", kill_on_drop: false }`
[INFO] [stdout] 093e63317c2e0b809595b9afc8902efd48ea0f206121d4937a378f94f520bf8e
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-3-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-3-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=warn" "-e" "RUSTDOCFLAGS=--cap-lints=warn" "-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:d429b63d4308055ea97f60fb1d3dfca48854a00942f1bd2ad806beaf015945ec" "/opt/rustwide/cargo-home/bin/cargo" "+1.95.0" "build" "--frozen" "--message-format=json", kill_on_drop: false }`
[INFO] [stdout] b263bdce31cd631d1c327069ad3e7f1c23c80ba29419a3b02ae15808389d2379
[INFO] running `Command { std: "docker" "start" "-a" "b263bdce31cd631d1c327069ad3e7f1c23c80ba29419a3b02ae15808389d2379", kill_on_drop: false }`
[INFO] [stderr] warning: the cargo feature `rename-dependency` has been stabilized in the 1.31 release and is no longer necessary to be listed in the manifest
[INFO] [stderr]   See https://doc.rust-lang.org/cargo/reference/specifying-dependencies.html#renaming-dependencies-in-cargotoml for more information about using this feature.
[INFO] [stderr] warning: no edition set: defaulting to the 2015 edition while the latest is 2024
[INFO] [stderr]    Compiling proc-macro2 v0.4.30
[INFO] [stderr]    Compiling unicode-xid v0.1.0
[INFO] [stderr]    Compiling syn v0.15.44
[INFO] [stderr]    Compiling assertions v0.1.0
[INFO] [stderr]    Compiling syscall_defines v0.1.0
[INFO] [stderr]    Compiling sync_panic v0.1.0
[INFO] [stderr]    Compiling data_model v0.1.0
[INFO] [stderr]    Compiling quote v0.6.13
[INFO] [stderr]    Compiling poll_token_derive v0.1.0
[INFO] [stderr]    Compiling sys_util v0.1.0 (/opt/rustwide/workdir)
[INFO] [stdout] warning: unexpected `cfg` condition value: `cargo-clippy`
[INFO] [stdout]   --> src/sock_ctrl_msg.rs:55:12
[INFO] [stdout]    |
[INFO] [stdout] 55 | #[cfg_attr(feature = "cargo-clippy", allow(cast_ptr_alignment))]
[INFO] [stdout]    |            ^^^^^^^^^^^^^^^^^^^^^^^^ help: remove the condition
[INFO] [stdout]    |
[INFO] [stdout]    = note: no expected values for `feature`
[INFO] [stdout]    = help: consider adding `cargo-clippy` as a feature in `Cargo.toml`
[INFO] [stdout]    = note: see <https://doc.rust-lang.org/nightly/rustc/check-cfg/cargo-specifics.html> for more information about checking conditional configuration
[INFO] [stdout]    = note: `#[warn(unexpected_cfgs)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unexpected `cfg` condition value: `cargo-clippy`
[INFO] [stdout]    --> src/sock_ctrl_msg.rs:315:16
[INFO] [stdout]     |
[INFO] [stdout] 315 |     #[cfg_attr(feature = "cargo-clippy", allow(useless_asref))]
[INFO] [stdout]     |                ^^^^^^^^^^^^^^^^^^^^^^^^ help: remove the condition
[INFO] [stdout]     |
[INFO] [stdout]     = note: no expected values for `feature`
[INFO] [stdout]     = help: consider adding `cargo-clippy` as a feature in `Cargo.toml`
[INFO] [stdout]     = note: see <https://doc.rust-lang.org/nightly/rustc/check-cfg/cargo-specifics.html> for more information about checking conditional configuration
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: trailing semicolon in macro used in expression position
[INFO] [stdout]    --> src/syslog.rs:252:10
[INFO] [stdout]     |
[INFO] [stdout] 252 |         };
[INFO] [stdout]     |          ^
[INFO] [stdout] ...
[INFO] [stdout] 263 |     let mut state = lock!();
[INFO] [stdout]     |                     ------- in this macro invocation
[INFO] [stdout]     |
[INFO] [stdout]     = warning: this was previously accepted by the compiler but is being phased out; it will become a hard error in a future release!
[INFO] [stdout]     = note: for more information, see issue #79813 <https://github.com/rust-lang/rust/issues/79813>
[INFO] [stdout]     = note: `#[warn(semicolon_in_expressions_from_macros)]` (part of `#[warn(future_incompatible)]`) on by default
[INFO] [stdout]     = note: this warning originates in the macro `lock` (in Nightly builds, run with -Z macro-backtrace for more info)
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: trailing semicolon in macro used in expression position
[INFO] [stdout]    --> src/syslog.rs:252:10
[INFO] [stdout]     |
[INFO] [stdout] 252 |         };
[INFO] [stdout]     |          ^
[INFO] [stdout] ...
[INFO] [stdout] 280 |     let mut state = lock!();
[INFO] [stdout]     |                     ------- in this macro invocation
[INFO] [stdout]     |
[INFO] [stdout]     = warning: this was previously accepted by the compiler but is being phased out; it will become a hard error in a future release!
[INFO] [stdout]     = note: for more information, see issue #79813 <https://github.com/rust-lang/rust/issues/79813>
[INFO] [stdout]     = note: this warning originates in the macro `lock` (in Nightly builds, run with -Z macro-backtrace for more info)
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: trailing semicolon in macro used in expression position
[INFO] [stdout]    --> src/syslog.rs:252:10
[INFO] [stdout]     |
[INFO] [stdout] 252 |         };
[INFO] [stdout]     |          ^
[INFO] [stdout] ...
[INFO] [stdout] 329 |     let mut state = lock!();
[INFO] [stdout]     |                     ------- in this macro invocation
[INFO] [stdout]     |
[INFO] [stdout]     = warning: this was previously accepted by the compiler but is being phased out; it will become a hard error in a future release!
[INFO] [stdout]     = note: for more information, see issue #79813 <https://github.com/rust-lang/rust/issues/79813>
[INFO] [stdout]     = note: this warning originates in the macro `lock` (in Nightly builds, run with -Z macro-backtrace for more info)
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: trailing semicolon in macro used in expression position
[INFO] [stdout]    --> src/syslog.rs:252:10
[INFO] [stdout]     |
[INFO] [stdout] 252 |         };
[INFO] [stdout]     |          ^
[INFO] [stdout] ...
[INFO] [stdout] 342 |     let mut state = lock!();
[INFO] [stdout]     |                     ------- in this macro invocation
[INFO] [stdout]     |
[INFO] [stdout]     = warning: this was previously accepted by the compiler but is being phased out; it will become a hard error in a future release!
[INFO] [stdout]     = note: for more information, see issue #79813 <https://github.com/rust-lang/rust/issues/79813>
[INFO] [stdout]     = note: this warning originates in the macro `lock` (in Nightly builds, run with -Z macro-backtrace for more info)
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: trailing semicolon in macro used in expression position
[INFO] [stdout]    --> src/syslog.rs:252:10
[INFO] [stdout]     |
[INFO] [stdout] 252 |         };
[INFO] [stdout]     |          ^
[INFO] [stdout] ...
[INFO] [stdout] 353 |     let state = lock!();
[INFO] [stdout]     |                 ------- in this macro invocation
[INFO] [stdout]     |
[INFO] [stdout]     = warning: this was previously accepted by the compiler but is being phased out; it will become a hard error in a future release!
[INFO] [stdout]     = note: for more information, see issue #79813 <https://github.com/rust-lang/rust/issues/79813>
[INFO] [stdout]     = note: this warning originates in the macro `lock` (in Nightly builds, run with -Z macro-backtrace for more info)
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: trailing semicolon in macro used in expression position
[INFO] [stdout]    --> src/syslog.rs:252:10
[INFO] [stdout]     |
[INFO] [stdout] 252 |         };
[INFO] [stdout]     |          ^
[INFO] [stdout] ...
[INFO] [stdout] 427 |     let mut state = lock!();
[INFO] [stdout]     |                     ------- in this macro invocation
[INFO] [stdout]     |
[INFO] [stdout]     = warning: this was previously accepted by the compiler but is being phased out; it will become a hard error in a future release!
[INFO] [stdout]     = note: for more information, see issue #79813 <https://github.com/rust-lang/rust/issues/79813>
[INFO] [stdout]     = note: this warning originates in the macro `lock` (in Nightly builds, run with -Z macro-backtrace for more info)
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated constant `std::sync::ONCE_INIT`: the `Once::new()` function is now preferred
[INFO] [stdout]   --> src/syslog.rs:39:35
[INFO] [stdout]    |
[INFO] [stdout] 39 | use std::sync::{MutexGuard, Once, ONCE_INIT};
[INFO] [stdout]    |                                   ^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(deprecated)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated constant `std::sync::ONCE_INIT`: the `Once::new()` function is now preferred
[INFO] [stdout]    --> src/syslog.rs:207:27
[INFO] [stdout]     |
[INFO] [stdout] 207 | static STATE_ONCE: Once = ONCE_INIT;
[INFO] [stdout]     |                           ^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout] help: replace the use of the deprecated constant
[INFO] [stdout]     |
[INFO] [stdout] 207 - static STATE_ONCE: Once = ONCE_INIT;
[INFO] [stdout] 207 + static STATE_ONCE: Once = Once::new();
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated function `std::mem::uninitialized`: use `mem::MaybeUninit` instead
[INFO] [stdout]   --> src/net.rs:16:44
[INFO] [stdout]    |
[INFO] [stdout] 16 |         let addr: libc::sockaddr_un = mem::uninitialized();
[INFO] [stdout]    |                                            ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stdout]    --> src/poll.rs:290:28
[INFO] [stdout]     |
[INFO] [stdout] 290 |     pub fn add(&self, fd: &AsRawFd, token: T) -> Result<()> {
[INFO] [stdout]     |                            ^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = warning: this is accepted in the current edition (Rust 2015) but is a hard error in Rust 2021!
[INFO] [stdout]     = note: for more information, see <https://doc.rust-lang.org/edition-guide/rust-2021/warnings-promoted-to-error.html>
[INFO] [stdout]     = note: `#[warn(bare_trait_objects)]` (part of `#[warn(rust_2021_compatibility)]`) on by default
[INFO] [stdout] help: if this is a dyn-compatible trait, use `dyn`
[INFO] [stdout]     |
[INFO] [stdout] 290 |     pub fn add(&self, fd: &dyn AsRawFd, token: T) -> Result<()> {
[INFO] [stdout]     |                            +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stdout]    --> src/poll.rs:300:43
[INFO] [stdout]     |
[INFO] [stdout] 300 |     pub fn add_fd_with_events(&self, fd: &AsRawFd, events: WatchingEvents, token: T) -> Result<()> {
[INFO] [stdout]     |                                           ^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = warning: this is accepted in the current edition (Rust 2015) but is a hard error in Rust 2021!
[INFO] [stdout]     = note: for more information, see <https://doc.rust-lang.org/edition-guide/rust-2021/warnings-promoted-to-error.html>
[INFO] [stdout] help: if this is a dyn-compatible trait, use `dyn`
[INFO] [stdout]     |
[INFO] [stdout] 300 |     pub fn add_fd_with_events(&self, fd: &dyn AsRawFd, events: WatchingEvents, token: T) -> Result<()> {
[INFO] [stdout]     |                                           +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stdout]    --> src/poll.rs:323:31
[INFO] [stdout]     |
[INFO] [stdout] 323 |     pub fn modify(&self, fd: &AsRawFd, events: WatchingEvents, token: T) -> Result<()> {
[INFO] [stdout]     |                               ^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = warning: this is accepted in the current edition (Rust 2015) but is a hard error in Rust 2021!
[INFO] [stdout]     = note: for more information, see <https://doc.rust-lang.org/edition-guide/rust-2021/warnings-promoted-to-error.html>
[INFO] [stdout] help: if this is a dyn-compatible trait, use `dyn`
[INFO] [stdout]     |
[INFO] [stdout] 323 |     pub fn modify(&self, fd: &dyn AsRawFd, events: WatchingEvents, token: T) -> Result<()> {
[INFO] [stdout]     |                               +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stdout]    --> src/poll.rs:350:31
[INFO] [stdout]     |
[INFO] [stdout] 350 |     pub fn delete(&self, fd: &AsRawFd) -> Result<()> {
[INFO] [stdout]     |                               ^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = warning: this is accepted in the current edition (Rust 2015) but is a hard error in Rust 2021!
[INFO] [stdout]     = note: for more information, see <https://doc.rust-lang.org/edition-guide/rust-2021/warnings-promoted-to-error.html>
[INFO] [stdout] help: if this is a dyn-compatible trait, use `dyn`
[INFO] [stdout]     |
[INFO] [stdout] 350 |     pub fn delete(&self, fd: &dyn AsRawFd) -> Result<()> {
[INFO] [stdout]     |                               +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stdout]    --> src/poll.rs:494:28
[INFO] [stdout]     |
[INFO] [stdout] 494 |     pub fn add(&self, fd: &AsRawFd, token: T) -> Result<()> {
[INFO] [stdout]     |                            ^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = warning: this is accepted in the current edition (Rust 2015) but is a hard error in Rust 2021!
[INFO] [stdout]     = note: for more information, see <https://doc.rust-lang.org/edition-guide/rust-2021/warnings-promoted-to-error.html>
[INFO] [stdout] help: if this is a dyn-compatible trait, use `dyn`
[INFO] [stdout]     |
[INFO] [stdout] 494 |     pub fn add(&self, fd: &dyn AsRawFd, token: T) -> Result<()> {
[INFO] [stdout]     |                            +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stdout]    --> src/poll.rs:504:43
[INFO] [stdout]     |
[INFO] [stdout] 504 |     pub fn add_fd_with_events(&self, fd: &AsRawFd, events: WatchingEvents, token: T) -> Result<()> {
[INFO] [stdout]     |                                           ^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = warning: this is accepted in the current edition (Rust 2015) but is a hard error in Rust 2021!
[INFO] [stdout]     = note: for more information, see <https://doc.rust-lang.org/edition-guide/rust-2021/warnings-promoted-to-error.html>
[INFO] [stdout] help: if this is a dyn-compatible trait, use `dyn`
[INFO] [stdout]     |
[INFO] [stdout] 504 |     pub fn add_fd_with_events(&self, fd: &dyn AsRawFd, events: WatchingEvents, token: T) -> Result<()> {
[INFO] [stdout]     |                                           +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stdout]    --> src/poll.rs:513:31
[INFO] [stdout]     |
[INFO] [stdout] 513 |     pub fn modify(&self, fd: &AsRawFd, events: WatchingEvents, token: T) -> Result<()> {
[INFO] [stdout]     |                               ^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = warning: this is accepted in the current edition (Rust 2015) but is a hard error in Rust 2021!
[INFO] [stdout]     = note: for more information, see <https://doc.rust-lang.org/edition-guide/rust-2021/warnings-promoted-to-error.html>
[INFO] [stdout] help: if this is a dyn-compatible trait, use `dyn`
[INFO] [stdout]     |
[INFO] [stdout] 513 |     pub fn modify(&self, fd: &dyn AsRawFd, events: WatchingEvents, token: T) -> Result<()> {
[INFO] [stdout]     |                               +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stdout]    --> src/poll.rs:523:31
[INFO] [stdout]     |
[INFO] [stdout] 523 |     pub fn delete(&self, fd: &AsRawFd) -> Result<()> {
[INFO] [stdout]     |                               ^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = warning: this is accepted in the current edition (Rust 2015) but is a hard error in Rust 2021!
[INFO] [stdout]     = note: for more information, see <https://doc.rust-lang.org/edition-guide/rust-2021/warnings-promoted-to-error.html>
[INFO] [stdout] help: if this is a dyn-compatible trait, use `dyn`
[INFO] [stdout]     |
[INFO] [stdout] 523 |     pub fn delete(&self, fd: &dyn AsRawFd) -> Result<()> {
[INFO] [stdout]     |                               +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stdout]    --> src/lib.rs:149:21
[INFO] [stdout]     |
[INFO] [stdout] 149 | pub fn flock(file: &AsRawFd, op: FlockOperation, nonblocking: bool) -> Result<()> {
[INFO] [stdout]     |                     ^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = warning: this is accepted in the current edition (Rust 2015) but is a hard error in Rust 2021!
[INFO] [stdout]     = note: for more information, see <https://doc.rust-lang.org/edition-guide/rust-2021/warnings-promoted-to-error.html>
[INFO] [stdout] help: if this is a dyn-compatible trait, use `dyn`
[INFO] [stdout]     |
[INFO] [stdout] 149 | pub fn flock(file: &dyn AsRawFd, op: FlockOperation, nonblocking: bool) -> Result<()> {
[INFO] [stdout]     |                     +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stdout]    --> src/lib.rs:178:12
[INFO] [stdout]     |
[INFO] [stdout] 178 |     file: &AsRawFd,
[INFO] [stdout]     |            ^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = warning: this is accepted in the current edition (Rust 2015) but is a hard error in Rust 2021!
[INFO] [stdout]     = note: for more information, see <https://doc.rust-lang.org/edition-guide/rust-2021/warnings-promoted-to-error.html>
[INFO] [stdout] help: if this is a dyn-compatible trait, use `dyn`
[INFO] [stdout]     |
[INFO] [stdout] 178 |     file: &dyn AsRawFd,
[INFO] [stdout]     |            +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stdout]   --> src/file_flags.rs:19:29
[INFO] [stdout]    |
[INFO] [stdout] 19 |     pub fn from_file(file: &AsRawFd) -> Result<FileFlags> {
[INFO] [stdout]    |                             ^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = warning: this is accepted in the current edition (Rust 2015) but is a hard error in Rust 2021!
[INFO] [stdout]    = note: for more information, see <https://doc.rust-lang.org/edition-guide/rust-2021/warnings-promoted-to-error.html>
[INFO] [stdout] help: if this is a dyn-compatible trait, use `dyn`
[INFO] [stdout]    |
[INFO] [stdout] 19 |     pub fn from_file(file: &dyn AsRawFd) -> Result<FileFlags> {
[INFO] [stdout]    |                             +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stdout]   --> src/mmap.rs:93:25
[INFO] [stdout]    |
[INFO] [stdout] 93 |     pub fn from_fd(fd: &AsRawFd, size: usize) -> Result<MemoryMapping> {
[INFO] [stdout]    |                         ^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = warning: this is accepted in the current edition (Rust 2015) but is a hard error in Rust 2021!
[INFO] [stdout]    = note: for more information, see <https://doc.rust-lang.org/edition-guide/rust-2021/warnings-promoted-to-error.html>
[INFO] [stdout] help: if this is a dyn-compatible trait, use `dyn`
[INFO] [stdout]    |
[INFO] [stdout] 93 |     pub fn from_fd(fd: &dyn AsRawFd, size: usize) -> Result<MemoryMapping> {
[INFO] [stdout]    |                         +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stdout]    --> src/mmap.rs:103:32
[INFO] [stdout]     |
[INFO] [stdout] 103 |     pub fn from_fd_offset(fd: &AsRawFd, size: usize, offset: usize) -> Result<MemoryMapping> {
[INFO] [stdout]     |                                ^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = warning: this is accepted in the current edition (Rust 2015) but is a hard error in Rust 2021!
[INFO] [stdout]     = note: for more information, see <https://doc.rust-lang.org/edition-guide/rust-2021/warnings-promoted-to-error.html>
[INFO] [stdout] help: if this is a dyn-compatible trait, use `dyn`
[INFO] [stdout]     |
[INFO] [stdout] 103 |     pub fn from_fd_offset(fd: &dyn AsRawFd, size: usize, offset: usize) -> Result<MemoryMapping> {
[INFO] [stdout]     |                                +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]    --> src/guest_memory.rs:250:32
[INFO] [stdout]     |
[INFO] [stdout] 250 |     pub fn read_at_addr(&self, mut buf: &mut [u8], guest_addr: GuestAddress) -> Result<usize> {
[INFO] [stdout]     |                                ----^^^
[INFO] [stdout]     |                                |
[INFO] [stdout]     |                                help: remove this `mut`
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(unused_mut)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stdout]    --> src/guest_memory.rs:467:18
[INFO] [stdout]     |
[INFO] [stdout] 467 |     fn get_slice(&self, offset: u64, count: u64) -> VolatileMemoryResult<VolatileSlice> {
[INFO] [stdout]     |                  ^^^^^ the lifetime is elided here                       ^^^^^^^^^^^^^ the same lifetime is hidden here
[INFO] [stdout]     |
[INFO] [stdout]     = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stdout]     = note: `#[warn(mismatched_lifetime_syntaxes)]` on by default
[INFO] [stdout] help: use `'_` for type paths
[INFO] [stdout]     |
[INFO] [stdout] 467 |     fn get_slice(&self, offset: u64, count: u64) -> VolatileMemoryResult<VolatileSlice<'_>> {
[INFO] [stdout]     |                                                                                       ++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stdout]    --> src/mmap.rs:377:18
[INFO] [stdout]     |
[INFO] [stdout] 377 |     fn get_slice(&self, offset: u64, count: u64) -> VolatileMemoryResult<VolatileSlice> {
[INFO] [stdout]     |                  ^^^^^ the lifetime is elided here                       ^^^^^^^^^^^^^ the same lifetime is hidden here
[INFO] [stdout]     |
[INFO] [stdout]     = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stdout] help: use `'_` for type paths
[INFO] [stdout]     |
[INFO] [stdout] 377 |     fn get_slice(&self, offset: u64, count: u64) -> VolatileMemoryResult<VolatileSlice<'_>> {
[INFO] [stdout]     |                                                                                       ++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the type `sockaddr_un` does not permit being left uninitialized
[INFO] [stdout]   --> src/net.rs:16:39
[INFO] [stdout]    |
[INFO] [stdout] 16 |         let addr: libc::sockaddr_un = mem::uninitialized();
[INFO] [stdout]    |                                       ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]    |                                       |
[INFO] [stdout]    |                                       this code causes undefined behavior when executed
[INFO] [stdout]    |                                       help: use `MaybeUninit<T>` instead, and only call `assume_init` after initialization is done
[INFO] [stdout]    |
[INFO] [stdout]    = note: integers must be initialized
[INFO] [stdout]    = note: `#[warn(invalid_value)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stdout]    --> src/poll.rs:181:17
[INFO] [stdout]     |
[INFO] [stdout] 181 |     pub fn iter(&self) -> PollEventIter<slice::Iter<epoll_event>, T> {
[INFO] [stdout]     |                 ^^^^^     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |                 |         |             |
[INFO] [stdout]     |                 |         |             the same lifetime is hidden here
[INFO] [stdout]     |                 |         the same lifetime is hidden here
[INFO] [stdout]     |                 the lifetime is elided here
[INFO] [stdout]     |
[INFO] [stdout]     = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stdout] help: use `'_` for type paths
[INFO] [stdout]     |
[INFO] [stdout] 181 |     pub fn iter(&self) -> PollEventIter<'_, slice::Iter<'_, epoll_event>, T> {
[INFO] [stdout]     |                                         +++             +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stdout]    --> src/poll.rs:190:26
[INFO] [stdout]     |
[INFO] [stdout] 190 |     pub fn iter_readable(&self) -> PollEventIter<slice::Iter<epoll_event>, T> {
[INFO] [stdout]     |                          ^^^^^     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |                          |         |             |
[INFO] [stdout]     |                          |         |             the same lifetime is hidden here
[INFO] [stdout]     |                          |         the same lifetime is hidden here
[INFO] [stdout]     |                          the lifetime is elided here
[INFO] [stdout]     |
[INFO] [stdout]     = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stdout] help: use `'_` for type paths
[INFO] [stdout]     |
[INFO] [stdout] 190 |     pub fn iter_readable(&self) -> PollEventIter<'_, slice::Iter<'_, epoll_event>, T> {
[INFO] [stdout]     |                                                  +++             +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stdout]    --> src/poll.rs:199:24
[INFO] [stdout]     |
[INFO] [stdout] 199 |     pub fn iter_hungup(&self) -> PollEventIter<slice::Iter<epoll_event>, T> {
[INFO] [stdout]     |                        ^^^^^     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |                        |         |             |
[INFO] [stdout]     |                        |         |             the same lifetime is hidden here
[INFO] [stdout]     |                        |         the same lifetime is hidden here
[INFO] [stdout]     |                        the lifetime is elided here
[INFO] [stdout]     |
[INFO] [stdout]     = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stdout] help: use `'_` for type paths
[INFO] [stdout]     |
[INFO] [stdout] 199 |     pub fn iter_hungup(&self) -> PollEventIter<'_, slice::Iter<'_, epoll_event>, T> {
[INFO] [stdout]     |                                                +++             +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stdout]    --> src/poll.rs:217:19
[INFO] [stdout]     |
[INFO] [stdout] 217 |     pub fn as_ref(&self) -> PollEvents<T> {
[INFO] [stdout]     |                   ^^^^^     ^^^^^^^^^^^^^ the same lifetime is hidden here
[INFO] [stdout]     |                   |
[INFO] [stdout]     |                   the lifetime is elided here
[INFO] [stdout]     |
[INFO] [stdout]     = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stdout] help: use `'_` for type paths
[INFO] [stdout]     |
[INFO] [stdout] 217 |     pub fn as_ref(&self) -> PollEvents<'_, T> {
[INFO] [stdout]     |                                        +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stdout]    --> src/poll.rs:579:17
[INFO] [stdout]     |
[INFO] [stdout] 579 |     pub fn wait(&self) -> Result<PollEvents<T>> {
[INFO] [stdout]     |                 ^^^^^            ^^^^^^^^^^^^^ the same lifetime is hidden here
[INFO] [stdout]     |                 |
[INFO] [stdout]     |                 the lifetime is elided here
[INFO] [stdout]     |
[INFO] [stdout]     = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stdout] help: use `'_` for type paths
[INFO] [stdout]     |
[INFO] [stdout] 579 |     pub fn wait(&self) -> Result<PollEvents<'_, T>> {
[INFO] [stdout]     |                                             +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stdout]    --> src/poll.rs:587:25
[INFO] [stdout]     |
[INFO] [stdout] 587 |     pub fn wait_timeout(&self, timeout: Duration) -> Result<PollEvents<T>> {
[INFO] [stdout]     |                         ^^^^^ the lifetime is elided here   ^^^^^^^^^^^^^ the same lifetime is hidden here
[INFO] [stdout]     |
[INFO] [stdout]     = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stdout] help: use `'_` for type paths
[INFO] [stdout]     |
[INFO] [stdout] 587 |     pub fn wait_timeout(&self, timeout: Duration) -> Result<PollEvents<'_, T>> {
[INFO] [stdout]     |                                                                        +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stderr]     Finished `dev` profile [unoptimized + debuginfo] target(s) in 4.22s
[INFO] [stderr] warning: the following packages contain code that will be rejected by a future version of Rust: sys_util v0.1.0 (/opt/rustwide/workdir)
[INFO] [stderr] note: to see what the problems were, use the option `--future-incompat-report`, or run `cargo report future-incompatibilities --id 1`
[INFO] running `Command { std: "docker" "inspect" "b263bdce31cd631d1c327069ad3e7f1c23c80ba29419a3b02ae15808389d2379", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "b263bdce31cd631d1c327069ad3e7f1c23c80ba29419a3b02ae15808389d2379", kill_on_drop: false }`
[INFO] [stdout] b263bdce31cd631d1c327069ad3e7f1c23c80ba29419a3b02ae15808389d2379
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-3-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-3-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=warn" "-e" "RUSTDOCFLAGS=--cap-lints=warn" "-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:d429b63d4308055ea97f60fb1d3dfca48854a00942f1bd2ad806beaf015945ec" "/opt/rustwide/cargo-home/bin/cargo" "+1.95.0" "test" "--frozen" "--no-run" "--message-format=json", kill_on_drop: false }`
[INFO] [stdout] 2b7c7a35ec2ab59bc1e3488add81c35daffdd42d03e502cadbe3ad76314e2ef7
[INFO] running `Command { std: "docker" "start" "-a" "2b7c7a35ec2ab59bc1e3488add81c35daffdd42d03e502cadbe3ad76314e2ef7", kill_on_drop: false }`
[INFO] [stderr] warning: the cargo feature `rename-dependency` has been stabilized in the 1.31 release and is no longer necessary to be listed in the manifest
[INFO] [stderr]   See https://doc.rust-lang.org/cargo/reference/specifying-dependencies.html#renaming-dependencies-in-cargotoml for more information about using this feature.
[INFO] [stderr] warning: no edition set: defaulting to the 2015 edition while the latest is 2024
[INFO] [stdout] warning: unexpected `cfg` condition value: `cargo-clippy`
[INFO] [stdout]   --> src/sock_ctrl_msg.rs:55:12
[INFO] [stdout]    |
[INFO] [stdout] 55 | #[cfg_attr(feature = "cargo-clippy", allow(cast_ptr_alignment))]
[INFO] [stdout]    |            ^^^^^^^^^^^^^^^^^^^^^^^^ help: remove the condition
[INFO] [stdout]    |
[INFO] [stdout]    = note: no expected values for `feature`
[INFO] [stdout]    = help: consider adding `cargo-clippy` as a feature in `Cargo.toml`
[INFO] [stdout]    = note: see <https://doc.rust-lang.org/nightly/rustc/check-cfg/cargo-specifics.html> for more information about checking conditional configuration
[INFO] [stdout]    = note: `#[warn(unexpected_cfgs)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unexpected `cfg` condition value: `cargo-clippy`
[INFO] [stdout]    --> src/sock_ctrl_msg.rs:315:16
[INFO] [stdout]     |
[INFO] [stdout] 315 |     #[cfg_attr(feature = "cargo-clippy", allow(useless_asref))]
[INFO] [stdout]     |                ^^^^^^^^^^^^^^^^^^^^^^^^ help: remove the condition
[INFO] [stdout]     |
[INFO] [stdout]     = note: no expected values for `feature`
[INFO] [stdout]     = help: consider adding `cargo-clippy` as a feature in `Cargo.toml`
[INFO] [stdout]     = note: see <https://doc.rust-lang.org/nightly/rustc/check-cfg/cargo-specifics.html> for more information about checking conditional configuration
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: trailing semicolon in macro used in expression position
[INFO] [stdout]    --> src/syslog.rs:252:10
[INFO] [stdout]     |
[INFO] [stdout] 252 |         };
[INFO] [stdout]     |          ^
[INFO] [stdout] ...
[INFO] [stdout] 263 |     let mut state = lock!();
[INFO] [stdout]     |                     ------- in this macro invocation
[INFO] [stdout]     |
[INFO] [stdout]     = warning: this was previously accepted by the compiler but is being phased out; it will become a hard error in a future release!
[INFO] [stdout]     = note: for more information, see issue #79813 <https://github.com/rust-lang/rust/issues/79813>
[INFO] [stdout]     = note: `#[warn(semicolon_in_expressions_from_macros)]` (part of `#[warn(future_incompatible)]`) on by default
[INFO] [stdout]     = note: this warning originates in the macro `lock` (in Nightly builds, run with -Z macro-backtrace for more info)
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: trailing semicolon in macro used in expression position
[INFO] [stdout]    --> src/syslog.rs:252:10
[INFO] [stdout]     |
[INFO] [stdout] 252 |         };
[INFO] [stdout]     |          ^
[INFO] [stdout] ...
[INFO] [stdout] 280 |     let mut state = lock!();
[INFO] [stdout]     |                     ------- in this macro invocation
[INFO] [stdout]     |
[INFO] [stdout]     = warning: this was previously accepted by the compiler but is being phased out; it will become a hard error in a future release!
[INFO] [stdout]     = note: for more information, see issue #79813 <https://github.com/rust-lang/rust/issues/79813>
[INFO] [stdout]     = note: this warning originates in the macro `lock` (in Nightly builds, run with -Z macro-backtrace for more info)
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: trailing semicolon in macro used in expression position
[INFO] [stdout]    --> src/syslog.rs:252:10
[INFO] [stdout]     |
[INFO] [stdout] 252 |         };
[INFO] [stdout]     |          ^
[INFO] [stdout] ...
[INFO] [stdout] 329 |     let mut state = lock!();
[INFO] [stdout]     |                     ------- in this macro invocation
[INFO] [stdout]     |
[INFO] [stdout]     = warning: this was previously accepted by the compiler but is being phased out; it will become a hard error in a future release!
[INFO] [stdout]     = note: for more information, see issue #79813 <https://github.com/rust-lang/rust/issues/79813>
[INFO] [stdout]     = note: this warning originates in the macro `lock` (in Nightly builds, run with -Z macro-backtrace for more info)
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: trailing semicolon in macro used in expression position
[INFO] [stdout]    --> src/syslog.rs:252:10
[INFO] [stdout]     |
[INFO] [stdout] 252 |         };
[INFO] [stdout]     |          ^
[INFO] [stdout] ...
[INFO] [stdout] 342 |     let mut state = lock!();
[INFO] [stdout]     |                     ------- in this macro invocation
[INFO] [stdout]     |
[INFO] [stdout]     = warning: this was previously accepted by the compiler but is being phased out; it will become a hard error in a future release!
[INFO] [stdout]     = note: for more information, see issue #79813 <https://github.com/rust-lang/rust/issues/79813>
[INFO] [stdout]     = note: this warning originates in the macro `lock` (in Nightly builds, run with -Z macro-backtrace for more info)
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: trailing semicolon in macro used in expression position
[INFO] [stdout]    --> src/syslog.rs:252:10
[INFO] [stdout]     |
[INFO] [stdout] 252 |         };
[INFO] [stdout]     |          ^
[INFO] [stdout] ...
[INFO] [stdout] 353 |     let state = lock!();
[INFO] [stdout]     |                 ------- in this macro invocation
[INFO] [stdout]     |
[INFO] [stdout]     = warning: this was previously accepted by the compiler but is being phased out; it will become a hard error in a future release!
[INFO] [stdout]     = note: for more information, see issue #79813 <https://github.com/rust-lang/rust/issues/79813>
[INFO] [stdout]     = note: this warning originates in the macro `lock` (in Nightly builds, run with -Z macro-backtrace for more info)
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: trailing semicolon in macro used in expression position
[INFO] [stdout]    --> src/syslog.rs:252:10
[INFO] [stdout]     |
[INFO] [stdout] 252 |         };
[INFO] [stdout]     |          ^
[INFO] [stdout] ...
[INFO] [stdout] 427 |     let mut state = lock!();
[INFO] [stdout]     |                     ------- in this macro invocation
[INFO] [stdout]     |
[INFO] [stdout]     = warning: this was previously accepted by the compiler but is being phased out; it will become a hard error in a future release!
[INFO] [stdout]     = note: for more information, see issue #79813 <https://github.com/rust-lang/rust/issues/79813>
[INFO] [stdout]     = note: this warning originates in the macro `lock` (in Nightly builds, run with -Z macro-backtrace for more info)
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated constant `std::sync::ONCE_INIT`: the `Once::new()` function is now preferred
[INFO] [stdout]   --> src/syslog.rs:39:35
[INFO] [stdout]    |
[INFO] [stdout] 39 | use std::sync::{MutexGuard, Once, ONCE_INIT};
[INFO] [stdout]    |                                   ^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(deprecated)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated constant `std::sync::ONCE_INIT`: the `Once::new()` function is now preferred
[INFO] [stdout]    --> src/syslog.rs:207:27
[INFO] [stdout]     |
[INFO] [stdout] 207 | static STATE_ONCE: Once = ONCE_INIT;
[INFO] [stdout]     |                           ^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout] help: replace the use of the deprecated constant
[INFO] [stdout]     |
[INFO] [stdout] 207 - static STATE_ONCE: Once = ONCE_INIT;
[INFO] [stdout] 207 + static STATE_ONCE: Once = Once::new();
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated function `std::mem::uninitialized`: use `mem::MaybeUninit` instead
[INFO] [stdout]   --> src/net.rs:16:44
[INFO] [stdout]    |
[INFO] [stdout] 16 |         let addr: libc::sockaddr_un = mem::uninitialized();
[INFO] [stdout]    |                                            ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stdout]    --> src/poll.rs:290:28
[INFO] [stdout]     |
[INFO] [stdout] 290 |     pub fn add(&self, fd: &AsRawFd, token: T) -> Result<()> {
[INFO] [stdout]     |                            ^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = warning: this is accepted in the current edition (Rust 2015) but is a hard error in Rust 2021!
[INFO] [stdout]     = note: for more information, see <https://doc.rust-lang.org/edition-guide/rust-2021/warnings-promoted-to-error.html>
[INFO] [stdout]     = note: `#[warn(bare_trait_objects)]` (part of `#[warn(rust_2021_compatibility)]`) on by default
[INFO] [stdout] help: if this is a dyn-compatible trait, use `dyn`
[INFO] [stdout]     |
[INFO] [stdout] 290 |     pub fn add(&self, fd: &dyn AsRawFd, token: T) -> Result<()> {
[INFO] [stdout]     |                            +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stdout]    --> src/poll.rs:300:43
[INFO] [stdout]     |
[INFO] [stdout] 300 |     pub fn add_fd_with_events(&self, fd: &AsRawFd, events: WatchingEvents, token: T) -> Result<()> {
[INFO] [stdout]     |                                           ^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = warning: this is accepted in the current edition (Rust 2015) but is a hard error in Rust 2021!
[INFO] [stdout]     = note: for more information, see <https://doc.rust-lang.org/edition-guide/rust-2021/warnings-promoted-to-error.html>
[INFO] [stdout] help: if this is a dyn-compatible trait, use `dyn`
[INFO] [stdout]     |
[INFO] [stdout] 300 |     pub fn add_fd_with_events(&self, fd: &dyn AsRawFd, events: WatchingEvents, token: T) -> Result<()> {
[INFO] [stdout]     |                                           +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stdout]    --> src/poll.rs:323:31
[INFO] [stdout]     |
[INFO] [stdout] 323 |     pub fn modify(&self, fd: &AsRawFd, events: WatchingEvents, token: T) -> Result<()> {
[INFO] [stdout]     |                               ^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = warning: this is accepted in the current edition (Rust 2015) but is a hard error in Rust 2021!
[INFO] [stdout]     = note: for more information, see <https://doc.rust-lang.org/edition-guide/rust-2021/warnings-promoted-to-error.html>
[INFO] [stdout] help: if this is a dyn-compatible trait, use `dyn`
[INFO] [stdout]     |
[INFO] [stdout] 323 |     pub fn modify(&self, fd: &dyn AsRawFd, events: WatchingEvents, token: T) -> Result<()> {
[INFO] [stdout]     |                               +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stdout]    --> src/poll.rs:350:31
[INFO] [stdout]     |
[INFO] [stdout] 350 |     pub fn delete(&self, fd: &AsRawFd) -> Result<()> {
[INFO] [stdout]     |                               ^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = warning: this is accepted in the current edition (Rust 2015) but is a hard error in Rust 2021!
[INFO] [stdout]     = note: for more information, see <https://doc.rust-lang.org/edition-guide/rust-2021/warnings-promoted-to-error.html>
[INFO] [stdout] help: if this is a dyn-compatible trait, use `dyn`
[INFO] [stdout]     |
[INFO] [stdout] 350 |     pub fn delete(&self, fd: &dyn AsRawFd) -> Result<()> {
[INFO] [stdout]     |                               +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stdout]    --> src/poll.rs:494:28
[INFO] [stdout]     |
[INFO] [stdout] 494 |     pub fn add(&self, fd: &AsRawFd, token: T) -> Result<()> {
[INFO] [stdout]     |                            ^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = warning: this is accepted in the current edition (Rust 2015) but is a hard error in Rust 2021!
[INFO] [stdout]     = note: for more information, see <https://doc.rust-lang.org/edition-guide/rust-2021/warnings-promoted-to-error.html>
[INFO] [stdout] help: if this is a dyn-compatible trait, use `dyn`
[INFO] [stdout]     |
[INFO] [stdout] 494 |     pub fn add(&self, fd: &dyn AsRawFd, token: T) -> Result<()> {
[INFO] [stdout]     |                            +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stdout]    --> src/poll.rs:504:43
[INFO] [stdout]     |
[INFO] [stdout] 504 |     pub fn add_fd_with_events(&self, fd: &AsRawFd, events: WatchingEvents, token: T) -> Result<()> {
[INFO] [stdout]     |                                           ^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = warning: this is accepted in the current edition (Rust 2015) but is a hard error in Rust 2021!
[INFO] [stdout]     = note: for more information, see <https://doc.rust-lang.org/edition-guide/rust-2021/warnings-promoted-to-error.html>
[INFO] [stdout] help: if this is a dyn-compatible trait, use `dyn`
[INFO] [stdout]     |
[INFO] [stdout] 504 |     pub fn add_fd_with_events(&self, fd: &dyn AsRawFd, events: WatchingEvents, token: T) -> Result<()> {
[INFO] [stdout]     |                                           +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stdout]    --> src/poll.rs:513:31
[INFO] [stdout]     |
[INFO] [stdout] 513 |     pub fn modify(&self, fd: &AsRawFd, events: WatchingEvents, token: T) -> Result<()> {
[INFO] [stdout]     |                               ^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = warning: this is accepted in the current edition (Rust 2015) but is a hard error in Rust 2021!
[INFO] [stdout]     = note: for more information, see <https://doc.rust-lang.org/edition-guide/rust-2021/warnings-promoted-to-error.html>
[INFO] [stdout] help: if this is a dyn-compatible trait, use `dyn`
[INFO] [stdout]     |
[INFO] [stdout] 513 |     pub fn modify(&self, fd: &dyn AsRawFd, events: WatchingEvents, token: T) -> Result<()> {
[INFO] [stdout]     |                               +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stdout]    --> src/poll.rs:523:31
[INFO] [stdout]     |
[INFO] [stdout] 523 |     pub fn delete(&self, fd: &AsRawFd) -> Result<()> {
[INFO] [stdout]     |                               ^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = warning: this is accepted in the current edition (Rust 2015) but is a hard error in Rust 2021!
[INFO] [stdout]     = note: for more information, see <https://doc.rust-lang.org/edition-guide/rust-2021/warnings-promoted-to-error.html>
[INFO] [stdout] help: if this is a dyn-compatible trait, use `dyn`
[INFO] [stdout]     |
[INFO] [stdout] 523 |     pub fn delete(&self, fd: &dyn AsRawFd) -> Result<()> {
[INFO] [stdout]     |                               +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stdout]    --> src/lib.rs:149:21
[INFO] [stdout]     |
[INFO] [stdout] 149 | pub fn flock(file: &AsRawFd, op: FlockOperation, nonblocking: bool) -> Result<()> {
[INFO] [stdout]     |                     ^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = warning: this is accepted in the current edition (Rust 2015) but is a hard error in Rust 2021!
[INFO] [stdout]     = note: for more information, see <https://doc.rust-lang.org/edition-guide/rust-2021/warnings-promoted-to-error.html>
[INFO] [stdout] help: if this is a dyn-compatible trait, use `dyn`
[INFO] [stdout]     |
[INFO] [stdout] 149 | pub fn flock(file: &dyn AsRawFd, op: FlockOperation, nonblocking: bool) -> Result<()> {
[INFO] [stdout]     |                     +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stdout]    --> src/lib.rs:178:12
[INFO] [stdout]     |
[INFO] [stdout] 178 |     file: &AsRawFd,
[INFO] [stdout]     |            ^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = warning: this is accepted in the current edition (Rust 2015) but is a hard error in Rust 2021!
[INFO] [stdout]     = note: for more information, see <https://doc.rust-lang.org/edition-guide/rust-2021/warnings-promoted-to-error.html>
[INFO] [stdout] help: if this is a dyn-compatible trait, use `dyn`
[INFO] [stdout]     |
[INFO] [stdout] 178 |     file: &dyn AsRawFd,
[INFO] [stdout]     |            +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stdout]   --> src/file_flags.rs:19:29
[INFO] [stdout]    |
[INFO] [stdout] 19 |     pub fn from_file(file: &AsRawFd) -> Result<FileFlags> {
[INFO] [stdout]    |                             ^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = warning: this is accepted in the current edition (Rust 2015) but is a hard error in Rust 2021!
[INFO] [stdout]    = note: for more information, see <https://doc.rust-lang.org/edition-guide/rust-2021/warnings-promoted-to-error.html>
[INFO] [stdout] help: if this is a dyn-compatible trait, use `dyn`
[INFO] [stdout]    |
[INFO] [stdout] 19 |     pub fn from_file(file: &dyn AsRawFd) -> Result<FileFlags> {
[INFO] [stdout]    |                             +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stdout]   --> src/mmap.rs:93:25
[INFO] [stdout]    |
[INFO] [stdout] 93 |     pub fn from_fd(fd: &AsRawFd, size: usize) -> Result<MemoryMapping> {
[INFO] [stdout]    |                         ^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = warning: this is accepted in the current edition (Rust 2015) but is a hard error in Rust 2021!
[INFO] [stdout]    = note: for more information, see <https://doc.rust-lang.org/edition-guide/rust-2021/warnings-promoted-to-error.html>
[INFO] [stdout] help: if this is a dyn-compatible trait, use `dyn`
[INFO] [stdout]    |
[INFO] [stdout] 93 |     pub fn from_fd(fd: &dyn AsRawFd, size: usize) -> Result<MemoryMapping> {
[INFO] [stdout]    |                         +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stdout]    --> src/mmap.rs:103:32
[INFO] [stdout]     |
[INFO] [stdout] 103 |     pub fn from_fd_offset(fd: &AsRawFd, size: usize, offset: usize) -> Result<MemoryMapping> {
[INFO] [stdout]     |                                ^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = warning: this is accepted in the current edition (Rust 2015) but is a hard error in Rust 2021!
[INFO] [stdout]     = note: for more information, see <https://doc.rust-lang.org/edition-guide/rust-2021/warnings-promoted-to-error.html>
[INFO] [stdout] help: if this is a dyn-compatible trait, use `dyn`
[INFO] [stdout]     |
[INFO] [stdout] 103 |     pub fn from_fd_offset(fd: &dyn AsRawFd, size: usize, offset: usize) -> Result<MemoryMapping> {
[INFO] [stdout]     |                                +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]    --> src/guest_memory.rs:250:32
[INFO] [stdout]     |
[INFO] [stdout] 250 |     pub fn read_at_addr(&self, mut buf: &mut [u8], guest_addr: GuestAddress) -> Result<usize> {
[INFO] [stdout]     |                                ----^^^
[INFO] [stdout]     |                                |
[INFO] [stdout]     |                                help: remove this `mut`
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(unused_mut)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stdout]    --> src/guest_memory.rs:467:18
[INFO] [stdout]     |
[INFO] [stdout] 467 |     fn get_slice(&self, offset: u64, count: u64) -> VolatileMemoryResult<VolatileSlice> {
[INFO] [stdout]     |                  ^^^^^ the lifetime is elided here                       ^^^^^^^^^^^^^ the same lifetime is hidden here
[INFO] [stdout]     |
[INFO] [stdout]     = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stdout]     = note: `#[warn(mismatched_lifetime_syntaxes)]` on by default
[INFO] [stdout] help: use `'_` for type paths
[INFO] [stdout]     |
[INFO] [stdout] 467 |     fn get_slice(&self, offset: u64, count: u64) -> VolatileMemoryResult<VolatileSlice<'_>> {
[INFO] [stdout]     |                                                                                       ++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stdout]    --> src/mmap.rs:377:18
[INFO] [stdout]     |
[INFO] [stdout] 377 |     fn get_slice(&self, offset: u64, count: u64) -> VolatileMemoryResult<VolatileSlice> {
[INFO] [stdout]     |                  ^^^^^ the lifetime is elided here                       ^^^^^^^^^^^^^ the same lifetime is hidden here
[INFO] [stdout]     |
[INFO] [stdout]     = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stdout] help: use `'_` for type paths
[INFO] [stdout]     |
[INFO] [stdout] 377 |     fn get_slice(&self, offset: u64, count: u64) -> VolatileMemoryResult<VolatileSlice<'_>> {
[INFO] [stdout]     |                                                                                       ++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the type `sockaddr_un` does not permit being left uninitialized
[INFO] [stdout]   --> src/net.rs:16:39
[INFO] [stdout]    |
[INFO] [stdout] 16 |         let addr: libc::sockaddr_un = mem::uninitialized();
[INFO] [stdout]    |                                       ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]    |                                       |
[INFO] [stdout]    |                                       this code causes undefined behavior when executed
[INFO] [stdout]    |                                       help: use `MaybeUninit<T>` instead, and only call `assume_init` after initialization is done
[INFO] [stdout]    |
[INFO] [stdout]    = note: integers must be initialized
[INFO] [stdout]    = note: `#[warn(invalid_value)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stdout]    --> src/poll.rs:181:17
[INFO] [stdout]     |
[INFO] [stdout] 181 |     pub fn iter(&self) -> PollEventIter<slice::Iter<epoll_event>, T> {
[INFO] [stdout]     |                 ^^^^^     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |                 |         |             |
[INFO] [stdout]     |                 |         |             the same lifetime is hidden here
[INFO] [stdout]     |                 |         the same lifetime is hidden here
[INFO] [stdout]     |                 the lifetime is elided here
[INFO] [stdout]     |
[INFO] [stdout]     = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stdout] help: use `'_` for type paths
[INFO] [stdout]     |
[INFO] [stdout] 181 |     pub fn iter(&self) -> PollEventIter<'_, slice::Iter<'_, epoll_event>, T> {
[INFO] [stdout]     |                                         +++             +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stdout]    --> src/poll.rs:190:26
[INFO] [stdout]     |
[INFO] [stdout] 190 |     pub fn iter_readable(&self) -> PollEventIter<slice::Iter<epoll_event>, T> {
[INFO] [stdout]     |                          ^^^^^     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |                          |         |             |
[INFO] [stdout]     |                          |         |             the same lifetime is hidden here
[INFO] [stdout]     |                          |         the same lifetime is hidden here
[INFO] [stdout]     |                          the lifetime is elided here
[INFO] [stdout]     |
[INFO] [stdout]     = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stdout] help: use `'_` for type paths
[INFO] [stdout]     |
[INFO] [stdout] 190 |     pub fn iter_readable(&self) -> PollEventIter<'_, slice::Iter<'_, epoll_event>, T> {
[INFO] [stdout]     |                                                  +++             +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stderr]    Compiling sys_util v0.1.0 (/opt/rustwide/workdir)
[INFO] [stdout] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stdout]    --> src/poll.rs:199:24
[INFO] [stdout]     |
[INFO] [stdout] 199 |     pub fn iter_hungup(&self) -> PollEventIter<slice::Iter<epoll_event>, T> {
[INFO] [stdout]     |                        ^^^^^     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |                        |         |             |
[INFO] [stdout]     |                        |         |             the same lifetime is hidden here
[INFO] [stdout]     |                        |         the same lifetime is hidden here
[INFO] [stdout]     |                        the lifetime is elided here
[INFO] [stdout]     |
[INFO] [stdout]     = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stdout] help: use `'_` for type paths
[INFO] [stdout]     |
[INFO] [stdout] 199 |     pub fn iter_hungup(&self) -> PollEventIter<'_, slice::Iter<'_, epoll_event>, T> {
[INFO] [stdout]     |                                                +++             +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stdout]    --> src/poll.rs:217:19
[INFO] [stdout]     |
[INFO] [stdout] 217 |     pub fn as_ref(&self) -> PollEvents<T> {
[INFO] [stdout]     |                   ^^^^^     ^^^^^^^^^^^^^ the same lifetime is hidden here
[INFO] [stdout]     |                   |
[INFO] [stdout]     |                   the lifetime is elided here
[INFO] [stdout]     |
[INFO] [stdout]     = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stdout] help: use `'_` for type paths
[INFO] [stdout]     |
[INFO] [stdout] 217 |     pub fn as_ref(&self) -> PollEvents<'_, T> {
[INFO] [stdout]     |                                        +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stdout]    --> src/poll.rs:579:17
[INFO] [stdout]     |
[INFO] [stdout] 579 |     pub fn wait(&self) -> Result<PollEvents<T>> {
[INFO] [stdout]     |                 ^^^^^            ^^^^^^^^^^^^^ the same lifetime is hidden here
[INFO] [stdout]     |                 |
[INFO] [stdout]     |                 the lifetime is elided here
[INFO] [stdout]     |
[INFO] [stdout]     = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stdout] help: use `'_` for type paths
[INFO] [stdout]     |
[INFO] [stdout] 579 |     pub fn wait(&self) -> Result<PollEvents<'_, T>> {
[INFO] [stdout]     |                                             +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stdout]    --> src/poll.rs:587:25
[INFO] [stdout]     |
[INFO] [stdout] 587 |     pub fn wait_timeout(&self, timeout: Duration) -> Result<PollEvents<T>> {
[INFO] [stdout]     |                         ^^^^^ the lifetime is elided here   ^^^^^^^^^^^^^ the same lifetime is hidden here
[INFO] [stdout]     |
[INFO] [stdout]     = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stdout] help: use `'_` for type paths
[INFO] [stdout]     |
[INFO] [stdout] 587 |     pub fn wait_timeout(&self, timeout: Duration) -> Result<PollEvents<'_, T>> {
[INFO] [stdout]     |                                                                        +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unexpected `cfg` condition value: `cargo-clippy`
[INFO] [stdout]   --> src/sock_ctrl_msg.rs:55:12
[INFO] [stdout]    |
[INFO] [stdout] 55 | #[cfg_attr(feature = "cargo-clippy", allow(cast_ptr_alignment))]
[INFO] [stdout]    |            ^^^^^^^^^^^^^^^^^^^^^^^^ help: remove the condition
[INFO] [stdout]    |
[INFO] [stdout]    = note: no expected values for `feature`
[INFO] [stdout]    = help: consider adding `cargo-clippy` as a feature in `Cargo.toml`
[INFO] [stdout]    = note: see <https://doc.rust-lang.org/nightly/rustc/check-cfg/cargo-specifics.html> for more information about checking conditional configuration
[INFO] [stdout]    = note: `#[warn(unexpected_cfgs)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unexpected `cfg` condition value: `cargo-clippy`
[INFO] [stdout]    --> src/sock_ctrl_msg.rs:315:16
[INFO] [stdout]     |
[INFO] [stdout] 315 |     #[cfg_attr(feature = "cargo-clippy", allow(useless_asref))]
[INFO] [stdout]     |                ^^^^^^^^^^^^^^^^^^^^^^^^ help: remove the condition
[INFO] [stdout]     |
[INFO] [stdout]     = note: no expected values for `feature`
[INFO] [stdout]     = help: consider adding `cargo-clippy` as a feature in `Cargo.toml`
[INFO] [stdout]     = note: see <https://doc.rust-lang.org/nightly/rustc/check-cfg/cargo-specifics.html> for more information about checking conditional configuration
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: trailing semicolon in macro used in expression position
[INFO] [stdout]    --> src/syslog.rs:252:10
[INFO] [stdout]     |
[INFO] [stdout] 252 |         };
[INFO] [stdout]     |          ^
[INFO] [stdout] ...
[INFO] [stdout] 263 |     let mut state = lock!();
[INFO] [stdout]     |                     ------- in this macro invocation
[INFO] [stdout]     |
[INFO] [stdout]     = warning: this was previously accepted by the compiler but is being phased out; it will become a hard error in a future release!
[INFO] [stdout]     = note: for more information, see issue #79813 <https://github.com/rust-lang/rust/issues/79813>
[INFO] [stdout]     = note: `#[warn(semicolon_in_expressions_from_macros)]` (part of `#[warn(future_incompatible)]`) on by default
[INFO] [stdout]     = note: this warning originates in the macro `lock` (in Nightly builds, run with -Z macro-backtrace for more info)
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: trailing semicolon in macro used in expression position
[INFO] [stdout]    --> src/syslog.rs:252:10
[INFO] [stdout]     |
[INFO] [stdout] 252 |         };
[INFO] [stdout]     |          ^
[INFO] [stdout] ...
[INFO] [stdout] 280 |     let mut state = lock!();
[INFO] [stdout]     |                     ------- in this macro invocation
[INFO] [stdout]     |
[INFO] [stdout]     = warning: this was previously accepted by the compiler but is being phased out; it will become a hard error in a future release!
[INFO] [stdout]     = note: for more information, see issue #79813 <https://github.com/rust-lang/rust/issues/79813>
[INFO] [stdout]     = note: this warning originates in the macro `lock` (in Nightly builds, run with -Z macro-backtrace for more info)
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: trailing semicolon in macro used in expression position
[INFO] [stdout]    --> src/syslog.rs:252:10
[INFO] [stdout]     |
[INFO] [stdout] 252 |         };
[INFO] [stdout]     |          ^
[INFO] [stdout] ...
[INFO] [stdout] 329 |     let mut state = lock!();
[INFO] [stdout]     |                     ------- in this macro invocation
[INFO] [stdout]     |
[INFO] [stdout]     = warning: this was previously accepted by the compiler but is being phased out; it will become a hard error in a future release!
[INFO] [stdout]     = note: for more information, see issue #79813 <https://github.com/rust-lang/rust/issues/79813>
[INFO] [stdout]     = note: this warning originates in the macro `lock` (in Nightly builds, run with -Z macro-backtrace for more info)
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: trailing semicolon in macro used in expression position
[INFO] [stdout]    --> src/syslog.rs:252:10
[INFO] [stdout]     |
[INFO] [stdout] 252 |         };
[INFO] [stdout]     |          ^
[INFO] [stdout] ...
[INFO] [stdout] 342 |     let mut state = lock!();
[INFO] [stdout]     |                     ------- in this macro invocation
[INFO] [stdout]     |
[INFO] [stdout]     = warning: this was previously accepted by the compiler but is being phased out; it will become a hard error in a future release!
[INFO] [stdout]     = note: for more information, see issue #79813 <https://github.com/rust-lang/rust/issues/79813>
[INFO] [stdout]     = note: this warning originates in the macro `lock` (in Nightly builds, run with -Z macro-backtrace for more info)
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: trailing semicolon in macro used in expression position
[INFO] [stdout]    --> src/syslog.rs:252:10
[INFO] [stdout]     |
[INFO] [stdout] 252 |         };
[INFO] [stdout]     |          ^
[INFO] [stdout] ...
[INFO] [stdout] 353 |     let state = lock!();
[INFO] [stdout]     |                 ------- in this macro invocation
[INFO] [stdout]     |
[INFO] [stdout]     = warning: this was previously accepted by the compiler but is being phased out; it will become a hard error in a future release!
[INFO] [stdout]     = note: for more information, see issue #79813 <https://github.com/rust-lang/rust/issues/79813>
[INFO] [stdout]     = note: this warning originates in the macro `lock` (in Nightly builds, run with -Z macro-backtrace for more info)
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: trailing semicolon in macro used in expression position
[INFO] [stdout]    --> src/syslog.rs:252:10
[INFO] [stdout]     |
[INFO] [stdout] 252 |         };
[INFO] [stdout]     |          ^
[INFO] [stdout] ...
[INFO] [stdout] 427 |     let mut state = lock!();
[INFO] [stdout]     |                     ------- in this macro invocation
[INFO] [stdout]     |
[INFO] [stdout]     = warning: this was previously accepted by the compiler but is being phased out; it will become a hard error in a future release!
[INFO] [stdout]     = note: for more information, see issue #79813 <https://github.com/rust-lang/rust/issues/79813>
[INFO] [stdout]     = note: this warning originates in the macro `lock` (in Nightly builds, run with -Z macro-backtrace for more info)
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated constant `std::sync::ONCE_INIT`: the `Once::new()` function is now preferred
[INFO] [stdout]   --> src/syslog.rs:39:35
[INFO] [stdout]    |
[INFO] [stdout] 39 | use std::sync::{MutexGuard, Once, ONCE_INIT};
[INFO] [stdout]    |                                   ^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(deprecated)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated constant `std::sync::ONCE_INIT`: the `Once::new()` function is now preferred
[INFO] [stdout]    --> src/syslog.rs:207:27
[INFO] [stdout]     |
[INFO] [stdout] 207 | static STATE_ONCE: Once = ONCE_INIT;
[INFO] [stdout]     |                           ^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout] help: replace the use of the deprecated constant
[INFO] [stdout]     |
[INFO] [stdout] 207 - static STATE_ONCE: Once = ONCE_INIT;
[INFO] [stdout] 207 + static STATE_ONCE: Once = Once::new();
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated function `std::mem::uninitialized`: use `mem::MaybeUninit` instead
[INFO] [stdout]   --> src/net.rs:16:44
[INFO] [stdout]    |
[INFO] [stdout] 16 |         let addr: libc::sockaddr_un = mem::uninitialized();
[INFO] [stdout]    |                                            ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stdout]    --> src/poll.rs:290:28
[INFO] [stdout]     |
[INFO] [stdout] 290 |     pub fn add(&self, fd: &AsRawFd, token: T) -> Result<()> {
[INFO] [stdout]     |                            ^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = warning: this is accepted in the current edition (Rust 2015) but is a hard error in Rust 2021!
[INFO] [stdout]     = note: for more information, see <https://doc.rust-lang.org/edition-guide/rust-2021/warnings-promoted-to-error.html>
[INFO] [stdout]     = note: `#[warn(bare_trait_objects)]` (part of `#[warn(rust_2021_compatibility)]`) on by default
[INFO] [stdout] help: if this is a dyn-compatible trait, use `dyn`
[INFO] [stdout]     |
[INFO] [stdout] 290 |     pub fn add(&self, fd: &dyn AsRawFd, token: T) -> Result<()> {
[INFO] [stdout]     |                            +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stdout]    --> src/poll.rs:300:43
[INFO] [stdout]     |
[INFO] [stdout] 300 |     pub fn add_fd_with_events(&self, fd: &AsRawFd, events: WatchingEvents, token: T) -> Result<()> {
[INFO] [stdout]     |                                           ^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = warning: this is accepted in the current edition (Rust 2015) but is a hard error in Rust 2021!
[INFO] [stdout]     = note: for more information, see <https://doc.rust-lang.org/edition-guide/rust-2021/warnings-promoted-to-error.html>
[INFO] [stdout] help: if this is a dyn-compatible trait, use `dyn`
[INFO] [stdout]     |
[INFO] [stdout] 300 |     pub fn add_fd_with_events(&self, fd: &dyn AsRawFd, events: WatchingEvents, token: T) -> Result<()> {
[INFO] [stdout]     |                                           +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stdout]    --> src/poll.rs:323:31
[INFO] [stdout]     |
[INFO] [stdout] 323 |     pub fn modify(&self, fd: &AsRawFd, events: WatchingEvents, token: T) -> Result<()> {
[INFO] [stdout]     |                               ^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = warning: this is accepted in the current edition (Rust 2015) but is a hard error in Rust 2021!
[INFO] [stdout]     = note: for more information, see <https://doc.rust-lang.org/edition-guide/rust-2021/warnings-promoted-to-error.html>
[INFO] [stdout] help: if this is a dyn-compatible trait, use `dyn`
[INFO] [stdout]     |
[INFO] [stdout] 323 |     pub fn modify(&self, fd: &dyn AsRawFd, events: WatchingEvents, token: T) -> Result<()> {
[INFO] [stdout]     |                               +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stdout]    --> src/poll.rs:350:31
[INFO] [stdout]     |
[INFO] [stdout] 350 |     pub fn delete(&self, fd: &AsRawFd) -> Result<()> {
[INFO] [stdout]     |                               ^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = warning: this is accepted in the current edition (Rust 2015) but is a hard error in Rust 2021!
[INFO] [stdout]     = note: for more information, see <https://doc.rust-lang.org/edition-guide/rust-2021/warnings-promoted-to-error.html>
[INFO] [stdout] help: if this is a dyn-compatible trait, use `dyn`
[INFO] [stdout]     |
[INFO] [stdout] 350 |     pub fn delete(&self, fd: &dyn AsRawFd) -> Result<()> {
[INFO] [stdout]     |                               +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stdout]    --> src/poll.rs:494:28
[INFO] [stdout]     |
[INFO] [stdout] 494 |     pub fn add(&self, fd: &AsRawFd, token: T) -> Result<()> {
[INFO] [stdout]     |                            ^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = warning: this is accepted in the current edition (Rust 2015) but is a hard error in Rust 2021!
[INFO] [stdout]     = note: for more information, see <https://doc.rust-lang.org/edition-guide/rust-2021/warnings-promoted-to-error.html>
[INFO] [stdout] help: if this is a dyn-compatible trait, use `dyn`
[INFO] [stdout]     |
[INFO] [stdout] 494 |     pub fn add(&self, fd: &dyn AsRawFd, token: T) -> Result<()> {
[INFO] [stdout]     |                            +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stdout]    --> src/poll.rs:504:43
[INFO] [stdout]     |
[INFO] [stdout] 504 |     pub fn add_fd_with_events(&self, fd: &AsRawFd, events: WatchingEvents, token: T) -> Result<()> {
[INFO] [stdout]     |                                           ^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = warning: this is accepted in the current edition (Rust 2015) but is a hard error in Rust 2021!
[INFO] [stdout]     = note: for more information, see <https://doc.rust-lang.org/edition-guide/rust-2021/warnings-promoted-to-error.html>
[INFO] [stdout] help: if this is a dyn-compatible trait, use `dyn`
[INFO] [stdout]     |
[INFO] [stdout] 504 |     pub fn add_fd_with_events(&self, fd: &dyn AsRawFd, events: WatchingEvents, token: T) -> Result<()> {
[INFO] [stdout]     |                                           +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stdout]    --> src/poll.rs:513:31
[INFO] [stdout]     |
[INFO] [stdout] 513 |     pub fn modify(&self, fd: &AsRawFd, events: WatchingEvents, token: T) -> Result<()> {
[INFO] [stdout]     |                               ^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = warning: this is accepted in the current edition (Rust 2015) but is a hard error in Rust 2021!
[INFO] [stdout]     = note: for more information, see <https://doc.rust-lang.org/edition-guide/rust-2021/warnings-promoted-to-error.html>
[INFO] [stdout] help: if this is a dyn-compatible trait, use `dyn`
[INFO] [stdout]     |
[INFO] [stdout] 513 |     pub fn modify(&self, fd: &dyn AsRawFd, events: WatchingEvents, token: T) -> Result<()> {
[INFO] [stdout]     |                               +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stdout]    --> src/poll.rs:523:31
[INFO] [stdout]     |
[INFO] [stdout] 523 |     pub fn delete(&self, fd: &AsRawFd) -> Result<()> {
[INFO] [stdout]     |                               ^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = warning: this is accepted in the current edition (Rust 2015) but is a hard error in Rust 2021!
[INFO] [stdout]     = note: for more information, see <https://doc.rust-lang.org/edition-guide/rust-2021/warnings-promoted-to-error.html>
[INFO] [stdout] help: if this is a dyn-compatible trait, use `dyn`
[INFO] [stdout]     |
[INFO] [stdout] 523 |     pub fn delete(&self, fd: &dyn AsRawFd) -> Result<()> {
[INFO] [stdout]     |                               +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stdout]    --> src/lib.rs:149:21
[INFO] [stdout]     |
[INFO] [stdout] 149 | pub fn flock(file: &AsRawFd, op: FlockOperation, nonblocking: bool) -> Result<()> {
[INFO] [stdout]     |                     ^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = warning: this is accepted in the current edition (Rust 2015) but is a hard error in Rust 2021!
[INFO] [stdout]     = note: for more information, see <https://doc.rust-lang.org/edition-guide/rust-2021/warnings-promoted-to-error.html>
[INFO] [stdout] help: if this is a dyn-compatible trait, use `dyn`
[INFO] [stdout]     |
[INFO] [stdout] 149 | pub fn flock(file: &dyn AsRawFd, op: FlockOperation, nonblocking: bool) -> Result<()> {
[INFO] [stdout]     |                     +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stdout]    --> src/lib.rs:178:12
[INFO] [stdout]     |
[INFO] [stdout] 178 |     file: &AsRawFd,
[INFO] [stdout]     |            ^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = warning: this is accepted in the current edition (Rust 2015) but is a hard error in Rust 2021!
[INFO] [stdout]     = note: for more information, see <https://doc.rust-lang.org/edition-guide/rust-2021/warnings-promoted-to-error.html>
[INFO] [stdout] help: if this is a dyn-compatible trait, use `dyn`
[INFO] [stdout]     |
[INFO] [stdout] 178 |     file: &dyn AsRawFd,
[INFO] [stdout]     |            +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stdout]   --> src/file_flags.rs:19:29
[INFO] [stdout]    |
[INFO] [stdout] 19 |     pub fn from_file(file: &AsRawFd) -> Result<FileFlags> {
[INFO] [stdout]    |                             ^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = warning: this is accepted in the current edition (Rust 2015) but is a hard error in Rust 2021!
[INFO] [stdout]    = note: for more information, see <https://doc.rust-lang.org/edition-guide/rust-2021/warnings-promoted-to-error.html>
[INFO] [stdout] help: if this is a dyn-compatible trait, use `dyn`
[INFO] [stdout]    |
[INFO] [stdout] 19 |     pub fn from_file(file: &dyn AsRawFd) -> Result<FileFlags> {
[INFO] [stdout]    |                             +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stdout]   --> src/mmap.rs:93:25
[INFO] [stdout]    |
[INFO] [stdout] 93 |     pub fn from_fd(fd: &AsRawFd, size: usize) -> Result<MemoryMapping> {
[INFO] [stdout]    |                         ^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = warning: this is accepted in the current edition (Rust 2015) but is a hard error in Rust 2021!
[INFO] [stdout]    = note: for more information, see <https://doc.rust-lang.org/edition-guide/rust-2021/warnings-promoted-to-error.html>
[INFO] [stdout] help: if this is a dyn-compatible trait, use `dyn`
[INFO] [stdout]    |
[INFO] [stdout] 93 |     pub fn from_fd(fd: &dyn AsRawFd, size: usize) -> Result<MemoryMapping> {
[INFO] [stdout]    |                         +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stdout]    --> src/mmap.rs:103:32
[INFO] [stdout]     |
[INFO] [stdout] 103 |     pub fn from_fd_offset(fd: &AsRawFd, size: usize, offset: usize) -> Result<MemoryMapping> {
[INFO] [stdout]     |                                ^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = warning: this is accepted in the current edition (Rust 2015) but is a hard error in Rust 2021!
[INFO] [stdout]     = note: for more information, see <https://doc.rust-lang.org/edition-guide/rust-2021/warnings-promoted-to-error.html>
[INFO] [stdout] help: if this is a dyn-compatible trait, use `dyn`
[INFO] [stdout]     |
[INFO] [stdout] 103 |     pub fn from_fd_offset(fd: &dyn AsRawFd, size: usize, offset: usize) -> Result<MemoryMapping> {
[INFO] [stdout]     |                                +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]    --> src/guest_memory.rs:250:32
[INFO] [stdout]     |
[INFO] [stdout] 250 |     pub fn read_at_addr(&self, mut buf: &mut [u8], guest_addr: GuestAddress) -> Result<usize> {
[INFO] [stdout]     |                                ----^^^
[INFO] [stdout]     |                                |
[INFO] [stdout]     |                                help: remove this `mut`
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(unused_mut)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stdout]    --> src/guest_memory.rs:467:18
[INFO] [stdout]     |
[INFO] [stdout] 467 |     fn get_slice(&self, offset: u64, count: u64) -> VolatileMemoryResult<VolatileSlice> {
[INFO] [stdout]     |                  ^^^^^ the lifetime is elided here                       ^^^^^^^^^^^^^ the same lifetime is hidden here
[INFO] [stdout]     |
[INFO] [stdout]     = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stdout]     = note: `#[warn(mismatched_lifetime_syntaxes)]` on by default
[INFO] [stdout] help: use `'_` for type paths
[INFO] [stdout]     |
[INFO] [stdout] 467 |     fn get_slice(&self, offset: u64, count: u64) -> VolatileMemoryResult<VolatileSlice<'_>> {
[INFO] [stdout]     |                                                                                       ++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stdout]    --> src/mmap.rs:377:18
[INFO] [stdout]     |
[INFO] [stdout] 377 |     fn get_slice(&self, offset: u64, count: u64) -> VolatileMemoryResult<VolatileSlice> {
[INFO] [stdout]     |                  ^^^^^ the lifetime is elided here                       ^^^^^^^^^^^^^ the same lifetime is hidden here
[INFO] [stdout]     |
[INFO] [stdout]     = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stdout] help: use `'_` for type paths
[INFO] [stdout]     |
[INFO] [stdout] 377 |     fn get_slice(&self, offset: u64, count: u64) -> VolatileMemoryResult<VolatileSlice<'_>> {
[INFO] [stdout]     |                                                                                       ++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the type `libc::sockaddr_un` does not permit being left uninitialized
[INFO] [stdout]   --> src/net.rs:16:39
[INFO] [stdout]    |
[INFO] [stdout] 16 |         let addr: libc::sockaddr_un = mem::uninitialized();
[INFO] [stdout]    |                                       ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]    |                                       |
[INFO] [stdout]    |                                       this code causes undefined behavior when executed
[INFO] [stdout]    |                                       help: use `MaybeUninit<T>` instead, and only call `assume_init` after initialization is done
[INFO] [stdout]    |
[INFO] [stdout]    = note: integers must be initialized
[INFO] [stdout]    = note: `#[warn(invalid_value)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stdout]    --> src/poll.rs:181:17
[INFO] [stdout]     |
[INFO] [stdout] 181 |     pub fn iter(&self) -> PollEventIter<slice::Iter<epoll_event>, T> {
[INFO] [stdout]     |                 ^^^^^     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |                 |         |             |
[INFO] [stdout]     |                 |         |             the same lifetime is hidden here
[INFO] [stdout]     |                 |         the same lifetime is hidden here
[INFO] [stdout]     |                 the lifetime is elided here
[INFO] [stdout]     |
[INFO] [stdout]     = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stdout] help: use `'_` for type paths
[INFO] [stdout]     |
[INFO] [stdout] 181 |     pub fn iter(&self) -> PollEventIter<'_, slice::Iter<'_, epoll_event>, T> {
[INFO] [stdout]     |                                         +++             +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stdout]    --> src/poll.rs:190:26
[INFO] [stdout]     |
[INFO] [stdout] 190 |     pub fn iter_readable(&self) -> PollEventIter<slice::Iter<epoll_event>, T> {
[INFO] [stdout]     |                          ^^^^^     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |                          |         |             |
[INFO] [stdout]     |                          |         |             the same lifetime is hidden here
[INFO] [stdout]     |                          |         the same lifetime is hidden here
[INFO] [stdout]     |                          the lifetime is elided here
[INFO] [stdout]     |
[INFO] [stdout]     = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stdout] help: use `'_` for type paths
[INFO] [stdout]     |
[INFO] [stdout] 190 |     pub fn iter_readable(&self) -> PollEventIter<'_, slice::Iter<'_, epoll_event>, T> {
[INFO] [stdout]     |                                                  +++             +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stdout]    --> src/poll.rs:199:24
[INFO] [stdout]     |
[INFO] [stdout] 199 |     pub fn iter_hungup(&self) -> PollEventIter<slice::Iter<epoll_event>, T> {
[INFO] [stdout]     |                        ^^^^^     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |                        |         |             |
[INFO] [stdout]     |                        |         |             the same lifetime is hidden here
[INFO] [stdout]     |                        |         the same lifetime is hidden here
[INFO] [stdout]     |                        the lifetime is elided here
[INFO] [stdout]     |
[INFO] [stdout]     = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stdout] help: use `'_` for type paths
[INFO] [stdout]     |
[INFO] [stdout] 199 |     pub fn iter_hungup(&self) -> PollEventIter<'_, slice::Iter<'_, epoll_event>, T> {
[INFO] [stdout]     |                                                +++             +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stdout]    --> src/poll.rs:217:19
[INFO] [stdout]     |
[INFO] [stdout] 217 |     pub fn as_ref(&self) -> PollEvents<T> {
[INFO] [stdout]     |                   ^^^^^     ^^^^^^^^^^^^^ the same lifetime is hidden here
[INFO] [stdout]     |                   |
[INFO] [stdout]     |                   the lifetime is elided here
[INFO] [stdout]     |
[INFO] [stdout]     = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stdout] help: use `'_` for type paths
[INFO] [stdout]     |
[INFO] [stdout] 217 |     pub fn as_ref(&self) -> PollEvents<'_, T> {
[INFO] [stdout]     |                                        +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stdout]    --> src/poll.rs:579:17
[INFO] [stdout]     |
[INFO] [stdout] 579 |     pub fn wait(&self) -> Result<PollEvents<T>> {
[INFO] [stdout]     |                 ^^^^^            ^^^^^^^^^^^^^ the same lifetime is hidden here
[INFO] [stdout]     |                 |
[INFO] [stdout]     |                 the lifetime is elided here
[INFO] [stdout]     |
[INFO] [stdout]     = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stdout] help: use `'_` for type paths
[INFO] [stdout]     |
[INFO] [stdout] 579 |     pub fn wait(&self) -> Result<PollEvents<'_, T>> {
[INFO] [stdout]     |                                             +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stdout]    --> src/poll.rs:587:25
[INFO] [stdout]     |
[INFO] [stdout] 587 |     pub fn wait_timeout(&self, timeout: Duration) -> Result<PollEvents<T>> {
[INFO] [stdout]     |                         ^^^^^ the lifetime is elided here   ^^^^^^^^^^^^^ the same lifetime is hidden here
[INFO] [stdout]     |
[INFO] [stdout]     = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stdout] help: use `'_` for type paths
[INFO] [stdout]     |
[INFO] [stdout] 587 |     pub fn wait_timeout(&self, timeout: Duration) -> Result<PollEvents<'_, T>> {
[INFO] [stdout]     |                                                                        +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stderr]     Finished `test` profile [unoptimized + debuginfo] target(s) in 1.80s
[INFO] [stderr] warning: the following packages contain code that will be rejected by a future version of Rust: sys_util v0.1.0 (/opt/rustwide/workdir)
[INFO] [stderr] note: to see what the problems were, use the option `--future-incompat-report`, or run `cargo report future-incompatibilities --id 2`
[INFO] running `Command { std: "docker" "inspect" "2b7c7a35ec2ab59bc1e3488add81c35daffdd42d03e502cadbe3ad76314e2ef7", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "2b7c7a35ec2ab59bc1e3488add81c35daffdd42d03e502cadbe3ad76314e2ef7", kill_on_drop: false }`
[INFO] [stdout] 2b7c7a35ec2ab59bc1e3488add81c35daffdd42d03e502cadbe3ad76314e2ef7
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-3-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-3-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=warn" "-e" "RUSTDOCFLAGS=--cap-lints=warn" "-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:d429b63d4308055ea97f60fb1d3dfca48854a00942f1bd2ad806beaf015945ec" "/opt/rustwide/cargo-home/bin/cargo" "+1.95.0" "test" "--frozen", kill_on_drop: false }`
[INFO] [stdout] a52fd64f4ecedcc11702a981933ce24be9bfa3fe53ef29fa7d75490955497261
[INFO] running `Command { std: "docker" "start" "-a" "a52fd64f4ecedcc11702a981933ce24be9bfa3fe53ef29fa7d75490955497261", kill_on_drop: false }`
[INFO] [stderr] warning: the cargo feature `rename-dependency` has been stabilized in the 1.31 release and is no longer necessary to be listed in the manifest
[INFO] [stderr]   See https://doc.rust-lang.org/cargo/reference/specifying-dependencies.html#renaming-dependencies-in-cargotoml for more information about using this feature.
[INFO] [stderr] warning: no edition set: defaulting to the 2015 edition while the latest is 2024
[INFO] [stderr] warning: unexpected `cfg` condition value: `cargo-clippy`
[INFO] [stderr]   --> src/sock_ctrl_msg.rs:55:12
[INFO] [stderr]    |
[INFO] [stderr] 55 | #[cfg_attr(feature = "cargo-clippy", allow(cast_ptr_alignment))]
[INFO] [stderr]    |            ^^^^^^^^^^^^^^^^^^^^^^^^ help: remove the condition
[INFO] [stderr]    |
[INFO] [stderr]    = note: no expected values for `feature`
[INFO] [stderr]    = help: consider adding `cargo-clippy` as a feature in `Cargo.toml`
[INFO] [stderr]    = note: see <https://doc.rust-lang.org/nightly/rustc/check-cfg/cargo-specifics.html> for more information about checking conditional configuration
[INFO] [stderr]    = note: `#[warn(unexpected_cfgs)]` on by default
[INFO] [stderr] 
[INFO] [stderr] warning: unexpected `cfg` condition value: `cargo-clippy`
[INFO] [stderr]    --> src/sock_ctrl_msg.rs:315:16
[INFO] [stderr]     |
[INFO] [stderr] 315 |     #[cfg_attr(feature = "cargo-clippy", allow(useless_asref))]
[INFO] [stderr]     |                ^^^^^^^^^^^^^^^^^^^^^^^^ help: remove the condition
[INFO] [stderr]     |
[INFO] [stderr]     = note: no expected values for `feature`
[INFO] [stderr]     = help: consider adding `cargo-clippy` as a feature in `Cargo.toml`
[INFO] [stderr]     = note: see <https://doc.rust-lang.org/nightly/rustc/check-cfg/cargo-specifics.html> for more information about checking conditional configuration
[INFO] [stderr] 
[INFO] [stderr] warning: trailing semicolon in macro used in expression position
[INFO] [stderr]    --> src/syslog.rs:252:10
[INFO] [stderr]     |
[INFO] [stderr] 252 |         };
[INFO] [stderr]     |          ^
[INFO] [stderr] ...
[INFO] [stderr] 263 |     let mut state = lock!();
[INFO] [stderr]     |                     ------- in this macro invocation
[INFO] [stderr]     |
[INFO] [stderr]     = warning: this was previously accepted by the compiler but is being phased out; it will become a hard error in a future release!
[INFO] [stderr]     = note: for more information, see issue #79813 <https://github.com/rust-lang/rust/issues/79813>
[INFO] [stderr]     = note: `#[warn(semicolon_in_expressions_from_macros)]` (part of `#[warn(future_incompatible)]`) on by default
[INFO] [stderr]     = note: this warning originates in the macro `lock` (in Nightly builds, run with -Z macro-backtrace for more info)
[INFO] [stderr] 
[INFO] [stderr] warning: trailing semicolon in macro used in expression position
[INFO] [stderr]    --> src/syslog.rs:252:10
[INFO] [stderr]     |
[INFO] [stderr] 252 |         };
[INFO] [stderr]     |          ^
[INFO] [stderr] ...
[INFO] [stderr] 280 |     let mut state = lock!();
[INFO] [stderr]     |                     ------- in this macro invocation
[INFO] [stderr]     |
[INFO] [stderr]     = warning: this was previously accepted by the compiler but is being phased out; it will become a hard error in a future release!
[INFO] [stderr]     = note: for more information, see issue #79813 <https://github.com/rust-lang/rust/issues/79813>
[INFO] [stderr]     = note: this warning originates in the macro `lock` (in Nightly builds, run with -Z macro-backtrace for more info)
[INFO] [stderr] 
[INFO] [stderr] warning: trailing semicolon in macro used in expression position
[INFO] [stderr]    --> src/syslog.rs:252:10
[INFO] [stderr]     |
[INFO] [stderr] 252 |         };
[INFO] [stderr]     |          ^
[INFO] [stderr] ...
[INFO] [stderr] 329 |     let mut state = lock!();
[INFO] [stderr]     |                     ------- in this macro invocation
[INFO] [stderr]     |
[INFO] [stderr]     = warning: this was previously accepted by the compiler but is being phased out; it will become a hard error in a future release!
[INFO] [stderr]     = note: for more information, see issue #79813 <https://github.com/rust-lang/rust/issues/79813>
[INFO] [stderr]     = note: this warning originates in the macro `lock` (in Nightly builds, run with -Z macro-backtrace for more info)
[INFO] [stderr] 
[INFO] [stderr] warning: trailing semicolon in macro used in expression position
[INFO] [stderr]    --> src/syslog.rs:252:10
[INFO] [stderr]     |
[INFO] [stderr] 252 |         };
[INFO] [stderr]     |          ^
[INFO] [stderr] ...
[INFO] [stderr] 342 |     let mut state = lock!();
[INFO] [stderr]     |                     ------- in this macro invocation
[INFO] [stderr]     |
[INFO] [stderr]     = warning: this was previously accepted by the compiler but is being phased out; it will become a hard error in a future release!
[INFO] [stderr]     = note: for more information, see issue #79813 <https://github.com/rust-lang/rust/issues/79813>
[INFO] [stderr]     = note: this warning originates in the macro `lock` (in Nightly builds, run with -Z macro-backtrace for more info)
[INFO] [stderr] 
[INFO] [stderr] warning: trailing semicolon in macro used in expression position
[INFO] [stderr]    --> src/syslog.rs:252:10
[INFO] [stderr]     |
[INFO] [stderr] 252 |         };
[INFO] [stderr]     |          ^
[INFO] [stderr] ...
[INFO] [stderr] 353 |     let state = lock!();
[INFO] [stderr]     |                 ------- in this macro invocation
[INFO] [stderr]     |
[INFO] [stderr]     = warning: this was previously accepted by the compiler but is being phased out; it will become a hard error in a future release!
[INFO] [stderr]     = note: for more information, see issue #79813 <https://github.com/rust-lang/rust/issues/79813>
[INFO] [stderr]     = note: this warning originates in the macro `lock` (in Nightly builds, run with -Z macro-backtrace for more info)
[INFO] [stderr] 
[INFO] [stderr] warning: trailing semicolon in macro used in expression position
[INFO] [stderr]    --> src/syslog.rs:252:10
[INFO] [stderr]     |
[INFO] [stderr] 252 |         };
[INFO] [stderr]     |          ^
[INFO] [stderr] ...
[INFO] [stderr] 427 |     let mut state = lock!();
[INFO] [stderr]     |                     ------- in this macro invocation
[INFO] [stderr]     |
[INFO] [stderr]     = warning: this was previously accepted by the compiler but is being phased out; it will become a hard error in a future release!
[INFO] [stderr]     = note: for more information, see issue #79813 <https://github.com/rust-lang/rust/issues/79813>
[INFO] [stderr]     = note: this warning originates in the macro `lock` (in Nightly builds, run with -Z macro-backtrace for more info)
[INFO] [stderr] 
[INFO] [stderr] warning: use of deprecated constant `std::sync::ONCE_INIT`: the `Once::new()` function is now preferred
[INFO] [stderr]   --> src/syslog.rs:39:35
[INFO] [stderr]    |
[INFO] [stderr] 39 | use std::sync::{MutexGuard, Once, ONCE_INIT};
[INFO] [stderr]    |                                   ^^^^^^^^^
[INFO] [stderr]    |
[INFO] [stderr]    = note: `#[warn(deprecated)]` on by default
[INFO] [stderr] 
[INFO] [stderr] warning: use of deprecated constant `std::sync::ONCE_INIT`: the `Once::new()` function is now preferred
[INFO] [stderr]    --> src/syslog.rs:207:27
[INFO] [stderr]     |
[INFO] [stderr] 207 | static STATE_ONCE: Once = ONCE_INIT;
[INFO] [stderr]     |                           ^^^^^^^^^
[INFO] [stderr]     |
[INFO] [stderr] help: replace the use of the deprecated constant
[INFO] [stderr]     |
[INFO] [stderr] 207 - static STATE_ONCE: Once = ONCE_INIT;
[INFO] [stderr] 207 + static STATE_ONCE: Once = Once::new();
[INFO] [stderr]     |
[INFO] [stderr] 
[INFO] [stderr] warning: use of deprecated function `std::mem::uninitialized`: use `mem::MaybeUninit` instead
[INFO] [stderr]   --> src/net.rs:16:44
[INFO] [stderr]    |
[INFO] [stderr] 16 |         let addr: libc::sockaddr_un = mem::uninitialized();
[INFO] [stderr]    |                                            ^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stderr]    --> src/poll.rs:290:28
[INFO] [stderr]     |
[INFO] [stderr] 290 |     pub fn add(&self, fd: &AsRawFd, token: T) -> Result<()> {
[INFO] [stderr]     |                            ^^^^^^^
[INFO] [stderr]     |
[INFO] [stderr]     = warning: this is accepted in the current edition (Rust 2015) but is a hard error in Rust 2021!
[INFO] [stderr]     = note: for more information, see <https://doc.rust-lang.org/edition-guide/rust-2021/warnings-promoted-to-error.html>
[INFO] [stderr]     = note: `#[warn(bare_trait_objects)]` (part of `#[warn(rust_2021_compatibility)]`) on by default
[INFO] [stderr] help: if this is a dyn-compatible trait, use `dyn`
[INFO] [stderr]     |
[INFO] [stderr] 290 |     pub fn add(&self, fd: &dyn AsRawFd, token: T) -> Result<()> {
[INFO] [stderr]     |                            +++
[INFO] [stderr] 
[INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stderr]    --> src/poll.rs:300:43
[INFO] [stderr]     |
[INFO] [stderr] 300 |     pub fn add_fd_with_events(&self, fd: &AsRawFd, events: WatchingEvents, token: T) -> Result<()> {
[INFO] [stderr]     |                                           ^^^^^^^
[INFO] [stderr]     |
[INFO] [stderr]     = warning: this is accepted in the current edition (Rust 2015) but is a hard error in Rust 2021!
[INFO] [stderr]     = note: for more information, see <https://doc.rust-lang.org/edition-guide/rust-2021/warnings-promoted-to-error.html>
[INFO] [stderr] help: if this is a dyn-compatible trait, use `dyn`
[INFO] [stderr]     |
[INFO] [stderr] 300 |     pub fn add_fd_with_events(&self, fd: &dyn AsRawFd, events: WatchingEvents, token: T) -> Result<()> {
[INFO] [stderr]     |                                           +++
[INFO] [stderr] 
[INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stderr]    --> src/poll.rs:323:31
[INFO] [stderr]     |
[INFO] [stderr] 323 |     pub fn modify(&self, fd: &AsRawFd, events: WatchingEvents, token: T) -> Result<()> {
[INFO] [stderr]     |                               ^^^^^^^
[INFO] [stderr]     |
[INFO] [stderr]     = warning: this is accepted in the current edition (Rust 2015) but is a hard error in Rust 2021!
[INFO] [stderr]     = note: for more information, see <https://doc.rust-lang.org/edition-guide/rust-2021/warnings-promoted-to-error.html>
[INFO] [stderr] help: if this is a dyn-compatible trait, use `dyn`
[INFO] [stderr]     |
[INFO] [stderr] 323 |     pub fn modify(&self, fd: &dyn AsRawFd, events: WatchingEvents, token: T) -> Result<()> {
[INFO] [stderr]     |                               +++
[INFO] [stderr] 
[INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stderr]    --> src/poll.rs:350:31
[INFO] [stderr]     |
[INFO] [stderr] 350 |     pub fn delete(&self, fd: &AsRawFd) -> Result<()> {
[INFO] [stderr]     |                               ^^^^^^^
[INFO] [stderr]     |
[INFO] [stderr]     = warning: this is accepted in the current edition (Rust 2015) but is a hard error in Rust 2021!
[INFO] [stderr]     = note: for more information, see <https://doc.rust-lang.org/edition-guide/rust-2021/warnings-promoted-to-error.html>
[INFO] [stderr] help: if this is a dyn-compatible trait, use `dyn`
[INFO] [stderr]     |
[INFO] [stderr] 350 |     pub fn delete(&self, fd: &dyn AsRawFd) -> Result<()> {
[INFO] [stderr]     |                               +++
[INFO] [stderr] 
[INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stderr]    --> src/poll.rs:494:28
[INFO] [stderr]     |
[INFO] [stderr] 494 |     pub fn add(&self, fd: &AsRawFd, token: T) -> Result<()> {
[INFO] [stderr]     |                            ^^^^^^^
[INFO] [stderr]     |
[INFO] [stderr]     = warning: this is accepted in the current edition (Rust 2015) but is a hard error in Rust 2021!
[INFO] [stderr]     = note: for more information, see <https://doc.rust-lang.org/edition-guide/rust-2021/warnings-promoted-to-error.html>
[INFO] [stderr] help: if this is a dyn-compatible trait, use `dyn`
[INFO] [stderr]     |
[INFO] [stderr] 494 |     pub fn add(&self, fd: &dyn AsRawFd, token: T) -> Result<()> {
[INFO] [stderr]     |                            +++
[INFO] [stderr] 
[INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stderr]    --> src/poll.rs:504:43
[INFO] [stderr]     |
[INFO] [stderr] 504 |     pub fn add_fd_with_events(&self, fd: &AsRawFd, events: WatchingEvents, token: T) -> Result<()> {
[INFO] [stderr]     |                                           ^^^^^^^
[INFO] [stderr]     |
[INFO] [stderr]     = warning: this is accepted in the current edition (Rust 2015) but is a hard error in Rust 2021!
[INFO] [stderr]     = note: for more information, see <https://doc.rust-lang.org/edition-guide/rust-2021/warnings-promoted-to-error.html>
[INFO] [stderr] help: if this is a dyn-compatible trait, use `dyn`
[INFO] [stderr]     |
[INFO] [stderr] 504 |     pub fn add_fd_with_events(&self, fd: &dyn AsRawFd, events: WatchingEvents, token: T) -> Result<()> {
[INFO] [stderr]     |                                           +++
[INFO] [stderr] 
[INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stderr]    --> src/poll.rs:513:31
[INFO] [stderr]     |
[INFO] [stderr] 513 |     pub fn modify(&self, fd: &AsRawFd, events: WatchingEvents, token: T) -> Result<()> {
[INFO] [stderr]     |                               ^^^^^^^
[INFO] [stderr]     |
[INFO] [stderr]     = warning: this is accepted in the current edition (Rust 2015) but is a hard error in Rust 2021!
[INFO] [stderr]     = note: for more information, see <https://doc.rust-lang.org/edition-guide/rust-2021/warnings-promoted-to-error.html>
[INFO] [stderr] help: if this is a dyn-compatible trait, use `dyn`
[INFO] [stderr]     |
[INFO] [stderr] 513 |     pub fn modify(&self, fd: &dyn AsRawFd, events: WatchingEvents, token: T) -> Result<()> {
[INFO] [stderr]     |                               +++
[INFO] [stderr] 
[INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stderr]    --> src/poll.rs:523:31
[INFO] [stderr]     |
[INFO] [stderr] 523 |     pub fn delete(&self, fd: &AsRawFd) -> Result<()> {
[INFO] [stderr]     |                               ^^^^^^^
[INFO] [stderr]     |
[INFO] [stderr]     = warning: this is accepted in the current edition (Rust 2015) but is a hard error in Rust 2021!
[INFO] [stderr]     = note: for more information, see <https://doc.rust-lang.org/edition-guide/rust-2021/warnings-promoted-to-error.html>
[INFO] [stderr] help: if this is a dyn-compatible trait, use `dyn`
[INFO] [stderr]     |
[INFO] [stderr] 523 |     pub fn delete(&self, fd: &dyn AsRawFd) -> Result<()> {
[INFO] [stderr]     |                               +++
[INFO] [stderr] 
[INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stderr]    --> src/lib.rs:149:21
[INFO] [stderr]     |
[INFO] [stderr] 149 | pub fn flock(file: &AsRawFd, op: FlockOperation, nonblocking: bool) -> Result<()> {
[INFO] [stderr]     |                     ^^^^^^^
[INFO] [stderr]     |
[INFO] [stderr]     = warning: this is accepted in the current edition (Rust 2015) but is a hard error in Rust 2021!
[INFO] [stderr]     = note: for more information, see <https://doc.rust-lang.org/edition-guide/rust-2021/warnings-promoted-to-error.html>
[INFO] [stderr] help: if this is a dyn-compatible trait, use `dyn`
[INFO] [stderr]     |
[INFO] [stderr] 149 | pub fn flock(file: &dyn AsRawFd, op: FlockOperation, nonblocking: bool) -> Result<()> {
[INFO] [stderr]     |                     +++
[INFO] [stderr] 
[INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stderr]    --> src/lib.rs:178:12
[INFO] [stderr]     |
[INFO] [stderr] 178 |     file: &AsRawFd,
[INFO] [stderr]     |            ^^^^^^^
[INFO] [stderr]     |
[INFO] [stderr]     = warning: this is accepted in the current edition (Rust 2015) but is a hard error in Rust 2021!
[INFO] [stderr]     = note: for more information, see <https://doc.rust-lang.org/edition-guide/rust-2021/warnings-promoted-to-error.html>
[INFO] [stderr] help: if this is a dyn-compatible trait, use `dyn`
[INFO] [stderr]     |
[INFO] [stderr] 178 |     file: &dyn AsRawFd,
[INFO] [stderr]     |            +++
[INFO] [stderr] 
[INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stderr]   --> src/file_flags.rs:19:29
[INFO] [stderr]    |
[INFO] [stderr] 19 |     pub fn from_file(file: &AsRawFd) -> Result<FileFlags> {
[INFO] [stderr]    |                             ^^^^^^^
[INFO] [stderr]    |
[INFO] [stderr]    = warning: this is accepted in the current edition (Rust 2015) but is a hard error in Rust 2021!
[INFO] [stderr]    = note: for more information, see <https://doc.rust-lang.org/edition-guide/rust-2021/warnings-promoted-to-error.html>
[INFO] [stderr] help: if this is a dyn-compatible trait, use `dyn`
[INFO] [stderr]    |
[INFO] [stderr] 19 |     pub fn from_file(file: &dyn AsRawFd) -> Result<FileFlags> {
[INFO] [stderr]    |                             +++
[INFO] [stderr] 
[INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stderr]   --> src/mmap.rs:93:25
[INFO] [stderr]    |
[INFO] [stderr] 93 |     pub fn from_fd(fd: &AsRawFd, size: usize) -> Result<MemoryMapping> {
[INFO] [stderr]    |                         ^^^^^^^
[INFO] [stderr]    |
[INFO] [stderr]    = warning: this is accepted in the current edition (Rust 2015) but is a hard error in Rust 2021!
[INFO] [stderr]    = note: for more information, see <https://doc.rust-lang.org/edition-guide/rust-2021/warnings-promoted-to-error.html>
[INFO] [stderr] help: if this is a dyn-compatible trait, use `dyn`
[INFO] [stderr]    |
[INFO] [stderr] 93 |     pub fn from_fd(fd: &dyn AsRawFd, size: usize) -> Result<MemoryMapping> {
[INFO] [stderr]    |                         +++
[INFO] [stderr] 
[INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stderr]    --> src/mmap.rs:103:32
[INFO] [stderr]     |
[INFO] [stderr] 103 |     pub fn from_fd_offset(fd: &AsRawFd, size: usize, offset: usize) -> Result<MemoryMapping> {
[INFO] [stderr]     |                                ^^^^^^^
[INFO] [stderr]     |
[INFO] [stderr]     = warning: this is accepted in the current edition (Rust 2015) but is a hard error in Rust 2021!
[INFO] [stderr]     = note: for more information, see <https://doc.rust-lang.org/edition-guide/rust-2021/warnings-promoted-to-error.html>
[INFO] [stderr] help: if this is a dyn-compatible trait, use `dyn`
[INFO] [stderr]     |
[INFO] [stderr] 103 |     pub fn from_fd_offset(fd: &dyn AsRawFd, size: usize, offset: usize) -> Result<MemoryMapping> {
[INFO] [stderr]     |                                +++
[INFO] [stderr] 
[INFO] [stderr] warning: variable does not need to be mutable
[INFO] [stderr]    --> src/guest_memory.rs:250:32
[INFO] [stderr]     |
[INFO] [stderr] 250 |     pub fn read_at_addr(&self, mut buf: &mut [u8], guest_addr: GuestAddress) -> Result<usize> {
[INFO] [stderr]     |                                ----^^^
[INFO] [stderr]     |                                |
[INFO] [stderr]     |                                help: remove this `mut`
[INFO] [stderr]     |
[INFO] [stderr]     = note: `#[warn(unused_mut)]` (part of `#[warn(unused)]`) on by default
[INFO] [stderr] 
[INFO] [stderr] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stderr]    --> src/guest_memory.rs:467:18
[INFO] [stderr]     |
[INFO] [stderr] 467 |     fn get_slice(&self, offset: u64, count: u64) -> VolatileMemoryResult<VolatileSlice> {
[INFO] [stderr]     |                  ^^^^^ the lifetime is elided here                       ^^^^^^^^^^^^^ the same lifetime is hidden here
[INFO] [stderr]     |
[INFO] [stderr]     = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stderr]     = note: `#[warn(mismatched_lifetime_syntaxes)]` on by default
[INFO] [stderr] help: use `'_` for type paths
[INFO] [stderr]     |
[INFO] [stderr] 467 |     fn get_slice(&self, offset: u64, count: u64) -> VolatileMemoryResult<VolatileSlice<'_>> {
[INFO] [stderr]     |                                                                                       ++++
[INFO] [stderr] 
[INFO] [stderr] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stderr]    --> src/mmap.rs:377:18
[INFO] [stderr]     |
[INFO] [stderr] 377 |     fn get_slice(&self, offset: u64, count: u64) -> VolatileMemoryResult<VolatileSlice> {
[INFO] [stderr]     |                  ^^^^^ the lifetime is elided here                       ^^^^^^^^^^^^^ the same lifetime is hidden here
[INFO] [stderr]     |
[INFO] [stderr]     = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stderr] help: use `'_` for type paths
[INFO] [stderr]     |
[INFO] [stderr] 377 |     fn get_slice(&self, offset: u64, count: u64) -> VolatileMemoryResult<VolatileSlice<'_>> {
[INFO] [stderr]     |                                                                                       ++++
[INFO] [stderr] 
[INFO] [stderr] warning: the type `sockaddr_un` does not permit being left uninitialized
[INFO] [stderr]   --> src/net.rs:16:39
[INFO] [stderr]    |
[INFO] [stderr] 16 |         let addr: libc::sockaddr_un = mem::uninitialized();
[INFO] [stderr]    |                                       ^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr]    |                                       |
[INFO] [stderr]    |                                       this code causes undefined behavior when executed
[INFO] [stderr]    |                                       help: use `MaybeUninit<T>` instead, and only call `assume_init` after initialization is done
[INFO] [stderr]    |
[INFO] [stderr]    = note: integers must be initialized
[INFO] [stderr]    = note: `#[warn(invalid_value)]` on by default
[INFO] [stderr] 
[INFO] [stderr] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stderr]    --> src/poll.rs:181:17
[INFO] [stderr]     |
[INFO] [stderr] 181 |     pub fn iter(&self) -> PollEventIter<slice::Iter<epoll_event>, T> {
[INFO] [stderr]     |                 ^^^^^     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr]     |                 |         |             |
[INFO] [stderr]     |                 |         |             the same lifetime is hidden here
[INFO] [stderr]     |                 |         the same lifetime is hidden here
[INFO] [stderr]     |                 the lifetime is elided here
[INFO] [stderr]     |
[INFO] [stderr]     = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stderr] help: use `'_` for type paths
[INFO] [stderr]     |
[INFO] [stderr] 181 |     pub fn iter(&self) -> PollEventIter<'_, slice::Iter<'_, epoll_event>, T> {
[INFO] [stderr]     |                                         +++             +++
[INFO] [stderr] 
[INFO] [stderr] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stderr]    --> src/poll.rs:190:26
[INFO] [stderr]     |
[INFO] [stderr] 190 |     pub fn iter_readable(&self) -> PollEventIter<slice::Iter<epoll_event>, T> {
[INFO] [stderr]     |                          ^^^^^     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr]     |                          |         |             |
[INFO] [stderr]     |                          |         |             the same lifetime is hidden here
[INFO] [stderr]     |                          |         the same lifetime is hidden here
[INFO] [stderr]     |                          the lifetime is elided here
[INFO] [stderr]     |
[INFO] [stderr]     = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stderr] help: use `'_` for type paths
[INFO] [stderr]     |
[INFO] [stderr] 190 |     pub fn iter_readable(&self) -> PollEventIter<'_, slice::Iter<'_, epoll_event>, T> {
[INFO] [stderr]     |                                                  +++             +++
[INFO] [stderr] 
[INFO] [stderr] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stderr]    --> src/poll.rs:199:24
[INFO] [stderr]     |
[INFO] [stderr] 199 |     pub fn iter_hungup(&self) -> PollEventIter<slice::Iter<epoll_event>, T> {
[INFO] [stderr]     |                        ^^^^^     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr]     |                        |         |             |
[INFO] [stderr]     |                        |         |             the same lifetime is hidden here
[INFO] [stderr]     |                        |         the same lifetime is hidden here
[INFO] [stderr]     |                        the lifetime is elided here
[INFO] [stderr]     |
[INFO] [stderr]     = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stderr] help: use `'_` for type paths
[INFO] [stderr]     |
[INFO] [stderr] 199 |     pub fn iter_hungup(&self) -> PollEventIter<'_, slice::Iter<'_, epoll_event>, T> {
[INFO] [stderr]     |                                                +++             +++
[INFO] [stderr] 
[INFO] [stderr] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stderr]    --> src/poll.rs:217:19
[INFO] [stderr]     |
[INFO] [stderr] 217 |     pub fn as_ref(&self) -> PollEvents<T> {
[INFO] [stderr]     |                   ^^^^^     ^^^^^^^^^^^^^ the same lifetime is hidden here
[INFO] [stderr]     |                   |
[INFO] [stderr]     |                   the lifetime is elided here
[INFO] [stderr]     |
[INFO] [stderr]     = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stderr] help: use `'_` for type paths
[INFO] [stderr]     |
[INFO] [stderr] 217 |     pub fn as_ref(&self) -> PollEvents<'_, T> {
[INFO] [stderr]     |                                        +++
[INFO] [stderr] 
[INFO] [stderr] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stderr]    --> src/poll.rs:579:17
[INFO] [stderr]     |
[INFO] [stderr] 579 |     pub fn wait(&self) -> Result<PollEvents<T>> {
[INFO] [stderr]     |                 ^^^^^            ^^^^^^^^^^^^^ the same lifetime is hidden here
[INFO] [stderr]     |                 |
[INFO] [stderr]     |                 the lifetime is elided here
[INFO] [stderr]     |
[INFO] [stderr]     = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stderr] help: use `'_` for type paths
[INFO] [stderr]     |
[INFO] [stderr] 579 |     pub fn wait(&self) -> Result<PollEvents<'_, T>> {
[INFO] [stderr]     |                                             +++
[INFO] [stderr] 
[INFO] [stderr] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stderr]    --> src/poll.rs:587:25
[INFO] [stderr]     |
[INFO] [stderr] 587 |     pub fn wait_timeout(&self, timeout: Duration) -> Result<PollEvents<T>> {
[INFO] [stderr]     |                         ^^^^^ the lifetime is elided here   ^^^^^^^^^^^^^ the same lifetime is hidden here
[INFO] [stderr]     |
[INFO] [stderr]     = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stderr] help: use `'_` for type paths
[INFO] [stderr]     |
[INFO] [stderr] 587 |     pub fn wait_timeout(&self, timeout: Duration) -> Result<PollEvents<'_, T>> {
[INFO] [stderr]     |                                                                        +++
[INFO] [stderr] 
[INFO] [stderr] warning: the type `libc::sockaddr_un` does not permit being left uninitialized
[INFO] [stderr]   --> src/net.rs:16:39
[INFO] [stderr]    |
[INFO] [stderr] 16 |         let addr: libc::sockaddr_un = mem::uninitialized();
[INFO] [stderr]    |                                       ^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr]    |                                       |
[INFO] [stderr]    |                                       this code causes undefined behavior when executed
[INFO] [stderr]    |                                       help: use `MaybeUninit<T>` instead, and only call `assume_init` after initialization is done
[INFO] [stderr]    |
[INFO] [stderr]    = note: integers must be initialized
[INFO] [stderr]    = note: `#[warn(invalid_value)]` on by default
[INFO] [stderr] 
[INFO] [stderr] warning: `sys_util` (lib) generated 34 warnings (run `cargo fix --lib -p sys_util` to apply 23 suggestions)
[INFO] [stderr] warning: `sys_util` (lib test) generated 34 warnings (33 duplicates)
[INFO] [stderr]     Finished `test` profile [unoptimized + debuginfo] target(s) in 0.05s
[INFO] [stderr] warning: the following packages contain code that will be rejected by a future version of Rust: sys_util v0.1.0 (/opt/rustwide/workdir)
[INFO] [stderr] note: to see what the problems were, use the option `--future-incompat-report`, or run `cargo report future-incompatibilities --id 2`
[INFO] [stderr]      Running unittests src/lib.rs (/opt/rustwide/target/debug/deps/sys_util-e674c14c824a7180)
[INFO] [stdout] 
[INFO] [stdout] running 84 tests
[INFO] [stdout] test eventfd::tests::new ... ok
[INFO] [stdout] test file_flags::tests::eventfd ... ok
[INFO] [stdout] test file_flags::tests::pipe_pair ... ok
[INFO] [stdout] test eventfd::tests::clone ... ok
[INFO] [stdout] test eventfd::tests::read_write ... ok
[INFO] [stdout] test guest_address::tests::add_sub ... ok
[INFO] [stdout] test guest_address::tests::equals ... ok
[INFO] [stdout] test fork::tests::pid_diff ... ok
[INFO] [stdout] test guest_memory::tests::guest_to_host ... ok
[INFO] [stdout] test guest_address::tests::mask ... ok
[INFO] [stdout] test guest_address::tests::cmp ... ok
[INFO] [stdout] test guest_memory::tests::test_memory_size ... ok
[INFO] [stdout] test guest_memory::tests::overlap_memory ... ok
[INFO] [stdout] test guest_address::tests::checked_add_overflow ... ok
[INFO] [stdout] test guest_memory::tests::test_read_u64 ... ok
[INFO] [stdout] test handle_eintr::tests::i32_eintr_errno ... ok
[INFO] [stdout] test handle_eintr::tests::io_eintr ... ok
[INFO] [stdout] test handle_eintr::tests::sys_eintr ... ok
[INFO] [stdout] test mmap::tests::map_invalid_size ... ok
[INFO] [stdout] test ioctl::tests::ioctl_macros ... ok
[INFO] [stdout] test mmap::tests::slice_addr ... ok
[INFO] [stdout] test mmap::tests::slice_oob_error ... ok
[INFO] [stdout] test mmap::tests::basic_map ... ok
[INFO] [stdout] test net::tests::sockaddr_un_long_input_err ... ok
[INFO] [stdout] test net::tests::sockaddr_un_long_input_pass ... ok
[INFO] [stdout] test net::tests::sockaddr_un_pass ... ok
[INFO] [stdout] test mmap::tests::slice_size ... ok
[INFO] [stdout] test guest_memory::tests::test_ref_store_u64 ... ok
[INFO] [stdout] test guest_memory::tests::two_regions ... ok
[INFO] [stdout] test mmap::tests::slice_overflow_error ... ok
[INFO] [stdout] test mmap::tests::slice_store ... ok
[INFO] [stdout] test mmap::tests::test_write_past_end ... ok
[INFO] [stdout] test net::tests::sockaddr_un_len_check ... ok
[INFO] [stdout] test net::tests::sockaddr_un_zero_length_input ... ok
[INFO] [stdout] test guest_memory::tests::test_ref_load_u64 ... ok
[INFO] [stdout] test net::tests::unix_seqpacket_path_not_exists ... ok
[INFO] [stdout] test poll::tests::poll_context ... ok
[INFO] [stdout] test poll::tests::poll_token_derive ... ok
[INFO] [stdout] test poll::tests::poll_context_overflow ... ok
[INFO] [stdout] test shm::tests::new ... ok
[INFO] [stdout] test shm::tests::mmap_page ... ok
[INFO] [stdout] test shm::tests::mmap_page_offset ... ok
[INFO] [stdout] test net::tests::unix_seqpacket_path_exists_pass ... ok
[INFO] [stdout] test shm::tests::new_named ... ok
[INFO] [stdout] test seek_hole::tests::seek_hole ... ok
[INFO] [stdout] test seek_hole::tests::seek_data ... ok
[INFO] [stdout] test passwd::tests::get_good_uid ... ok
[INFO] [stdout] test passwd::tests::get_good_gid ... ok
[INFO] [stdout] test shm::tests::new_huge ... ok
[INFO] [stdout] test shm::tests::new_sealed ... ok
[INFO] [stdout] test sock_ctrl_msg::tests::send_recv_no_fd ... ok
[INFO] [stdout] test shm::tests::new_sized ... ok
[INFO] [stdout] test shm::tests::new_too_huge ... ok
[INFO] [stdout] test signalfd::tests::drop ... ok
[INFO] [stdout] test signalfd::tests::new ... ok
[INFO] [stdout] test signalfd::tests::read ... ok
[INFO] [stdout] test sock_ctrl_msg::tests::buffer_len ... ok
[INFO] [stdout] test sock_ctrl_msg::tests::send_recv_with_fd ... ok
[INFO] [stdout] test sock_ctrl_msg::tests::send_recv_only_fd ... ok
[INFO] [stdout] test struct_util::test::struct_basic_read ... ok
[INFO] [stdout] test struct_util::test::struct_slice_read ... ok
[INFO] [stdout] test poll::tests::poll_context_timeout ... ok
[INFO] [stdout] test struct_util::test::struct_read_past_end ... ok
[INFO] [stdout] test timerfd::tests::fake_one_shot ... ok
[INFO] [stdout] test tempdir::tests::create_dir ... ok
[INFO] [stdout] test tempdir::tests::remove_dir ... ok
[INFO] [stdout] test timerfd::tests::fake_repeating ... ok
[INFO] [stdout] test write_zeroes::tests::large_write_zeroes ... ok
[INFO] [stdout] test mmap::tests::map_invalid_fd ... FAILED
[INFO] [stdout] test mmap::tests::from_fd_offset_invalid ... FAILED
[INFO] [stdout] test poll::tests::poll_context_hungup - should panic ... ok
[INFO] [stdout] test syslog::tests::fds ... FAILED
[INFO] [stdout] test syslog::tests::init_syslog ... FAILED
[INFO] [stdout] test syslog::tests::proc_name ... FAILED
[INFO] [stdout] test syslog::tests::syslog_file ... FAILED
[INFO] [stdout] test syslog::tests::syslog_log ... FAILED
[INFO] [stdout] test syslog::tests::macros ... FAILED
[INFO] [stdout] test passwd::tests::get_bad_uid ... ok
[INFO] [stdout] test passwd::tests::get_bad_gid ... ok
[INFO] [stdout] test write_zeroes::tests::simple_test ... ok
[INFO] [stdout] test handle_eintr::tests::i32_eintr_rc ... ok
[INFO] [stdout] test timerfd::tests::one_shot ... ok
[INFO] [stdout] test timerfd::tests::repeating ... ok
[INFO] [stdout] test fork::tests::panic_safe has been running for over 60 seconds
[ERROR] error running command: no output for 300 seconds
[INFO] running `Command { std: "docker" "inspect" "a52fd64f4ecedcc11702a981933ce24be9bfa3fe53ef29fa7d75490955497261", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "a52fd64f4ecedcc11702a981933ce24be9bfa3fe53ef29fa7d75490955497261", kill_on_drop: false }`
[INFO] [stdout] a52fd64f4ecedcc11702a981933ce24be9bfa3fe53ef29fa7d75490955497261
