[INFO] cloning repository https://github.com/GhostedGaming/eclipse-os
[INFO] running `Command { std: "git" "-c" "credential.helper=" "-c" "credential.helper=/workspace/cargo-home/bin/git-credential-null" "clone" "--bare" "https://github.com/GhostedGaming/eclipse-os" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2FGhostedGaming%2Feclipse-os", kill_on_drop: false }`
[INFO] [stderr] Cloning into bare repository '/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2FGhostedGaming%2Feclipse-os'...
[INFO] running `Command { std: "git" "rev-parse" "HEAD", kill_on_drop: false }`
[INFO] [stdout] eef014d45329f250250b777cd2162c30bd9d608c
[INFO] checking GhostedGaming/eclipse-os against try#2b39fe756f52bc2825bf5b2bfc385cab922dae10 for pr-143011
[INFO] running `Command { std: "git" "clone" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2FGhostedGaming%2Feclipse-os" "/workspace/builds/worker-6-tc2/source", kill_on_drop: false }`
[INFO] [stderr] Cloning into '/workspace/builds/worker-6-tc2/source'...
[INFO] [stderr] done.
[INFO] removed /workspace/builds/worker-6-tc2/source/.cargo/config.toml
[INFO] removed /workspace/builds/worker-6-tc2/source/rust-toolchain
[INFO] started tweaking git repo https://github.com/GhostedGaming/eclipse-os
[INFO] removed 0 missing tests
[INFO] finished tweaking git repo https://github.com/GhostedGaming/eclipse-os
[INFO] tweaked toml for git repo https://github.com/GhostedGaming/eclipse-os written to /workspace/builds/worker-6-tc2/source/Cargo.toml
[INFO] validating manifest of git repo https://github.com/GhostedGaming/eclipse-os on toolchain 2b39fe756f52bc2825bf5b2bfc385cab922dae10
[INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+2b39fe756f52bc2825bf5b2bfc385cab922dae10" "metadata" "--manifest-path" "Cargo.toml" "--no-deps", kill_on_drop: false }`
[INFO] crate git repo https://github.com/GhostedGaming/eclipse-os already has a lockfile, it will not be regenerated
[INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+2b39fe756f52bc2825bf5b2bfc385cab922dae10" "fetch" "--manifest-path" "Cargo.toml", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-6-tc2/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-6-tc2/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:90999bfc7ae267e83380e433d8e61a7c072ca6729e92edbae886d3423b3a6f4c" "/opt/rustwide/cargo-home/bin/cargo" "+2b39fe756f52bc2825bf5b2bfc385cab922dae10" "metadata" "--no-deps" "--format-version=1", kill_on_drop: false }`
[INFO] [stdout] 6680491b7c488085536011fc6968aed0485e65c8d8e85981eba5f77df1a08379
[INFO] running `Command { std: "docker" "start" "-a" "6680491b7c488085536011fc6968aed0485e65c8d8e85981eba5f77df1a08379", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "inspect" "6680491b7c488085536011fc6968aed0485e65c8d8e85981eba5f77df1a08379", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "6680491b7c488085536011fc6968aed0485e65c8d8e85981eba5f77df1a08379", kill_on_drop: false }`
[INFO] [stdout] 6680491b7c488085536011fc6968aed0485e65c8d8e85981eba5f77df1a08379
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-6-tc2/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-6-tc2/source:/opt/rustwide/workdir:ro,Z" "-v" "/var/lib/crater-agent-workspace/cargo-home:/opt/rustwide/cargo-home:ro,Z" "-v" "/var/lib/crater-agent-workspace/rustup-home:/opt/rustwide/rustup-home:ro,Z" "-e" "SOURCE_DIR=/opt/rustwide/workdir" "-e" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_INCREMENTAL=0" "-e" "RUST_BACKTRACE=full" "-e" "RUSTFLAGS=--cap-lints=forbid" "-e" "RUSTDOCFLAGS=--cap-lints=forbid" "-e" "CARGO_HOME=/opt/rustwide/cargo-home" "-e" "RUSTUP_HOME=/opt/rustwide/rustup-home" "-w" "/opt/rustwide/workdir" "-m" "1610612736" "--user" "0:0" "--network" "none" "ghcr.io/rust-lang/crates-build-env/linux@sha256:90999bfc7ae267e83380e433d8e61a7c072ca6729e92edbae886d3423b3a6f4c" "/opt/rustwide/cargo-home/bin/cargo" "+2b39fe756f52bc2825bf5b2bfc385cab922dae10" "check" "--frozen" "--all" "--all-targets" "--message-format=json", kill_on_drop: false }`
[INFO] [stdout] b241dc97f88e9ab05771c73031e71ac3410108b9f5e851c3a0e3bf0aa20db28f
[INFO] running `Command { std: "docker" "start" "-a" "b241dc97f88e9ab05771c73031e71ac3410108b9f5e851c3a0e3bf0aa20db28f", kill_on_drop: false }`
[INFO] [stderr]    Compiling proc-macro2 v1.0.95
[INFO] [stderr]    Compiling unicode-ident v1.0.18
[INFO] [stderr]    Compiling rustversion v1.0.20
[INFO] [stderr]    Compiling serde v1.0.219
[INFO] [stderr]     Checking volatile v0.4.6
[INFO] [stderr]     Checking bitflags v2.9.0
[INFO] [stderr]     Checking bit_field v0.10.2
[INFO] [stderr]    Compiling lock_api v0.4.12
[INFO] [stderr]    Compiling crossbeam-utils v0.8.21
[INFO] [stderr]    Compiling bootloader v0.9.31
[INFO] [stderr]    Compiling serde_json v1.0.140
[INFO] [stderr]     Checking powerfmt v0.2.0
[INFO] [stderr]    Compiling libm v0.2.15
[INFO] [stderr]     Checking futures-task v0.3.31
[INFO] [stderr]     Checking ryu v1.0.20
[INFO] [stderr]     Checking time-core v0.1.4
[INFO] [stderr]     Checking spinning_top v0.2.5
[INFO] [stderr]     Checking futures-core v0.3.31
[INFO] [stderr]     Checking itoa v1.0.15
[INFO] [stderr]     Checking deranged v0.4.0
[INFO] [stderr]     Checking num-conv v0.1.0
[INFO] [stderr]     Checking spin v0.9.8
[INFO] [stderr]     Checking cobs v0.2.3
[INFO] [stderr]     Checking conquer-util v0.2.0
[INFO] [stderr]     Checking memchr v2.7.4
[INFO] [stderr]     Checking lazy_static v1.5.0
[INFO] [stderr]     Checking futures-util v0.3.31
[INFO] [stderr]     Checking conquer-once v0.2.1
[INFO] [stderr]     Checking crossbeam-queue v0.3.12
[INFO] [stderr]     Checking linked_list_allocator v0.10.5
[INFO] [stderr]     Checking volatile v0.2.7
[INFO] [stderr]     Checking spin v0.5.2
[INFO] [stderr]     Checking pc-keyboard v0.7.0
[INFO] [stderr]     Checking x86_64 v0.14.13
[INFO] [stderr]    Compiling quote v1.0.40
[INFO] [stderr]    Compiling syn v2.0.101
[INFO] [stderr]     Checking time v0.3.41
[INFO] [stderr]     Checking pic8259 v0.10.4
[INFO] [stderr]     Checking uart_16550 v0.2.19
[INFO] [stderr]    Compiling serde_derive v1.0.219
[INFO] [stderr]     Checking postcard v1.1.1
[INFO] [stderr]     Checking eclipse_os v0.1.0 (/opt/rustwide/workdir)
[INFO] [stdout] error: invalid signature for `extern "x86-interrupt"` function
[INFO] [stdout]    --> src/interrupts.rs:260:6
[INFO] [stdout]     |
[INFO] [stdout] 260 | ) -> ! {
[INFO] [stdout]     |      ^
[INFO] [stdout]     |
[INFO] [stdout]     = note: functions with the "custom" ABI cannot have a return type
[INFO] [stdout] help: remove the return type
[INFO] [stdout]    --> src/interrupts.rs:260:6
[INFO] [stdout]     |
[INFO] [stdout] 260 | ) -> ! {
[INFO] [stdout]     |      ^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `align_up`
[INFO] [stdout]  --> src/allocator/fixed_size_block.rs:1:13
[INFO] [stdout]   |
[INFO] [stdout] 1 | use super::{align_up, Locked};
[INFO] [stdout]   |             ^^^^^^^^
[INFO] [stdout]   |
[INFO] [stdout]   = note: `#[warn(unused_imports)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `crate::pc_speaker`
[INFO] [stdout]  --> src/vga_buffer.rs:1:5
[INFO] [stdout]   |
[INFO] [stdout] 1 | use crate::pc_speaker;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `crate::text_editor::express_editor::EDITOR_DATA`
[INFO] [stdout]  --> src/vga_buffer.rs:6:5
[INFO] [stdout]   |
[INFO] [stdout] 6 | use crate::text_editor::express_editor::EDITOR_DATA;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `String` and `ToString`
[INFO] [stdout]    --> src/shell/mod.rs:229:25
[INFO] [stdout]     |
[INFO] [stdout] 229 |     use alloc::string::{String, ToString};
[INFO] [stdout]     |                         ^^^^^^  ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `crude_storage`
[INFO] [stdout]    --> src/shell/mod.rs:232:17
[INFO] [stdout]     |
[INFO] [stdout] 232 |     use crate::{crude_storage, println, rtc, vga_buffer};
[INFO] [stdout]     |                 ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `println`
[INFO] [stdout]  --> src/intereperter/run.rs:9:13
[INFO] [stdout]   |
[INFO] [stdout] 9 | use crate::{println};
[INFO] [stdout]   |             ^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `self` and `shell`
[INFO] [stdout]  --> src/crude_storage/crude_storage.rs:4:32
[INFO] [stdout]   |
[INFO] [stdout] 4 | use crate::{intereperter::run, shell, text_editor::{self, express_editor::EDITOR_DATA}};
[INFO] [stdout]   |                                ^^^^^                ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error: invalid signature for `extern "x86-interrupt"` function
[INFO] [stdout]    --> src/interrupts.rs:260:6
[INFO] [stdout]     |
[INFO] [stdout] 260 | ) -> ! {
[INFO] [stdout]     |      ^
[INFO] [stdout]     |
[INFO] [stdout]     = note: functions with the "custom" ABI cannot have a return type
[INFO] [stdout] help: remove the return type
[INFO] [stdout]    --> src/interrupts.rs:260:6
[INFO] [stdout]     |
[INFO] [stdout] 260 | ) -> ! {
[INFO] [stdout]     |      ^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `align_up`
[INFO] [stdout]  --> src/allocator/fixed_size_block.rs:1:13
[INFO] [stdout]   |
[INFO] [stdout] 1 | use super::{align_up, Locked};
[INFO] [stdout]   |             ^^^^^^^^
[INFO] [stdout]   |
[INFO] [stdout]   = note: `#[warn(unused_imports)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `crate::pc_speaker`
[INFO] [stdout]  --> src/vga_buffer.rs:1:5
[INFO] [stdout]   |
[INFO] [stdout] 1 | use crate::pc_speaker;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `crate::text_editor::express_editor::EDITOR_DATA`
[INFO] [stdout]  --> src/vga_buffer.rs:6:5
[INFO] [stdout]   |
[INFO] [stdout] 6 | use crate::text_editor::express_editor::EDITOR_DATA;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `String` and `ToString`
[INFO] [stdout]    --> src/shell/mod.rs:229:25
[INFO] [stdout]     |
[INFO] [stdout] 229 |     use alloc::string::{String, ToString};
[INFO] [stdout]     |                         ^^^^^^  ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `crude_storage`
[INFO] [stdout]    --> src/shell/mod.rs:232:17
[INFO] [stdout]     |
[INFO] [stdout] 232 |     use crate::{crude_storage, println, rtc, vga_buffer};
[INFO] [stdout]     |                 ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `println`
[INFO] [stdout]  --> src/intereperter/run.rs:9:13
[INFO] [stdout]   |
[INFO] [stdout] 9 | use crate::{println};
[INFO] [stdout]   |             ^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `self` and `shell`
[INFO] [stdout]  --> src/crude_storage/crude_storage.rs:4:32
[INFO] [stdout]   |
[INFO] [stdout] 4 | use crate::{intereperter::run, shell, text_editor::{self, express_editor::EDITOR_DATA}};
[INFO] [stdout]   |                                ^^^^^                ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `super::*`
[INFO] [stdout]    --> src/lib.rs:127:9
[INFO] [stdout]     |
[INFO] [stdout] 127 |     use super::*;
[INFO] [stdout]     |         ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error: unwinding panics are not supported without std
[INFO] [stdout]   |
[INFO] [stdout]   = help: using nightly cargo, use -Zbuild-std with panic="abort" to avoid unwinding
[INFO] [stdout]   = note: since the core library is usually precompiled with panic="unwind", rebuilding your crate with panic="abort" may not be enough to fix the problem
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning[E0133]: call to unsafe function `core::ptr::mut_ptr::<impl *mut T>::write` is unsafe and requires unsafe block
[INFO] [stdout]   --> src/allocator/fixed_size_block.rs:78:17
[INFO] [stdout]    |
[INFO] [stdout] 78 |                 new_node_ptr.write(new_node);
[INFO] [stdout]    |                 ^^^^^^^^^^^^^^^^^^^^^^^^^^^^ call to unsafe function
[INFO] [stdout]    |
[INFO] [stdout]    = note: for more information, see <https://doc.rust-lang.org/nightly/edition-guide/rust-2024/unsafe-op-in-unsafe-fn.html>
[INFO] [stdout]    = note: consult the function's documentation for information on how to avoid undefined behavior
[INFO] [stdout] note: an unsafe function restricts its caller, but its body is safe by default
[INFO] [stdout]   --> src/allocator/fixed_size_block.rs:66:5
[INFO] [stdout]    |
[INFO] [stdout] 66 |     unsafe fn dealloc(&self, ptr: *mut u8, layout: Layout) {
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]    = note: `#[warn(unsafe_op_in_unsafe_fn)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning[E0133]: dereference of raw pointer is unsafe and requires unsafe block
[INFO] [stdout]   --> src/allocator/fixed_size_block.rs:79:57
[INFO] [stdout]    |
[INFO] [stdout] 79 |                 allocator.list_heads[index] = Some(&mut *new_node_ptr);
[INFO] [stdout]    |                                                         ^^^^^^^^^^^^^ dereference of raw pointer
[INFO] [stdout]    |
[INFO] [stdout]    = note: for more information, see <https://doc.rust-lang.org/nightly/edition-guide/rust-2024/unsafe-op-in-unsafe-fn.html>
[INFO] [stdout]    = note: raw pointers may be null, dangling or unaligned; they can violate aliasing rules and cause data races: all of these are undefined behavior
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning[E0133]: call to unsafe function `linked_list_allocator::Heap::deallocate` is unsafe and requires unsafe block
[INFO] [stdout]   --> src/allocator/fixed_size_block.rs:83:17
[INFO] [stdout]    |
[INFO] [stdout] 83 |                 allocator.fallback_allocator.deallocate(ptr, layout);
[INFO] [stdout]    |                 ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ call to unsafe function
[INFO] [stdout]    |
[INFO] [stdout]    = note: for more information, see <https://doc.rust-lang.org/nightly/edition-guide/rust-2024/unsafe-op-in-unsafe-fn.html>
[INFO] [stdout]    = note: consult the function's documentation for information on how to avoid undefined behavior
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning[E0133]: call to unsafe function `core::alloc::GlobalAlloc::alloc` is unsafe and requires unsafe block
[INFO] [stdout]   --> src/allocator.rs:64:19
[INFO] [stdout]    |
[INFO] [stdout] 64 |         let ptr = self.0.alloc(layout);
[INFO] [stdout]    |                   ^^^^^^^^^^^^^^^^^^^^ call to unsafe function
[INFO] [stdout]    |
[INFO] [stdout]    = note: for more information, see <https://doc.rust-lang.org/nightly/edition-guide/rust-2024/unsafe-op-in-unsafe-fn.html>
[INFO] [stdout]    = note: consult the function's documentation for information on how to avoid undefined behavior
[INFO] [stdout] note: an unsafe function restricts its caller, but its body is safe by default
[INFO] [stdout]   --> src/allocator.rs:63:5
[INFO] [stdout]    |
[INFO] [stdout] 63 |     unsafe fn alloc(&self, layout: Layout) -> *mut u8 {
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning[E0133]: call to unsafe function `core::alloc::GlobalAlloc::dealloc` is unsafe and requires unsafe block
[INFO] [stdout]   --> src/allocator.rs:72:9
[INFO] [stdout]    |
[INFO] [stdout] 72 |         self.0.dealloc(ptr, layout);
[INFO] [stdout]    |         ^^^^^^^^^^^^^^^^^^^^^^^^^^^ call to unsafe function
[INFO] [stdout]    |
[INFO] [stdout]    = note: for more information, see <https://doc.rust-lang.org/nightly/edition-guide/rust-2024/unsafe-op-in-unsafe-fn.html>
[INFO] [stdout]    = note: consult the function's documentation for information on how to avoid undefined behavior
[INFO] [stdout] note: an unsafe function restricts its caller, but its body is safe by default
[INFO] [stdout]   --> src/allocator.rs:71:5
[INFO] [stdout]    |
[INFO] [stdout] 71 |     unsafe fn dealloc(&self, ptr: *mut u8, layout: Layout) {
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning[E0133]: call to unsafe function `interrupts::inb` is unsafe and requires unsafe block
[INFO] [stdout]    --> src/interrupts.rs:148:21
[INFO] [stdout]     |
[INFO] [stdout] 148 |         let mask1 = inb(PIC1_DATA);
[INFO] [stdout]     |                     ^^^^^^^^^^^^^^ call to unsafe function
[INFO] [stdout]     |
[INFO] [stdout]     = note: for more information, see <https://doc.rust-lang.org/nightly/edition-guide/rust-2024/unsafe-op-in-unsafe-fn.html>
[INFO] [stdout]     = note: consult the function's documentation for information on how to avoid undefined behavior
[INFO] [stdout] note: an unsafe function restricts its caller, but its body is safe by default
[INFO] [stdout]    --> src/interrupts.rs:146:5
[INFO] [stdout]     |
[INFO] [stdout] 146 |     pub unsafe fn initialize(&mut self) {
[INFO] [stdout]     |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning[E0133]: call to unsafe function `interrupts::inb` is unsafe and requires unsafe block
[INFO] [stdout]    --> src/interrupts.rs:149:21
[INFO] [stdout]     |
[INFO] [stdout] 149 |         let mask2 = inb(PIC2_DATA);
[INFO] [stdout]     |                     ^^^^^^^^^^^^^^ call to unsafe function
[INFO] [stdout]     |
[INFO] [stdout]     = note: for more information, see <https://doc.rust-lang.org/nightly/edition-guide/rust-2024/unsafe-op-in-unsafe-fn.html>
[INFO] [stdout]     = note: consult the function's documentation for information on how to avoid undefined behavior
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning[E0133]: call to unsafe function `interrupts::outb` is unsafe and requires unsafe block
[INFO] [stdout]    --> src/interrupts.rs:152:9
[INFO] [stdout]     |
[INFO] [stdout] 152 |         outb(PIC1_COMMAND, ICW1_INIT | ICW1_ICW4);
[INFO] [stdout]     |         ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ call to unsafe function
[INFO] [stdout]     |
[INFO] [stdout]     = note: for more information, see <https://doc.rust-lang.org/nightly/edition-guide/rust-2024/unsafe-op-in-unsafe-fn.html>
[INFO] [stdout]     = note: consult the function's documentation for information on how to avoid undefined behavior
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning[E0133]: call to unsafe function `interrupts::outb` is unsafe and requires unsafe block
[INFO] [stdout]    --> src/interrupts.rs:153:9
[INFO] [stdout]     |
[INFO] [stdout] 153 |         outb(PIC2_COMMAND, ICW1_INIT | ICW1_ICW4);
[INFO] [stdout]     |         ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ call to unsafe function
[INFO] [stdout]     |
[INFO] [stdout]     = note: for more information, see <https://doc.rust-lang.org/nightly/edition-guide/rust-2024/unsafe-op-in-unsafe-fn.html>
[INFO] [stdout]     = note: consult the function's documentation for information on how to avoid undefined behavior
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning[E0133]: call to unsafe function `interrupts::outb` is unsafe and requires unsafe block
[INFO] [stdout]    --> src/interrupts.rs:156:9
[INFO] [stdout]     |
[INFO] [stdout] 156 |         outb(PIC1_DATA, self.pics[0].offset);
[INFO] [stdout]     |         ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ call to unsafe function
[INFO] [stdout]     |
[INFO] [stdout]     = note: for more information, see <https://doc.rust-lang.org/nightly/edition-guide/rust-2024/unsafe-op-in-unsafe-fn.html>
[INFO] [stdout]     = note: consult the function's documentation for information on how to avoid undefined behavior
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning[E0133]: call to unsafe function `interrupts::outb` is unsafe and requires unsafe block
[INFO] [stdout]    --> src/interrupts.rs:157:9
[INFO] [stdout]     |
[INFO] [stdout] 157 |         outb(PIC2_DATA, self.pics[1].offset);
[INFO] [stdout]     |         ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ call to unsafe function
[INFO] [stdout]     |
[INFO] [stdout]     = note: for more information, see <https://doc.rust-lang.org/nightly/edition-guide/rust-2024/unsafe-op-in-unsafe-fn.html>
[INFO] [stdout]     = note: consult the function's documentation for information on how to avoid undefined behavior
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning[E0133]: call to unsafe function `interrupts::outb` is unsafe and requires unsafe block
[INFO] [stdout]    --> src/interrupts.rs:160:9
[INFO] [stdout]     |
[INFO] [stdout] 160 |         outb(PIC1_DATA, 4); // PIC2 at IRQ2
[INFO] [stdout]     |         ^^^^^^^^^^^^^^^^^^ call to unsafe function
[INFO] [stdout]     |
[INFO] [stdout]     = note: for more information, see <https://doc.rust-lang.org/nightly/edition-guide/rust-2024/unsafe-op-in-unsafe-fn.html>
[INFO] [stdout]     = note: consult the function's documentation for information on how to avoid undefined behavior
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning[E0133]: call to unsafe function `interrupts::outb` is unsafe and requires unsafe block
[INFO] [stdout]    --> src/interrupts.rs:161:9
[INFO] [stdout]     |
[INFO] [stdout] 161 |         outb(PIC2_DATA, 2); // Cascade identity
[INFO] [stdout]     |         ^^^^^^^^^^^^^^^^^^ call to unsafe function
[INFO] [stdout]     |
[INFO] [stdout]     = note: for more information, see <https://doc.rust-lang.org/nightly/edition-guide/rust-2024/unsafe-op-in-unsafe-fn.html>
[INFO] [stdout]     = note: consult the function's documentation for information on how to avoid undefined behavior
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning[E0133]: call to unsafe function `interrupts::outb` is unsafe and requires unsafe block
[INFO] [stdout]    --> src/interrupts.rs:164:9
[INFO] [stdout]     |
[INFO] [stdout] 164 |         outb(PIC1_DATA, ICW4_8086);
[INFO] [stdout]     |         ^^^^^^^^^^^^^^^^^^^^^^^^^^ call to unsafe function
[INFO] [stdout]     |
[INFO] [stdout]     = note: for more information, see <https://doc.rust-lang.org/nightly/edition-guide/rust-2024/unsafe-op-in-unsafe-fn.html>
[INFO] [stdout]     = note: consult the function's documentation for information on how to avoid undefined behavior
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning[E0133]: call to unsafe function `interrupts::outb` is unsafe and requires unsafe block
[INFO] [stdout]    --> src/interrupts.rs:165:9
[INFO] [stdout]     |
[INFO] [stdout] 165 |         outb(PIC2_DATA, ICW4_8086);
[INFO] [stdout]     |         ^^^^^^^^^^^^^^^^^^^^^^^^^^ call to unsafe function
[INFO] [stdout]     |
[INFO] [stdout]     = note: for more information, see <https://doc.rust-lang.org/nightly/edition-guide/rust-2024/unsafe-op-in-unsafe-fn.html>
[INFO] [stdout]     = note: consult the function's documentation for information on how to avoid undefined behavior
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning[E0133]: call to unsafe function `interrupts::outb` is unsafe and requires unsafe block
[INFO] [stdout]    --> src/interrupts.rs:168:9
[INFO] [stdout]     |
[INFO] [stdout] 168 |         outb(PIC1_DATA, mask1);
[INFO] [stdout]     |         ^^^^^^^^^^^^^^^^^^^^^^ call to unsafe function
[INFO] [stdout]     |
[INFO] [stdout]     = note: for more information, see <https://doc.rust-lang.org/nightly/edition-guide/rust-2024/unsafe-op-in-unsafe-fn.html>
[INFO] [stdout]     = note: consult the function's documentation for information on how to avoid undefined behavior
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning[E0133]: call to unsafe function `interrupts::outb` is unsafe and requires unsafe block
[INFO] [stdout]    --> src/interrupts.rs:169:9
[INFO] [stdout]     |
[INFO] [stdout] 169 |         outb(PIC2_DATA, mask2);
[INFO] [stdout]     |         ^^^^^^^^^^^^^^^^^^^^^^ call to unsafe function
[INFO] [stdout]     |
[INFO] [stdout]     = note: for more information, see <https://doc.rust-lang.org/nightly/edition-guide/rust-2024/unsafe-op-in-unsafe-fn.html>
[INFO] [stdout]     = note: consult the function's documentation for information on how to avoid undefined behavior
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning[E0133]: call to unsafe function `interrupts::outb` is unsafe and requires unsafe block
[INFO] [stdout]    --> src/interrupts.rs:174:13
[INFO] [stdout]     |
[INFO] [stdout] 174 |             outb(PIC2_COMMAND, 0x20);
[INFO] [stdout]     |             ^^^^^^^^^^^^^^^^^^^^^^^^ call to unsafe function
[INFO] [stdout]     |
[INFO] [stdout]     = note: for more information, see <https://doc.rust-lang.org/nightly/edition-guide/rust-2024/unsafe-op-in-unsafe-fn.html>
[INFO] [stdout]     = note: consult the function's documentation for information on how to avoid undefined behavior
[INFO] [stdout] note: an unsafe function restricts its caller, but its body is safe by default
[INFO] [stdout]    --> src/interrupts.rs:172:5
[INFO] [stdout]     |
[INFO] [stdout] 172 |     pub unsafe fn notify_end_of_interrupt(&mut self, interrupt_id: u8) {
[INFO] [stdout]     |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning[E0133]: call to unsafe function `interrupts::outb` is unsafe and requires unsafe block
[INFO] [stdout]    --> src/interrupts.rs:176:9
[INFO] [stdout]     |
[INFO] [stdout] 176 |         outb(PIC1_COMMAND, 0x20);
[INFO] [stdout]     |         ^^^^^^^^^^^^^^^^^^^^^^^^ call to unsafe function
[INFO] [stdout]     |
[INFO] [stdout]     = note: for more information, see <https://doc.rust-lang.org/nightly/edition-guide/rust-2024/unsafe-op-in-unsafe-fn.html>
[INFO] [stdout]     = note: consult the function's documentation for information on how to avoid undefined behavior
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning[E0133]: use of inline assembly is unsafe and requires unsafe block
[INFO] [stdout]    --> src/interrupts.rs:185:5
[INFO] [stdout]     |
[INFO] [stdout] 185 | /     core::arch::asm!(
[INFO] [stdout] 186 | |         "out dx, al",
[INFO] [stdout] 187 | |         in("dx") port,
[INFO] [stdout] 188 | |         in("al") value,
[INFO] [stdout] 189 | |         options(nomem, nostack, preserves_flags)
[INFO] [stdout] 190 | |     );
[INFO] [stdout]     | |_____^ use of inline assembly
[INFO] [stdout]     |
[INFO] [stdout]     = note: for more information, see <https://doc.rust-lang.org/nightly/edition-guide/rust-2024/unsafe-op-in-unsafe-fn.html>
[INFO] [stdout]     = note: inline assembly is entirely unchecked and can cause undefined behavior
[INFO] [stdout] note: an unsafe function restricts its caller, but its body is safe by default
[INFO] [stdout]    --> src/interrupts.rs:184:1
[INFO] [stdout]     |
[INFO] [stdout] 184 | unsafe fn outb(port: u16, value: u8) {
[INFO] [stdout]     | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning[E0133]: use of inline assembly is unsafe and requires unsafe block
[INFO] [stdout]    --> src/interrupts.rs:195:5
[INFO] [stdout]     |
[INFO] [stdout] 195 | /     core::arch::asm!(
[INFO] [stdout] 196 | |         "in al, dx",
[INFO] [stdout] 197 | |         out("al") value,
[INFO] [stdout] 198 | |         in("dx") port,
[INFO] [stdout] 199 | |         options(nomem, nostack, preserves_flags)
[INFO] [stdout] 200 | |     );
[INFO] [stdout]     | |_____^ use of inline assembly
[INFO] [stdout]     |
[INFO] [stdout]     = note: for more information, see <https://doc.rust-lang.org/nightly/edition-guide/rust-2024/unsafe-op-in-unsafe-fn.html>
[INFO] [stdout]     = note: inline assembly is entirely unchecked and can cause undefined behavior
[INFO] [stdout] note: an unsafe function restricts its caller, but its body is safe by default
[INFO] [stdout]    --> src/interrupts.rs:193:1
[INFO] [stdout]     |
[INFO] [stdout] 193 | unsafe fn inb(port: u16) -> u8 {
[INFO] [stdout]     | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning[E0133]: use of inline assembly is unsafe and requires unsafe block
[INFO] [stdout]    --> src/interrupts.rs:207:5
[INFO] [stdout]     |
[INFO] [stdout] 207 | /     core::arch::asm!(
[INFO] [stdout] 208 | |         "mov {}, cr2",
[INFO] [stdout] 209 | |         out(reg) value,
[INFO] [stdout] 210 | |         options(nomem, nostack, preserves_flags)
[INFO] [stdout] 211 | |     );
[INFO] [stdout]     | |_____^ use of inline assembly
[INFO] [stdout]     |
[INFO] [stdout]     = note: for more information, see <https://doc.rust-lang.org/nightly/edition-guide/rust-2024/unsafe-op-in-unsafe-fn.html>
[INFO] [stdout]     = note: inline assembly is entirely unchecked and can cause undefined behavior
[INFO] [stdout] note: an unsafe function restricts its caller, but its body is safe by default
[INFO] [stdout]    --> src/interrupts.rs:205:1
[INFO] [stdout]     |
[INFO] [stdout] 205 | unsafe fn read_cr2() -> u64 {
[INFO] [stdout]     | ^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `current_row`
[INFO] [stdout]    --> src/shell/mod.rs:125:14
[INFO] [stdout]     |
[INFO] [stdout] 125 |         let (current_row, current_col) = vga_buffer::get_cursor_position();
[INFO] [stdout]     |              ^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_current_row`
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(unused_variables)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `current_col`
[INFO] [stdout]    --> src/shell/mod.rs:125:27
[INFO] [stdout]     |
[INFO] [stdout] 125 |         let (current_row, current_col) = vga_buffer::get_cursor_position();
[INFO] [stdout]     |                           ^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_current_col`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `result`
[INFO] [stdout]   --> src/intereperter/run.rs:76:13
[INFO] [stdout]    |
[INFO] [stdout] 76 |         let result = parser.parse();
[INFO] [stdout]    |             ^^^^^^ help: if this is intentional, prefix it with an underscore: `_result`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable `content` is assigned to, but never used
[INFO] [stdout]   --> src/crude_storage/crude_storage.rs:28:13
[INFO] [stdout]    |
[INFO] [stdout] 28 |     let mut content: String = "null".to_string();
[INFO] [stdout]    |             ^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: consider using `_content` instead
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: value assigned to `content` is never read
[INFO] [stdout]   --> src/crude_storage/crude_storage.rs:32:9
[INFO] [stdout]    |
[INFO] [stdout] 32 |         content = entry.content.clone();
[INFO] [stdout]    |         ^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = help: maybe it is overwritten before being read?
[INFO] [stdout]    = note: `#[warn(unused_assignments)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] For more information about this error, try `rustc --explain E0133`.
[INFO] [stdout] 
[INFO] [stderr] error: could not compile `eclipse_os` (lib) due to 1 previous error; 34 warnings emitted
[INFO] [stderr] warning: build failed, waiting for other jobs to finish...
[INFO] [stdout] warning[E0133]: call to unsafe function `core::ptr::mut_ptr::<impl *mut T>::write` is unsafe and requires unsafe block
[INFO] [stdout]   --> src/allocator/fixed_size_block.rs:78:17
[INFO] [stdout]    |
[INFO] [stdout] 78 |                 new_node_ptr.write(new_node);
[INFO] [stdout]    |                 ^^^^^^^^^^^^^^^^^^^^^^^^^^^^ call to unsafe function
[INFO] [stdout]    |
[INFO] [stdout]    = note: for more information, see <https://doc.rust-lang.org/nightly/edition-guide/rust-2024/unsafe-op-in-unsafe-fn.html>
[INFO] [stdout]    = note: consult the function's documentation for information on how to avoid undefined behavior
[INFO] [stdout] note: an unsafe function restricts its caller, but its body is safe by default
[INFO] [stdout]   --> src/allocator/fixed_size_block.rs:66:5
[INFO] [stdout]    |
[INFO] [stdout] 66 |     unsafe fn dealloc(&self, ptr: *mut u8, layout: Layout) {
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]    = note: `#[warn(unsafe_op_in_unsafe_fn)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning[E0133]: dereference of raw pointer is unsafe and requires unsafe block
[INFO] [stdout]   --> src/allocator/fixed_size_block.rs:79:57
[INFO] [stdout]    |
[INFO] [stdout] 79 |                 allocator.list_heads[index] = Some(&mut *new_node_ptr);
[INFO] [stdout]    |                                                         ^^^^^^^^^^^^^ dereference of raw pointer
[INFO] [stdout]    |
[INFO] [stdout]    = note: for more information, see <https://doc.rust-lang.org/nightly/edition-guide/rust-2024/unsafe-op-in-unsafe-fn.html>
[INFO] [stdout]    = note: raw pointers may be null, dangling or unaligned; they can violate aliasing rules and cause data races: all of these are undefined behavior
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning[E0133]: call to unsafe function `linked_list_allocator::Heap::deallocate` is unsafe and requires unsafe block
[INFO] [stdout]   --> src/allocator/fixed_size_block.rs:83:17
[INFO] [stdout]    |
[INFO] [stdout] 83 |                 allocator.fallback_allocator.deallocate(ptr, layout);
[INFO] [stdout]    |                 ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ call to unsafe function
[INFO] [stdout]    |
[INFO] [stdout]    = note: for more information, see <https://doc.rust-lang.org/nightly/edition-guide/rust-2024/unsafe-op-in-unsafe-fn.html>
[INFO] [stdout]    = note: consult the function's documentation for information on how to avoid undefined behavior
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning[E0133]: call to unsafe function `core::alloc::GlobalAlloc::alloc` is unsafe and requires unsafe block
[INFO] [stdout]   --> src/allocator.rs:64:19
[INFO] [stdout]    |
[INFO] [stdout] 64 |         let ptr = self.0.alloc(layout);
[INFO] [stdout]    |                   ^^^^^^^^^^^^^^^^^^^^ call to unsafe function
[INFO] [stdout]    |
[INFO] [stdout]    = note: for more information, see <https://doc.rust-lang.org/nightly/edition-guide/rust-2024/unsafe-op-in-unsafe-fn.html>
[INFO] [stdout]    = note: consult the function's documentation for information on how to avoid undefined behavior
[INFO] [stdout] note: an unsafe function restricts its caller, but its body is safe by default
[INFO] [stdout]   --> src/allocator.rs:63:5
[INFO] [stdout]    |
[INFO] [stdout] 63 |     unsafe fn alloc(&self, layout: Layout) -> *mut u8 {
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning[E0133]: call to unsafe function `core::alloc::GlobalAlloc::dealloc` is unsafe and requires unsafe block
[INFO] [stdout]   --> src/allocator.rs:72:9
[INFO] [stdout]    |
[INFO] [stdout] 72 |         self.0.dealloc(ptr, layout);
[INFO] [stdout]    |         ^^^^^^^^^^^^^^^^^^^^^^^^^^^ call to unsafe function
[INFO] [stdout]    |
[INFO] [stdout]    = note: for more information, see <https://doc.rust-lang.org/nightly/edition-guide/rust-2024/unsafe-op-in-unsafe-fn.html>
[INFO] [stdout]    = note: consult the function's documentation for information on how to avoid undefined behavior
[INFO] [stdout] note: an unsafe function restricts its caller, but its body is safe by default
[INFO] [stdout]   --> src/allocator.rs:71:5
[INFO] [stdout]    |
[INFO] [stdout] 71 |     unsafe fn dealloc(&self, ptr: *mut u8, layout: Layout) {
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning[E0133]: call to unsafe function `interrupts::inb` is unsafe and requires unsafe block
[INFO] [stdout]    --> src/interrupts.rs:148:21
[INFO] [stdout]     |
[INFO] [stdout] 148 |         let mask1 = inb(PIC1_DATA);
[INFO] [stdout]     |                     ^^^^^^^^^^^^^^ call to unsafe function
[INFO] [stdout]     |
[INFO] [stdout]     = note: for more information, see <https://doc.rust-lang.org/nightly/edition-guide/rust-2024/unsafe-op-in-unsafe-fn.html>
[INFO] [stdout]     = note: consult the function's documentation for information on how to avoid undefined behavior
[INFO] [stdout] note: an unsafe function restricts its caller, but its body is safe by default
[INFO] [stdout]    --> src/interrupts.rs:146:5
[INFO] [stdout]     |
[INFO] [stdout] 146 |     pub unsafe fn initialize(&mut self) {
[INFO] [stdout]     |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning[E0133]: call to unsafe function `interrupts::inb` is unsafe and requires unsafe block
[INFO] [stdout]    --> src/interrupts.rs:149:21
[INFO] [stdout]     |
[INFO] [stdout] 149 |         let mask2 = inb(PIC2_DATA);
[INFO] [stdout]     |                     ^^^^^^^^^^^^^^ call to unsafe function
[INFO] [stdout]     |
[INFO] [stdout]     = note: for more information, see <https://doc.rust-lang.org/nightly/edition-guide/rust-2024/unsafe-op-in-unsafe-fn.html>
[INFO] [stdout]     = note: consult the function's documentation for information on how to avoid undefined behavior
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning[E0133]: call to unsafe function `interrupts::outb` is unsafe and requires unsafe block
[INFO] [stdout]    --> src/interrupts.rs:152:9
[INFO] [stdout]     |
[INFO] [stdout] 152 |         outb(PIC1_COMMAND, ICW1_INIT | ICW1_ICW4);
[INFO] [stdout]     |         ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ call to unsafe function
[INFO] [stdout]     |
[INFO] [stdout]     = note: for more information, see <https://doc.rust-lang.org/nightly/edition-guide/rust-2024/unsafe-op-in-unsafe-fn.html>
[INFO] [stdout]     = note: consult the function's documentation for information on how to avoid undefined behavior
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning[E0133]: call to unsafe function `interrupts::outb` is unsafe and requires unsafe block
[INFO] [stdout]    --> src/interrupts.rs:153:9
[INFO] [stdout]     |
[INFO] [stdout] 153 |         outb(PIC2_COMMAND, ICW1_INIT | ICW1_ICW4);
[INFO] [stdout]     |         ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ call to unsafe function
[INFO] [stdout]     |
[INFO] [stdout]     = note: for more information, see <https://doc.rust-lang.org/nightly/edition-guide/rust-2024/unsafe-op-in-unsafe-fn.html>
[INFO] [stdout]     = note: consult the function's documentation for information on how to avoid undefined behavior
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning[E0133]: call to unsafe function `interrupts::outb` is unsafe and requires unsafe block
[INFO] [stdout]    --> src/interrupts.rs:156:9
[INFO] [stdout]     |
[INFO] [stdout] 156 |         outb(PIC1_DATA, self.pics[0].offset);
[INFO] [stdout]     |         ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ call to unsafe function
[INFO] [stdout]     |
[INFO] [stdout]     = note: for more information, see <https://doc.rust-lang.org/nightly/edition-guide/rust-2024/unsafe-op-in-unsafe-fn.html>
[INFO] [stdout]     = note: consult the function's documentation for information on how to avoid undefined behavior
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning[E0133]: call to unsafe function `interrupts::outb` is unsafe and requires unsafe block
[INFO] [stdout]    --> src/interrupts.rs:157:9
[INFO] [stdout]     |
[INFO] [stdout] 157 |         outb(PIC2_DATA, self.pics[1].offset);
[INFO] [stdout]     |         ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ call to unsafe function
[INFO] [stdout]     |
[INFO] [stdout]     = note: for more information, see <https://doc.rust-lang.org/nightly/edition-guide/rust-2024/unsafe-op-in-unsafe-fn.html>
[INFO] [stdout]     = note: consult the function's documentation for information on how to avoid undefined behavior
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning[E0133]: call to unsafe function `interrupts::outb` is unsafe and requires unsafe block
[INFO] [stdout]    --> src/interrupts.rs:160:9
[INFO] [stdout]     |
[INFO] [stdout] 160 |         outb(PIC1_DATA, 4); // PIC2 at IRQ2
[INFO] [stdout]     |         ^^^^^^^^^^^^^^^^^^ call to unsafe function
[INFO] [stdout]     |
[INFO] [stdout]     = note: for more information, see <https://doc.rust-lang.org/nightly/edition-guide/rust-2024/unsafe-op-in-unsafe-fn.html>
[INFO] [stdout]     = note: consult the function's documentation for information on how to avoid undefined behavior
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning[E0133]: call to unsafe function `interrupts::outb` is unsafe and requires unsafe block
[INFO] [stdout]    --> src/interrupts.rs:161:9
[INFO] [stdout]     |
[INFO] [stdout] 161 |         outb(PIC2_DATA, 2); // Cascade identity
[INFO] [stdout]     |         ^^^^^^^^^^^^^^^^^^ call to unsafe function
[INFO] [stdout]     |
[INFO] [stdout]     = note: for more information, see <https://doc.rust-lang.org/nightly/edition-guide/rust-2024/unsafe-op-in-unsafe-fn.html>
[INFO] [stdout]     = note: consult the function's documentation for information on how to avoid undefined behavior
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning[E0133]: call to unsafe function `interrupts::outb` is unsafe and requires unsafe block
[INFO] [stdout]    --> src/interrupts.rs:164:9
[INFO] [stdout]     |
[INFO] [stdout] 164 |         outb(PIC1_DATA, ICW4_8086);
[INFO] [stdout]     |         ^^^^^^^^^^^^^^^^^^^^^^^^^^ call to unsafe function
[INFO] [stdout]     |
[INFO] [stdout]     = note: for more information, see <https://doc.rust-lang.org/nightly/edition-guide/rust-2024/unsafe-op-in-unsafe-fn.html>
[INFO] [stdout]     = note: consult the function's documentation for information on how to avoid undefined behavior
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning[E0133]: call to unsafe function `interrupts::outb` is unsafe and requires unsafe block
[INFO] [stdout]    --> src/interrupts.rs:165:9
[INFO] [stdout]     |
[INFO] [stdout] 165 |         outb(PIC2_DATA, ICW4_8086);
[INFO] [stdout]     |         ^^^^^^^^^^^^^^^^^^^^^^^^^^ call to unsafe function
[INFO] [stdout]     |
[INFO] [stdout]     = note: for more information, see <https://doc.rust-lang.org/nightly/edition-guide/rust-2024/unsafe-op-in-unsafe-fn.html>
[INFO] [stdout]     = note: consult the function's documentation for information on how to avoid undefined behavior
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning[E0133]: call to unsafe function `interrupts::outb` is unsafe and requires unsafe block
[INFO] [stdout]    --> src/interrupts.rs:168:9
[INFO] [stdout]     |
[INFO] [stdout] 168 |         outb(PIC1_DATA, mask1);
[INFO] [stdout]     |         ^^^^^^^^^^^^^^^^^^^^^^ call to unsafe function
[INFO] [stdout]     |
[INFO] [stdout]     = note: for more information, see <https://doc.rust-lang.org/nightly/edition-guide/rust-2024/unsafe-op-in-unsafe-fn.html>
[INFO] [stdout]     = note: consult the function's documentation for information on how to avoid undefined behavior
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning[E0133]: call to unsafe function `interrupts::outb` is unsafe and requires unsafe block
[INFO] [stdout]    --> src/interrupts.rs:169:9
[INFO] [stdout]     |
[INFO] [stdout] 169 |         outb(PIC2_DATA, mask2);
[INFO] [stdout]     |         ^^^^^^^^^^^^^^^^^^^^^^ call to unsafe function
[INFO] [stdout]     |
[INFO] [stdout]     = note: for more information, see <https://doc.rust-lang.org/nightly/edition-guide/rust-2024/unsafe-op-in-unsafe-fn.html>
[INFO] [stdout]     = note: consult the function's documentation for information on how to avoid undefined behavior
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning[E0133]: call to unsafe function `interrupts::outb` is unsafe and requires unsafe block
[INFO] [stdout]    --> src/interrupts.rs:174:13
[INFO] [stdout]     |
[INFO] [stdout] 174 |             outb(PIC2_COMMAND, 0x20);
[INFO] [stdout]     |             ^^^^^^^^^^^^^^^^^^^^^^^^ call to unsafe function
[INFO] [stdout]     |
[INFO] [stdout]     = note: for more information, see <https://doc.rust-lang.org/nightly/edition-guide/rust-2024/unsafe-op-in-unsafe-fn.html>
[INFO] [stdout]     = note: consult the function's documentation for information on how to avoid undefined behavior
[INFO] [stdout] note: an unsafe function restricts its caller, but its body is safe by default
[INFO] [stdout]    --> src/interrupts.rs:172:5
[INFO] [stdout]     |
[INFO] [stdout] 172 |     pub unsafe fn notify_end_of_interrupt(&mut self, interrupt_id: u8) {
[INFO] [stdout]     |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning[E0133]: call to unsafe function `interrupts::outb` is unsafe and requires unsafe block
[INFO] [stdout]    --> src/interrupts.rs:176:9
[INFO] [stdout]     |
[INFO] [stdout] 176 |         outb(PIC1_COMMAND, 0x20);
[INFO] [stdout]     |         ^^^^^^^^^^^^^^^^^^^^^^^^ call to unsafe function
[INFO] [stdout]     |
[INFO] [stdout]     = note: for more information, see <https://doc.rust-lang.org/nightly/edition-guide/rust-2024/unsafe-op-in-unsafe-fn.html>
[INFO] [stdout]     = note: consult the function's documentation for information on how to avoid undefined behavior
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning[E0133]: use of inline assembly is unsafe and requires unsafe block
[INFO] [stdout]    --> src/interrupts.rs:185:5
[INFO] [stdout]     |
[INFO] [stdout] 185 | /     core::arch::asm!(
[INFO] [stdout] 186 | |         "out dx, al",
[INFO] [stdout] 187 | |         in("dx") port,
[INFO] [stdout] 188 | |         in("al") value,
[INFO] [stdout] 189 | |         options(nomem, nostack, preserves_flags)
[INFO] [stdout] 190 | |     );
[INFO] [stdout]     | |_____^ use of inline assembly
[INFO] [stdout]     |
[INFO] [stdout]     = note: for more information, see <https://doc.rust-lang.org/nightly/edition-guide/rust-2024/unsafe-op-in-unsafe-fn.html>
[INFO] [stdout]     = note: inline assembly is entirely unchecked and can cause undefined behavior
[INFO] [stdout] note: an unsafe function restricts its caller, but its body is safe by default
[INFO] [stdout]    --> src/interrupts.rs:184:1
[INFO] [stdout]     |
[INFO] [stdout] 184 | unsafe fn outb(port: u16, value: u8) {
[INFO] [stdout]     | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning[E0133]: use of inline assembly is unsafe and requires unsafe block
[INFO] [stdout]    --> src/interrupts.rs:195:5
[INFO] [stdout]     |
[INFO] [stdout] 195 | /     core::arch::asm!(
[INFO] [stdout] 196 | |         "in al, dx",
[INFO] [stdout] 197 | |         out("al") value,
[INFO] [stdout] 198 | |         in("dx") port,
[INFO] [stdout] 199 | |         options(nomem, nostack, preserves_flags)
[INFO] [stdout] 200 | |     );
[INFO] [stdout]     | |_____^ use of inline assembly
[INFO] [stdout]     |
[INFO] [stdout]     = note: for more information, see <https://doc.rust-lang.org/nightly/edition-guide/rust-2024/unsafe-op-in-unsafe-fn.html>
[INFO] [stdout]     = note: inline assembly is entirely unchecked and can cause undefined behavior
[INFO] [stdout] note: an unsafe function restricts its caller, but its body is safe by default
[INFO] [stdout]    --> src/interrupts.rs:193:1
[INFO] [stdout]     |
[INFO] [stdout] 193 | unsafe fn inb(port: u16) -> u8 {
[INFO] [stdout]     | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning[E0133]: use of inline assembly is unsafe and requires unsafe block
[INFO] [stdout]    --> src/interrupts.rs:207:5
[INFO] [stdout]     |
[INFO] [stdout] 207 | /     core::arch::asm!(
[INFO] [stdout] 208 | |         "mov {}, cr2",
[INFO] [stdout] 209 | |         out(reg) value,
[INFO] [stdout] 210 | |         options(nomem, nostack, preserves_flags)
[INFO] [stdout] 211 | |     );
[INFO] [stdout]     | |_____^ use of inline assembly
[INFO] [stdout]     |
[INFO] [stdout]     = note: for more information, see <https://doc.rust-lang.org/nightly/edition-guide/rust-2024/unsafe-op-in-unsafe-fn.html>
[INFO] [stdout]     = note: inline assembly is entirely unchecked and can cause undefined behavior
[INFO] [stdout] note: an unsafe function restricts its caller, but its body is safe by default
[INFO] [stdout]    --> src/interrupts.rs:205:1
[INFO] [stdout]     |
[INFO] [stdout] 205 | unsafe fn read_cr2() -> u64 {
[INFO] [stdout]     | ^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `current_row`
[INFO] [stdout]    --> src/shell/mod.rs:125:14
[INFO] [stdout]     |
[INFO] [stdout] 125 |         let (current_row, current_col) = vga_buffer::get_cursor_position();
[INFO] [stdout]     |              ^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_current_row`
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(unused_variables)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `current_col`
[INFO] [stdout]    --> src/shell/mod.rs:125:27
[INFO] [stdout]     |
[INFO] [stdout] 125 |         let (current_row, current_col) = vga_buffer::get_cursor_position();
[INFO] [stdout]     |                           ^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_current_col`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `result`
[INFO] [stdout]   --> src/intereperter/run.rs:76:13
[INFO] [stdout]    |
[INFO] [stdout] 76 |         let result = parser.parse();
[INFO] [stdout]    |             ^^^^^^ help: if this is intentional, prefix it with an underscore: `_result`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable `content` is assigned to, but never used
[INFO] [stdout]   --> src/crude_storage/crude_storage.rs:28:13
[INFO] [stdout]    |
[INFO] [stdout] 28 |     let mut content: String = "null".to_string();
[INFO] [stdout]    |             ^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: consider using `_content` instead
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: value assigned to `content` is never read
[INFO] [stdout]   --> src/crude_storage/crude_storage.rs:32:9
[INFO] [stdout]    |
[INFO] [stdout] 32 |         content = entry.content.clone();
[INFO] [stdout]    |         ^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = help: maybe it is overwritten before being read?
[INFO] [stdout]    = note: `#[warn(unused_assignments)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] For more information about this error, try `rustc --explain E0133`.
[INFO] [stdout] 
[INFO] [stderr] error: could not compile `eclipse_os` (lib test) due to 2 previous errors; 35 warnings emitted
[INFO] running `Command { std: "docker" "inspect" "b241dc97f88e9ab05771c73031e71ac3410108b9f5e851c3a0e3bf0aa20db28f", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "b241dc97f88e9ab05771c73031e71ac3410108b9f5e851c3a0e3bf0aa20db28f", kill_on_drop: false }`
[INFO] [stdout] b241dc97f88e9ab05771c73031e71ac3410108b9f5e851c3a0e3bf0aa20db28f
