[INFO] cloning repository https://github.com/enathang/Risc-V-Emulator
[INFO] running `Command { std: "git" "-c" "credential.helper=" "-c" "credential.helper=/workspace/cargo-home/bin/git-credential-null" "clone" "--bare" "https://github.com/enathang/Risc-V-Emulator" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2Fenathang%2FRisc-V-Emulator", kill_on_drop: false }`
[INFO] [stderr] Cloning into bare repository '/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2Fenathang%2FRisc-V-Emulator'...
[INFO] running `Command { std: "git" "rev-parse" "HEAD", kill_on_drop: false }`
[INFO] [stdout] cee42650155107329d57e98f1156823e4463ad88
[INFO] testing enathang/Risc-V-Emulator against beta-2025-09-21 for beta-1.91-2
[INFO] running `Command { std: "git" "clone" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2Fenathang%2FRisc-V-Emulator" "/workspace/builds/worker-5-tc2/source", kill_on_drop: false }`
[INFO] [stderr] Cloning into '/workspace/builds/worker-5-tc2/source'...
[INFO] [stderr] done.
[INFO] started tweaking git repo https://github.com/enathang/Risc-V-Emulator
[INFO] finished tweaking git repo https://github.com/enathang/Risc-V-Emulator
[INFO] tweaked toml for git repo https://github.com/enathang/Risc-V-Emulator written to /workspace/builds/worker-5-tc2/source/Cargo.toml
[INFO] validating manifest of git repo https://github.com/enathang/Risc-V-Emulator on toolchain beta-2025-09-21
[INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+beta-2025-09-21" "metadata" "--manifest-path" "Cargo.toml" "--no-deps", kill_on_drop: false }`
[INFO] crate git repo https://github.com/enathang/Risc-V-Emulator 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" "+beta-2025-09-21" "fetch" "--manifest-path" "Cargo.toml", kill_on_drop: false }`
[INFO] [stderr]     Updating crates.io index
[INFO] [stderr]      Locking 1 package to latest compatible version
[INFO] [stderr]       Adding asm_riscv v0.1.0 (available: v0.2.0)
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-5-tc2/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-5-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:e90291280db7d1fac5b66fc6dad9f9662629e7365a55743daf9bdf73ebc4ea79" "/opt/rustwide/cargo-home/bin/cargo" "+beta-2025-09-21" "metadata" "--no-deps" "--format-version=1", kill_on_drop: false }`
[INFO] [stdout] ca4eccd63be396977acc204ba670ff2574dca450ea5c7443276bd21175aba290
[INFO] running `Command { std: "docker" "start" "-a" "ca4eccd63be396977acc204ba670ff2574dca450ea5c7443276bd21175aba290", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "inspect" "ca4eccd63be396977acc204ba670ff2574dca450ea5c7443276bd21175aba290", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "ca4eccd63be396977acc204ba670ff2574dca450ea5c7443276bd21175aba290", kill_on_drop: false }`
[INFO] [stdout] ca4eccd63be396977acc204ba670ff2574dca450ea5c7443276bd21175aba290
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-5-tc2/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-5-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=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:e90291280db7d1fac5b66fc6dad9f9662629e7365a55743daf9bdf73ebc4ea79" "/opt/rustwide/cargo-home/bin/cargo" "+beta-2025-09-21" "build" "--frozen" "--message-format=json", kill_on_drop: false }`
[INFO] [stdout] 6bf01dbda355cca14267f9afe1f594678b47e6de6f8bbc1161fb9b0a33686013
[INFO] running `Command { std: "docker" "start" "-a" "6bf01dbda355cca14267f9afe1f594678b47e6de6f8bbc1161fb9b0a33686013", kill_on_drop: false }`
[INFO] [stderr]    Compiling asm_riscv v0.1.0
[INFO] [stderr]    Compiling Risc-V-Emulator v0.1.0 (/opt/rustwide/workdir)
[INFO] [stdout] warning: unnecessary parentheses around `match` scrutinee expression
[INFO] [stdout]   --> src/emulator/bus.rs:20:15
[INFO] [stdout]    |
[INFO] [stdout] 20 |         match (addr) {
[INFO] [stdout]    |               ^    ^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(unused_parens)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] help: remove these parentheses
[INFO] [stdout]    |
[INFO] [stdout] 20 -         match (addr) {
[INFO] [stdout] 20 +         match addr {
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary parentheses around `match` scrutinee expression
[INFO] [stdout]   --> src/emulator/bus.rs:28:14
[INFO] [stdout]    |
[INFO] [stdout] 28 |         match(addr) {
[INFO] [stdout]    |              ^    ^
[INFO] [stdout]    |
[INFO] [stdout] help: remove these parentheses
[INFO] [stdout]    |
[INFO] [stdout] 28 -         match(addr) {
[INFO] [stdout] 28 +         match addr {
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary parentheses around `if` condition
[INFO] [stdout]   --> src/emulator/dram.rs:17:12
[INFO] [stdout]    |
[INFO] [stdout] 17 |         if (![8, 16, 32, 64].contains(&size)) {
[INFO] [stdout]    |            ^                                ^
[INFO] [stdout]    |
[INFO] [stdout] help: remove these parentheses
[INFO] [stdout]    |
[INFO] [stdout] 17 -         if (![8, 16, 32, 64].contains(&size)) {
[INFO] [stdout] 17 +         if ![8, 16, 32, 64].contains(&size) {
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary parentheses around `if` condition
[INFO] [stdout]   --> src/emulator/dram.rs:33:12
[INFO] [stdout]    |
[INFO] [stdout] 33 |         if (![8, 16, 32, 64].contains(&size)) {
[INFO] [stdout]    |            ^                                ^
[INFO] [stdout]    |
[INFO] [stdout] help: remove these parentheses
[INFO] [stdout]    |
[INFO] [stdout] 33 -         if (![8, 16, 32, 64].contains(&size)) {
[INFO] [stdout] 33 +         if ![8, 16, 32, 64].contains(&size) {
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary parentheses around `match` scrutinee expression
[INFO] [stdout]   --> src/emulator/errors.rs:53:14
[INFO] [stdout]    |
[INFO] [stdout] 53 |         match(self) {
[INFO] [stdout]    |              ^    ^
[INFO] [stdout]    |
[INFO] [stdout] help: remove these parentheses
[INFO] [stdout]    |
[INFO] [stdout] 53 -         match(self) {
[INFO] [stdout] 53 +         match self {
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary parentheses around `match` scrutinee expression
[INFO] [stdout]   --> src/emulator/errors.rs:72:14
[INFO] [stdout]    |
[INFO] [stdout] 72 |         match(self) {
[INFO] [stdout]    |              ^    ^
[INFO] [stdout]    |
[INFO] [stdout] help: remove these parentheses
[INFO] [stdout]    |
[INFO] [stdout] 72 -         match(self) {
[INFO] [stdout] 72 +         match self {
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: type `R_Instr` should have an upper camel case name
[INFO] [stdout]   --> src/emulator/instructions.rs:19:12
[INFO] [stdout]    |
[INFO] [stdout] 19 | pub struct R_Instr {
[INFO] [stdout]    |            ^^^^^^^ help: convert the identifier to upper camel case: `RInstr`
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(non_camel_case_types)]` (part of `#[warn(nonstandard_style)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: type `I_Instr` should have an upper camel case name
[INFO] [stdout]   --> src/emulator/instructions.rs:42:12
[INFO] [stdout]    |
[INFO] [stdout] 42 | pub struct I_Instr {
[INFO] [stdout]    |            ^^^^^^^ help: convert the identifier to upper camel case: `IInstr`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: type `S_Instr` should have an upper camel case name
[INFO] [stdout]   --> src/emulator/instructions.rs:63:12
[INFO] [stdout]    |
[INFO] [stdout] 63 | pub struct S_Instr {
[INFO] [stdout]    |            ^^^^^^^ help: convert the identifier to upper camel case: `SInstr`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: type `B_Instr` should have an upper camel case name
[INFO] [stdout]   --> src/emulator/instructions.rs:86:12
[INFO] [stdout]    |
[INFO] [stdout] 86 | pub struct B_Instr {
[INFO] [stdout]    |            ^^^^^^^ help: convert the identifier to upper camel case: `BInstr`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: type `U_Instr` should have an upper camel case name
[INFO] [stdout]    --> src/emulator/instructions.rs:115:12
[INFO] [stdout]     |
[INFO] [stdout] 115 | pub struct U_Instr {
[INFO] [stdout]     |            ^^^^^^^ help: convert the identifier to upper camel case: `UInstr`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: type `J_Instr` should have an upper camel case name
[INFO] [stdout]    --> src/emulator/instructions.rs:134:12
[INFO] [stdout]     |
[INFO] [stdout] 134 | pub struct J_Instr {
[INFO] [stdout]     |            ^^^^^^^ help: convert the identifier to upper camel case: `JInstr`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary parentheses around `match` scrutinee expression
[INFO] [stdout]   --> src/emulator/interrupt.rs:16:35
[INFO] [stdout]    |
[INFO] [stdout] 16 |         let interrupt_code = match(self) {
[INFO] [stdout]    |                                   ^    ^
[INFO] [stdout]    |
[INFO] [stdout] help: remove these parentheses
[INFO] [stdout]    |
[INFO] [stdout] 16 -         let interrupt_code = match(self) {
[INFO] [stdout] 16 +         let interrupt_code = match self {
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary parentheses around `match` scrutinee expression
[INFO] [stdout]   --> src/emulator/plic.rs:33:14
[INFO] [stdout]    |
[INFO] [stdout] 33 |         match(addr) {
[INFO] [stdout]    |              ^    ^
[INFO] [stdout]    |
[INFO] [stdout] help: remove these parentheses
[INFO] [stdout]    |
[INFO] [stdout] 33 -         match(addr) {
[INFO] [stdout] 33 +         match addr {
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary parentheses around `match` scrutinee expression
[INFO] [stdout]   --> src/emulator/plic.rs:46:14
[INFO] [stdout]    |
[INFO] [stdout] 46 |         match(addr) {
[INFO] [stdout]    |              ^    ^
[INFO] [stdout]    |
[INFO] [stdout] help: remove these parentheses
[INFO] [stdout]    |
[INFO] [stdout] 46 -         match(addr) {
[INFO] [stdout] 46 +         match addr {
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary parentheses around `match` scrutinee expression
[INFO] [stdout]   --> src/emulator/uart.rs:59:18
[INFO] [stdout]    |
[INFO] [stdout] 59 |             match(read_io) {
[INFO] [stdout]    |                  ^       ^
[INFO] [stdout]    |
[INFO] [stdout] help: remove these parentheses
[INFO] [stdout]    |
[INFO] [stdout] 59 -             match(read_io) {
[INFO] [stdout] 59 +             match read_io {
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary parentheses around `while` condition
[INFO] [stdout]   --> src/emulator/uart.rs:65:27
[INFO] [stdout]    |
[INFO] [stdout] 65 |                     while (array[UART_LSR_INDEX as usize] & UART_LSR_RHR_STATUS_FLAG == 1) {
[INFO] [stdout]    |                           ^                                                              ^
[INFO] [stdout]    |
[INFO] [stdout] help: remove these parentheses
[INFO] [stdout]    |
[INFO] [stdout] 65 -                     while (array[UART_LSR_INDEX as usize] & UART_LSR_RHR_STATUS_FLAG == 1) {
[INFO] [stdout] 65 +                     while array[UART_LSR_INDEX as usize] & UART_LSR_RHR_STATUS_FLAG == 1 {
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary parentheses around `match` scrutinee expression
[INFO] [stdout]   --> src/emulator/uart.rs:85:15
[INFO] [stdout]    |
[INFO] [stdout] 85 |         match (index) {
[INFO] [stdout]    |               ^     ^
[INFO] [stdout]    |
[INFO] [stdout] help: remove these parentheses
[INFO] [stdout]    |
[INFO] [stdout] 85 -         match (index) {
[INFO] [stdout] 85 +         match index {
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary parentheses around `match` scrutinee expression
[INFO] [stdout]    --> src/emulator/uart.rs:101:15
[INFO] [stdout]     |
[INFO] [stdout] 101 |         match (index) {
[INFO] [stdout]     |               ^     ^
[INFO] [stdout]     |
[INFO] [stdout] help: remove these parentheses
[INFO] [stdout]     |
[INFO] [stdout] 101 -         match (index) {
[INFO] [stdout] 101 +         match index {
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary parentheses around `while` condition
[INFO] [stdout]   --> src/emulator.rs:49:15
[INFO] [stdout]    |
[INFO] [stdout] 49 |         while (self.pc < self.bus.dram.dram.len() as u64) {
[INFO] [stdout]    |               ^                                         ^
[INFO] [stdout]    |
[INFO] [stdout] help: remove these parentheses
[INFO] [stdout]    |
[INFO] [stdout] 49 -         while (self.pc < self.bus.dram.dram.len() as u64) {
[INFO] [stdout] 49 +         while self.pc < self.bus.dram.dram.len() as u64 {
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary parentheses around method argument
[INFO] [stdout]   --> src/emulator.rs:77:35
[INFO] [stdout]    |
[INFO] [stdout] 77 |         let instr = self.bus.load((index as u64), 32);
[INFO] [stdout]    |                                   ^            ^
[INFO] [stdout]    |
[INFO] [stdout] help: remove these parentheses
[INFO] [stdout]    |
[INFO] [stdout] 77 -         let instr = self.bus.load((index as u64), 32);
[INFO] [stdout] 77 +         let instr = self.bus.load(index as u64, 32);
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary parentheses around `for` iterator expression
[INFO] [stdout]   --> src/emulator.rs:99:18
[INFO] [stdout]    |
[INFO] [stdout] 99 |         for i in (0..self.regs.len()) {
[INFO] [stdout]    |                  ^                  ^
[INFO] [stdout]    |
[INFO] [stdout] help: remove these parentheses
[INFO] [stdout]    |
[INFO] [stdout] 99 -         for i in (0..self.regs.len()) {
[INFO] [stdout] 99 +         for i in 0..self.regs.len() {
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary parentheses around `if` condition
[INFO] [stdout]    --> src/emulator.rs:110:12
[INFO] [stdout]     |
[INFO] [stdout] 110 |         if (delegate_to_s_mode) {
[INFO] [stdout]     |            ^                  ^
[INFO] [stdout]     |
[INFO] [stdout] help: remove these parentheses
[INFO] [stdout]     |
[INFO] [stdout] 110 -         if (delegate_to_s_mode) {
[INFO] [stdout] 110 +         if delegate_to_s_mode {
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary parentheses around `if` condition
[INFO] [stdout]    --> src/emulator.rs:113:16
[INFO] [stdout]     |
[INFO] [stdout] 113 |             if (tvec & 0b11 == 0) {
[INFO] [stdout]     |                ^                ^
[INFO] [stdout]     |
[INFO] [stdout] help: remove these parentheses
[INFO] [stdout]     |
[INFO] [stdout] 113 -             if (tvec & 0b11 == 0) {
[INFO] [stdout] 113 +             if tvec & 0b11 == 0 {
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary parentheses around `if` condition
[INFO] [stdout]    --> src/emulator.rs:132:16
[INFO] [stdout]     |
[INFO] [stdout] 132 |             if (tvec & 0b11 == 0) {
[INFO] [stdout]     |                ^                ^
[INFO] [stdout]     |
[INFO] [stdout] help: remove these parentheses
[INFO] [stdout]     |
[INFO] [stdout] 132 -             if (tvec & 0b11 == 0) {
[INFO] [stdout] 132 +             if tvec & 0b11 == 0 {
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary parentheses around `if` condition
[INFO] [stdout]    --> src/emulator.rs:154:12
[INFO] [stdout]     |
[INFO] [stdout] 154 |         if (error.is_fatal()) { 
[INFO] [stdout]     |            ^                ^
[INFO] [stdout]     |
[INFO] [stdout] help: remove these parentheses
[INFO] [stdout]     |
[INFO] [stdout] 154 -         if (error.is_fatal()) { 
[INFO] [stdout] 154 +         if error.is_fatal() { 
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary parentheses around `if` condition
[INFO] [stdout]    --> src/emulator.rs:167:12
[INFO] [stdout]     |
[INFO] [stdout] 167 |         if (should_deleg_to_supervisor) {
[INFO] [stdout]     |            ^                          ^
[INFO] [stdout]     |
[INFO] [stdout] help: remove these parentheses
[INFO] [stdout]     |
[INFO] [stdout] 167 -         if (should_deleg_to_supervisor) {
[INFO] [stdout] 167 +         if should_deleg_to_supervisor {
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary parentheses around `if` condition
[INFO] [stdout]    --> src/emulator.rs:206:12
[INFO] [stdout]     |
[INFO] [stdout] 206 |         if (self.mode == Machine && (self.csr.load(MSTATUS) & MASK_MIE) == 0) {
[INFO] [stdout]     |            ^                                                                ^
[INFO] [stdout]     |
[INFO] [stdout] help: remove these parentheses
[INFO] [stdout]     |
[INFO] [stdout] 206 -         if (self.mode == Machine && (self.csr.load(MSTATUS) & MASK_MIE) == 0) {
[INFO] [stdout] 206 +         if self.mode == Machine && (self.csr.load(MSTATUS) & MASK_MIE) == 0 {
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary parentheses around `if` condition
[INFO] [stdout]    --> src/emulator.rs:211:12
[INFO] [stdout]     |
[INFO] [stdout] 211 |         if ((self.mode == Supervisor) &&  (self.csr.load(MSTATUS) & MASK_SIE) == 0) {
[INFO] [stdout]     |            ^                                                                      ^
[INFO] [stdout]     |
[INFO] [stdout] help: remove these parentheses
[INFO] [stdout]     |
[INFO] [stdout] 211 -         if ((self.mode == Supervisor) &&  (self.csr.load(MSTATUS) & MASK_SIE) == 0) {
[INFO] [stdout] 211 +         if (self.mode == Supervisor) &&  (self.csr.load(MSTATUS) & MASK_SIE) == 0 {
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary parentheses around `if` condition
[INFO] [stdout]    --> src/emulator.rs:215:12
[INFO] [stdout]     |
[INFO] [stdout] 215 |         if (self.bus.uart.is_interrupting()) {
[INFO] [stdout]     |            ^                               ^
[INFO] [stdout]     |
[INFO] [stdout] help: remove these parentheses
[INFO] [stdout]     |
[INFO] [stdout] 215 -         if (self.bus.uart.is_interrupting()) {
[INFO] [stdout] 215 +         if self.bus.uart.is_interrupting() {
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary parentheses around assigned value
[INFO] [stdout]    --> src/emulator.rs:257:25
[INFO] [stdout]     |
[INFO] [stdout] 257 |         let flag_mask = (1 << flag_index);
[INFO] [stdout]     |                         ^               ^
[INFO] [stdout]     |
[INFO] [stdout] help: remove these parentheses
[INFO] [stdout]     |
[INFO] [stdout] 257 -         let flag_mask = (1 << flag_index);
[INFO] [stdout] 257 +         let flag_mask = 1 << flag_index;
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary parentheses around `return` value
[INFO] [stdout]    --> src/emulator.rs:258:16
[INFO] [stdout]     |
[INFO] [stdout] 258 |         return ((status & flag_mask) > 0);
[INFO] [stdout]     |                ^                        ^
[INFO] [stdout]     |
[INFO] [stdout] help: remove these parentheses
[INFO] [stdout]     |
[INFO] [stdout] 258 -         return ((status & flag_mask) > 0);
[INFO] [stdout] 258 +         return (status & flag_mask) > 0;
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary parentheses around `match` scrutinee expression
[INFO] [stdout]    --> src/emulator.rs:272:14
[INFO] [stdout]     |
[INFO] [stdout] 272 |         match(inst.opcode) {
[INFO] [stdout]     |              ^           ^
[INFO] [stdout]     |
[INFO] [stdout] help: remove these parentheses
[INFO] [stdout]     |
[INFO] [stdout] 272 -         match(inst.opcode) {
[INFO] [stdout] 272 +         match inst.opcode {
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary parentheses around `match` scrutinee expression
[INFO] [stdout]    --> src/emulator.rs:274:23
[INFO] [stdout]     |
[INFO] [stdout] 274 |                 match (inst.funct3) {
[INFO] [stdout]     |                       ^           ^
[INFO] [stdout]     |
[INFO] [stdout] help: remove these parentheses
[INFO] [stdout]     |
[INFO] [stdout] 274 -                 match (inst.funct3) {
[INFO] [stdout] 274 +                 match inst.funct3 {
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary parentheses around `match` scrutinee expression
[INFO] [stdout]    --> src/emulator.rs:276:31
[INFO] [stdout]     |
[INFO] [stdout] 276 |                         match (inst.funct7) {
[INFO] [stdout]     |                               ^           ^
[INFO] [stdout]     |
[INFO] [stdout] help: remove these parentheses
[INFO] [stdout]     |
[INFO] [stdout] 276 -                         match (inst.funct7) {
[INFO] [stdout] 276 +                         match inst.funct7 {
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary parentheses around `match` scrutinee expression
[INFO] [stdout]    --> src/emulator.rs:290:22
[INFO] [stdout]     |
[INFO] [stdout] 290 |                 match(inst.funct3) {
[INFO] [stdout]     |                      ^           ^
[INFO] [stdout]     |
[INFO] [stdout] help: remove these parentheses
[INFO] [stdout]     |
[INFO] [stdout] 290 -                 match(inst.funct3) {
[INFO] [stdout] 290 +                 match inst.funct3 {
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary parentheses around assigned value
[INFO] [stdout]    --> src/emulator.rs:301:38
[INFO] [stdout]     |
[INFO] [stdout] 301 |                         let result = ((self.regs[inst.rs1] as i64) < imm as i64);
[INFO] [stdout]     |                                      ^                                         ^
[INFO] [stdout]     |
[INFO] [stdout] help: remove these parentheses
[INFO] [stdout]     |
[INFO] [stdout] 301 -                         let result = ((self.regs[inst.rs1] as i64) < imm as i64);
[INFO] [stdout] 301 +                         let result = (self.regs[inst.rs1] as i64) < imm as i64;
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary parentheses around assigned value
[INFO] [stdout]    --> src/emulator.rs:305:38
[INFO] [stdout]     |
[INFO] [stdout] 305 |                         let result = ((self.regs[inst.rs1] as u64) < imm);
[INFO] [stdout]     |                                      ^                                  ^
[INFO] [stdout]     |
[INFO] [stdout] help: remove these parentheses
[INFO] [stdout]     |
[INFO] [stdout] 305 -                         let result = ((self.regs[inst.rs1] as u64) < imm);
[INFO] [stdout] 305 +                         let result = (self.regs[inst.rs1] as u64) < imm;
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary parentheses around `match` scrutinee expression
[INFO] [stdout]    --> src/emulator.rs:312:30
[INFO] [stdout]     |
[INFO] [stdout] 312 |                         match(inst.funct7) {
[INFO] [stdout]     |                              ^           ^
[INFO] [stdout]     |
[INFO] [stdout] help: remove these parentheses
[INFO] [stdout]     |
[INFO] [stdout] 312 -                         match(inst.funct7) {
[INFO] [stdout] 312 +                         match inst.funct7 {
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary parentheses around assigned value
[INFO] [stdout]    --> src/emulator.rs:335:38
[INFO] [stdout]     |
[INFO] [stdout] 335 |                 self.regs[inst.rd] = (imm << 12);
[INFO] [stdout]     |                                      ^         ^
[INFO] [stdout]     |
[INFO] [stdout] help: remove these parentheses
[INFO] [stdout]     |
[INFO] [stdout] 335 -                 self.regs[inst.rd] = (imm << 12);
[INFO] [stdout] 335 +                 self.regs[inst.rd] = imm << 12;
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary parentheses around assigned value
[INFO] [stdout]    --> src/emulator.rs:355:37
[INFO] [stdout]     |
[INFO] [stdout] 355 |                         self.mode = (updated_sstatus & (1 << SPP_FLAG_POS) >> SPP_FLAG_POS);
[INFO] [stdout]     |                                     ^                                                     ^
[INFO] [stdout]     |
[INFO] [stdout] help: remove these parentheses
[INFO] [stdout]     |
[INFO] [stdout] 355 -                         self.mode = (updated_sstatus & (1 << SPP_FLAG_POS) >> SPP_FLAG_POS);
[INFO] [stdout] 355 +                         self.mode = updated_sstatus & (1 << SPP_FLAG_POS) >> SPP_FLAG_POS;
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary parentheses around assigned value
[INFO] [stdout]    --> src/emulator.rs:361:36
[INFO] [stdout]     |
[INFO] [stdout] 361 |                         let spie = (updated_sstatus & (1 << SPIE_FLAG_POS) >> SPIE_FLAG_POS);
[INFO] [stdout]     |                                    ^                                                       ^
[INFO] [stdout]     |
[INFO] [stdout] help: remove these parentheses
[INFO] [stdout]     |
[INFO] [stdout] 361 -                         let spie = (updated_sstatus & (1 << SPIE_FLAG_POS) >> SPIE_FLAG_POS);
[INFO] [stdout] 361 +                         let spie = updated_sstatus & (1 << SPIE_FLAG_POS) >> SPIE_FLAG_POS;
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary parentheses around assigned value
[INFO] [stdout]    --> src/emulator.rs:365:44
[INFO] [stdout]     |
[INFO] [stdout] 365 |                         updated_sstatus |= (1 << SPIE_FLAG_POS);
[INFO] [stdout]     |                                            ^                  ^
[INFO] [stdout]     |
[INFO] [stdout] help: remove these parentheses
[INFO] [stdout]     |
[INFO] [stdout] 365 -                         updated_sstatus |= (1 << SPIE_FLAG_POS);
[INFO] [stdout] 365 +                         updated_sstatus |= 1 << SPIE_FLAG_POS;
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary parentheses around `if` condition
[INFO] [stdout]   --> src/lib.rs:14:8
[INFO] [stdout]    |
[INFO] [stdout] 14 |     if (args.len() != 2) {
[INFO] [stdout]    |        ^               ^
[INFO] [stdout]    |
[INFO] [stdout] help: remove these parentheses
[INFO] [stdout]    |
[INFO] [stdout] 14 -     if (args.len() != 2) {
[INFO] [stdout] 14 +     if args.len() != 2 {
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning[E0170]: pattern binding `SupervisorSoftwareInterrupt` is named the same as one of the variants of the type `emulator::interrupt::Interrupt`
[INFO] [stdout]   --> src/emulator/interrupt.rs:17:13
[INFO] [stdout]    |
[INFO] [stdout] 17 |             SupervisorSoftwareInterrupt => 1,
[INFO] [stdout]    |             ^^^^^^^^^^^^^^^^^^^^^^^^^^^ help: to match on the variant, qualify the path: `emulator::interrupt::Interrupt::SupervisorSoftwareInterrupt`
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(bindings_with_variant_name)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning[E0170]: pattern binding `MachineSoftwareInterrupt` is named the same as one of the variants of the type `emulator::interrupt::Interrupt`
[INFO] [stdout]   --> src/emulator/interrupt.rs:18:13
[INFO] [stdout]    |
[INFO] [stdout] 18 |             MachineSoftwareInterrupt => 3,
[INFO] [stdout]    |             ^^^^^^^^^^^^^^^^^^^^^^^^ help: to match on the variant, qualify the path: `emulator::interrupt::Interrupt::MachineSoftwareInterrupt`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning[E0170]: pattern binding `SupervisorTimerInterrupt` is named the same as one of the variants of the type `emulator::interrupt::Interrupt`
[INFO] [stdout]   --> src/emulator/interrupt.rs:19:13
[INFO] [stdout]    |
[INFO] [stdout] 19 |             SupervisorTimerInterrupt => 5,
[INFO] [stdout]    |             ^^^^^^^^^^^^^^^^^^^^^^^^ help: to match on the variant, qualify the path: `emulator::interrupt::Interrupt::SupervisorTimerInterrupt`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning[E0170]: pattern binding `MachineTimerInterrupt` is named the same as one of the variants of the type `emulator::interrupt::Interrupt`
[INFO] [stdout]   --> src/emulator/interrupt.rs:20:13
[INFO] [stdout]    |
[INFO] [stdout] 20 |             MachineTimerInterrupt => 7,
[INFO] [stdout]    |             ^^^^^^^^^^^^^^^^^^^^^ help: to match on the variant, qualify the path: `emulator::interrupt::Interrupt::MachineTimerInterrupt`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning[E0170]: pattern binding `SupervisorExternalInterrupt` is named the same as one of the variants of the type `emulator::interrupt::Interrupt`
[INFO] [stdout]   --> src/emulator/interrupt.rs:21:13
[INFO] [stdout]    |
[INFO] [stdout] 21 |             SupervisorExternalInterrupt => 9,
[INFO] [stdout]    |             ^^^^^^^^^^^^^^^^^^^^^^^^^^^ help: to match on the variant, qualify the path: `emulator::interrupt::Interrupt::SupervisorExternalInterrupt`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning[E0170]: pattern binding `MachineExternalInterrupt` is named the same as one of the variants of the type `emulator::interrupt::Interrupt`
[INFO] [stdout]   --> src/emulator/interrupt.rs:22:13
[INFO] [stdout]    |
[INFO] [stdout] 22 |             MachineExternalInterrupt => 11,
[INFO] [stdout]    |             ^^^^^^^^^^^^^^^^^^^^^^^^ help: to match on the variant, qualify the path: `emulator::interrupt::Interrupt::MachineExternalInterrupt`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unreachable pattern
[INFO] [stdout]   --> src/emulator/interrupt.rs:18:13
[INFO] [stdout]    |
[INFO] [stdout] 17 |             SupervisorSoftwareInterrupt => 1,
[INFO] [stdout]    |             --------------------------- matches any value
[INFO] [stdout] 18 |             MachineSoftwareInterrupt => 3,
[INFO] [stdout]    |             ^^^^^^^^^^^^^^^^^^^^^^^^ no value can reach this
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(unreachable_patterns)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unreachable pattern
[INFO] [stdout]   --> src/emulator/interrupt.rs:19:13
[INFO] [stdout]    |
[INFO] [stdout] 17 |             SupervisorSoftwareInterrupt => 1,
[INFO] [stdout]    |             --------------------------- matches any value
[INFO] [stdout] 18 |             MachineSoftwareInterrupt => 3,
[INFO] [stdout] 19 |             SupervisorTimerInterrupt => 5,
[INFO] [stdout]    |             ^^^^^^^^^^^^^^^^^^^^^^^^ no value can reach this
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unreachable pattern
[INFO] [stdout]   --> src/emulator/interrupt.rs:20:13
[INFO] [stdout]    |
[INFO] [stdout] 17 |             SupervisorSoftwareInterrupt => 1,
[INFO] [stdout]    |             --------------------------- matches any value
[INFO] [stdout] ...
[INFO] [stdout] 20 |             MachineTimerInterrupt => 7,
[INFO] [stdout]    |             ^^^^^^^^^^^^^^^^^^^^^ no value can reach this
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unreachable pattern
[INFO] [stdout]   --> src/emulator/interrupt.rs:21:13
[INFO] [stdout]    |
[INFO] [stdout] 17 |             SupervisorSoftwareInterrupt => 1,
[INFO] [stdout]    |             --------------------------- matches any value
[INFO] [stdout] ...
[INFO] [stdout] 21 |             SupervisorExternalInterrupt => 9,
[INFO] [stdout]    |             ^^^^^^^^^^^^^^^^^^^^^^^^^^^ no value can reach this
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unreachable pattern
[INFO] [stdout]   --> src/emulator/interrupt.rs:22:13
[INFO] [stdout]    |
[INFO] [stdout] 17 |             SupervisorSoftwareInterrupt => 1,
[INFO] [stdout]    |             --------------------------- matches any value
[INFO] [stdout] ...
[INFO] [stdout] 22 |             MachineExternalInterrupt => 11,
[INFO] [stdout]    |             ^^^^^^^^^^^^^^^^^^^^^^^^ no value can reach this
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `SupervisorSoftwareInterrupt`
[INFO] [stdout]   --> src/emulator/interrupt.rs:17:13
[INFO] [stdout]    |
[INFO] [stdout] 17 |             SupervisorSoftwareInterrupt => 1,
[INFO] [stdout]    |             ^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(unused_variables)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] help: if this is intentional, prefix it with an underscore
[INFO] [stdout]    |
[INFO] [stdout] 17 |             _SupervisorSoftwareInterrupt => 1,
[INFO] [stdout]    |             +
[INFO] [stdout] help: you might have meant to pattern match on the similarly named variant `SupervisorSoftwareInterrupt`
[INFO] [stdout]    |
[INFO] [stdout] 17 |             emulator::interrupt::Interrupt::SupervisorSoftwareInterrupt => 1,
[INFO] [stdout]    |             ++++++++++++++++++++++++++++++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `MachineSoftwareInterrupt`
[INFO] [stdout]   --> src/emulator/interrupt.rs:18:13
[INFO] [stdout]    |
[INFO] [stdout] 18 |             MachineSoftwareInterrupt => 3,
[INFO] [stdout]    |             ^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout] help: if this is intentional, prefix it with an underscore
[INFO] [stdout]    |
[INFO] [stdout] 18 |             _MachineSoftwareInterrupt => 3,
[INFO] [stdout]    |             +
[INFO] [stdout] help: you might have meant to pattern match on the similarly named variant `MachineSoftwareInterrupt`
[INFO] [stdout]    |
[INFO] [stdout] 18 |             emulator::interrupt::Interrupt::MachineSoftwareInterrupt => 3,
[INFO] [stdout]    |             ++++++++++++++++++++++++++++++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `SupervisorTimerInterrupt`
[INFO] [stdout]   --> src/emulator/interrupt.rs:19:13
[INFO] [stdout]    |
[INFO] [stdout] 19 |             SupervisorTimerInterrupt => 5,
[INFO] [stdout]    |             ^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout] help: if this is intentional, prefix it with an underscore
[INFO] [stdout]    |
[INFO] [stdout] 19 |             _SupervisorTimerInterrupt => 5,
[INFO] [stdout]    |             +
[INFO] [stdout] help: you might have meant to pattern match on the similarly named variant `SupervisorTimerInterrupt`
[INFO] [stdout]    |
[INFO] [stdout] 19 |             emulator::interrupt::Interrupt::SupervisorTimerInterrupt => 5,
[INFO] [stdout]    |             ++++++++++++++++++++++++++++++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `MachineTimerInterrupt`
[INFO] [stdout]   --> src/emulator/interrupt.rs:20:13
[INFO] [stdout]    |
[INFO] [stdout] 20 |             MachineTimerInterrupt => 7,
[INFO] [stdout]    |             ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout] help: if this is intentional, prefix it with an underscore
[INFO] [stdout]    |
[INFO] [stdout] 20 |             _MachineTimerInterrupt => 7,
[INFO] [stdout]    |             +
[INFO] [stdout] help: you might have meant to pattern match on the similarly named variant `MachineTimerInterrupt`
[INFO] [stdout]    |
[INFO] [stdout] 20 |             emulator::interrupt::Interrupt::MachineTimerInterrupt => 7,
[INFO] [stdout]    |             ++++++++++++++++++++++++++++++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `SupervisorExternalInterrupt`
[INFO] [stdout]   --> src/emulator/interrupt.rs:21:13
[INFO] [stdout]    |
[INFO] [stdout] 21 |             SupervisorExternalInterrupt => 9,
[INFO] [stdout]    |             ^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout] help: if this is intentional, prefix it with an underscore
[INFO] [stdout]    |
[INFO] [stdout] 21 |             _SupervisorExternalInterrupt => 9,
[INFO] [stdout]    |             +
[INFO] [stdout] help: you might have meant to pattern match on the similarly named variant `SupervisorExternalInterrupt`
[INFO] [stdout]    |
[INFO] [stdout] 21 |             emulator::interrupt::Interrupt::SupervisorExternalInterrupt => 9,
[INFO] [stdout]    |             ++++++++++++++++++++++++++++++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `MachineExternalInterrupt`
[INFO] [stdout]   --> src/emulator/interrupt.rs:22:13
[INFO] [stdout]    |
[INFO] [stdout] 22 |             MachineExternalInterrupt => 11,
[INFO] [stdout]    |             ^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout] help: if this is intentional, prefix it with an underscore
[INFO] [stdout]    |
[INFO] [stdout] 22 |             _MachineExternalInterrupt => 11,
[INFO] [stdout]    |             +
[INFO] [stdout] help: you might have meant to pattern match on the similarly named variant `MachineExternalInterrupt`
[INFO] [stdout]    |
[INFO] [stdout] 22 |             emulator::interrupt::Interrupt::MachineExternalInterrupt => 11,
[INFO] [stdout]    |             ++++++++++++++++++++++++++++++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]   --> src/emulator/uart.rs:39:13
[INFO] [stdout]    |
[INFO] [stdout] 39 |         let mut array = [0; UART_SIZE as 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: unused variable: `size`
[INFO] [stdout]   --> src/emulator/uart.rs:80:35
[INFO] [stdout]    |
[INFO] [stdout] 80 |     pub fn load(&self, addr: u64, size: u64) -> Result<u64, errors::Exception> {
[INFO] [stdout]    |                                   ^^^^
[INFO] [stdout]    |
[INFO] [stdout] help: if this is intentional, prefix it with an underscore
[INFO] [stdout]    |
[INFO] [stdout] 80 |     pub fn load(&self, addr: u64, _size: u64) -> Result<u64, errors::Exception> {
[INFO] [stdout]    |                                   +
[INFO] [stdout] help: you might have meant to pattern match on the similarly named constant `Machine`
[INFO] [stdout]    |
[INFO] [stdout] 80 -     pub fn load(&self, addr: u64, size: u64) -> Result<u64, errors::Exception> {
[INFO] [stdout] 80 +     pub fn load(&self, addr: u64, emulator::Machine: u64) -> Result<u64, errors::Exception> {
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `cvar`
[INFO] [stdout]   --> src/emulator/uart.rs:96:20
[INFO] [stdout]    |
[INFO] [stdout] 96 |         let (uart, cvar) = &*self.uart;
[INFO] [stdout]    |                    ^^^^ help: if this is intentional, prefix it with an underscore: `_cvar`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `size`
[INFO] [stdout]   --> src/emulator/uart.rs:95:40
[INFO] [stdout]    |
[INFO] [stdout] 95 |     pub fn store(&mut self, addr: u64, size: u64, value: u64) -> Result<(), errors::Exception> {
[INFO] [stdout]    |                                        ^^^^
[INFO] [stdout]    |
[INFO] [stdout] help: if this is intentional, prefix it with an underscore
[INFO] [stdout]    |
[INFO] [stdout] 95 |     pub fn store(&mut self, addr: u64, _size: u64, value: u64) -> Result<(), errors::Exception> {
[INFO] [stdout]    |                                        +
[INFO] [stdout] help: you might have meant to pattern match on the similarly named constant `Machine`
[INFO] [stdout]    |
[INFO] [stdout] 95 -     pub fn store(&mut self, addr: u64, size: u64, value: u64) -> Result<(), errors::Exception> {
[INFO] [stdout] 95 +     pub fn store(&mut self, addr: u64, emulator::Machine: u64, value: u64) -> Result<(), errors::Exception> {
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `main` is never used
[INFO] [stdout]  --> src/lib.rs:8:4
[INFO] [stdout]   |
[INFO] [stdout] 8 | fn main() -> io::Result<()> {
[INFO] [stdout]   |    ^^^^
[INFO] [stdout]   |
[INFO] [stdout]   = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `User` is never used
[INFO] [stdout]   --> src/emulator.rs:14:7
[INFO] [stdout]    |
[INFO] [stdout] 14 | const User: Mode = 0; // 0b00
[INFO] [stdout]    |       ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated function `get_status_flag` is never used
[INFO] [stdout]    --> src/emulator.rs:256:8
[INFO] [stdout]     |
[INFO] [stdout]  26 | impl Cpu {
[INFO] [stdout]     | -------- associated function in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 256 |     fn get_status_flag(status: &u64, flag_index: u64) -> bool {
[INFO] [stdout]     |        ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `MCOUNTEREN` is never used
[INFO] [stdout]   --> src/emulator/csr.rs:12:11
[INFO] [stdout]    |
[INFO] [stdout] 12 | pub const MCOUNTEREN: usize = 0x306;
[INFO] [stdout]    |           ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `MSCRATCH` is never used
[INFO] [stdout]   --> src/emulator/csr.rs:14:11
[INFO] [stdout]    |
[INFO] [stdout] 14 | pub const MSCRATCH: usize = 0x340;
[INFO] [stdout]    |           ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `SSCRATCH` is never used
[INFO] [stdout]   --> src/emulator/csr.rs:32:11
[INFO] [stdout]    |
[INFO] [stdout] 32 | pub const SSCRATCH: usize = 0x140;
[INFO] [stdout]    |           ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `SATP` is never used
[INFO] [stdout]   --> src/emulator/csr.rs:42:11
[INFO] [stdout]    |
[INFO] [stdout] 42 | pub const SATP: usize = 0x180;
[INFO] [stdout]    |           ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `MASK_VS` is never used
[INFO] [stdout]   --> src/emulator/csr.rs:51:11
[INFO] [stdout]    |
[INFO] [stdout] 51 | pub const MASK_VS: u64 = 0b11 << 9;
[INFO] [stdout]    |           ^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `MASK_MPRV` is never used
[INFO] [stdout]   --> src/emulator/csr.rs:55:11
[INFO] [stdout]    |
[INFO] [stdout] 55 | pub const MASK_MPRV: u64 = 1 << 17;
[INFO] [stdout]    |           ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `MASK_TVM` is never used
[INFO] [stdout]   --> src/emulator/csr.rs:58:11
[INFO] [stdout]    |
[INFO] [stdout] 58 | pub const MASK_TVM: u64 = 1 << 20;
[INFO] [stdout]    |           ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `MASK_TW` is never used
[INFO] [stdout]   --> src/emulator/csr.rs:59:11
[INFO] [stdout]    |
[INFO] [stdout] 59 | pub const MASK_TW: u64 = 1 << 21;
[INFO] [stdout]    |           ^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `MASK_TSR` is never used
[INFO] [stdout]   --> src/emulator/csr.rs:60:11
[INFO] [stdout]    |
[INFO] [stdout] 60 | pub const MASK_TSR: u64 = 1 << 22;
[INFO] [stdout]    |           ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `MASK_SXL` is never used
[INFO] [stdout]   --> src/emulator/csr.rs:62:11
[INFO] [stdout]    |
[INFO] [stdout] 62 | pub const MASK_SXL: u64 = 0b11 << 34;
[INFO] [stdout]    |           ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `MASK_SBE` is never used
[INFO] [stdout]   --> src/emulator/csr.rs:63:11
[INFO] [stdout]    |
[INFO] [stdout] 63 | pub const MASK_SBE: u64 = 1 << 36;
[INFO] [stdout]    |           ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `MASK_MBE` is never used
[INFO] [stdout]   --> src/emulator/csr.rs:64:11
[INFO] [stdout]    |
[INFO] [stdout] 64 | pub const MASK_MBE: u64 = 1 << 37;
[INFO] [stdout]    |           ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `Thing` is never constructed
[INFO] [stdout]  --> src/emulator/errors.rs:4:12
[INFO] [stdout]   |
[INFO] [stdout] 4 | pub struct Thing;
[INFO] [stdout]   |            ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated function `from_u32` is never used
[INFO] [stdout]   --> src/emulator/instructions.rs:29:12
[INFO] [stdout]    |
[INFO] [stdout] 28 | impl R_Instr {
[INFO] [stdout]    | ------------ associated function in this implementation
[INFO] [stdout] 29 |     pub fn from_u32(inst: u32) -> R_Instr {
[INFO] [stdout]    |            ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `I_Instr` is never constructed
[INFO] [stdout]   --> src/emulator/instructions.rs:42:12
[INFO] [stdout]    |
[INFO] [stdout] 42 | pub struct I_Instr {
[INFO] [stdout]    |            ^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated function `from_u32` is never used
[INFO] [stdout]   --> src/emulator/instructions.rs:51:12
[INFO] [stdout]    |
[INFO] [stdout] 50 | impl I_Instr {
[INFO] [stdout]    | ------------ associated function in this implementation
[INFO] [stdout] 51 |     pub fn from_u32(inst: u32) -> I_Instr {
[INFO] [stdout]    |            ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `S_Instr` is never constructed
[INFO] [stdout]   --> src/emulator/instructions.rs:63:12
[INFO] [stdout]    |
[INFO] [stdout] 63 | pub struct S_Instr {
[INFO] [stdout]    |            ^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated function `from_u32` is never used
[INFO] [stdout]   --> src/emulator/instructions.rs:72:12
[INFO] [stdout]    |
[INFO] [stdout] 71 | impl S_Instr {
[INFO] [stdout]    | ------------ associated function in this implementation
[INFO] [stdout] 72 |     pub fn from_u32(inst: u32) -> S_Instr {
[INFO] [stdout]    |            ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `B_Instr` is never constructed
[INFO] [stdout]   --> src/emulator/instructions.rs:86:12
[INFO] [stdout]    |
[INFO] [stdout] 86 | pub struct B_Instr {
[INFO] [stdout]    |            ^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated function `from_u32` is never used
[INFO] [stdout]   --> src/emulator/instructions.rs:95:12
[INFO] [stdout]    |
[INFO] [stdout] 94 | impl B_Instr {
[INFO] [stdout]    | ------------ associated function in this implementation
[INFO] [stdout] 95 |     pub fn from_u32(inst: u32) -> B_Instr {
[INFO] [stdout]    |            ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `U_Instr` is never constructed
[INFO] [stdout]    --> src/emulator/instructions.rs:115:12
[INFO] [stdout]     |
[INFO] [stdout] 115 | pub struct U_Instr {
[INFO] [stdout]     |            ^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated function `from_u32` is never used
[INFO] [stdout]    --> src/emulator/instructions.rs:122:12
[INFO] [stdout]     |
[INFO] [stdout] 121 | impl U_Instr {
[INFO] [stdout]     | ------------ associated function in this implementation
[INFO] [stdout] 122 |     pub fn from_u32(inst: u32) -> U_Instr {
[INFO] [stdout]     |            ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `J_Instr` is never constructed
[INFO] [stdout]    --> src/emulator/instructions.rs:134:12
[INFO] [stdout]     |
[INFO] [stdout] 134 | pub struct J_Instr {
[INFO] [stdout]     |            ^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated function `from_u32` is never used
[INFO] [stdout]    --> src/emulator/instructions.rs:141:12
[INFO] [stdout]     |
[INFO] [stdout] 140 | impl J_Instr {
[INFO] [stdout]     | ------------ associated function in this implementation
[INFO] [stdout] 141 |     pub fn from_u32(inst: u32) -> J_Instr {
[INFO] [stdout]     |            ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `Plic` is never constructed
[INFO] [stdout]  --> src/emulator/plic.rs:6:12
[INFO] [stdout]   |
[INFO] [stdout] 6 | pub struct Plic {
[INFO] [stdout]   |            ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `PLIC_COMPLETED_ADDR` is never used
[INFO] [stdout]   --> src/emulator/plic.rs:18:11
[INFO] [stdout]    |
[INFO] [stdout] 18 | pub const PLIC_COMPLETED_ADDR: u64 = PLIC_CLAIM_ADDR + 4;
[INFO] [stdout]    |           ^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `PLIC_END` is never used
[INFO] [stdout]   --> src/emulator/plic.rs:19:11
[INFO] [stdout]    |
[INFO] [stdout] 19 | pub const PLIC_END: u64 = PLIC_COMPLETED_ADDR;
[INFO] [stdout]    |           ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated items `new`, `load`, and `store` are never used
[INFO] [stdout]   --> src/emulator/plic.rs:22:12
[INFO] [stdout]    |
[INFO] [stdout] 21 | impl Plic {
[INFO] [stdout]    | --------- associated items in this implementation
[INFO] [stdout] 22 |     pub fn new() -> Self {
[INFO] [stdout]    |            ^^^
[INFO] [stdout] ...
[INFO] [stdout] 32 |     pub fn load(&self, addr: u64) -> Result<u64, errors::Exception> {
[INFO] [stdout]    |            ^^^^
[INFO] [stdout] ...
[INFO] [stdout] 45 |     pub fn store(&mut self, addr: u64, value: u64) -> Result<(), errors::Exception> {
[INFO] [stdout]    |            ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `UART_LSR_THR_STATUS_FLAG` is never used
[INFO] [stdout]   --> src/emulator/uart.rs:26:11
[INFO] [stdout]    |
[INFO] [stdout] 26 | pub const UART_LSR_THR_STATUS_FLAG: u8 = 1 << 5;
[INFO] [stdout]    |           ^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: crate `Risc_V_Emulator` should have a snake case name
[INFO] [stdout]   |
[INFO] [stdout]   = help: convert the identifier to snake case: `risc_v_emulator`
[INFO] [stdout]   = note: `#[warn(non_snake_case)]` (part of `#[warn(nonstandard_style)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused `Result` that must be used
[INFO] [stdout]   --> src/lib.rs:20:5
[INFO] [stdout]    |
[INFO] [stdout] 20 |     file.read_to_end(&mut code);
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: this `Result` may be an `Err` variant, which should be handled
[INFO] [stdout]    = note: `#[warn(unused_must_use)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] help: use `let _ = ...` to ignore the resulting value
[INFO] [stdout]    |
[INFO] [stdout] 20 |     let _ = file.read_to_end(&mut code);
[INFO] [stdout]    |     +++++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `User` should have an upper case name
[INFO] [stdout]   --> src/emulator.rs:14:7
[INFO] [stdout]    |
[INFO] [stdout] 14 | const User: Mode = 0; // 0b00
[INFO] [stdout]    |       ^^^^ help: convert the identifier to upper case: `USER`
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(non_upper_case_globals)]` (part of `#[warn(nonstandard_style)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `Supervisor` should have an upper case name
[INFO] [stdout]   --> src/emulator.rs:15:7
[INFO] [stdout]    |
[INFO] [stdout] 15 | const Supervisor: Mode = 1; // 0b01
[INFO] [stdout]    |       ^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout] help: convert the identifier to upper case
[INFO] [stdout]    |
[INFO] [stdout] 15 - const Supervisor: Mode = 1; // 0b01
[INFO] [stdout] 15 + const SUPERVISOR: Mode = 1; // 0b01
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `Machine` should have an upper case name
[INFO] [stdout]   --> src/emulator.rs:16:7
[INFO] [stdout]    |
[INFO] [stdout] 16 | const Machine: Mode = 3; // 0b11
[INFO] [stdout]    |       ^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout] help: convert the identifier to upper case
[INFO] [stdout]    |
[INFO] [stdout] 16 - const Machine: Mode = 3; // 0b11
[INFO] [stdout] 16 + const MACHINE: Mode = 3; // 0b11
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable `MEMORY_SIZE` should have a snake case name
[INFO] [stdout]   --> src/emulator.rs:41:13
[INFO] [stdout]    |
[INFO] [stdout] 41 |         let MEMORY_SIZE = 1024*1024*128; // Define 10MiB memory
[INFO] [stdout]    |             ^^^^^^^^^^^ help: convert the identifier to snake case: `memory_size`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable `SPP_FLAG_POS` should have a snake case name
[INFO] [stdout]    --> src/emulator.rs:354:29
[INFO] [stdout]     |
[INFO] [stdout] 354 |                         let SPP_FLAG_POS = 8; 
[INFO] [stdout]     |                             ^^^^^^^^^^^^ help: convert the identifier to snake case: `spp_flag_pos`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable `SPIE_FLAG_POS` should have a snake case name
[INFO] [stdout]    --> src/emulator.rs:359:29
[INFO] [stdout]     |
[INFO] [stdout] 359 |                         let SPIE_FLAG_POS = 5;
[INFO] [stdout]     |                             ^^^^^^^^^^^^^ help: convert the identifier to snake case: `spie_flag_pos`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable `SIE_FLAG_POS` should have a snake case name
[INFO] [stdout]    --> src/emulator.rs:360:29
[INFO] [stdout]     |
[INFO] [stdout] 360 |                         let SIE_FLAG_POS = 1;
[INFO] [stdout]     |                             ^^^^^^^^^^^^ help: convert the identifier to snake case: `sie_flag_pos`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable `SupervisorSoftwareInterrupt` should have a snake case name
[INFO] [stdout]   --> src/emulator/interrupt.rs:17:13
[INFO] [stdout]    |
[INFO] [stdout] 17 |             SupervisorSoftwareInterrupt => 1,
[INFO] [stdout]    |             ^^^^^^^^^^^^^^^^^^^^^^^^^^^ help: convert the identifier to snake case: `supervisor_software_interrupt`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable `MachineSoftwareInterrupt` should have a snake case name
[INFO] [stdout]   --> src/emulator/interrupt.rs:18:13
[INFO] [stdout]    |
[INFO] [stdout] 18 |             MachineSoftwareInterrupt => 3,
[INFO] [stdout]    |             ^^^^^^^^^^^^^^^^^^^^^^^^ help: convert the identifier to snake case: `machine_software_interrupt`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable `SupervisorTimerInterrupt` should have a snake case name
[INFO] [stdout]   --> src/emulator/interrupt.rs:19:13
[INFO] [stdout]    |
[INFO] [stdout] 19 |             SupervisorTimerInterrupt => 5,
[INFO] [stdout]    |             ^^^^^^^^^^^^^^^^^^^^^^^^ help: convert the identifier to snake case: `supervisor_timer_interrupt`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable `MachineTimerInterrupt` should have a snake case name
[INFO] [stdout]   --> src/emulator/interrupt.rs:20:13
[INFO] [stdout]    |
[INFO] [stdout] 20 |             MachineTimerInterrupt => 7,
[INFO] [stdout]    |             ^^^^^^^^^^^^^^^^^^^^^ help: convert the identifier to snake case: `machine_timer_interrupt`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable `SupervisorExternalInterrupt` should have a snake case name
[INFO] [stdout]   --> src/emulator/interrupt.rs:21:13
[INFO] [stdout]    |
[INFO] [stdout] 21 |             SupervisorExternalInterrupt => 9,
[INFO] [stdout]    |             ^^^^^^^^^^^^^^^^^^^^^^^^^^^ help: convert the identifier to snake case: `supervisor_external_interrupt`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable `MachineExternalInterrupt` should have a snake case name
[INFO] [stdout]   --> src/emulator/interrupt.rs:22:13
[INFO] [stdout]    |
[INFO] [stdout] 22 |             MachineExternalInterrupt => 11,
[INFO] [stdout]    |             ^^^^^^^^^^^^^^^^^^^^^^^^ help: convert the identifier to snake case: `machine_external_interrupt`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] For more information about this error, try `rustc --explain E0170`.
[INFO] [stdout] 
[INFO] [stderr]     Finished `dev` profile [unoptimized + debuginfo] target(s) in 0.64s
[INFO] running `Command { std: "docker" "inspect" "6bf01dbda355cca14267f9afe1f594678b47e6de6f8bbc1161fb9b0a33686013", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "6bf01dbda355cca14267f9afe1f594678b47e6de6f8bbc1161fb9b0a33686013", kill_on_drop: false }`
[INFO] [stdout] 6bf01dbda355cca14267f9afe1f594678b47e6de6f8bbc1161fb9b0a33686013
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-5-tc2/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-5-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=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:e90291280db7d1fac5b66fc6dad9f9662629e7365a55743daf9bdf73ebc4ea79" "/opt/rustwide/cargo-home/bin/cargo" "+beta-2025-09-21" "test" "--frozen" "--no-run" "--message-format=json", kill_on_drop: false }`
[INFO] [stdout] 387426ede206d705eb68be7c3b7c3a98916c91d18694ef0b96f178a8d89930be
[INFO] running `Command { std: "docker" "start" "-a" "387426ede206d705eb68be7c3b7c3a98916c91d18694ef0b96f178a8d89930be", kill_on_drop: false }`
[INFO] [stdout] warning: unnecessary parentheses around `match` scrutinee expression
[INFO] [stdout]   --> src/emulator/bus.rs:20:15
[INFO] [stdout]    |
[INFO] [stdout] 20 |         match (addr) {
[INFO] [stdout]    |               ^    ^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(unused_parens)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] help: remove these parentheses
[INFO] [stdout]    |
[INFO] [stdout] 20 -         match (addr) {
[INFO] [stdout] 20 +         match addr {
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary parentheses around `match` scrutinee expression
[INFO] [stdout]   --> src/emulator/bus.rs:28:14
[INFO] [stdout]    |
[INFO] [stdout] 28 |         match(addr) {
[INFO] [stdout]    |              ^    ^
[INFO] [stdout]    |
[INFO] [stdout] help: remove these parentheses
[INFO] [stdout]    |
[INFO] [stdout] 28 -         match(addr) {
[INFO] [stdout] 28 +         match addr {
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary parentheses around `if` condition
[INFO] [stdout]   --> src/emulator/dram.rs:17:12
[INFO] [stdout]    |
[INFO] [stdout] 17 |         if (![8, 16, 32, 64].contains(&size)) {
[INFO] [stdout]    |            ^                                ^
[INFO] [stdout]    |
[INFO] [stdout] help: remove these parentheses
[INFO] [stdout]    |
[INFO] [stdout] 17 -         if (![8, 16, 32, 64].contains(&size)) {
[INFO] [stdout] 17 +         if ![8, 16, 32, 64].contains(&size) {
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary parentheses around `if` condition
[INFO] [stdout]   --> src/emulator/dram.rs:33:12
[INFO] [stdout]    |
[INFO] [stdout] 33 |         if (![8, 16, 32, 64].contains(&size)) {
[INFO] [stdout]    |            ^                                ^
[INFO] [stdout]    |
[INFO] [stdout] help: remove these parentheses
[INFO] [stdout]    |
[INFO] [stdout] 33 -         if (![8, 16, 32, 64].contains(&size)) {
[INFO] [stdout] 33 +         if ![8, 16, 32, 64].contains(&size) {
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary parentheses around `match` scrutinee expression
[INFO] [stdout]   --> src/emulator/errors.rs:53:14
[INFO] [stdout]    |
[INFO] [stdout] 53 |         match(self) {
[INFO] [stdout]    |              ^    ^
[INFO] [stdout]    |
[INFO] [stdout] help: remove these parentheses
[INFO] [stdout]    |
[INFO] [stdout] 53 -         match(self) {
[INFO] [stdout] 53 +         match self {
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary parentheses around `match` scrutinee expression
[INFO] [stdout]   --> src/emulator/errors.rs:72:14
[INFO] [stdout]    |
[INFO] [stdout] 72 |         match(self) {
[INFO] [stdout]    |              ^    ^
[INFO] [stdout]    |
[INFO] [stdout] help: remove these parentheses
[INFO] [stdout]    |
[INFO] [stdout] 72 -         match(self) {
[INFO] [stdout] 72 +         match self {
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: type `R_Instr` should have an upper camel case name
[INFO] [stdout]   --> src/emulator/instructions.rs:19:12
[INFO] [stdout]    |
[INFO] [stdout] 19 | pub struct R_Instr {
[INFO] [stdout]    |            ^^^^^^^ help: convert the identifier to upper camel case: `RInstr`
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(non_camel_case_types)]` (part of `#[warn(nonstandard_style)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: type `I_Instr` should have an upper camel case name
[INFO] [stdout]   --> src/emulator/instructions.rs:42:12
[INFO] [stdout]    |
[INFO] [stdout] 42 | pub struct I_Instr {
[INFO] [stdout]    |            ^^^^^^^ help: convert the identifier to upper camel case: `IInstr`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: type `S_Instr` should have an upper camel case name
[INFO] [stdout]   --> src/emulator/instructions.rs:63:12
[INFO] [stdout]    |
[INFO] [stdout] 63 | pub struct S_Instr {
[INFO] [stdout]    |            ^^^^^^^ help: convert the identifier to upper camel case: `SInstr`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: type `B_Instr` should have an upper camel case name
[INFO] [stdout]   --> src/emulator/instructions.rs:86:12
[INFO] [stdout]    |
[INFO] [stdout] 86 | pub struct B_Instr {
[INFO] [stdout]    |            ^^^^^^^ help: convert the identifier to upper camel case: `BInstr`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: type `U_Instr` should have an upper camel case name
[INFO] [stdout]    --> src/emulator/instructions.rs:115:12
[INFO] [stdout]     |
[INFO] [stdout] 115 | pub struct U_Instr {
[INFO] [stdout]     |            ^^^^^^^ help: convert the identifier to upper camel case: `UInstr`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: type `J_Instr` should have an upper camel case name
[INFO] [stdout]    --> src/emulator/instructions.rs:134:12
[INFO] [stdout]     |
[INFO] [stdout] 134 | pub struct J_Instr {
[INFO] [stdout]     |            ^^^^^^^ help: convert the identifier to upper camel case: `JInstr`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary parentheses around `match` scrutinee expression
[INFO] [stdout]   --> src/emulator/interrupt.rs:16:35
[INFO] [stdout]    |
[INFO] [stdout] 16 |         let interrupt_code = match(self) {
[INFO] [stdout]    |                                   ^    ^
[INFO] [stdout]    |
[INFO] [stdout] help: remove these parentheses
[INFO] [stdout]    |
[INFO] [stdout] 16 -         let interrupt_code = match(self) {
[INFO] [stdout] 16 +         let interrupt_code = match self {
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary parentheses around `match` scrutinee expression
[INFO] [stdout]   --> src/emulator/plic.rs:33:14
[INFO] [stdout]    |
[INFO] [stdout] 33 |         match(addr) {
[INFO] [stdout]    |              ^    ^
[INFO] [stdout]    |
[INFO] [stdout] help: remove these parentheses
[INFO] [stdout]    |
[INFO] [stdout] 33 -         match(addr) {
[INFO] [stdout] 33 +         match addr {
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary parentheses around `match` scrutinee expression
[INFO] [stdout]   --> src/emulator/plic.rs:46:14
[INFO] [stdout]    |
[INFO] [stdout] 46 |         match(addr) {
[INFO] [stdout]    |              ^    ^
[INFO] [stdout]    |
[INFO] [stdout] help: remove these parentheses
[INFO] [stdout]    |
[INFO] [stdout] 46 -         match(addr) {
[INFO] [stdout] 46 +         match addr {
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary parentheses around `match` scrutinee expression
[INFO] [stdout]   --> src/emulator/uart.rs:59:18
[INFO] [stdout]    |
[INFO] [stdout] 59 |             match(read_io) {
[INFO] [stdout]    |                  ^       ^
[INFO] [stdout]    |
[INFO] [stdout] help: remove these parentheses
[INFO] [stdout]    |
[INFO] [stdout] 59 -             match(read_io) {
[INFO] [stdout] 59 +             match read_io {
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary parentheses around `while` condition
[INFO] [stdout]   --> src/emulator/uart.rs:65:27
[INFO] [stdout]    |
[INFO] [stdout] 65 |                     while (array[UART_LSR_INDEX as usize] & UART_LSR_RHR_STATUS_FLAG == 1) {
[INFO] [stdout]    |                           ^                                                              ^
[INFO] [stdout]    |
[INFO] [stdout] help: remove these parentheses
[INFO] [stdout]    |
[INFO] [stdout] 65 -                     while (array[UART_LSR_INDEX as usize] & UART_LSR_RHR_STATUS_FLAG == 1) {
[INFO] [stdout] 65 +                     while array[UART_LSR_INDEX as usize] & UART_LSR_RHR_STATUS_FLAG == 1 {
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary parentheses around `match` scrutinee expression
[INFO] [stdout]   --> src/emulator/uart.rs:85:15
[INFO] [stdout]    |
[INFO] [stdout] 85 |         match (index) {
[INFO] [stdout]    |               ^     ^
[INFO] [stdout]    |
[INFO] [stdout] help: remove these parentheses
[INFO] [stdout]    |
[INFO] [stdout] 85 -         match (index) {
[INFO] [stdout] 85 +         match index {
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary parentheses around `match` scrutinee expression
[INFO] [stdout]    --> src/emulator/uart.rs:101:15
[INFO] [stdout]     |
[INFO] [stdout] 101 |         match (index) {
[INFO] [stdout]     |               ^     ^
[INFO] [stdout]     |
[INFO] [stdout] help: remove these parentheses
[INFO] [stdout]     |
[INFO] [stdout] 101 -         match (index) {
[INFO] [stdout] 101 +         match index {
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary parentheses around `while` condition
[INFO] [stdout]   --> src/emulator.rs:49:15
[INFO] [stdout]    |
[INFO] [stdout] 49 |         while (self.pc < self.bus.dram.dram.len() as u64) {
[INFO] [stdout]    |               ^                                         ^
[INFO] [stdout]    |
[INFO] [stdout] help: remove these parentheses
[INFO] [stdout]    |
[INFO] [stdout] 49 -         while (self.pc < self.bus.dram.dram.len() as u64) {
[INFO] [stdout] 49 +         while self.pc < self.bus.dram.dram.len() as u64 {
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary parentheses around method argument
[INFO] [stdout]   --> src/emulator.rs:77:35
[INFO] [stdout]    |
[INFO] [stdout] 77 |         let instr = self.bus.load((index as u64), 32);
[INFO] [stdout]    |                                   ^            ^
[INFO] [stdout]    |
[INFO] [stdout] help: remove these parentheses
[INFO] [stdout]    |
[INFO] [stdout] 77 -         let instr = self.bus.load((index as u64), 32);
[INFO] [stdout] 77 +         let instr = self.bus.load(index as u64, 32);
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary parentheses around `for` iterator expression
[INFO] [stdout]   --> src/emulator.rs:99:18
[INFO] [stdout]    |
[INFO] [stdout] 99 |         for i in (0..self.regs.len()) {
[INFO] [stdout]    |                  ^                  ^
[INFO] [stdout]    |
[INFO] [stdout] help: remove these parentheses
[INFO] [stdout]    |
[INFO] [stdout] 99 -         for i in (0..self.regs.len()) {
[INFO] [stdout] 99 +         for i in 0..self.regs.len() {
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary parentheses around `if` condition
[INFO] [stdout]    --> src/emulator.rs:110:12
[INFO] [stdout]     |
[INFO] [stdout] 110 |         if (delegate_to_s_mode) {
[INFO] [stdout]     |            ^                  ^
[INFO] [stdout]     |
[INFO] [stdout] help: remove these parentheses
[INFO] [stdout]     |
[INFO] [stdout] 110 -         if (delegate_to_s_mode) {
[INFO] [stdout] 110 +         if delegate_to_s_mode {
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary parentheses around `if` condition
[INFO] [stdout]    --> src/emulator.rs:113:16
[INFO] [stdout]     |
[INFO] [stdout] 113 |             if (tvec & 0b11 == 0) {
[INFO] [stdout]     |                ^                ^
[INFO] [stdout]     |
[INFO] [stdout] help: remove these parentheses
[INFO] [stdout]     |
[INFO] [stdout] 113 -             if (tvec & 0b11 == 0) {
[INFO] [stdout] 113 +             if tvec & 0b11 == 0 {
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary parentheses around `if` condition
[INFO] [stdout]    --> src/emulator.rs:132:16
[INFO] [stdout]     |
[INFO] [stdout] 132 |             if (tvec & 0b11 == 0) {
[INFO] [stdout]     |                ^                ^
[INFO] [stdout]     |
[INFO] [stdout] help: remove these parentheses
[INFO] [stdout]     |
[INFO] [stdout] 132 -             if (tvec & 0b11 == 0) {
[INFO] [stdout] 132 +             if tvec & 0b11 == 0 {
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary parentheses around `if` condition
[INFO] [stdout]    --> src/emulator.rs:154:12
[INFO] [stdout]     |
[INFO] [stdout] 154 |         if (error.is_fatal()) { 
[INFO] [stdout]     |            ^                ^
[INFO] [stdout]     |
[INFO] [stdout] help: remove these parentheses
[INFO] [stdout]     |
[INFO] [stdout] 154 -         if (error.is_fatal()) { 
[INFO] [stdout] 154 +         if error.is_fatal() { 
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary parentheses around `if` condition
[INFO] [stdout]    --> src/emulator.rs:167:12
[INFO] [stdout]     |
[INFO] [stdout] 167 |         if (should_deleg_to_supervisor) {
[INFO] [stdout]     |            ^                          ^
[INFO] [stdout]     |
[INFO] [stdout] help: remove these parentheses
[INFO] [stdout]     |
[INFO] [stdout] 167 -         if (should_deleg_to_supervisor) {
[INFO] [stdout] 167 +         if should_deleg_to_supervisor {
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary parentheses around `if` condition
[INFO] [stdout]    --> src/emulator.rs:206:12
[INFO] [stdout]     |
[INFO] [stdout] 206 |         if (self.mode == Machine && (self.csr.load(MSTATUS) & MASK_MIE) == 0) {
[INFO] [stdout]     |            ^                                                                ^
[INFO] [stdout]     |
[INFO] [stdout] help: remove these parentheses
[INFO] [stdout]     |
[INFO] [stdout] 206 -         if (self.mode == Machine && (self.csr.load(MSTATUS) & MASK_MIE) == 0) {
[INFO] [stdout] 206 +         if self.mode == Machine && (self.csr.load(MSTATUS) & MASK_MIE) == 0 {
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary parentheses around `if` condition
[INFO] [stdout]    --> src/emulator.rs:211:12
[INFO] [stdout]     |
[INFO] [stdout] 211 |         if ((self.mode == Supervisor) &&  (self.csr.load(MSTATUS) & MASK_SIE) == 0) {
[INFO] [stdout]     |            ^                                                                      ^
[INFO] [stdout]     |
[INFO] [stdout] help: remove these parentheses
[INFO] [stdout]     |
[INFO] [stdout] 211 -         if ((self.mode == Supervisor) &&  (self.csr.load(MSTATUS) & MASK_SIE) == 0) {
[INFO] [stdout] 211 +         if (self.mode == Supervisor) &&  (self.csr.load(MSTATUS) & MASK_SIE) == 0 {
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary parentheses around `if` condition
[INFO] [stdout]    --> src/emulator.rs:215:12
[INFO] [stdout]     |
[INFO] [stdout] 215 |         if (self.bus.uart.is_interrupting()) {
[INFO] [stdout]     |            ^                               ^
[INFO] [stdout]     |
[INFO] [stdout] help: remove these parentheses
[INFO] [stdout]     |
[INFO] [stdout] 215 -         if (self.bus.uart.is_interrupting()) {
[INFO] [stdout] 215 +         if self.bus.uart.is_interrupting() {
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary parentheses around assigned value
[INFO] [stdout]    --> src/emulator.rs:257:25
[INFO] [stdout]     |
[INFO] [stdout] 257 |         let flag_mask = (1 << flag_index);
[INFO] [stdout]     |                         ^               ^
[INFO] [stdout]     |
[INFO] [stdout] help: remove these parentheses
[INFO] [stdout]     |
[INFO] [stdout] 257 -         let flag_mask = (1 << flag_index);
[INFO] [stdout] 257 +         let flag_mask = 1 << flag_index;
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary parentheses around `return` value
[INFO] [stdout]    --> src/emulator.rs:258:16
[INFO] [stdout]     |
[INFO] [stdout] 258 |         return ((status & flag_mask) > 0);
[INFO] [stdout]     |                ^                        ^
[INFO] [stdout]     |
[INFO] [stdout] help: remove these parentheses
[INFO] [stdout]     |
[INFO] [stdout] 258 -         return ((status & flag_mask) > 0);
[INFO] [stdout] 258 +         return (status & flag_mask) > 0;
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary parentheses around `match` scrutinee expression
[INFO] [stdout]    --> src/emulator.rs:272:14
[INFO] [stdout]     |
[INFO] [stdout] 272 |         match(inst.opcode) {
[INFO] [stdout]     |              ^           ^
[INFO] [stdout]     |
[INFO] [stdout] help: remove these parentheses
[INFO] [stdout]     |
[INFO] [stdout] 272 -         match(inst.opcode) {
[INFO] [stdout] 272 +         match inst.opcode {
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary parentheses around `match` scrutinee expression
[INFO] [stdout]    --> src/emulator.rs:274:23
[INFO] [stdout]     |
[INFO] [stdout] 274 |                 match (inst.funct3) {
[INFO] [stdout]     |                       ^           ^
[INFO] [stdout]     |
[INFO] [stdout] help: remove these parentheses
[INFO] [stdout]     |
[INFO] [stdout] 274 -                 match (inst.funct3) {
[INFO] [stdout] 274 +                 match inst.funct3 {
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary parentheses around `match` scrutinee expression
[INFO] [stdout]    --> src/emulator.rs:276:31
[INFO] [stdout]     |
[INFO] [stdout] 276 |                         match (inst.funct7) {
[INFO] [stdout]     |                               ^           ^
[INFO] [stdout]     |
[INFO] [stdout] help: remove these parentheses
[INFO] [stdout]     |
[INFO] [stdout] 276 -                         match (inst.funct7) {
[INFO] [stdout] 276 +                         match inst.funct7 {
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary parentheses around `match` scrutinee expression
[INFO] [stdout]    --> src/emulator.rs:290:22
[INFO] [stdout]     |
[INFO] [stdout] 290 |                 match(inst.funct3) {
[INFO] [stdout]     |                      ^           ^
[INFO] [stdout]     |
[INFO] [stdout] help: remove these parentheses
[INFO] [stdout]     |
[INFO] [stdout] 290 -                 match(inst.funct3) {
[INFO] [stdout] 290 +                 match inst.funct3 {
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary parentheses around assigned value
[INFO] [stdout]    --> src/emulator.rs:301:38
[INFO] [stdout]     |
[INFO] [stdout] 301 |                         let result = ((self.regs[inst.rs1] as i64) < imm as i64);
[INFO] [stdout]     |                                      ^                                         ^
[INFO] [stdout]     |
[INFO] [stdout] help: remove these parentheses
[INFO] [stdout]     |
[INFO] [stdout] 301 -                         let result = ((self.regs[inst.rs1] as i64) < imm as i64);
[INFO] [stdout] 301 +                         let result = (self.regs[inst.rs1] as i64) < imm as i64;
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary parentheses around assigned value
[INFO] [stdout]    --> src/emulator.rs:305:38
[INFO] [stdout]     |
[INFO] [stdout] 305 |                         let result = ((self.regs[inst.rs1] as u64) < imm);
[INFO] [stdout]     |                                      ^                                  ^
[INFO] [stdout]     |
[INFO] [stdout] help: remove these parentheses
[INFO] [stdout]     |
[INFO] [stdout] 305 -                         let result = ((self.regs[inst.rs1] as u64) < imm);
[INFO] [stdout] 305 +                         let result = (self.regs[inst.rs1] as u64) < imm;
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary parentheses around `match` scrutinee expression
[INFO] [stdout]    --> src/emulator.rs:312:30
[INFO] [stdout]     |
[INFO] [stdout] 312 |                         match(inst.funct7) {
[INFO] [stdout]     |                              ^           ^
[INFO] [stdout]     |
[INFO] [stdout] help: remove these parentheses
[INFO] [stdout]     |
[INFO] [stdout] 312 -                         match(inst.funct7) {
[INFO] [stdout] 312 +                         match inst.funct7 {
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary parentheses around assigned value
[INFO] [stdout]    --> src/emulator.rs:335:38
[INFO] [stdout]     |
[INFO] [stdout] 335 |                 self.regs[inst.rd] = (imm << 12);
[INFO] [stdout]     |                                      ^         ^
[INFO] [stdout]     |
[INFO] [stdout] help: remove these parentheses
[INFO] [stdout]     |
[INFO] [stdout] 335 -                 self.regs[inst.rd] = (imm << 12);
[INFO] [stdout] 335 +                 self.regs[inst.rd] = imm << 12;
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary parentheses around assigned value
[INFO] [stdout]    --> src/emulator.rs:355:37
[INFO] [stdout]     |
[INFO] [stdout] 355 |                         self.mode = (updated_sstatus & (1 << SPP_FLAG_POS) >> SPP_FLAG_POS);
[INFO] [stdout]     |                                     ^                                                     ^
[INFO] [stdout]     |
[INFO] [stdout] help: remove these parentheses
[INFO] [stdout]     |
[INFO] [stdout] 355 -                         self.mode = (updated_sstatus & (1 << SPP_FLAG_POS) >> SPP_FLAG_POS);
[INFO] [stdout] 355 +                         self.mode = updated_sstatus & (1 << SPP_FLAG_POS) >> SPP_FLAG_POS;
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary parentheses around assigned value
[INFO] [stdout]    --> src/emulator.rs:361:36
[INFO] [stdout]     |
[INFO] [stdout] 361 |                         let spie = (updated_sstatus & (1 << SPIE_FLAG_POS) >> SPIE_FLAG_POS);
[INFO] [stdout]     |                                    ^                                                       ^
[INFO] [stdout]     |
[INFO] [stdout] help: remove these parentheses
[INFO] [stdout]     |
[INFO] [stdout] 361 -                         let spie = (updated_sstatus & (1 << SPIE_FLAG_POS) >> SPIE_FLAG_POS);
[INFO] [stdout] 361 +                         let spie = updated_sstatus & (1 << SPIE_FLAG_POS) >> SPIE_FLAG_POS;
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary parentheses around assigned value
[INFO] [stdout]    --> src/emulator.rs:365:44
[INFO] [stdout]     |
[INFO] [stdout] 365 |                         updated_sstatus |= (1 << SPIE_FLAG_POS);
[INFO] [stdout]     |                                            ^                  ^
[INFO] [stdout]     |
[INFO] [stdout] help: remove these parentheses
[INFO] [stdout]     |
[INFO] [stdout] 365 -                         updated_sstatus |= (1 << SPIE_FLAG_POS);
[INFO] [stdout] 365 +                         updated_sstatus |= 1 << SPIE_FLAG_POS;
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary parentheses around `if` condition
[INFO] [stdout]   --> src/lib.rs:14:8
[INFO] [stdout]    |
[INFO] [stdout] 14 |     if (args.len() != 2) {
[INFO] [stdout]    |        ^               ^
[INFO] [stdout]    |
[INFO] [stdout] help: remove these parentheses
[INFO] [stdout]    |
[INFO] [stdout] 14 -     if (args.len() != 2) {
[INFO] [stdout] 14 +     if args.len() != 2 {
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning[E0170]: pattern binding `SupervisorSoftwareInterrupt` is named the same as one of the variants of the type `emulator::interrupt::Interrupt`
[INFO] [stdout]   --> src/emulator/interrupt.rs:17:13
[INFO] [stdout]    |
[INFO] [stdout] 17 |             SupervisorSoftwareInterrupt => 1,
[INFO] [stdout]    |             ^^^^^^^^^^^^^^^^^^^^^^^^^^^ help: to match on the variant, qualify the path: `emulator::interrupt::Interrupt::SupervisorSoftwareInterrupt`
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(bindings_with_variant_name)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning[E0170]: pattern binding `MachineSoftwareInterrupt` is named the same as one of the variants of the type `emulator::interrupt::Interrupt`
[INFO] [stdout]   --> src/emulator/interrupt.rs:18:13
[INFO] [stdout]    |
[INFO] [stdout] 18 |             MachineSoftwareInterrupt => 3,
[INFO] [stdout]    |             ^^^^^^^^^^^^^^^^^^^^^^^^ help: to match on the variant, qualify the path: `emulator::interrupt::Interrupt::MachineSoftwareInterrupt`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning[E0170]: pattern binding `SupervisorTimerInterrupt` is named the same as one of the variants of the type `emulator::interrupt::Interrupt`
[INFO] [stdout]   --> src/emulator/interrupt.rs:19:13
[INFO] [stdout]    |
[INFO] [stdout] 19 |             SupervisorTimerInterrupt => 5,
[INFO] [stdout]    |             ^^^^^^^^^^^^^^^^^^^^^^^^ help: to match on the variant, qualify the path: `emulator::interrupt::Interrupt::SupervisorTimerInterrupt`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning[E0170]: pattern binding `MachineTimerInterrupt` is named the same as one of the variants of the type `emulator::interrupt::Interrupt`
[INFO] [stdout]   --> src/emulator/interrupt.rs:20:13
[INFO] [stdout]    |
[INFO] [stdout] 20 |             MachineTimerInterrupt => 7,
[INFO] [stdout]    |             ^^^^^^^^^^^^^^^^^^^^^ help: to match on the variant, qualify the path: `emulator::interrupt::Interrupt::MachineTimerInterrupt`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning[E0170]: pattern binding `SupervisorExternalInterrupt` is named the same as one of the variants of the type `emulator::interrupt::Interrupt`
[INFO] [stdout]   --> src/emulator/interrupt.rs:21:13
[INFO] [stdout]    |
[INFO] [stdout] 21 |             SupervisorExternalInterrupt => 9,
[INFO] [stdout]    |             ^^^^^^^^^^^^^^^^^^^^^^^^^^^ help: to match on the variant, qualify the path: `emulator::interrupt::Interrupt::SupervisorExternalInterrupt`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning[E0170]: pattern binding `MachineExternalInterrupt` is named the same as one of the variants of the type `emulator::interrupt::Interrupt`
[INFO] [stdout]   --> src/emulator/interrupt.rs:22:13
[INFO] [stdout]    |
[INFO] [stdout] 22 |             MachineExternalInterrupt => 11,
[INFO] [stdout]    |             ^^^^^^^^^^^^^^^^^^^^^^^^ help: to match on the variant, qualify the path: `emulator::interrupt::Interrupt::MachineExternalInterrupt`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unreachable pattern
[INFO] [stdout]   --> src/emulator/interrupt.rs:18:13
[INFO] [stdout]    |
[INFO] [stdout] 17 |             SupervisorSoftwareInterrupt => 1,
[INFO] [stdout]    |             --------------------------- matches any value
[INFO] [stdout] 18 |             MachineSoftwareInterrupt => 3,
[INFO] [stdout]    |             ^^^^^^^^^^^^^^^^^^^^^^^^ no value can reach this
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(unreachable_patterns)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unreachable pattern
[INFO] [stdout]   --> src/emulator/interrupt.rs:19:13
[INFO] [stdout]    |
[INFO] [stdout] 17 |             SupervisorSoftwareInterrupt => 1,
[INFO] [stdout]    |             --------------------------- matches any value
[INFO] [stdout] 18 |             MachineSoftwareInterrupt => 3,
[INFO] [stdout] 19 |             SupervisorTimerInterrupt => 5,
[INFO] [stdout]    |             ^^^^^^^^^^^^^^^^^^^^^^^^ no value can reach this
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unreachable pattern
[INFO] [stdout]   --> src/emulator/interrupt.rs:20:13
[INFO] [stdout]    |
[INFO] [stdout] 17 |             SupervisorSoftwareInterrupt => 1,
[INFO] [stdout]    |             --------------------------- matches any value
[INFO] [stdout] ...
[INFO] [stdout] 20 |             MachineTimerInterrupt => 7,
[INFO] [stdout]    |             ^^^^^^^^^^^^^^^^^^^^^ no value can reach this
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unreachable pattern
[INFO] [stdout]   --> src/emulator/interrupt.rs:21:13
[INFO] [stdout]    |
[INFO] [stdout] 17 |             SupervisorSoftwareInterrupt => 1,
[INFO] [stdout]    |             --------------------------- matches any value
[INFO] [stdout] ...
[INFO] [stdout] 21 |             SupervisorExternalInterrupt => 9,
[INFO] [stdout]    |             ^^^^^^^^^^^^^^^^^^^^^^^^^^^ no value can reach this
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unreachable pattern
[INFO] [stdout]   --> src/emulator/interrupt.rs:22:13
[INFO] [stdout]    |
[INFO] [stdout] 17 |             SupervisorSoftwareInterrupt => 1,
[INFO] [stdout]    |             --------------------------- matches any value
[INFO] [stdout] ...
[INFO] [stdout] 22 |             MachineExternalInterrupt => 11,
[INFO] [stdout]    |             ^^^^^^^^^^^^^^^^^^^^^^^^ no value can reach this
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `SupervisorSoftwareInterrupt`
[INFO] [stdout]   --> src/emulator/interrupt.rs:17:13
[INFO] [stdout]    |
[INFO] [stdout] 17 |             SupervisorSoftwareInterrupt => 1,
[INFO] [stdout]    |             ^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(unused_variables)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] help: if this is intentional, prefix it with an underscore
[INFO] [stdout]    |
[INFO] [stdout] 17 |             _SupervisorSoftwareInterrupt => 1,
[INFO] [stdout]    |             +
[INFO] [stdout] help: you might have meant to pattern match on the similarly named variant `SupervisorSoftwareInterrupt`
[INFO] [stdout]    |
[INFO] [stdout] 17 |             emulator::interrupt::Interrupt::SupervisorSoftwareInterrupt => 1,
[INFO] [stdout]    |             ++++++++++++++++++++++++++++++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `MachineSoftwareInterrupt`
[INFO] [stdout]   --> src/emulator/interrupt.rs:18:13
[INFO] [stdout]    |
[INFO] [stdout] 18 |             MachineSoftwareInterrupt => 3,
[INFO] [stdout]    |             ^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout] help: if this is intentional, prefix it with an underscore
[INFO] [stdout]    |
[INFO] [stdout] 18 |             _MachineSoftwareInterrupt => 3,
[INFO] [stdout]    |             +
[INFO] [stdout] help: you might have meant to pattern match on the similarly named variant `MachineSoftwareInterrupt`
[INFO] [stdout]    |
[INFO] [stdout] 18 |             emulator::interrupt::Interrupt::MachineSoftwareInterrupt => 3,
[INFO] [stdout]    |             ++++++++++++++++++++++++++++++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `SupervisorTimerInterrupt`
[INFO] [stdout]   --> src/emulator/interrupt.rs:19:13
[INFO] [stdout]    |
[INFO] [stdout] 19 |             SupervisorTimerInterrupt => 5,
[INFO] [stdout]    |             ^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout] help: if this is intentional, prefix it with an underscore
[INFO] [stdout]    |
[INFO] [stdout] 19 |             _SupervisorTimerInterrupt => 5,
[INFO] [stdout]    |             +
[INFO] [stdout] help: you might have meant to pattern match on the similarly named variant `SupervisorTimerInterrupt`
[INFO] [stdout]    |
[INFO] [stdout] 19 |             emulator::interrupt::Interrupt::SupervisorTimerInterrupt => 5,
[INFO] [stdout]    |             ++++++++++++++++++++++++++++++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `MachineTimerInterrupt`
[INFO] [stdout]   --> src/emulator/interrupt.rs:20:13
[INFO] [stdout]    |
[INFO] [stdout] 20 |             MachineTimerInterrupt => 7,
[INFO] [stdout]    |             ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout] help: if this is intentional, prefix it with an underscore
[INFO] [stdout]    |
[INFO] [stdout] 20 |             _MachineTimerInterrupt => 7,
[INFO] [stdout]    |             +
[INFO] [stdout] help: you might have meant to pattern match on the similarly named variant `MachineTimerInterrupt`
[INFO] [stdout]    |
[INFO] [stdout] 20 |             emulator::interrupt::Interrupt::MachineTimerInterrupt => 7,
[INFO] [stdout]    |             ++++++++++++++++++++++++++++++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `SupervisorExternalInterrupt`
[INFO] [stdout]   --> src/emulator/interrupt.rs:21:13
[INFO] [stdout]    |
[INFO] [stdout] 21 |             SupervisorExternalInterrupt => 9,
[INFO] [stdout]    |             ^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout] help: if this is intentional, prefix it with an underscore
[INFO] [stdout]    |
[INFO] [stdout] 21 |             _SupervisorExternalInterrupt => 9,
[INFO] [stdout]    |             +
[INFO] [stdout] help: you might have meant to pattern match on the similarly named variant `SupervisorExternalInterrupt`
[INFO] [stdout]    |
[INFO] [stdout] 21 |             emulator::interrupt::Interrupt::SupervisorExternalInterrupt => 9,
[INFO] [stdout]    |             ++++++++++++++++++++++++++++++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `MachineExternalInterrupt`
[INFO] [stdout]   --> src/emulator/interrupt.rs:22:13
[INFO] [stdout]    |
[INFO] [stdout] 22 |             MachineExternalInterrupt => 11,
[INFO] [stdout]    |             ^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout] help: if this is intentional, prefix it with an underscore
[INFO] [stdout]    |
[INFO] [stdout] 22 |             _MachineExternalInterrupt => 11,
[INFO] [stdout]    |             +
[INFO] [stdout] help: you might have meant to pattern match on the similarly named variant `MachineExternalInterrupt`
[INFO] [stdout]    |
[INFO] [stdout] 22 |             emulator::interrupt::Interrupt::MachineExternalInterrupt => 11,
[INFO] [stdout]    |             ++++++++++++++++++++++++++++++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]   --> src/emulator/uart.rs:39:13
[INFO] [stdout]    |
[INFO] [stdout] 39 |         let mut array = [0; UART_SIZE as 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: unused variable: `size`
[INFO] [stdout]   --> src/emulator/uart.rs:80:35
[INFO] [stdout]    |
[INFO] [stdout] 80 |     pub fn load(&self, addr: u64, size: u64) -> Result<u64, errors::Exception> {
[INFO] [stdout]    |                                   ^^^^
[INFO] [stdout]    |
[INFO] [stdout] help: if this is intentional, prefix it with an underscore
[INFO] [stdout]    |
[INFO] [stdout] 80 |     pub fn load(&self, addr: u64, _size: u64) -> Result<u64, errors::Exception> {
[INFO] [stdout]    |                                   +
[INFO] [stdout] help: you might have meant to pattern match on the similarly named constant `Machine`
[INFO] [stdout]    |
[INFO] [stdout] 80 -     pub fn load(&self, addr: u64, size: u64) -> Result<u64, errors::Exception> {
[INFO] [stdout] 80 +     pub fn load(&self, addr: u64, emulator::Machine: u64) -> Result<u64, errors::Exception> {
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `cvar`
[INFO] [stdout]   --> src/emulator/uart.rs:96:20
[INFO] [stdout]    |
[INFO] [stdout] 96 |         let (uart, cvar) = &*self.uart;
[INFO] [stdout]    |                    ^^^^ help: if this is intentional, prefix it with an underscore: `_cvar`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `size`
[INFO] [stdout]   --> src/emulator/uart.rs:95:40
[INFO] [stdout]    |
[INFO] [stdout] 95 |     pub fn store(&mut self, addr: u64, size: u64, value: u64) -> Result<(), errors::Exception> {
[INFO] [stdout]    |                                        ^^^^
[INFO] [stdout]    |
[INFO] [stdout] help: if this is intentional, prefix it with an underscore
[INFO] [stdout]    |
[INFO] [stdout] 95 |     pub fn store(&mut self, addr: u64, _size: u64, value: u64) -> Result<(), errors::Exception> {
[INFO] [stdout]    |                                        +
[INFO] [stdout] help: you might have meant to pattern match on the similarly named constant `Machine`
[INFO] [stdout]    |
[INFO] [stdout] 95 -     pub fn store(&mut self, addr: u64, size: u64, value: u64) -> Result<(), errors::Exception> {
[INFO] [stdout] 95 +     pub fn store(&mut self, addr: u64, emulator::Machine: u64, value: u64) -> Result<(), errors::Exception> {
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `main` is never used
[INFO] [stdout]  --> src/lib.rs:8:4
[INFO] [stdout]   |
[INFO] [stdout] 8 | fn main() -> io::Result<()> {
[INFO] [stdout]   |    ^^^^
[INFO] [stdout]   |
[INFO] [stdout]   = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `User` is never used
[INFO] [stdout]   --> src/emulator.rs:14:7
[INFO] [stdout]    |
[INFO] [stdout] 14 | const User: Mode = 0; // 0b00
[INFO] [stdout]    |       ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated function `get_status_flag` is never used
[INFO] [stdout]    --> src/emulator.rs:256:8
[INFO] [stdout]     |
[INFO] [stdout]  26 | impl Cpu {
[INFO] [stdout]     | -------- associated function in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 256 |     fn get_status_flag(status: &u64, flag_index: u64) -> bool {
[INFO] [stdout]     |        ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `MCOUNTEREN` is never used
[INFO] [stdout]   --> src/emulator/csr.rs:12:11
[INFO] [stdout]    |
[INFO] [stdout] 12 | pub const MCOUNTEREN: usize = 0x306;
[INFO] [stdout]    |           ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `MSCRATCH` is never used
[INFO] [stdout]   --> src/emulator/csr.rs:14:11
[INFO] [stdout]    |
[INFO] [stdout] 14 | pub const MSCRATCH: usize = 0x340;
[INFO] [stdout]    |           ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `SSCRATCH` is never used
[INFO] [stdout]   --> src/emulator/csr.rs:32:11
[INFO] [stdout]    |
[INFO] [stdout] 32 | pub const SSCRATCH: usize = 0x140;
[INFO] [stdout]    |           ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `SATP` is never used
[INFO] [stdout]   --> src/emulator/csr.rs:42:11
[INFO] [stdout]    |
[INFO] [stdout] 42 | pub const SATP: usize = 0x180;
[INFO] [stdout]    |           ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `MASK_VS` is never used
[INFO] [stdout]   --> src/emulator/csr.rs:51:11
[INFO] [stdout]    |
[INFO] [stdout] 51 | pub const MASK_VS: u64 = 0b11 << 9;
[INFO] [stdout]    |           ^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `MASK_MPRV` is never used
[INFO] [stdout]   --> src/emulator/csr.rs:55:11
[INFO] [stdout]    |
[INFO] [stdout] 55 | pub const MASK_MPRV: u64 = 1 << 17;
[INFO] [stdout]    |           ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `MASK_TVM` is never used
[INFO] [stdout]   --> src/emulator/csr.rs:58:11
[INFO] [stdout]    |
[INFO] [stdout] 58 | pub const MASK_TVM: u64 = 1 << 20;
[INFO] [stdout]    |           ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `MASK_TW` is never used
[INFO] [stdout]   --> src/emulator/csr.rs:59:11
[INFO] [stdout]    |
[INFO] [stdout] 59 | pub const MASK_TW: u64 = 1 << 21;
[INFO] [stdout]    |           ^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `MASK_TSR` is never used
[INFO] [stdout]   --> src/emulator/csr.rs:60:11
[INFO] [stdout]    |
[INFO] [stdout] 60 | pub const MASK_TSR: u64 = 1 << 22;
[INFO] [stdout]    |           ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `MASK_SXL` is never used
[INFO] [stdout]   --> src/emulator/csr.rs:62:11
[INFO] [stdout]    |
[INFO] [stdout] 62 | pub const MASK_SXL: u64 = 0b11 << 34;
[INFO] [stdout]    |           ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `MASK_SBE` is never used
[INFO] [stdout]   --> src/emulator/csr.rs:63:11
[INFO] [stdout]    |
[INFO] [stdout] 63 | pub const MASK_SBE: u64 = 1 << 36;
[INFO] [stdout]    |           ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `MASK_MBE` is never used
[INFO] [stdout]   --> src/emulator/csr.rs:64:11
[INFO] [stdout]    |
[INFO] [stdout] 64 | pub const MASK_MBE: u64 = 1 << 37;
[INFO] [stdout]    |           ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `Thing` is never constructed
[INFO] [stdout]  --> src/emulator/errors.rs:4:12
[INFO] [stdout]   |
[INFO] [stdout] 4 | pub struct Thing;
[INFO] [stdout]   |            ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated function `from_u32` is never used
[INFO] [stdout]   --> src/emulator/instructions.rs:29:12
[INFO] [stdout]    |
[INFO] [stdout] 28 | impl R_Instr {
[INFO] [stdout]    | ------------ associated function in this implementation
[INFO] [stdout] 29 |     pub fn from_u32(inst: u32) -> R_Instr {
[INFO] [stdout]    |            ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `I_Instr` is never constructed
[INFO] [stdout]   --> src/emulator/instructions.rs:42:12
[INFO] [stdout]    |
[INFO] [stdout] 42 | pub struct I_Instr {
[INFO] [stdout]    |            ^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated function `from_u32` is never used
[INFO] [stdout]   --> src/emulator/instructions.rs:51:12
[INFO] [stdout]    |
[INFO] [stdout] 50 | impl I_Instr {
[INFO] [stdout]    | ------------ associated function in this implementation
[INFO] [stdout] 51 |     pub fn from_u32(inst: u32) -> I_Instr {
[INFO] [stdout]    |            ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `S_Instr` is never constructed
[INFO] [stdout]   --> src/emulator/instructions.rs:63:12
[INFO] [stdout]    |
[INFO] [stdout] 63 | pub struct S_Instr {
[INFO] [stdout]    |            ^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated function `from_u32` is never used
[INFO] [stdout]   --> src/emulator/instructions.rs:72:12
[INFO] [stdout]    |
[INFO] [stdout] 71 | impl S_Instr {
[INFO] [stdout]    | ------------ associated function in this implementation
[INFO] [stdout] 72 |     pub fn from_u32(inst: u32) -> S_Instr {
[INFO] [stdout]    |            ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `B_Instr` is never constructed
[INFO] [stdout]   --> src/emulator/instructions.rs:86:12
[INFO] [stdout]    |
[INFO] [stdout] 86 | pub struct B_Instr {
[INFO] [stdout]    |            ^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated function `from_u32` is never used
[INFO] [stdout]   --> src/emulator/instructions.rs:95:12
[INFO] [stdout]    |
[INFO] [stdout] 94 | impl B_Instr {
[INFO] [stdout]    | ------------ associated function in this implementation
[INFO] [stdout] 95 |     pub fn from_u32(inst: u32) -> B_Instr {
[INFO] [stdout]    |            ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `U_Instr` is never constructed
[INFO] [stdout]    --> src/emulator/instructions.rs:115:12
[INFO] [stdout]     |
[INFO] [stdout] 115 | pub struct U_Instr {
[INFO] [stdout]     |            ^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated function `from_u32` is never used
[INFO] [stdout]    --> src/emulator/instructions.rs:122:12
[INFO] [stdout]     |
[INFO] [stdout] 121 | impl U_Instr {
[INFO] [stdout]     | ------------ associated function in this implementation
[INFO] [stdout] 122 |     pub fn from_u32(inst: u32) -> U_Instr {
[INFO] [stdout]     |            ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `J_Instr` is never constructed
[INFO] [stdout]    --> src/emulator/instructions.rs:134:12
[INFO] [stdout]     |
[INFO] [stdout] 134 | pub struct J_Instr {
[INFO] [stdout]     |            ^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated function `from_u32` is never used
[INFO] [stdout]    --> src/emulator/instructions.rs:141:12
[INFO] [stdout]     |
[INFO] [stdout] 140 | impl J_Instr {
[INFO] [stdout]     | ------------ associated function in this implementation
[INFO] [stdout] 141 |     pub fn from_u32(inst: u32) -> J_Instr {
[INFO] [stdout]     |            ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `Plic` is never constructed
[INFO] [stdout]  --> src/emulator/plic.rs:6:12
[INFO] [stdout]   |
[INFO] [stdout] 6 | pub struct Plic {
[INFO] [stdout]   |            ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `PLIC_COMPLETED_ADDR` is never used
[INFO] [stdout]   --> src/emulator/plic.rs:18:11
[INFO] [stdout]    |
[INFO] [stdout] 18 | pub const PLIC_COMPLETED_ADDR: u64 = PLIC_CLAIM_ADDR + 4;
[INFO] [stdout]    |           ^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `PLIC_END` is never used
[INFO] [stdout]   --> src/emulator/plic.rs:19:11
[INFO] [stdout]    |
[INFO] [stdout] 19 | pub const PLIC_END: u64 = PLIC_COMPLETED_ADDR;
[INFO] [stdout]    |           ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated items `new`, `load`, and `store` are never used
[INFO] [stdout]   --> src/emulator/plic.rs:22:12
[INFO] [stdout]    |
[INFO] [stdout] 21 | impl Plic {
[INFO] [stdout]    | --------- associated items in this implementation
[INFO] [stdout] 22 |     pub fn new() -> Self {
[INFO] [stdout]    |            ^^^
[INFO] [stdout] ...
[INFO] [stdout] 32 |     pub fn load(&self, addr: u64) -> Result<u64, errors::Exception> {
[INFO] [stdout]    |            ^^^^
[INFO] [stdout] ...
[INFO] [stdout] 45 |     pub fn store(&mut self, addr: u64, value: u64) -> Result<(), errors::Exception> {
[INFO] [stdout]    |            ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `UART_LSR_THR_STATUS_FLAG` is never used
[INFO] [stdout]   --> src/emulator/uart.rs:26:11
[INFO] [stdout]    |
[INFO] [stdout] 26 | pub const UART_LSR_THR_STATUS_FLAG: u8 = 1 << 5;
[INFO] [stdout]    |           ^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: crate `Risc_V_Emulator` should have a snake case name
[INFO] [stdout]   |
[INFO] [stdout]   = help: convert the identifier to snake case: `risc_v_emulator`
[INFO] [stdout]   = note: `#[warn(non_snake_case)]` (part of `#[warn(nonstandard_style)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused `Result` that must be used
[INFO] [stdout]   --> src/lib.rs:20:5
[INFO] [stdout]    |
[INFO] [stdout] 20 |     file.read_to_end(&mut code);
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: this `Result` may be an `Err` variant, which should be handled
[INFO] [stdout]    = note: `#[warn(unused_must_use)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] help: use `let _ = ...` to ignore the resulting value
[INFO] [stdout]    |
[INFO] [stdout] 20 |     let _ = file.read_to_end(&mut code);
[INFO] [stdout]    |     +++++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `User` should have an upper case name
[INFO] [stdout]   --> src/emulator.rs:14:7
[INFO] [stdout]    |
[INFO] [stdout] 14 | const User: Mode = 0; // 0b00
[INFO] [stdout]    |       ^^^^ help: convert the identifier to upper case: `USER`
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(non_upper_case_globals)]` (part of `#[warn(nonstandard_style)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `Supervisor` should have an upper case name
[INFO] [stdout]   --> src/emulator.rs:15:7
[INFO] [stdout]    |
[INFO] [stdout] 15 | const Supervisor: Mode = 1; // 0b01
[INFO] [stdout]    |       ^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout] help: convert the identifier to upper case
[INFO] [stdout]    |
[INFO] [stdout] 15 - const Supervisor: Mode = 1; // 0b01
[INFO] [stdout] 15 + const SUPERVISOR: Mode = 1; // 0b01
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `Machine` should have an upper case name
[INFO] [stdout]   --> src/emulator.rs:16:7
[INFO] [stdout]    |
[INFO] [stdout] 16 | const Machine: Mode = 3; // 0b11
[INFO] [stdout]    |       ^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout] help: convert the identifier to upper case
[INFO] [stdout]    |
[INFO] [stdout] 16 - const Machine: Mode = 3; // 0b11
[INFO] [stdout] 16 + const MACHINE: Mode = 3; // 0b11
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stderr]    Compiling Risc-V-Emulator v0.1.0 (/opt/rustwide/workdir)
[INFO] [stdout] warning: variable `MEMORY_SIZE` should have a snake case name
[INFO] [stdout]   --> src/emulator.rs:41:13
[INFO] [stdout]    |
[INFO] [stdout] 41 |         let MEMORY_SIZE = 1024*1024*128; // Define 10MiB memory
[INFO] [stdout]    |             ^^^^^^^^^^^ help: convert the identifier to snake case: `memory_size`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable `SPP_FLAG_POS` should have a snake case name
[INFO] [stdout]    --> src/emulator.rs:354:29
[INFO] [stdout]     |
[INFO] [stdout] 354 |                         let SPP_FLAG_POS = 8; 
[INFO] [stdout]     |                             ^^^^^^^^^^^^ help: convert the identifier to snake case: `spp_flag_pos`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable `SPIE_FLAG_POS` should have a snake case name
[INFO] [stdout]    --> src/emulator.rs:359:29
[INFO] [stdout]     |
[INFO] [stdout] 359 |                         let SPIE_FLAG_POS = 5;
[INFO] [stdout]     |                             ^^^^^^^^^^^^^ help: convert the identifier to snake case: `spie_flag_pos`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable `SIE_FLAG_POS` should have a snake case name
[INFO] [stdout]    --> src/emulator.rs:360:29
[INFO] [stdout]     |
[INFO] [stdout] 360 |                         let SIE_FLAG_POS = 1;
[INFO] [stdout]     |                             ^^^^^^^^^^^^ help: convert the identifier to snake case: `sie_flag_pos`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable `SupervisorSoftwareInterrupt` should have a snake case name
[INFO] [stdout]   --> src/emulator/interrupt.rs:17:13
[INFO] [stdout]    |
[INFO] [stdout] 17 |             SupervisorSoftwareInterrupt => 1,
[INFO] [stdout]    |             ^^^^^^^^^^^^^^^^^^^^^^^^^^^ help: convert the identifier to snake case: `supervisor_software_interrupt`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable `MachineSoftwareInterrupt` should have a snake case name
[INFO] [stdout]   --> src/emulator/interrupt.rs:18:13
[INFO] [stdout]    |
[INFO] [stdout] 18 |             MachineSoftwareInterrupt => 3,
[INFO] [stdout]    |             ^^^^^^^^^^^^^^^^^^^^^^^^ help: convert the identifier to snake case: `machine_software_interrupt`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable `SupervisorTimerInterrupt` should have a snake case name
[INFO] [stdout]   --> src/emulator/interrupt.rs:19:13
[INFO] [stdout]    |
[INFO] [stdout] 19 |             SupervisorTimerInterrupt => 5,
[INFO] [stdout]    |             ^^^^^^^^^^^^^^^^^^^^^^^^ help: convert the identifier to snake case: `supervisor_timer_interrupt`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable `MachineTimerInterrupt` should have a snake case name
[INFO] [stdout]   --> src/emulator/interrupt.rs:20:13
[INFO] [stdout]    |
[INFO] [stdout] 20 |             MachineTimerInterrupt => 7,
[INFO] [stdout]    |             ^^^^^^^^^^^^^^^^^^^^^ help: convert the identifier to snake case: `machine_timer_interrupt`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable `SupervisorExternalInterrupt` should have a snake case name
[INFO] [stdout]   --> src/emulator/interrupt.rs:21:13
[INFO] [stdout]    |
[INFO] [stdout] 21 |             SupervisorExternalInterrupt => 9,
[INFO] [stdout]    |             ^^^^^^^^^^^^^^^^^^^^^^^^^^^ help: convert the identifier to snake case: `supervisor_external_interrupt`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable `MachineExternalInterrupt` should have a snake case name
[INFO] [stdout]   --> src/emulator/interrupt.rs:22:13
[INFO] [stdout]    |
[INFO] [stdout] 22 |             MachineExternalInterrupt => 11,
[INFO] [stdout]    |             ^^^^^^^^^^^^^^^^^^^^^^^^ help: convert the identifier to snake case: `machine_external_interrupt`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] For more information about this error, try `rustc --explain E0170`.
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::env`
[INFO] [stdout]  --> tests/test_add.rs:5:5
[INFO] [stdout]   |
[INFO] [stdout] 5 | use std::env;
[INFO] [stdout]   |     ^^^^^^^^
[INFO] [stdout]   |
[INFO] [stdout]   = note: `#[warn(unused_imports)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary parentheses around `match` scrutinee expression
[INFO] [stdout]   --> src/emulator/bus.rs:20:15
[INFO] [stdout]    |
[INFO] [stdout] 20 |         match (addr) {
[INFO] [stdout]    |               ^    ^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(unused_parens)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] help: remove these parentheses
[INFO] [stdout]    |
[INFO] [stdout] 20 -         match (addr) {
[INFO] [stdout] 20 +         match addr {
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary parentheses around `match` scrutinee expression
[INFO] [stdout]   --> src/emulator/bus.rs:28:14
[INFO] [stdout]    |
[INFO] [stdout] 28 |         match(addr) {
[INFO] [stdout]    |              ^    ^
[INFO] [stdout]    |
[INFO] [stdout] help: remove these parentheses
[INFO] [stdout]    |
[INFO] [stdout] 28 -         match(addr) {
[INFO] [stdout] 28 +         match addr {
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary parentheses around `if` condition
[INFO] [stdout]   --> src/emulator/dram.rs:17:12
[INFO] [stdout]    |
[INFO] [stdout] 17 |         if (![8, 16, 32, 64].contains(&size)) {
[INFO] [stdout]    |            ^                                ^
[INFO] [stdout]    |
[INFO] [stdout] help: remove these parentheses
[INFO] [stdout]    |
[INFO] [stdout] 17 -         if (![8, 16, 32, 64].contains(&size)) {
[INFO] [stdout] 17 +         if ![8, 16, 32, 64].contains(&size) {
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary parentheses around `if` condition
[INFO] [stdout]   --> src/emulator/dram.rs:33:12
[INFO] [stdout]    |
[INFO] [stdout] 33 |         if (![8, 16, 32, 64].contains(&size)) {
[INFO] [stdout]    |            ^                                ^
[INFO] [stdout]    |
[INFO] [stdout] help: remove these parentheses
[INFO] [stdout]    |
[INFO] [stdout] 33 -         if (![8, 16, 32, 64].contains(&size)) {
[INFO] [stdout] 33 +         if ![8, 16, 32, 64].contains(&size) {
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary parentheses around `match` scrutinee expression
[INFO] [stdout]   --> src/emulator/errors.rs:53:14
[INFO] [stdout]    |
[INFO] [stdout] 53 |         match(self) {
[INFO] [stdout]    |              ^    ^
[INFO] [stdout]    |
[INFO] [stdout] help: remove these parentheses
[INFO] [stdout]    |
[INFO] [stdout] 53 -         match(self) {
[INFO] [stdout] 53 +         match self {
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary parentheses around `match` scrutinee expression
[INFO] [stdout]   --> src/emulator/errors.rs:72:14
[INFO] [stdout]    |
[INFO] [stdout] 72 |         match(self) {
[INFO] [stdout]    |              ^    ^
[INFO] [stdout]    |
[INFO] [stdout] help: remove these parentheses
[INFO] [stdout]    |
[INFO] [stdout] 72 -         match(self) {
[INFO] [stdout] 72 +         match self {
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: type `R_Instr` should have an upper camel case name
[INFO] [stdout]   --> src/emulator/instructions.rs:19:12
[INFO] [stdout]    |
[INFO] [stdout] 19 | pub struct R_Instr {
[INFO] [stdout]    |            ^^^^^^^ help: convert the identifier to upper camel case: `RInstr`
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(non_camel_case_types)]` (part of `#[warn(nonstandard_style)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: type `I_Instr` should have an upper camel case name
[INFO] [stdout]   --> src/emulator/instructions.rs:42:12
[INFO] [stdout]    |
[INFO] [stdout] 42 | pub struct I_Instr {
[INFO] [stdout]    |            ^^^^^^^ help: convert the identifier to upper camel case: `IInstr`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: type `S_Instr` should have an upper camel case name
[INFO] [stdout]   --> src/emulator/instructions.rs:63:12
[INFO] [stdout]    |
[INFO] [stdout] 63 | pub struct S_Instr {
[INFO] [stdout]    |            ^^^^^^^ help: convert the identifier to upper camel case: `SInstr`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: type `B_Instr` should have an upper camel case name
[INFO] [stdout]   --> src/emulator/instructions.rs:86:12
[INFO] [stdout]    |
[INFO] [stdout] 86 | pub struct B_Instr {
[INFO] [stdout]    |            ^^^^^^^ help: convert the identifier to upper camel case: `BInstr`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: type `U_Instr` should have an upper camel case name
[INFO] [stdout]    --> src/emulator/instructions.rs:115:12
[INFO] [stdout]     |
[INFO] [stdout] 115 | pub struct U_Instr {
[INFO] [stdout]     |            ^^^^^^^ help: convert the identifier to upper camel case: `UInstr`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: type `J_Instr` should have an upper camel case name
[INFO] [stdout]    --> src/emulator/instructions.rs:134:12
[INFO] [stdout]     |
[INFO] [stdout] 134 | pub struct J_Instr {
[INFO] [stdout]     |            ^^^^^^^ help: convert the identifier to upper camel case: `JInstr`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary parentheses around `match` scrutinee expression
[INFO] [stdout]   --> src/emulator/interrupt.rs:16:35
[INFO] [stdout]    |
[INFO] [stdout] 16 |         let interrupt_code = match(self) {
[INFO] [stdout]    |                                   ^    ^
[INFO] [stdout]    |
[INFO] [stdout] help: remove these parentheses
[INFO] [stdout]    |
[INFO] [stdout] 16 -         let interrupt_code = match(self) {
[INFO] [stdout] 16 +         let interrupt_code = match self {
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary parentheses around `match` scrutinee expression
[INFO] [stdout]   --> src/emulator/plic.rs:33:14
[INFO] [stdout]    |
[INFO] [stdout] 33 |         match(addr) {
[INFO] [stdout]    |              ^    ^
[INFO] [stdout]    |
[INFO] [stdout] help: remove these parentheses
[INFO] [stdout]    |
[INFO] [stdout] 33 -         match(addr) {
[INFO] [stdout] 33 +         match addr {
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary parentheses around `match` scrutinee expression
[INFO] [stdout]   --> src/emulator/plic.rs:46:14
[INFO] [stdout]    |
[INFO] [stdout] 46 |         match(addr) {
[INFO] [stdout]    |              ^    ^
[INFO] [stdout]    |
[INFO] [stdout] help: remove these parentheses
[INFO] [stdout]    |
[INFO] [stdout] 46 -         match(addr) {
[INFO] [stdout] 46 +         match addr {
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary parentheses around `match` scrutinee expression
[INFO] [stdout]   --> src/emulator/uart.rs:59:18
[INFO] [stdout]    |
[INFO] [stdout] 59 |             match(read_io) {
[INFO] [stdout]    |                  ^       ^
[INFO] [stdout]    |
[INFO] [stdout] help: remove these parentheses
[INFO] [stdout]    |
[INFO] [stdout] 59 -             match(read_io) {
[INFO] [stdout] 59 +             match read_io {
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary parentheses around `while` condition
[INFO] [stdout]   --> src/emulator/uart.rs:65:27
[INFO] [stdout]    |
[INFO] [stdout] 65 |                     while (array[UART_LSR_INDEX as usize] & UART_LSR_RHR_STATUS_FLAG == 1) {
[INFO] [stdout]    |                           ^                                                              ^
[INFO] [stdout]    |
[INFO] [stdout] help: remove these parentheses
[INFO] [stdout]    |
[INFO] [stdout] 65 -                     while (array[UART_LSR_INDEX as usize] & UART_LSR_RHR_STATUS_FLAG == 1) {
[INFO] [stdout] 65 +                     while array[UART_LSR_INDEX as usize] & UART_LSR_RHR_STATUS_FLAG == 1 {
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary parentheses around `match` scrutinee expression
[INFO] [stdout]   --> src/emulator/uart.rs:85:15
[INFO] [stdout]    |
[INFO] [stdout] 85 |         match (index) {
[INFO] [stdout]    |               ^     ^
[INFO] [stdout]    |
[INFO] [stdout] help: remove these parentheses
[INFO] [stdout]    |
[INFO] [stdout] 85 -         match (index) {
[INFO] [stdout] 85 +         match index {
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary parentheses around `match` scrutinee expression
[INFO] [stdout]    --> src/emulator/uart.rs:101:15
[INFO] [stdout]     |
[INFO] [stdout] 101 |         match (index) {
[INFO] [stdout]     |               ^     ^
[INFO] [stdout]     |
[INFO] [stdout] help: remove these parentheses
[INFO] [stdout]     |
[INFO] [stdout] 101 -         match (index) {
[INFO] [stdout] 101 +         match index {
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary parentheses around `while` condition
[INFO] [stdout]   --> src/emulator.rs:49:15
[INFO] [stdout]    |
[INFO] [stdout] 49 |         while (self.pc < self.bus.dram.dram.len() as u64) {
[INFO] [stdout]    |               ^                                         ^
[INFO] [stdout]    |
[INFO] [stdout] help: remove these parentheses
[INFO] [stdout]    |
[INFO] [stdout] 49 -         while (self.pc < self.bus.dram.dram.len() as u64) {
[INFO] [stdout] 49 +         while self.pc < self.bus.dram.dram.len() as u64 {
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary parentheses around method argument
[INFO] [stdout]   --> src/emulator.rs:77:35
[INFO] [stdout]    |
[INFO] [stdout] 77 |         let instr = self.bus.load((index as u64), 32);
[INFO] [stdout]    |                                   ^            ^
[INFO] [stdout]    |
[INFO] [stdout] help: remove these parentheses
[INFO] [stdout]    |
[INFO] [stdout] 77 -         let instr = self.bus.load((index as u64), 32);
[INFO] [stdout] 77 +         let instr = self.bus.load(index as u64, 32);
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary parentheses around `for` iterator expression
[INFO] [stdout]   --> src/emulator.rs:99:18
[INFO] [stdout]    |
[INFO] [stdout] 99 |         for i in (0..self.regs.len()) {
[INFO] [stdout]    |                  ^                  ^
[INFO] [stdout]    |
[INFO] [stdout] help: remove these parentheses
[INFO] [stdout]    |
[INFO] [stdout] 99 -         for i in (0..self.regs.len()) {
[INFO] [stdout] 99 +         for i in 0..self.regs.len() {
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary parentheses around `if` condition
[INFO] [stdout]    --> src/emulator.rs:110:12
[INFO] [stdout]     |
[INFO] [stdout] 110 |         if (delegate_to_s_mode) {
[INFO] [stdout]     |            ^                  ^
[INFO] [stdout]     |
[INFO] [stdout] help: remove these parentheses
[INFO] [stdout]     |
[INFO] [stdout] 110 -         if (delegate_to_s_mode) {
[INFO] [stdout] 110 +         if delegate_to_s_mode {
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary parentheses around `if` condition
[INFO] [stdout]    --> src/emulator.rs:113:16
[INFO] [stdout]     |
[INFO] [stdout] 113 |             if (tvec & 0b11 == 0) {
[INFO] [stdout]     |                ^                ^
[INFO] [stdout]     |
[INFO] [stdout] help: remove these parentheses
[INFO] [stdout]     |
[INFO] [stdout] 113 -             if (tvec & 0b11 == 0) {
[INFO] [stdout] 113 +             if tvec & 0b11 == 0 {
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary parentheses around `if` condition
[INFO] [stdout]    --> src/emulator.rs:132:16
[INFO] [stdout]     |
[INFO] [stdout] 132 |             if (tvec & 0b11 == 0) {
[INFO] [stdout]     |                ^                ^
[INFO] [stdout]     |
[INFO] [stdout] help: remove these parentheses
[INFO] [stdout]     |
[INFO] [stdout] 132 -             if (tvec & 0b11 == 0) {
[INFO] [stdout] 132 +             if tvec & 0b11 == 0 {
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary parentheses around `if` condition
[INFO] [stdout]    --> src/emulator.rs:154:12
[INFO] [stdout]     |
[INFO] [stdout] 154 |         if (error.is_fatal()) { 
[INFO] [stdout]     |            ^                ^
[INFO] [stdout]     |
[INFO] [stdout] help: remove these parentheses
[INFO] [stdout]     |
[INFO] [stdout] 154 -         if (error.is_fatal()) { 
[INFO] [stdout] 154 +         if error.is_fatal() { 
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary parentheses around `if` condition
[INFO] [stdout]    --> src/emulator.rs:167:12
[INFO] [stdout]     |
[INFO] [stdout] 167 |         if (should_deleg_to_supervisor) {
[INFO] [stdout]     |            ^                          ^
[INFO] [stdout]     |
[INFO] [stdout] help: remove these parentheses
[INFO] [stdout]     |
[INFO] [stdout] 167 -         if (should_deleg_to_supervisor) {
[INFO] [stdout] 167 +         if should_deleg_to_supervisor {
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary parentheses around `if` condition
[INFO] [stdout]    --> src/emulator.rs:206:12
[INFO] [stdout]     |
[INFO] [stdout] 206 |         if (self.mode == Machine && (self.csr.load(MSTATUS) & MASK_MIE) == 0) {
[INFO] [stdout]     |            ^                                                                ^
[INFO] [stdout]     |
[INFO] [stdout] help: remove these parentheses
[INFO] [stdout]     |
[INFO] [stdout] 206 -         if (self.mode == Machine && (self.csr.load(MSTATUS) & MASK_MIE) == 0) {
[INFO] [stdout] 206 +         if self.mode == Machine && (self.csr.load(MSTATUS) & MASK_MIE) == 0 {
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary parentheses around `if` condition
[INFO] [stdout]    --> src/emulator.rs:211:12
[INFO] [stdout]     |
[INFO] [stdout] 211 |         if ((self.mode == Supervisor) &&  (self.csr.load(MSTATUS) & MASK_SIE) == 0) {
[INFO] [stdout]     |            ^                                                                      ^
[INFO] [stdout]     |
[INFO] [stdout] help: remove these parentheses
[INFO] [stdout]     |
[INFO] [stdout] 211 -         if ((self.mode == Supervisor) &&  (self.csr.load(MSTATUS) & MASK_SIE) == 0) {
[INFO] [stdout] 211 +         if (self.mode == Supervisor) &&  (self.csr.load(MSTATUS) & MASK_SIE) == 0 {
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary parentheses around `if` condition
[INFO] [stdout]    --> src/emulator.rs:215:12
[INFO] [stdout]     |
[INFO] [stdout] 215 |         if (self.bus.uart.is_interrupting()) {
[INFO] [stdout]     |            ^                               ^
[INFO] [stdout]     |
[INFO] [stdout] help: remove these parentheses
[INFO] [stdout]     |
[INFO] [stdout] 215 -         if (self.bus.uart.is_interrupting()) {
[INFO] [stdout] 215 +         if self.bus.uart.is_interrupting() {
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary parentheses around assigned value
[INFO] [stdout]    --> src/emulator.rs:257:25
[INFO] [stdout]     |
[INFO] [stdout] 257 |         let flag_mask = (1 << flag_index);
[INFO] [stdout]     |                         ^               ^
[INFO] [stdout]     |
[INFO] [stdout] help: remove these parentheses
[INFO] [stdout]     |
[INFO] [stdout] 257 -         let flag_mask = (1 << flag_index);
[INFO] [stdout] 257 +         let flag_mask = 1 << flag_index;
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary parentheses around `return` value
[INFO] [stdout]    --> src/emulator.rs:258:16
[INFO] [stdout]     |
[INFO] [stdout] 258 |         return ((status & flag_mask) > 0);
[INFO] [stdout]     |                ^                        ^
[INFO] [stdout]     |
[INFO] [stdout] help: remove these parentheses
[INFO] [stdout]     |
[INFO] [stdout] 258 -         return ((status & flag_mask) > 0);
[INFO] [stdout] 258 +         return (status & flag_mask) > 0;
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary parentheses around `match` scrutinee expression
[INFO] [stdout]    --> src/emulator.rs:272:14
[INFO] [stdout]     |
[INFO] [stdout] 272 |         match(inst.opcode) {
[INFO] [stdout]     |              ^           ^
[INFO] [stdout]     |
[INFO] [stdout] help: remove these parentheses
[INFO] [stdout]     |
[INFO] [stdout] 272 -         match(inst.opcode) {
[INFO] [stdout] 272 +         match inst.opcode {
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary parentheses around `match` scrutinee expression
[INFO] [stdout]    --> src/emulator.rs:274:23
[INFO] [stdout]     |
[INFO] [stdout] 274 |                 match (inst.funct3) {
[INFO] [stdout]     |                       ^           ^
[INFO] [stdout]     |
[INFO] [stdout] help: remove these parentheses
[INFO] [stdout]     |
[INFO] [stdout] 274 -                 match (inst.funct3) {
[INFO] [stdout] 274 +                 match inst.funct3 {
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary parentheses around `match` scrutinee expression
[INFO] [stdout]    --> src/emulator.rs:276:31
[INFO] [stdout]     |
[INFO] [stdout] 276 |                         match (inst.funct7) {
[INFO] [stdout]     |                               ^           ^
[INFO] [stdout]     |
[INFO] [stdout] help: remove these parentheses
[INFO] [stdout]     |
[INFO] [stdout] 276 -                         match (inst.funct7) {
[INFO] [stdout] 276 +                         match inst.funct7 {
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary parentheses around `match` scrutinee expression
[INFO] [stdout]    --> src/emulator.rs:290:22
[INFO] [stdout]     |
[INFO] [stdout] 290 |                 match(inst.funct3) {
[INFO] [stdout]     |                      ^           ^
[INFO] [stdout]     |
[INFO] [stdout] help: remove these parentheses
[INFO] [stdout]     |
[INFO] [stdout] 290 -                 match(inst.funct3) {
[INFO] [stdout] 290 +                 match inst.funct3 {
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary parentheses around assigned value
[INFO] [stdout]    --> src/emulator.rs:301:38
[INFO] [stdout]     |
[INFO] [stdout] 301 |                         let result = ((self.regs[inst.rs1] as i64) < imm as i64);
[INFO] [stdout]     |                                      ^                                         ^
[INFO] [stdout]     |
[INFO] [stdout] help: remove these parentheses
[INFO] [stdout]     |
[INFO] [stdout] 301 -                         let result = ((self.regs[inst.rs1] as i64) < imm as i64);
[INFO] [stdout] 301 +                         let result = (self.regs[inst.rs1] as i64) < imm as i64;
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary parentheses around assigned value
[INFO] [stdout]    --> src/emulator.rs:305:38
[INFO] [stdout]     |
[INFO] [stdout] 305 |                         let result = ((self.regs[inst.rs1] as u64) < imm);
[INFO] [stdout]     |                                      ^                                  ^
[INFO] [stdout]     |
[INFO] [stdout] help: remove these parentheses
[INFO] [stdout]     |
[INFO] [stdout] 305 -                         let result = ((self.regs[inst.rs1] as u64) < imm);
[INFO] [stdout] 305 +                         let result = (self.regs[inst.rs1] as u64) < imm;
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary parentheses around `match` scrutinee expression
[INFO] [stdout]    --> src/emulator.rs:312:30
[INFO] [stdout]     |
[INFO] [stdout] 312 |                         match(inst.funct7) {
[INFO] [stdout]     |                              ^           ^
[INFO] [stdout]     |
[INFO] [stdout] help: remove these parentheses
[INFO] [stdout]     |
[INFO] [stdout] 312 -                         match(inst.funct7) {
[INFO] [stdout] 312 +                         match inst.funct7 {
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary parentheses around assigned value
[INFO] [stdout]    --> src/emulator.rs:335:38
[INFO] [stdout]     |
[INFO] [stdout] 335 |                 self.regs[inst.rd] = (imm << 12);
[INFO] [stdout]     |                                      ^         ^
[INFO] [stdout]     |
[INFO] [stdout] help: remove these parentheses
[INFO] [stdout]     |
[INFO] [stdout] 335 -                 self.regs[inst.rd] = (imm << 12);
[INFO] [stdout] 335 +                 self.regs[inst.rd] = imm << 12;
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary parentheses around assigned value
[INFO] [stdout]    --> src/emulator.rs:355:37
[INFO] [stdout]     |
[INFO] [stdout] 355 |                         self.mode = (updated_sstatus & (1 << SPP_FLAG_POS) >> SPP_FLAG_POS);
[INFO] [stdout]     |                                     ^                                                     ^
[INFO] [stdout]     |
[INFO] [stdout] help: remove these parentheses
[INFO] [stdout]     |
[INFO] [stdout] 355 -                         self.mode = (updated_sstatus & (1 << SPP_FLAG_POS) >> SPP_FLAG_POS);
[INFO] [stdout] 355 +                         self.mode = updated_sstatus & (1 << SPP_FLAG_POS) >> SPP_FLAG_POS;
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary parentheses around assigned value
[INFO] [stdout]    --> src/emulator.rs:361:36
[INFO] [stdout]     |
[INFO] [stdout] 361 |                         let spie = (updated_sstatus & (1 << SPIE_FLAG_POS) >> SPIE_FLAG_POS);
[INFO] [stdout]     |                                    ^                                                       ^
[INFO] [stdout]     |
[INFO] [stdout] help: remove these parentheses
[INFO] [stdout]     |
[INFO] [stdout] 361 -                         let spie = (updated_sstatus & (1 << SPIE_FLAG_POS) >> SPIE_FLAG_POS);
[INFO] [stdout] 361 +                         let spie = updated_sstatus & (1 << SPIE_FLAG_POS) >> SPIE_FLAG_POS;
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary parentheses around assigned value
[INFO] [stdout]    --> src/emulator.rs:365:44
[INFO] [stdout]     |
[INFO] [stdout] 365 |                         updated_sstatus |= (1 << SPIE_FLAG_POS);
[INFO] [stdout]     |                                            ^                  ^
[INFO] [stdout]     |
[INFO] [stdout] help: remove these parentheses
[INFO] [stdout]     |
[INFO] [stdout] 365 -                         updated_sstatus |= (1 << SPIE_FLAG_POS);
[INFO] [stdout] 365 +                         updated_sstatus |= 1 << SPIE_FLAG_POS;
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary parentheses around `if` condition
[INFO] [stdout]   --> src/lib.rs:14:8
[INFO] [stdout]    |
[INFO] [stdout] 14 |     if (args.len() != 2) {
[INFO] [stdout]    |        ^               ^
[INFO] [stdout]    |
[INFO] [stdout] help: remove these parentheses
[INFO] [stdout]    |
[INFO] [stdout] 14 -     if (args.len() != 2) {
[INFO] [stdout] 14 +     if args.len() != 2 {
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `result`
[INFO] [stdout]   --> tests/test_add.rs:22:9
[INFO] [stdout]    |
[INFO] [stdout] 22 |     let result = read_binary(&mut code, &prog_file);
[INFO] [stdout]    |         ^^^^^^ help: if this is intentional, prefix it with an underscore: `_result`
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(unused_variables)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning[E0170]: pattern binding `SupervisorSoftwareInterrupt` is named the same as one of the variants of the type `emulator::interrupt::Interrupt`
[INFO] [stdout]   --> src/emulator/interrupt.rs:17:13
[INFO] [stdout]    |
[INFO] [stdout] 17 |             SupervisorSoftwareInterrupt => 1,
[INFO] [stdout]    |             ^^^^^^^^^^^^^^^^^^^^^^^^^^^ help: to match on the variant, qualify the path: `emulator::interrupt::Interrupt::SupervisorSoftwareInterrupt`
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(bindings_with_variant_name)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning[E0170]: pattern binding `MachineSoftwareInterrupt` is named the same as one of the variants of the type `emulator::interrupt::Interrupt`
[INFO] [stdout]   --> src/emulator/interrupt.rs:18:13
[INFO] [stdout]    |
[INFO] [stdout] 18 |             MachineSoftwareInterrupt => 3,
[INFO] [stdout]    |             ^^^^^^^^^^^^^^^^^^^^^^^^ help: to match on the variant, qualify the path: `emulator::interrupt::Interrupt::MachineSoftwareInterrupt`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning[E0170]: pattern binding `SupervisorTimerInterrupt` is named the same as one of the variants of the type `emulator::interrupt::Interrupt`
[INFO] [stdout]   --> src/emulator/interrupt.rs:19:13
[INFO] [stdout]    |
[INFO] [stdout] 19 |             SupervisorTimerInterrupt => 5,
[INFO] [stdout]    |             ^^^^^^^^^^^^^^^^^^^^^^^^ help: to match on the variant, qualify the path: `emulator::interrupt::Interrupt::SupervisorTimerInterrupt`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning[E0170]: pattern binding `MachineTimerInterrupt` is named the same as one of the variants of the type `emulator::interrupt::Interrupt`
[INFO] [stdout]   --> src/emulator/interrupt.rs:20:13
[INFO] [stdout]    |
[INFO] [stdout] 20 |             MachineTimerInterrupt => 7,
[INFO] [stdout]    |             ^^^^^^^^^^^^^^^^^^^^^ help: to match on the variant, qualify the path: `emulator::interrupt::Interrupt::MachineTimerInterrupt`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning[E0170]: pattern binding `SupervisorExternalInterrupt` is named the same as one of the variants of the type `emulator::interrupt::Interrupt`
[INFO] [stdout]   --> src/emulator/interrupt.rs:21:13
[INFO] [stdout]    |
[INFO] [stdout] 21 |             SupervisorExternalInterrupt => 9,
[INFO] [stdout]    |             ^^^^^^^^^^^^^^^^^^^^^^^^^^^ help: to match on the variant, qualify the path: `emulator::interrupt::Interrupt::SupervisorExternalInterrupt`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning[E0170]: pattern binding `MachineExternalInterrupt` is named the same as one of the variants of the type `emulator::interrupt::Interrupt`
[INFO] [stdout]   --> src/emulator/interrupt.rs:22:13
[INFO] [stdout]    |
[INFO] [stdout] 22 |             MachineExternalInterrupt => 11,
[INFO] [stdout]    |             ^^^^^^^^^^^^^^^^^^^^^^^^ help: to match on the variant, qualify the path: `emulator::interrupt::Interrupt::MachineExternalInterrupt`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unreachable pattern
[INFO] [stdout]   --> src/emulator/interrupt.rs:18:13
[INFO] [stdout]    |
[INFO] [stdout] 17 |             SupervisorSoftwareInterrupt => 1,
[INFO] [stdout]    |             --------------------------- matches any value
[INFO] [stdout] 18 |             MachineSoftwareInterrupt => 3,
[INFO] [stdout]    |             ^^^^^^^^^^^^^^^^^^^^^^^^ no value can reach this
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(unreachable_patterns)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unreachable pattern
[INFO] [stdout]   --> src/emulator/interrupt.rs:19:13
[INFO] [stdout]    |
[INFO] [stdout] 17 |             SupervisorSoftwareInterrupt => 1,
[INFO] [stdout]    |             --------------------------- matches any value
[INFO] [stdout] 18 |             MachineSoftwareInterrupt => 3,
[INFO] [stdout] 19 |             SupervisorTimerInterrupt => 5,
[INFO] [stdout]    |             ^^^^^^^^^^^^^^^^^^^^^^^^ no value can reach this
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unreachable pattern
[INFO] [stdout]   --> src/emulator/interrupt.rs:20:13
[INFO] [stdout]    |
[INFO] [stdout] 17 |             SupervisorSoftwareInterrupt => 1,
[INFO] [stdout]    |             --------------------------- matches any value
[INFO] [stdout] ...
[INFO] [stdout] 20 |             MachineTimerInterrupt => 7,
[INFO] [stdout]    |             ^^^^^^^^^^^^^^^^^^^^^ no value can reach this
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unreachable pattern
[INFO] [stdout]   --> src/emulator/interrupt.rs:21:13
[INFO] [stdout]    |
[INFO] [stdout] 17 |             SupervisorSoftwareInterrupt => 1,
[INFO] [stdout]    |             --------------------------- matches any value
[INFO] [stdout] ...
[INFO] [stdout] 21 |             SupervisorExternalInterrupt => 9,
[INFO] [stdout]    |             ^^^^^^^^^^^^^^^^^^^^^^^^^^^ no value can reach this
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unreachable pattern
[INFO] [stdout]   --> src/emulator/interrupt.rs:22:13
[INFO] [stdout]    |
[INFO] [stdout] 17 |             SupervisorSoftwareInterrupt => 1,
[INFO] [stdout]    |             --------------------------- matches any value
[INFO] [stdout] ...
[INFO] [stdout] 22 |             MachineExternalInterrupt => 11,
[INFO] [stdout]    |             ^^^^^^^^^^^^^^^^^^^^^^^^ no value can reach this
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `SupervisorSoftwareInterrupt`
[INFO] [stdout]   --> src/emulator/interrupt.rs:17:13
[INFO] [stdout]    |
[INFO] [stdout] 17 |             SupervisorSoftwareInterrupt => 1,
[INFO] [stdout]    |             ^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(unused_variables)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] help: if this is intentional, prefix it with an underscore
[INFO] [stdout]    |
[INFO] [stdout] 17 |             _SupervisorSoftwareInterrupt => 1,
[INFO] [stdout]    |             +
[INFO] [stdout] help: you might have meant to pattern match on the similarly named variant `SupervisorSoftwareInterrupt`
[INFO] [stdout]    |
[INFO] [stdout] 17 |             emulator::interrupt::Interrupt::SupervisorSoftwareInterrupt => 1,
[INFO] [stdout]    |             ++++++++++++++++++++++++++++++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `MachineSoftwareInterrupt`
[INFO] [stdout]   --> src/emulator/interrupt.rs:18:13
[INFO] [stdout]    |
[INFO] [stdout] 18 |             MachineSoftwareInterrupt => 3,
[INFO] [stdout]    |             ^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout] help: if this is intentional, prefix it with an underscore
[INFO] [stdout]    |
[INFO] [stdout] 18 |             _MachineSoftwareInterrupt => 3,
[INFO] [stdout]    |             +
[INFO] [stdout] help: you might have meant to pattern match on the similarly named variant `MachineSoftwareInterrupt`
[INFO] [stdout]    |
[INFO] [stdout] 18 |             emulator::interrupt::Interrupt::MachineSoftwareInterrupt => 3,
[INFO] [stdout]    |             ++++++++++++++++++++++++++++++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `SupervisorTimerInterrupt`
[INFO] [stdout]   --> src/emulator/interrupt.rs:19:13
[INFO] [stdout]    |
[INFO] [stdout] 19 |             SupervisorTimerInterrupt => 5,
[INFO] [stdout]    |             ^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout] help: if this is intentional, prefix it with an underscore
[INFO] [stdout]    |
[INFO] [stdout] 19 |             _SupervisorTimerInterrupt => 5,
[INFO] [stdout]    |             +
[INFO] [stdout] help: you might have meant to pattern match on the similarly named variant `SupervisorTimerInterrupt`
[INFO] [stdout]    |
[INFO] [stdout] 19 |             emulator::interrupt::Interrupt::SupervisorTimerInterrupt => 5,
[INFO] [stdout]    |             ++++++++++++++++++++++++++++++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `MachineTimerInterrupt`
[INFO] [stdout]   --> src/emulator/interrupt.rs:20:13
[INFO] [stdout]    |
[INFO] [stdout] 20 |             MachineTimerInterrupt => 7,
[INFO] [stdout]    |             ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout] help: if this is intentional, prefix it with an underscore
[INFO] [stdout]    |
[INFO] [stdout] 20 |             _MachineTimerInterrupt => 7,
[INFO] [stdout]    |             +
[INFO] [stdout] help: you might have meant to pattern match on the similarly named variant `MachineTimerInterrupt`
[INFO] [stdout]    |
[INFO] [stdout] 20 |             emulator::interrupt::Interrupt::MachineTimerInterrupt => 7,
[INFO] [stdout]    |             ++++++++++++++++++++++++++++++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `SupervisorExternalInterrupt`
[INFO] [stdout]   --> src/emulator/interrupt.rs:21:13
[INFO] [stdout]    |
[INFO] [stdout] 21 |             SupervisorExternalInterrupt => 9,
[INFO] [stdout]    |             ^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout] help: if this is intentional, prefix it with an underscore
[INFO] [stdout]    |
[INFO] [stdout] 21 |             _SupervisorExternalInterrupt => 9,
[INFO] [stdout]    |             +
[INFO] [stdout] help: you might have meant to pattern match on the similarly named variant `SupervisorExternalInterrupt`
[INFO] [stdout]    |
[INFO] [stdout] 21 |             emulator::interrupt::Interrupt::SupervisorExternalInterrupt => 9,
[INFO] [stdout]    |             ++++++++++++++++++++++++++++++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `MachineExternalInterrupt`
[INFO] [stdout]   --> src/emulator/interrupt.rs:22:13
[INFO] [stdout]    |
[INFO] [stdout] 22 |             MachineExternalInterrupt => 11,
[INFO] [stdout]    |             ^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout] help: if this is intentional, prefix it with an underscore
[INFO] [stdout]    |
[INFO] [stdout] 22 |             _MachineExternalInterrupt => 11,
[INFO] [stdout]    |             +
[INFO] [stdout] help: you might have meant to pattern match on the similarly named variant `MachineExternalInterrupt`
[INFO] [stdout]    |
[INFO] [stdout] 22 |             emulator::interrupt::Interrupt::MachineExternalInterrupt => 11,
[INFO] [stdout]    |             ++++++++++++++++++++++++++++++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]   --> src/emulator/uart.rs:39:13
[INFO] [stdout]    |
[INFO] [stdout] 39 |         let mut array = [0; UART_SIZE as 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: unused variable: `size`
[INFO] [stdout]   --> src/emulator/uart.rs:80:35
[INFO] [stdout]    |
[INFO] [stdout] 80 |     pub fn load(&self, addr: u64, size: u64) -> Result<u64, errors::Exception> {
[INFO] [stdout]    |                                   ^^^^
[INFO] [stdout]    |
[INFO] [stdout] help: if this is intentional, prefix it with an underscore
[INFO] [stdout]    |
[INFO] [stdout] 80 |     pub fn load(&self, addr: u64, _size: u64) -> Result<u64, errors::Exception> {
[INFO] [stdout]    |                                   +
[INFO] [stdout] help: you might have meant to pattern match on the similarly named constant `Machine`
[INFO] [stdout]    |
[INFO] [stdout] 80 -     pub fn load(&self, addr: u64, size: u64) -> Result<u64, errors::Exception> {
[INFO] [stdout] 80 +     pub fn load(&self, addr: u64, emulator::Machine: u64) -> Result<u64, errors::Exception> {
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `cvar`
[INFO] [stdout]   --> src/emulator/uart.rs:96:20
[INFO] [stdout]    |
[INFO] [stdout] 96 |         let (uart, cvar) = &*self.uart;
[INFO] [stdout]    |                    ^^^^ help: if this is intentional, prefix it with an underscore: `_cvar`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `size`
[INFO] [stdout]   --> src/emulator/uart.rs:95:40
[INFO] [stdout]    |
[INFO] [stdout] 95 |     pub fn store(&mut self, addr: u64, size: u64, value: u64) -> Result<(), errors::Exception> {
[INFO] [stdout]    |                                        ^^^^
[INFO] [stdout]    |
[INFO] [stdout] help: if this is intentional, prefix it with an underscore
[INFO] [stdout]    |
[INFO] [stdout] 95 |     pub fn store(&mut self, addr: u64, _size: u64, value: u64) -> Result<(), errors::Exception> {
[INFO] [stdout]    |                                        +
[INFO] [stdout] help: you might have meant to pattern match on the similarly named constant `Machine`
[INFO] [stdout]    |
[INFO] [stdout] 95 -     pub fn store(&mut self, addr: u64, size: u64, value: u64) -> Result<(), errors::Exception> {
[INFO] [stdout] 95 +     pub fn store(&mut self, addr: u64, emulator::Machine: u64, value: u64) -> Result<(), errors::Exception> {
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `User` is never used
[INFO] [stdout]   --> src/emulator.rs:14:7
[INFO] [stdout]    |
[INFO] [stdout] 14 | const User: Mode = 0; // 0b00
[INFO] [stdout]    |       ^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated function `get_status_flag` is never used
[INFO] [stdout]    --> src/emulator.rs:256:8
[INFO] [stdout]     |
[INFO] [stdout]  26 | impl Cpu {
[INFO] [stdout]     | -------- associated function in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 256 |     fn get_status_flag(status: &u64, flag_index: u64) -> bool {
[INFO] [stdout]     |        ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `MCOUNTEREN` is never used
[INFO] [stdout]   --> src/emulator/csr.rs:12:11
[INFO] [stdout]    |
[INFO] [stdout] 12 | pub const MCOUNTEREN: usize = 0x306;
[INFO] [stdout]    |           ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `MSCRATCH` is never used
[INFO] [stdout]   --> src/emulator/csr.rs:14:11
[INFO] [stdout]    |
[INFO] [stdout] 14 | pub const MSCRATCH: usize = 0x340;
[INFO] [stdout]    |           ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `SSCRATCH` is never used
[INFO] [stdout]   --> src/emulator/csr.rs:32:11
[INFO] [stdout]    |
[INFO] [stdout] 32 | pub const SSCRATCH: usize = 0x140;
[INFO] [stdout]    |           ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `SATP` is never used
[INFO] [stdout]   --> src/emulator/csr.rs:42:11
[INFO] [stdout]    |
[INFO] [stdout] 42 | pub const SATP: usize = 0x180;
[INFO] [stdout]    |           ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `MASK_VS` is never used
[INFO] [stdout]   --> src/emulator/csr.rs:51:11
[INFO] [stdout]    |
[INFO] [stdout] 51 | pub const MASK_VS: u64 = 0b11 << 9;
[INFO] [stdout]    |           ^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `MASK_MPRV` is never used
[INFO] [stdout]   --> src/emulator/csr.rs:55:11
[INFO] [stdout]    |
[INFO] [stdout] 55 | pub const MASK_MPRV: u64 = 1 << 17;
[INFO] [stdout]    |           ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `MASK_TVM` is never used
[INFO] [stdout]   --> src/emulator/csr.rs:58:11
[INFO] [stdout]    |
[INFO] [stdout] 58 | pub const MASK_TVM: u64 = 1 << 20;
[INFO] [stdout]    |           ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `MASK_TW` is never used
[INFO] [stdout]   --> src/emulator/csr.rs:59:11
[INFO] [stdout]    |
[INFO] [stdout] 59 | pub const MASK_TW: u64 = 1 << 21;
[INFO] [stdout]    |           ^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `MASK_TSR` is never used
[INFO] [stdout]   --> src/emulator/csr.rs:60:11
[INFO] [stdout]    |
[INFO] [stdout] 60 | pub const MASK_TSR: u64 = 1 << 22;
[INFO] [stdout]    |           ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `MASK_SXL` is never used
[INFO] [stdout]   --> src/emulator/csr.rs:62:11
[INFO] [stdout]    |
[INFO] [stdout] 62 | pub const MASK_SXL: u64 = 0b11 << 34;
[INFO] [stdout]    |           ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `MASK_SBE` is never used
[INFO] [stdout]   --> src/emulator/csr.rs:63:11
[INFO] [stdout]    |
[INFO] [stdout] 63 | pub const MASK_SBE: u64 = 1 << 36;
[INFO] [stdout]    |           ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `MASK_MBE` is never used
[INFO] [stdout]   --> src/emulator/csr.rs:64:11
[INFO] [stdout]    |
[INFO] [stdout] 64 | pub const MASK_MBE: u64 = 1 << 37;
[INFO] [stdout]    |           ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `Thing` is never constructed
[INFO] [stdout]  --> src/emulator/errors.rs:4:12
[INFO] [stdout]   |
[INFO] [stdout] 4 | pub struct Thing;
[INFO] [stdout]   |            ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `Plic` is never constructed
[INFO] [stdout]  --> src/emulator/plic.rs:6:12
[INFO] [stdout]   |
[INFO] [stdout] 6 | pub struct Plic {
[INFO] [stdout]   |            ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `PLIC_COMPLETED_ADDR` is never used
[INFO] [stdout]   --> src/emulator/plic.rs:18:11
[INFO] [stdout]    |
[INFO] [stdout] 18 | pub const PLIC_COMPLETED_ADDR: u64 = PLIC_CLAIM_ADDR + 4;
[INFO] [stdout]    |           ^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `PLIC_END` is never used
[INFO] [stdout]   --> src/emulator/plic.rs:19:11
[INFO] [stdout]    |
[INFO] [stdout] 19 | pub const PLIC_END: u64 = PLIC_COMPLETED_ADDR;
[INFO] [stdout]    |           ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated items `new`, `load`, and `store` are never used
[INFO] [stdout]   --> src/emulator/plic.rs:22:12
[INFO] [stdout]    |
[INFO] [stdout] 21 | impl Plic {
[INFO] [stdout]    | --------- associated items in this implementation
[INFO] [stdout] 22 |     pub fn new() -> Self {
[INFO] [stdout]    |            ^^^
[INFO] [stdout] ...
[INFO] [stdout] 32 |     pub fn load(&self, addr: u64) -> Result<u64, errors::Exception> {
[INFO] [stdout]    |            ^^^^
[INFO] [stdout] ...
[INFO] [stdout] 45 |     pub fn store(&mut self, addr: u64, value: u64) -> Result<(), errors::Exception> {
[INFO] [stdout]    |            ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `UART_LSR_THR_STATUS_FLAG` is never used
[INFO] [stdout]   --> src/emulator/uart.rs:26:11
[INFO] [stdout]    |
[INFO] [stdout] 26 | pub const UART_LSR_THR_STATUS_FLAG: u8 = 1 << 5;
[INFO] [stdout]    |           ^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused `Result` that must be used
[INFO] [stdout]   --> src/lib.rs:20:5
[INFO] [stdout]    |
[INFO] [stdout] 20 |     file.read_to_end(&mut code);
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: this `Result` may be an `Err` variant, which should be handled
[INFO] [stdout]    = note: `#[warn(unused_must_use)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] help: use `let _ = ...` to ignore the resulting value
[INFO] [stdout]    |
[INFO] [stdout] 20 |     let _ = file.read_to_end(&mut code);
[INFO] [stdout]    |     +++++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `User` should have an upper case name
[INFO] [stdout]   --> src/emulator.rs:14:7
[INFO] [stdout]    |
[INFO] [stdout] 14 | const User: Mode = 0; // 0b00
[INFO] [stdout]    |       ^^^^ help: convert the identifier to upper case: `USER`
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(non_upper_case_globals)]` (part of `#[warn(nonstandard_style)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `Supervisor` should have an upper case name
[INFO] [stdout]   --> src/emulator.rs:15:7
[INFO] [stdout]    |
[INFO] [stdout] 15 | const Supervisor: Mode = 1; // 0b01
[INFO] [stdout]    |       ^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout] help: convert the identifier to upper case
[INFO] [stdout]    |
[INFO] [stdout] 15 - const Supervisor: Mode = 1; // 0b01
[INFO] [stdout] 15 + const SUPERVISOR: Mode = 1; // 0b01
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `Machine` should have an upper case name
[INFO] [stdout]   --> src/emulator.rs:16:7
[INFO] [stdout]    |
[INFO] [stdout] 16 | const Machine: Mode = 3; // 0b11
[INFO] [stdout]    |       ^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout] help: convert the identifier to upper case
[INFO] [stdout]    |
[INFO] [stdout] 16 - const Machine: Mode = 3; // 0b11
[INFO] [stdout] 16 + const MACHINE: Mode = 3; // 0b11
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable `MEMORY_SIZE` should have a snake case name
[INFO] [stdout]   --> src/emulator.rs:41:13
[INFO] [stdout]    |
[INFO] [stdout] 41 |         let MEMORY_SIZE = 1024*1024*128; // Define 10MiB memory
[INFO] [stdout]    |             ^^^^^^^^^^^ help: convert the identifier to snake case: `memory_size`
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(non_snake_case)]` (part of `#[warn(nonstandard_style)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable `SPP_FLAG_POS` should have a snake case name
[INFO] [stdout]    --> src/emulator.rs:354:29
[INFO] [stdout]     |
[INFO] [stdout] 354 |                         let SPP_FLAG_POS = 8; 
[INFO] [stdout]     |                             ^^^^^^^^^^^^ help: convert the identifier to snake case: `spp_flag_pos`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable `SPIE_FLAG_POS` should have a snake case name
[INFO] [stdout]    --> src/emulator.rs:359:29
[INFO] [stdout]     |
[INFO] [stdout] 359 |                         let SPIE_FLAG_POS = 5;
[INFO] [stdout]     |                             ^^^^^^^^^^^^^ help: convert the identifier to snake case: `spie_flag_pos`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable `SIE_FLAG_POS` should have a snake case name
[INFO] [stdout]    --> src/emulator.rs:360:29
[INFO] [stdout]     |
[INFO] [stdout] 360 |                         let SIE_FLAG_POS = 1;
[INFO] [stdout]     |                             ^^^^^^^^^^^^ help: convert the identifier to snake case: `sie_flag_pos`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `test_R_instr_decode` should have a snake case name
[INFO] [stdout]    --> src/emulator/instructions.rs:158:8
[INFO] [stdout]     |
[INFO] [stdout] 158 |     fn test_R_instr_decode() {
[INFO] [stdout]     |        ^^^^^^^^^^^^^^^^^^^ help: convert the identifier to snake case: `test_r_instr_decode`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `test_I_instr_decode` should have a snake case name
[INFO] [stdout]    --> src/emulator/instructions.rs:172:8
[INFO] [stdout]     |
[INFO] [stdout] 172 |     fn test_I_instr_decode() {
[INFO] [stdout]     |        ^^^^^^^^^^^^^^^^^^^ help: convert the identifier to snake case (notice the capitalization): `test_i_instr_decode`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `test_S_instr_decode` should have a snake case name
[INFO] [stdout]    --> src/emulator/instructions.rs:186:8
[INFO] [stdout]     |
[INFO] [stdout] 186 |     fn test_S_instr_decode() {
[INFO] [stdout]     |        ^^^^^^^^^^^^^^^^^^^ help: convert the identifier to snake case (notice the capitalization): `test_s_instr_decode`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `test_B_instr_decode` should have a snake case name
[INFO] [stdout]    --> src/emulator/instructions.rs:200:8
[INFO] [stdout]     |
[INFO] [stdout] 200 |     fn test_B_instr_decode() {
[INFO] [stdout]     |        ^^^^^^^^^^^^^^^^^^^ help: convert the identifier to snake case: `test_b_instr_decode`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `test_U_instr_decode` should have a snake case name
[INFO] [stdout]    --> src/emulator/instructions.rs:215:8
[INFO] [stdout]     |
[INFO] [stdout] 215 |     fn test_U_instr_decode() {
[INFO] [stdout]     |        ^^^^^^^^^^^^^^^^^^^ help: convert the identifier to snake case (notice the capitalization): `test_u_instr_decode`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `test_J_instr_decode` should have a snake case name
[INFO] [stdout]    --> src/emulator/instructions.rs:229:8
[INFO] [stdout]     |
[INFO] [stdout] 229 |     fn test_J_instr_decode() {
[INFO] [stdout]     |        ^^^^^^^^^^^^^^^^^^^ help: convert the identifier to snake case: `test_j_instr_decode`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable `SupervisorSoftwareInterrupt` should have a snake case name
[INFO] [stdout]   --> src/emulator/interrupt.rs:17:13
[INFO] [stdout]    |
[INFO] [stdout] 17 |             SupervisorSoftwareInterrupt => 1,
[INFO] [stdout]    |             ^^^^^^^^^^^^^^^^^^^^^^^^^^^ help: convert the identifier to snake case: `supervisor_software_interrupt`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable `MachineSoftwareInterrupt` should have a snake case name
[INFO] [stdout]   --> src/emulator/interrupt.rs:18:13
[INFO] [stdout]    |
[INFO] [stdout] 18 |             MachineSoftwareInterrupt => 3,
[INFO] [stdout]    |             ^^^^^^^^^^^^^^^^^^^^^^^^ help: convert the identifier to snake case: `machine_software_interrupt`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable `SupervisorTimerInterrupt` should have a snake case name
[INFO] [stdout]   --> src/emulator/interrupt.rs:19:13
[INFO] [stdout]    |
[INFO] [stdout] 19 |             SupervisorTimerInterrupt => 5,
[INFO] [stdout]    |             ^^^^^^^^^^^^^^^^^^^^^^^^ help: convert the identifier to snake case: `supervisor_timer_interrupt`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable `MachineTimerInterrupt` should have a snake case name
[INFO] [stdout]   --> src/emulator/interrupt.rs:20:13
[INFO] [stdout]    |
[INFO] [stdout] 20 |             MachineTimerInterrupt => 7,
[INFO] [stdout]    |             ^^^^^^^^^^^^^^^^^^^^^ help: convert the identifier to snake case: `machine_timer_interrupt`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable `SupervisorExternalInterrupt` should have a snake case name
[INFO] [stdout]   --> src/emulator/interrupt.rs:21:13
[INFO] [stdout]    |
[INFO] [stdout] 21 |             SupervisorExternalInterrupt => 9,
[INFO] [stdout]    |             ^^^^^^^^^^^^^^^^^^^^^^^^^^^ help: convert the identifier to snake case: `supervisor_external_interrupt`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable `MachineExternalInterrupt` should have a snake case name
[INFO] [stdout]   --> src/emulator/interrupt.rs:22:13
[INFO] [stdout]    |
[INFO] [stdout] 22 |             MachineExternalInterrupt => 11,
[INFO] [stdout]    |             ^^^^^^^^^^^^^^^^^^^^^^^^ help: convert the identifier to snake case: `machine_external_interrupt`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused `Result` that must be used
[INFO] [stdout]    --> src/emulator.rs:402:13
[INFO] [stdout]     |
[INFO] [stdout] 402 |             cpu.execute(d);
[INFO] [stdout]     |             ^^^^^^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: this `Result` may be an `Err` variant, which should be handled
[INFO] [stdout] help: use `let _ = ...` to ignore the resulting value
[INFO] [stdout]     |
[INFO] [stdout] 402 |             let _ = cpu.execute(d);
[INFO] [stdout]     |             +++++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused `Result` that must be used
[INFO] [stdout]    --> src/emulator.rs:516:9
[INFO] [stdout]     |
[INFO] [stdout] 516 |         cpu.execute(inst_obj);
[INFO] [stdout]     |         ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: this `Result` may be an `Err` variant, which should be handled
[INFO] [stdout] help: use `let _ = ...` to ignore the resulting value
[INFO] [stdout]     |
[INFO] [stdout] 516 |         let _ = cpu.execute(inst_obj);
[INFO] [stdout]     |         +++++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] For more information about this error, try `rustc --explain E0170`.
[INFO] [stdout] 
[INFO] [stderr]     Finished `test` profile [unoptimized + debuginfo] target(s) in 0.69s
[INFO] running `Command { std: "docker" "inspect" "387426ede206d705eb68be7c3b7c3a98916c91d18694ef0b96f178a8d89930be", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "387426ede206d705eb68be7c3b7c3a98916c91d18694ef0b96f178a8d89930be", kill_on_drop: false }`
[INFO] [stdout] 387426ede206d705eb68be7c3b7c3a98916c91d18694ef0b96f178a8d89930be
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-5-tc2/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-5-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=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:e90291280db7d1fac5b66fc6dad9f9662629e7365a55743daf9bdf73ebc4ea79" "/opt/rustwide/cargo-home/bin/cargo" "+beta-2025-09-21" "test" "--frozen", kill_on_drop: false }`
[INFO] [stdout] 84a84b3b9d232a9936726de30dba2e07d9871b1de8d4ca6aa099cf8fa6be7056
[INFO] running `Command { std: "docker" "start" "-a" "84a84b3b9d232a9936726de30dba2e07d9871b1de8d4ca6aa099cf8fa6be7056", kill_on_drop: false }`
[INFO] [stderr] warning: unnecessary parentheses around `match` scrutinee expression
[INFO] [stderr]   --> src/emulator/bus.rs:20:15
[INFO] [stderr]    |
[INFO] [stderr] 20 |         match (addr) {
[INFO] [stderr]    |               ^    ^
[INFO] [stderr]    |
[INFO] [stderr]    = note: `#[warn(unused_parens)]` (part of `#[warn(unused)]`) on by default
[INFO] [stderr] help: remove these parentheses
[INFO] [stderr]    |
[INFO] [stderr] 20 -         match (addr) {
[INFO] [stderr] 20 +         match addr {
[INFO] [stderr]    |
[INFO] [stderr] 
[INFO] [stderr] warning: unnecessary parentheses around `match` scrutinee expression
[INFO] [stderr]   --> src/emulator/bus.rs:28:14
[INFO] [stderr]    |
[INFO] [stderr] 28 |         match(addr) {
[INFO] [stderr]    |              ^    ^
[INFO] [stderr]    |
[INFO] [stderr] help: remove these parentheses
[INFO] [stderr]    |
[INFO] [stderr] 28 -         match(addr) {
[INFO] [stderr] 28 +         match addr {
[INFO] [stderr]    |
[INFO] [stderr] 
[INFO] [stderr] warning: unnecessary parentheses around `if` condition
[INFO] [stderr]   --> src/emulator/dram.rs:17:12
[INFO] [stderr]    |
[INFO] [stderr] 17 |         if (![8, 16, 32, 64].contains(&size)) {
[INFO] [stderr]    |            ^                                ^
[INFO] [stderr]    |
[INFO] [stderr] help: remove these parentheses
[INFO] [stderr]    |
[INFO] [stderr] 17 -         if (![8, 16, 32, 64].contains(&size)) {
[INFO] [stderr] 17 +         if ![8, 16, 32, 64].contains(&size) {
[INFO] [stderr]    |
[INFO] [stderr] 
[INFO] [stderr] warning: unnecessary parentheses around `if` condition
[INFO] [stderr]   --> src/emulator/dram.rs:33:12
[INFO] [stderr]    |
[INFO] [stderr] 33 |         if (![8, 16, 32, 64].contains(&size)) {
[INFO] [stderr]    |            ^                                ^
[INFO] [stderr]    |
[INFO] [stderr] help: remove these parentheses
[INFO] [stderr]    |
[INFO] [stderr] 33 -         if (![8, 16, 32, 64].contains(&size)) {
[INFO] [stderr] 33 +         if ![8, 16, 32, 64].contains(&size) {
[INFO] [stderr]    |
[INFO] [stderr] 
[INFO] [stderr] warning: unnecessary parentheses around `match` scrutinee expression
[INFO] [stderr]   --> src/emulator/errors.rs:53:14
[INFO] [stderr]    |
[INFO] [stderr] 53 |         match(self) {
[INFO] [stderr]    |              ^    ^
[INFO] [stderr]    |
[INFO] [stderr] help: remove these parentheses
[INFO] [stderr]    |
[INFO] [stderr] 53 -         match(self) {
[INFO] [stderr] 53 +         match self {
[INFO] [stderr]    |
[INFO] [stderr] 
[INFO] [stderr] warning: unnecessary parentheses around `match` scrutinee expression
[INFO] [stderr]   --> src/emulator/errors.rs:72:14
[INFO] [stderr]    |
[INFO] [stderr] 72 |         match(self) {
[INFO] [stderr]    |              ^    ^
[INFO] [stderr]    |
[INFO] [stderr] help: remove these parentheses
[INFO] [stderr]    |
[INFO] [stderr] 72 -         match(self) {
[INFO] [stderr] 72 +         match self {
[INFO] [stderr]    |
[INFO] [stderr] 
[INFO] [stderr] warning: type `R_Instr` should have an upper camel case name
[INFO] [stderr]   --> src/emulator/instructions.rs:19:12
[INFO] [stderr]    |
[INFO] [stderr] 19 | pub struct R_Instr {
[INFO] [stderr]    |            ^^^^^^^ help: convert the identifier to upper camel case: `RInstr`
[INFO] [stderr]    |
[INFO] [stderr]    = note: `#[warn(non_camel_case_types)]` (part of `#[warn(nonstandard_style)]`) on by default
[INFO] [stderr] 
[INFO] [stderr] warning: type `I_Instr` should have an upper camel case name
[INFO] [stderr]   --> src/emulator/instructions.rs:42:12
[INFO] [stderr]    |
[INFO] [stderr] 42 | pub struct I_Instr {
[INFO] [stderr]    |            ^^^^^^^ help: convert the identifier to upper camel case: `IInstr`
[INFO] [stderr] 
[INFO] [stderr] warning: type `S_Instr` should have an upper camel case name
[INFO] [stderr]   --> src/emulator/instructions.rs:63:12
[INFO] [stderr]    |
[INFO] [stderr] 63 | pub struct S_Instr {
[INFO] [stderr]    |            ^^^^^^^ help: convert the identifier to upper camel case: `SInstr`
[INFO] [stderr] 
[INFO] [stderr] warning: type `B_Instr` should have an upper camel case name
[INFO] [stderr]   --> src/emulator/instructions.rs:86:12
[INFO] [stderr]    |
[INFO] [stderr] 86 | pub struct B_Instr {
[INFO] [stderr]    |            ^^^^^^^ help: convert the identifier to upper camel case: `BInstr`
[INFO] [stderr] 
[INFO] [stderr] warning: type `U_Instr` should have an upper camel case name
[INFO] [stderr]    --> src/emulator/instructions.rs:115:12
[INFO] [stderr]     |
[INFO] [stderr] 115 | pub struct U_Instr {
[INFO] [stderr]     |            ^^^^^^^ help: convert the identifier to upper camel case: `UInstr`
[INFO] [stderr] 
[INFO] [stderr] warning: type `J_Instr` should have an upper camel case name
[INFO] [stderr]    --> src/emulator/instructions.rs:134:12
[INFO] [stderr]     |
[INFO] [stderr] 134 | pub struct J_Instr {
[INFO] [stderr]     |            ^^^^^^^ help: convert the identifier to upper camel case: `JInstr`
[INFO] [stderr] 
[INFO] [stderr] warning: unnecessary parentheses around `match` scrutinee expression
[INFO] [stderr]   --> src/emulator/interrupt.rs:16:35
[INFO] [stderr]    |
[INFO] [stderr] 16 |         let interrupt_code = match(self) {
[INFO] [stderr]    |                                   ^    ^
[INFO] [stderr]    |
[INFO] [stderr] help: remove these parentheses
[INFO] [stderr]    |
[INFO] [stderr] 16 -         let interrupt_code = match(self) {
[INFO] [stderr] 16 +         let interrupt_code = match self {
[INFO] [stderr]    |
[INFO] [stderr] 
[INFO] [stderr] warning: unnecessary parentheses around `match` scrutinee expression
[INFO] [stderr]   --> src/emulator/plic.rs:33:14
[INFO] [stderr]    |
[INFO] [stderr] 33 |         match(addr) {
[INFO] [stderr]    |              ^    ^
[INFO] [stderr]    |
[INFO] [stderr] help: remove these parentheses
[INFO] [stderr]    |
[INFO] [stderr] 33 -         match(addr) {
[INFO] [stderr] 33 +         match addr {
[INFO] [stderr]    |
[INFO] [stderr] 
[INFO] [stderr] warning: unnecessary parentheses around `match` scrutinee expression
[INFO] [stderr]   --> src/emulator/plic.rs:46:14
[INFO] [stderr]    |
[INFO] [stderr] 46 |         match(addr) {
[INFO] [stderr]    |              ^    ^
[INFO] [stderr]    |
[INFO] [stderr] help: remove these parentheses
[INFO] [stderr]    |
[INFO] [stderr] 46 -         match(addr) {
[INFO] [stderr] 46 +         match addr {
[INFO] [stderr]    |
[INFO] [stderr] 
[INFO] [stderr] warning: unnecessary parentheses around `match` scrutinee expression
[INFO] [stderr]   --> src/emulator/uart.rs:59:18
[INFO] [stderr]    |
[INFO] [stderr] 59 |             match(read_io) {
[INFO] [stderr]    |                  ^       ^
[INFO] [stderr]    |
[INFO] [stderr] help: remove these parentheses
[INFO] [stderr]    |
[INFO] [stderr] 59 -             match(read_io) {
[INFO] [stderr] 59 +             match read_io {
[INFO] [stderr]    |
[INFO] [stderr] 
[INFO] [stderr] warning: unnecessary parentheses around `while` condition
[INFO] [stderr]   --> src/emulator/uart.rs:65:27
[INFO] [stderr]    |
[INFO] [stderr] 65 |                     while (array[UART_LSR_INDEX as usize] & UART_LSR_RHR_STATUS_FLAG == 1) {
[INFO] [stderr]    |                           ^                                                              ^
[INFO] [stderr]    |
[INFO] [stderr] help: remove these parentheses
[INFO] [stderr]    |
[INFO] [stderr] 65 -                     while (array[UART_LSR_INDEX as usize] & UART_LSR_RHR_STATUS_FLAG == 1) {
[INFO] [stderr] 65 +                     while array[UART_LSR_INDEX as usize] & UART_LSR_RHR_STATUS_FLAG == 1 {
[INFO] [stderr]    |
[INFO] [stderr] 
[INFO] [stderr] warning: unnecessary parentheses around `match` scrutinee expression
[INFO] [stderr]   --> src/emulator/uart.rs:85:15
[INFO] [stderr]    |
[INFO] [stderr] 85 |         match (index) {
[INFO] [stderr]    |               ^     ^
[INFO] [stderr]    |
[INFO] [stderr] help: remove these parentheses
[INFO] [stderr]    |
[INFO] [stderr] 85 -         match (index) {
[INFO] [stderr] 85 +         match index {
[INFO] [stderr]    |
[INFO] [stderr] 
[INFO] [stderr] warning: unnecessary parentheses around `match` scrutinee expression
[INFO] [stderr]    --> src/emulator/uart.rs:101:15
[INFO] [stderr]     |
[INFO] [stderr] 101 |         match (index) {
[INFO] [stderr]     |               ^     ^
[INFO] [stderr]     |
[INFO] [stderr] help: remove these parentheses
[INFO] [stderr]     |
[INFO] [stderr] 101 -         match (index) {
[INFO] [stderr] 101 +         match index {
[INFO] [stderr]     |
[INFO] [stderr] 
[INFO] [stderr] warning: unnecessary parentheses around `while` condition
[INFO] [stderr]   --> src/emulator.rs:49:15
[INFO] [stderr]    |
[INFO] [stderr] 49 |         while (self.pc < self.bus.dram.dram.len() as u64) {
[INFO] [stderr]    |               ^                                         ^
[INFO] [stderr]    |
[INFO] [stderr] help: remove these parentheses
[INFO] [stderr]    |
[INFO] [stderr] 49 -         while (self.pc < self.bus.dram.dram.len() as u64) {
[INFO] [stderr] 49 +         while self.pc < self.bus.dram.dram.len() as u64 {
[INFO] [stderr]    |
[INFO] [stderr] 
[INFO] [stderr] warning: unnecessary parentheses around method argument
[INFO] [stderr]   --> src/emulator.rs:77:35
[INFO] [stderr]    |
[INFO] [stderr] 77 |         let instr = self.bus.load((index as u64), 32);
[INFO] [stderr]    |                                   ^            ^
[INFO] [stderr]    |
[INFO] [stderr] help: remove these parentheses
[INFO] [stderr]    |
[INFO] [stderr] 77 -         let instr = self.bus.load((index as u64), 32);
[INFO] [stderr] 77 +         let instr = self.bus.load(index as u64, 32);
[INFO] [stderr]    |
[INFO] [stderr] 
[INFO] [stderr] warning: unnecessary parentheses around `for` iterator expression
[INFO] [stderr]   --> src/emulator.rs:99:18
[INFO] [stderr]    |
[INFO] [stderr] 99 |         for i in (0..self.regs.len()) {
[INFO] [stderr]    |                  ^                  ^
[INFO] [stderr]    |
[INFO] [stderr] help: remove these parentheses
[INFO] [stderr]    |
[INFO] [stderr] 99 -         for i in (0..self.regs.len()) {
[INFO] [stderr] 99 +         for i in 0..self.regs.len() {
[INFO] [stderr]    |
[INFO] [stderr] 
[INFO] [stderr] warning: unnecessary parentheses around `if` condition
[INFO] [stderr]    --> src/emulator.rs:110:12
[INFO] [stderr]     |
[INFO] [stderr] 110 |         if (delegate_to_s_mode) {
[INFO] [stderr]     |            ^                  ^
[INFO] [stderr]     |
[INFO] [stderr] help: remove these parentheses
[INFO] [stderr]     |
[INFO] [stderr] 110 -         if (delegate_to_s_mode) {
[INFO] [stderr] 110 +         if delegate_to_s_mode {
[INFO] [stderr]     |
[INFO] [stderr] 
[INFO] [stderr] warning: unnecessary parentheses around `if` condition
[INFO] [stderr]    --> src/emulator.rs:113:16
[INFO] [stderr]     |
[INFO] [stderr] 113 |             if (tvec & 0b11 == 0) {
[INFO] [stderr]     |                ^                ^
[INFO] [stderr]     |
[INFO] [stderr] help: remove these parentheses
[INFO] [stderr]     |
[INFO] [stderr] 113 -             if (tvec & 0b11 == 0) {
[INFO] [stderr] 113 +             if tvec & 0b11 == 0 {
[INFO] [stderr]     |
[INFO] [stderr] 
[INFO] [stderr] warning: unnecessary parentheses around `if` condition
[INFO] [stderr]    --> src/emulator.rs:132:16
[INFO] [stderr]     |
[INFO] [stderr] 132 |             if (tvec & 0b11 == 0) {
[INFO] [stderr]     |                ^                ^
[INFO] [stderr]     |
[INFO] [stderr] help: remove these parentheses
[INFO] [stderr]     |
[INFO] [stderr] 132 -             if (tvec & 0b11 == 0) {
[INFO] [stderr] 132 +             if tvec & 0b11 == 0 {
[INFO] [stderr]     |
[INFO] [stderr] 
[INFO] [stderr] warning: unnecessary parentheses around `if` condition
[INFO] [stderr]    --> src/emulator.rs:154:12
[INFO] [stderr]     |
[INFO] [stderr] 154 |         if (error.is_fatal()) { 
[INFO] [stderr]     |            ^                ^
[INFO] [stderr]     |
[INFO] [stderr] help: remove these parentheses
[INFO] [stderr]     |
[INFO] [stderr] 154 -         if (error.is_fatal()) { 
[INFO] [stderr] 154 +         if error.is_fatal() { 
[INFO] [stderr]     |
[INFO] [stderr] 
[INFO] [stderr] warning: unnecessary parentheses around `if` condition
[INFO] [stderr]    --> src/emulator.rs:167:12
[INFO] [stderr]     |
[INFO] [stderr] 167 |         if (should_deleg_to_supervisor) {
[INFO] [stderr]     |            ^                          ^
[INFO] [stderr]     |
[INFO] [stderr] help: remove these parentheses
[INFO] [stderr]     |
[INFO] [stderr] 167 -         if (should_deleg_to_supervisor) {
[INFO] [stderr] 167 +         if should_deleg_to_supervisor {
[INFO] [stderr]     |
[INFO] [stderr] 
[INFO] [stderr] warning: unnecessary parentheses around `if` condition
[INFO] [stderr]    --> src/emulator.rs:206:12
[INFO] [stderr]     |
[INFO] [stderr] 206 |         if (self.mode == Machine && (self.csr.load(MSTATUS) & MASK_MIE) == 0) {
[INFO] [stderr]     |            ^                                                                ^
[INFO] [stderr]     |
[INFO] [stderr] help: remove these parentheses
[INFO] [stderr]     |
[INFO] [stderr] 206 -         if (self.mode == Machine && (self.csr.load(MSTATUS) & MASK_MIE) == 0) {
[INFO] [stderr] 206 +         if self.mode == Machine && (self.csr.load(MSTATUS) & MASK_MIE) == 0 {
[INFO] [stderr]     |
[INFO] [stderr] 
[INFO] [stderr] warning: unnecessary parentheses around `if` condition
[INFO] [stderr]    --> src/emulator.rs:211:12
[INFO] [stderr]     |
[INFO] [stderr] 211 |         if ((self.mode == Supervisor) &&  (self.csr.load(MSTATUS) & MASK_SIE) == 0) {
[INFO] [stderr]     |            ^                                                                      ^
[INFO] [stderr]     |
[INFO] [stderr] help: remove these parentheses
[INFO] [stderr]     |
[INFO] [stderr] 211 -         if ((self.mode == Supervisor) &&  (self.csr.load(MSTATUS) & MASK_SIE) == 0) {
[INFO] [stderr] 211 +         if (self.mode == Supervisor) &&  (self.csr.load(MSTATUS) & MASK_SIE) == 0 {
[INFO] [stderr]     |
[INFO] [stderr] 
[INFO] [stderr] warning: unnecessary parentheses around `if` condition
[INFO] [stderr]    --> src/emulator.rs:215:12
[INFO] [stderr]     |
[INFO] [stderr] 215 |         if (self.bus.uart.is_interrupting()) {
[INFO] [stderr]     |            ^                               ^
[INFO] [stderr]     |
[INFO] [stderr] help: remove these parentheses
[INFO] [stderr]     |
[INFO] [stderr] 215 -         if (self.bus.uart.is_interrupting()) {
[INFO] [stderr] 215 +         if self.bus.uart.is_interrupting() {
[INFO] [stderr]     |
[INFO] [stderr] 
[INFO] [stderr] warning: unnecessary parentheses around assigned value
[INFO] [stderr]    --> src/emulator.rs:257:25
[INFO] [stderr]     |
[INFO] [stderr] 257 |         let flag_mask = (1 << flag_index);
[INFO] [stderr]     |                         ^               ^
[INFO] [stderr]     |
[INFO] [stderr] help: remove these parentheses
[INFO] [stderr]     |
[INFO] [stderr] 257 -         let flag_mask = (1 << flag_index);
[INFO] [stderr] 257 +         let flag_mask = 1 << flag_index;
[INFO] [stderr]     |
[INFO] [stderr] 
[INFO] [stderr] warning: unnecessary parentheses around `return` value
[INFO] [stderr]    --> src/emulator.rs:258:16
[INFO] [stderr]     |
[INFO] [stderr] 258 |         return ((status & flag_mask) > 0);
[INFO] [stderr]     |                ^                        ^
[INFO] [stderr]     |
[INFO] [stderr] help: remove these parentheses
[INFO] [stderr]     |
[INFO] [stderr] 258 -         return ((status & flag_mask) > 0);
[INFO] [stderr] 258 +         return (status & flag_mask) > 0;
[INFO] [stderr]     |
[INFO] [stderr] 
[INFO] [stderr] warning: unnecessary parentheses around `match` scrutinee expression
[INFO] [stderr]    --> src/emulator.rs:272:14
[INFO] [stderr]     |
[INFO] [stderr] 272 |         match(inst.opcode) {
[INFO] [stderr]     |              ^           ^
[INFO] [stderr]     |
[INFO] [stderr] help: remove these parentheses
[INFO] [stderr]     |
[INFO] [stderr] 272 -         match(inst.opcode) {
[INFO] [stderr] 272 +         match inst.opcode {
[INFO] [stderr]     |
[INFO] [stderr] 
[INFO] [stderr] warning: unnecessary parentheses around `match` scrutinee expression
[INFO] [stderr]    --> src/emulator.rs:274:23
[INFO] [stderr]     |
[INFO] [stderr] 274 |                 match (inst.funct3) {
[INFO] [stderr]     |                       ^           ^
[INFO] [stderr]     |
[INFO] [stderr] help: remove these parentheses
[INFO] [stderr]     |
[INFO] [stderr] 274 -                 match (inst.funct3) {
[INFO] [stderr] 274 +                 match inst.funct3 {
[INFO] [stderr]     |
[INFO] [stderr] 
[INFO] [stderr] warning: unnecessary parentheses around `match` scrutinee expression
[INFO] [stderr]    --> src/emulator.rs:276:31
[INFO] [stderr]     |
[INFO] [stderr] 276 |                         match (inst.funct7) {
[INFO] [stderr]     |                               ^           ^
[INFO] [stderr]     |
[INFO] [stderr] help: remove these parentheses
[INFO] [stderr]     |
[INFO] [stderr] 276 -                         match (inst.funct7) {
[INFO] [stderr] 276 +                         match inst.funct7 {
[INFO] [stderr]     |
[INFO] [stderr] 
[INFO] [stderr] warning: unnecessary parentheses around `match` scrutinee expression
[INFO] [stderr]    --> src/emulator.rs:290:22
[INFO] [stderr]     |
[INFO] [stderr] 290 |                 match(inst.funct3) {
[INFO] [stderr]     |                      ^           ^
[INFO] [stderr]     |
[INFO] [stderr] help: remove these parentheses
[INFO] [stderr]     |
[INFO] [stderr] 290 -                 match(inst.funct3) {
[INFO] [stderr] 290 +                 match inst.funct3 {
[INFO] [stderr]     |
[INFO] [stderr] 
[INFO] [stderr] warning: unnecessary parentheses around assigned value
[INFO] [stderr]    --> src/emulator.rs:301:38
[INFO] [stderr]     |
[INFO] [stderr] 301 |                         let result = ((self.regs[inst.rs1] as i64) < imm as i64);
[INFO] [stderr]     |                                      ^                                         ^
[INFO] [stderr]     |
[INFO] [stderr] help: remove these parentheses
[INFO] [stderr]     |
[INFO] [stderr] 301 -                         let result = ((self.regs[inst.rs1] as i64) < imm as i64);
[INFO] [stderr] 301 +                         let result = (self.regs[inst.rs1] as i64) < imm as i64;
[INFO] [stderr]     |
[INFO] [stderr] 
[INFO] [stderr] warning: unnecessary parentheses around assigned value
[INFO] [stderr]    --> src/emulator.rs:305:38
[INFO] [stderr]     |
[INFO] [stderr] 305 |                         let result = ((self.regs[inst.rs1] as u64) < imm);
[INFO] [stderr]     |                                      ^                                  ^
[INFO] [stderr]     |
[INFO] [stderr] help: remove these parentheses
[INFO] [stderr]     |
[INFO] [stderr] 305 -                         let result = ((self.regs[inst.rs1] as u64) < imm);
[INFO] [stderr] 305 +                         let result = (self.regs[inst.rs1] as u64) < imm;
[INFO] [stderr]     |
[INFO] [stderr] 
[INFO] [stderr] warning: unnecessary parentheses around `match` scrutinee expression
[INFO] [stderr]    --> src/emulator.rs:312:30
[INFO] [stderr]     |
[INFO] [stderr] 312 |                         match(inst.funct7) {
[INFO] [stderr]     |                              ^           ^
[INFO] [stderr]     |
[INFO] [stderr] help: remove these parentheses
[INFO] [stderr]     |
[INFO] [stderr] 312 -                         match(inst.funct7) {
[INFO] [stderr] 312 +                         match inst.funct7 {
[INFO] [stderr]     |
[INFO] [stderr] 
[INFO] [stderr] warning: unnecessary parentheses around assigned value
[INFO] [stderr]    --> src/emulator.rs:335:38
[INFO] [stderr]     |
[INFO] [stderr] 335 |                 self.regs[inst.rd] = (imm << 12);
[INFO] [stderr]     |                                      ^         ^
[INFO] [stderr]     |
[INFO] [stderr] help: remove these parentheses
[INFO] [stderr]     |
[INFO] [stderr] 335 -                 self.regs[inst.rd] = (imm << 12);
[INFO] [stderr] 335 +                 self.regs[inst.rd] = imm << 12;
[INFO] [stderr]     |
[INFO] [stderr] 
[INFO] [stderr] warning: unnecessary parentheses around assigned value
[INFO] [stderr]    --> src/emulator.rs:355:37
[INFO] [stderr]     |
[INFO] [stderr] 355 |                         self.mode = (updated_sstatus & (1 << SPP_FLAG_POS) >> SPP_FLAG_POS);
[INFO] [stderr]     |                                     ^                                                     ^
[INFO] [stderr]     |
[INFO] [stderr] help: remove these parentheses
[INFO] [stderr]     |
[INFO] [stderr] 355 -                         self.mode = (updated_sstatus & (1 << SPP_FLAG_POS) >> SPP_FLAG_POS);
[INFO] [stderr] 355 +                         self.mode = updated_sstatus & (1 << SPP_FLAG_POS) >> SPP_FLAG_POS;
[INFO] [stderr]     |
[INFO] [stderr] 
[INFO] [stderr] warning: unnecessary parentheses around assigned value
[INFO] [stderr]    --> src/emulator.rs:361:36
[INFO] [stderr]     |
[INFO] [stderr] 361 |                         let spie = (updated_sstatus & (1 << SPIE_FLAG_POS) >> SPIE_FLAG_POS);
[INFO] [stderr]     |                                    ^                                                       ^
[INFO] [stderr]     |
[INFO] [stderr] help: remove these parentheses
[INFO] [stderr]     |
[INFO] [stderr] 361 -                         let spie = (updated_sstatus & (1 << SPIE_FLAG_POS) >> SPIE_FLAG_POS);
[INFO] [stderr] 361 +                         let spie = updated_sstatus & (1 << SPIE_FLAG_POS) >> SPIE_FLAG_POS;
[INFO] [stderr]     |
[INFO] [stderr] 
[INFO] [stderr] warning: unnecessary parentheses around assigned value
[INFO] [stderr]    --> src/emulator.rs:365:44
[INFO] [stderr]     |
[INFO] [stderr] 365 |                         updated_sstatus |= (1 << SPIE_FLAG_POS);
[INFO] [stderr]     |                                            ^                  ^
[INFO] [stderr]     |
[INFO] [stderr] help: remove these parentheses
[INFO] [stderr]     |
[INFO] [stderr] 365 -                         updated_sstatus |= (1 << SPIE_FLAG_POS);
[INFO] [stderr] 365 +                         updated_sstatus |= 1 << SPIE_FLAG_POS;
[INFO] [stderr]     |
[INFO] [stderr] 
[INFO] [stderr] warning: unnecessary parentheses around `if` condition
[INFO] [stderr]   --> src/lib.rs:14:8
[INFO] [stderr]    |
[INFO] [stderr] 14 |     if (args.len() != 2) {
[INFO] [stderr]    |        ^               ^
[INFO] [stderr]    |
[INFO] [stderr] help: remove these parentheses
[INFO] [stderr]    |
[INFO] [stderr] 14 -     if (args.len() != 2) {
[INFO] [stderr] 14 +     if args.len() != 2 {
[INFO] [stderr]    |
[INFO] [stderr] 
[INFO] [stderr] warning[E0170]: pattern binding `SupervisorSoftwareInterrupt` is named the same as one of the variants of the type `emulator::interrupt::Interrupt`
[INFO] [stderr]   --> src/emulator/interrupt.rs:17:13
[INFO] [stderr]    |
[INFO] [stderr] 17 |             SupervisorSoftwareInterrupt => 1,
[INFO] [stderr]    |             ^^^^^^^^^^^^^^^^^^^^^^^^^^^ help: to match on the variant, qualify the path: `emulator::interrupt::Interrupt::SupervisorSoftwareInterrupt`
[INFO] [stderr]    |
[INFO] [stderr]    = note: `#[warn(bindings_with_variant_name)]` on by default
[INFO] [stderr] 
[INFO] [stderr] warning[E0170]: pattern binding `MachineSoftwareInterrupt` is named the same as one of the variants of the type `emulator::interrupt::Interrupt`
[INFO] [stderr]   --> src/emulator/interrupt.rs:18:13
[INFO] [stderr]    |
[INFO] [stderr] 18 |             MachineSoftwareInterrupt => 3,
[INFO] [stderr]    |             ^^^^^^^^^^^^^^^^^^^^^^^^ help: to match on the variant, qualify the path: `emulator::interrupt::Interrupt::MachineSoftwareInterrupt`
[INFO] [stderr] 
[INFO] [stderr] warning[E0170]: pattern binding `SupervisorTimerInterrupt` is named the same as one of the variants of the type `emulator::interrupt::Interrupt`
[INFO] [stderr]   --> src/emulator/interrupt.rs:19:13
[INFO] [stderr]    |
[INFO] [stderr] 19 |             SupervisorTimerInterrupt => 5,
[INFO] [stderr]    |             ^^^^^^^^^^^^^^^^^^^^^^^^ help: to match on the variant, qualify the path: `emulator::interrupt::Interrupt::SupervisorTimerInterrupt`
[INFO] [stderr] 
[INFO] [stderr] warning[E0170]: pattern binding `MachineTimerInterrupt` is named the same as one of the variants of the type `emulator::interrupt::Interrupt`
[INFO] [stderr]   --> src/emulator/interrupt.rs:20:13
[INFO] [stderr]    |
[INFO] [stderr] 20 |             MachineTimerInterrupt => 7,
[INFO] [stderr]    |             ^^^^^^^^^^^^^^^^^^^^^ help: to match on the variant, qualify the path: `emulator::interrupt::Interrupt::MachineTimerInterrupt`
[INFO] [stderr] 
[INFO] [stderr] warning[E0170]: pattern binding `SupervisorExternalInterrupt` is named the same as one of the variants of the type `emulator::interrupt::Interrupt`
[INFO] [stderr]   --> src/emulator/interrupt.rs:21:13
[INFO] [stderr]    |
[INFO] [stderr] 21 |             SupervisorExternalInterrupt => 9,
[INFO] [stderr]    |             ^^^^^^^^^^^^^^^^^^^^^^^^^^^ help: to match on the variant, qualify the path: `emulator::interrupt::Interrupt::SupervisorExternalInterrupt`
[INFO] [stderr] 
[INFO] [stderr] warning[E0170]: pattern binding `MachineExternalInterrupt` is named the same as one of the variants of the type `emulator::interrupt::Interrupt`
[INFO] [stderr]   --> src/emulator/interrupt.rs:22:13
[INFO] [stderr]    |
[INFO] [stderr] 22 |             MachineExternalInterrupt => 11,
[INFO] [stderr]    |             ^^^^^^^^^^^^^^^^^^^^^^^^ help: to match on the variant, qualify the path: `emulator::interrupt::Interrupt::MachineExternalInterrupt`
[INFO] [stderr] 
[INFO] [stderr] warning: unreachable pattern
[INFO] [stderr]   --> src/emulator/interrupt.rs:18:13
[INFO] [stderr]    |
[INFO] [stderr] 17 |             SupervisorSoftwareInterrupt => 1,
[INFO] [stderr]    |             --------------------------- matches any value
[INFO] [stderr] 18 |             MachineSoftwareInterrupt => 3,
[INFO] [stderr]    |             ^^^^^^^^^^^^^^^^^^^^^^^^ no value can reach this
[INFO] [stderr]    |
[INFO] [stderr]    = note: `#[warn(unreachable_patterns)]` (part of `#[warn(unused)]`) on by default
[INFO] [stderr] 
[INFO] [stderr] warning: unreachable pattern
[INFO] [stderr]   --> src/emulator/interrupt.rs:19:13
[INFO] [stderr]    |
[INFO] [stderr] 17 |             SupervisorSoftwareInterrupt => 1,
[INFO] [stderr]    |             --------------------------- matches any value
[INFO] [stderr] 18 |             MachineSoftwareInterrupt => 3,
[INFO] [stderr] 19 |             SupervisorTimerInterrupt => 5,
[INFO] [stderr]    |             ^^^^^^^^^^^^^^^^^^^^^^^^ no value can reach this
[INFO] [stderr] 
[INFO] [stderr] warning: unreachable pattern
[INFO] [stderr]   --> src/emulator/interrupt.rs:20:13
[INFO] [stderr]    |
[INFO] [stderr] 17 |             SupervisorSoftwareInterrupt => 1,
[INFO] [stderr]    |             --------------------------- matches any value
[INFO] [stderr] ...
[INFO] [stderr] 20 |             MachineTimerInterrupt => 7,
[INFO] [stderr]    |             ^^^^^^^^^^^^^^^^^^^^^ no value can reach this
[INFO] [stderr] 
[INFO] [stderr] warning: unreachable pattern
[INFO] [stderr]   --> src/emulator/interrupt.rs:21:13
[INFO] [stderr]    |
[INFO] [stderr] 17 |             SupervisorSoftwareInterrupt => 1,
[INFO] [stderr]    |             --------------------------- matches any value
[INFO] [stderr] ...
[INFO] [stderr] 21 |             SupervisorExternalInterrupt => 9,
[INFO] [stderr]    |             ^^^^^^^^^^^^^^^^^^^^^^^^^^^ no value can reach this
[INFO] [stderr] 
[INFO] [stderr] warning: unreachable pattern
[INFO] [stderr]   --> src/emulator/interrupt.rs:22:13
[INFO] [stderr]    |
[INFO] [stderr] 17 |             SupervisorSoftwareInterrupt => 1,
[INFO] [stderr]    |             --------------------------- matches any value
[INFO] [stderr] ...
[INFO] [stderr] 22 |             MachineExternalInterrupt => 11,
[INFO] [stderr]    |             ^^^^^^^^^^^^^^^^^^^^^^^^ no value can reach this
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `SupervisorSoftwareInterrupt`
[INFO] [stderr]   --> src/emulator/interrupt.rs:17:13
[INFO] [stderr]    |
[INFO] [stderr] 17 |             SupervisorSoftwareInterrupt => 1,
[INFO] [stderr]    |             ^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr]    |
[INFO] [stderr]    = note: `#[warn(unused_variables)]` (part of `#[warn(unused)]`) on by default
[INFO] [stderr] help: if this is intentional, prefix it with an underscore
[INFO] [stderr]    |
[INFO] [stderr] 17 |             _SupervisorSoftwareInterrupt => 1,
[INFO] [stderr]    |             +
[INFO] [stderr] help: you might have meant to pattern match on the similarly named variant `SupervisorSoftwareInterrupt`
[INFO] [stderr]    |
[INFO] [stderr] 17 |             emulator::interrupt::Interrupt::SupervisorSoftwareInterrupt => 1,
[INFO] [stderr]    |             ++++++++++++++++++++++++++++++++
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `MachineSoftwareInterrupt`
[INFO] [stderr]   --> src/emulator/interrupt.rs:18:13
[INFO] [stderr]    |
[INFO] [stderr] 18 |             MachineSoftwareInterrupt => 3,
[INFO] [stderr]    |             ^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr]    |
[INFO] [stderr] help: if this is intentional, prefix it with an underscore
[INFO] [stderr]    |
[INFO] [stderr] 18 |             _MachineSoftwareInterrupt => 3,
[INFO] [stderr]    |             +
[INFO] [stderr] help: you might have meant to pattern match on the similarly named variant `MachineSoftwareInterrupt`
[INFO] [stderr]    |
[INFO] [stderr] 18 |             emulator::interrupt::Interrupt::MachineSoftwareInterrupt => 3,
[INFO] [stderr]    |             ++++++++++++++++++++++++++++++++
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `SupervisorTimerInterrupt`
[INFO] [stderr]   --> src/emulator/interrupt.rs:19:13
[INFO] [stderr]    |
[INFO] [stderr] 19 |             SupervisorTimerInterrupt => 5,
[INFO] [stderr]    |             ^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr]    |
[INFO] [stderr] help: if this is intentional, prefix it with an underscore
[INFO] [stderr]    |
[INFO] [stderr] 19 |             _SupervisorTimerInterrupt => 5,
[INFO] [stderr]    |             +
[INFO] [stderr] help: you might have meant to pattern match on the similarly named variant `SupervisorTimerInterrupt`
[INFO] [stderr]    |
[INFO] [stderr] 19 |             emulator::interrupt::Interrupt::SupervisorTimerInterrupt => 5,
[INFO] [stderr]    |             ++++++++++++++++++++++++++++++++
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `MachineTimerInterrupt`
[INFO] [stderr]   --> src/emulator/interrupt.rs:20:13
[INFO] [stderr]    |
[INFO] [stderr] 20 |             MachineTimerInterrupt => 7,
[INFO] [stderr]    |             ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr]    |
[INFO] [stderr] help: if this is intentional, prefix it with an underscore
[INFO] [stderr]    |
[INFO] [stderr] 20 |             _MachineTimerInterrupt => 7,
[INFO] [stderr]    |             +
[INFO] [stderr] help: you might have meant to pattern match on the similarly named variant `MachineTimerInterrupt`
[INFO] [stderr]    |
[INFO] [stderr] 20 |             emulator::interrupt::Interrupt::MachineTimerInterrupt => 7,
[INFO] [stderr]    |             ++++++++++++++++++++++++++++++++
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `SupervisorExternalInterrupt`
[INFO] [stderr]   --> src/emulator/interrupt.rs:21:13
[INFO] [stderr]    |
[INFO] [stderr] 21 |             SupervisorExternalInterrupt => 9,
[INFO] [stderr]    |             ^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr]    |
[INFO] [stderr] help: if this is intentional, prefix it with an underscore
[INFO] [stderr]    |
[INFO] [stderr] 21 |             _SupervisorExternalInterrupt => 9,
[INFO] [stderr]    |             +
[INFO] [stderr] help: you might have meant to pattern match on the similarly named variant `SupervisorExternalInterrupt`
[INFO] [stderr]    |
[INFO] [stderr] 21 |             emulator::interrupt::Interrupt::SupervisorExternalInterrupt => 9,
[INFO] [stderr]    |             ++++++++++++++++++++++++++++++++
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `MachineExternalInterrupt`
[INFO] [stderr]   --> src/emulator/interrupt.rs:22:13
[INFO] [stderr]    |
[INFO] [stderr] 22 |             MachineExternalInterrupt => 11,
[INFO] [stderr]    |             ^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr]    |
[INFO] [stderr] help: if this is intentional, prefix it with an underscore
[INFO] [stderr]    |
[INFO] [stderr] 22 |             _MachineExternalInterrupt => 11,
[INFO] [stderr]    |             +
[INFO] [stderr] help: you might have meant to pattern match on the similarly named variant `MachineExternalInterrupt`
[INFO] [stderr]    |
[INFO] [stderr] 22 |             emulator::interrupt::Interrupt::MachineExternalInterrupt => 11,
[INFO] [stderr]    |             ++++++++++++++++++++++++++++++++
[INFO] [stderr] 
[INFO] [stderr] warning: variable does not need to be mutable
[INFO] [stderr]   --> src/emulator/uart.rs:39:13
[INFO] [stderr]    |
[INFO] [stderr] 39 |         let mut array = [0; UART_SIZE as 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: unused variable: `size`
[INFO] [stderr]   --> src/emulator/uart.rs:80:35
[INFO] [stderr]    |
[INFO] [stderr] 80 |     pub fn load(&self, addr: u64, size: u64) -> Result<u64, errors::Exception> {
[INFO] [stderr]    |                                   ^^^^
[INFO] [stderr]    |
[INFO] [stderr] help: if this is intentional, prefix it with an underscore
[INFO] [stderr]    |
[INFO] [stderr] 80 |     pub fn load(&self, addr: u64, _size: u64) -> Result<u64, errors::Exception> {
[INFO] [stderr]    |                                   +
[INFO] [stderr] help: you might have meant to pattern match on the similarly named constant `Machine`
[INFO] [stderr]    |
[INFO] [stderr] 80 -     pub fn load(&self, addr: u64, size: u64) -> Result<u64, errors::Exception> {
[INFO] [stderr] 80 +     pub fn load(&self, addr: u64, emulator::Machine: u64) -> Result<u64, errors::Exception> {
[INFO] [stderr]    |
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `cvar`
[INFO] [stderr]   --> src/emulator/uart.rs:96:20
[INFO] [stderr]    |
[INFO] [stderr] 96 |         let (uart, cvar) = &*self.uart;
[INFO] [stderr]    |                    ^^^^ help: if this is intentional, prefix it with an underscore: `_cvar`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `size`
[INFO] [stderr]   --> src/emulator/uart.rs:95:40
[INFO] [stderr]    |
[INFO] [stderr] 95 |     pub fn store(&mut self, addr: u64, size: u64, value: u64) -> Result<(), errors::Exception> {
[INFO] [stderr]    |                                        ^^^^
[INFO] [stderr]    |
[INFO] [stderr] help: if this is intentional, prefix it with an underscore
[INFO] [stderr]    |
[INFO] [stderr] 95 |     pub fn store(&mut self, addr: u64, _size: u64, value: u64) -> Result<(), errors::Exception> {
[INFO] [stderr]    |                                        +
[INFO] [stderr] help: you might have meant to pattern match on the similarly named constant `Machine`
[INFO] [stderr]    |
[INFO] [stderr] 95 -     pub fn store(&mut self, addr: u64, size: u64, value: u64) -> Result<(), errors::Exception> {
[INFO] [stderr] 95 +     pub fn store(&mut self, addr: u64, emulator::Machine: u64, value: u64) -> Result<(), errors::Exception> {
[INFO] [stderr]    |
[INFO] [stderr] 
[INFO] [stderr] warning: function `main` is never used
[INFO] [stderr]  --> src/lib.rs:8:4
[INFO] [stderr]   |
[INFO] [stderr] 8 | fn main() -> io::Result<()> {
[INFO] [stderr]   |    ^^^^
[INFO] [stderr]   |
[INFO] [stderr]   = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default
[INFO] [stderr] 
[INFO] [stderr] warning: constant `User` is never used
[INFO] [stderr]   --> src/emulator.rs:14:7
[INFO] [stderr]    |
[INFO] [stderr] 14 | const User: Mode = 0; // 0b00
[INFO] [stderr]    |       ^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: associated function `get_status_flag` is never used
[INFO] [stderr]    --> src/emulator.rs:256:8
[INFO] [stderr]     |
[INFO] [stderr]  26 | impl Cpu {
[INFO] [stderr]     | -------- associated function in this implementation
[INFO] [stderr] ...
[INFO] [stderr] 256 |     fn get_status_flag(status: &u64, flag_index: u64) -> bool {
[INFO] [stderr]     |        ^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: constant `MCOUNTEREN` is never used
[INFO] [stderr]   --> src/emulator/csr.rs:12:11
[INFO] [stderr]    |
[INFO] [stderr] 12 | pub const MCOUNTEREN: usize = 0x306;
[INFO] [stderr]    |           ^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: constant `MSCRATCH` is never used
[INFO] [stderr]   --> src/emulator/csr.rs:14:11
[INFO] [stderr]    |
[INFO] [stderr] 14 | pub const MSCRATCH: usize = 0x340;
[INFO] [stderr]    |           ^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: constant `SSCRATCH` is never used
[INFO] [stderr]   --> src/emulator/csr.rs:32:11
[INFO] [stderr]    |
[INFO] [stderr] 32 | pub const SSCRATCH: usize = 0x140;
[INFO] [stderr]    |           ^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: constant `SATP` is never used
[INFO] [stderr]   --> src/emulator/csr.rs:42:11
[INFO] [stderr]    |
[INFO] [stderr] 42 | pub const SATP: usize = 0x180;
[INFO] [stderr]    |           ^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: constant `MASK_VS` is never used
[INFO] [stderr]   --> src/emulator/csr.rs:51:11
[INFO] [stderr]    |
[INFO] [stderr] 51 | pub const MASK_VS: u64 = 0b11 << 9;
[INFO] [stderr]    |           ^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: constant `MASK_MPRV` is never used
[INFO] [stderr]   --> src/emulator/csr.rs:55:11
[INFO] [stderr]    |
[INFO] [stderr] 55 | pub const MASK_MPRV: u64 = 1 << 17;
[INFO] [stderr]    |           ^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: constant `MASK_TVM` is never used
[INFO] [stderr]   --> src/emulator/csr.rs:58:11
[INFO] [stderr]    |
[INFO] [stderr] 58 | pub const MASK_TVM: u64 = 1 << 20;
[INFO] [stderr]    |           ^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: constant `MASK_TW` is never used
[INFO] [stderr]   --> src/emulator/csr.rs:59:11
[INFO] [stderr]    |
[INFO] [stderr] 59 | pub const MASK_TW: u64 = 1 << 21;
[INFO] [stderr]    |           ^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: constant `MASK_TSR` is never used
[INFO] [stderr]   --> src/emulator/csr.rs:60:11
[INFO] [stderr]    |
[INFO] [stderr] 60 | pub const MASK_TSR: u64 = 1 << 22;
[INFO] [stderr]    |           ^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: constant `MASK_SXL` is never used
[INFO] [stderr]   --> src/emulator/csr.rs:62:11
[INFO] [stderr]    |
[INFO] [stderr] 62 | pub const MASK_SXL: u64 = 0b11 << 34;
[INFO] [stderr]    |           ^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: constant `MASK_SBE` is never used
[INFO] [stderr]   --> src/emulator/csr.rs:63:11
[INFO] [stderr]    |
[INFO] [stderr] 63 | pub const MASK_SBE: u64 = 1 << 36;
[INFO] [stderr]    |           ^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: constant `MASK_MBE` is never used
[INFO] [stderr]   --> src/emulator/csr.rs:64:11
[INFO] [stderr]    |
[INFO] [stderr] 64 | pub const MASK_MBE: u64 = 1 << 37;
[INFO] [stderr]    |           ^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: struct `Thing` is never constructed
[INFO] [stderr]  --> src/emulator/errors.rs:4:12
[INFO] [stderr]   |
[INFO] [stderr] 4 | pub struct Thing;
[INFO] [stderr]   |            ^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: associated function `from_u32` is never used
[INFO] [stderr]   --> src/emulator/instructions.rs:29:12
[INFO] [stderr]    |
[INFO] [stderr] 28 | impl R_Instr {
[INFO] [stderr]    | ------------ associated function in this implementation
[INFO] [stderr] 29 |     pub fn from_u32(inst: u32) -> R_Instr {
[INFO] [stderr]    |            ^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: struct `I_Instr` is never constructed
[INFO] [stderr]   --> src/emulator/instructions.rs:42:12
[INFO] [stderr]    |
[INFO] [stderr] 42 | pub struct I_Instr {
[INFO] [stderr]    |            ^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: associated function `from_u32` is never used
[INFO] [stderr]   --> src/emulator/instructions.rs:51:12
[INFO] [stderr]    |
[INFO] [stderr] 50 | impl I_Instr {
[INFO] [stderr]    | ------------ associated function in this implementation
[INFO] [stderr] 51 |     pub fn from_u32(inst: u32) -> I_Instr {
[INFO] [stderr]    |            ^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: struct `S_Instr` is never constructed
[INFO] [stderr]   --> src/emulator/instructions.rs:63:12
[INFO] [stderr]    |
[INFO] [stderr] 63 | pub struct S_Instr {
[INFO] [stderr]    |            ^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: associated function `from_u32` is never used
[INFO] [stderr]   --> src/emulator/instructions.rs:72:12
[INFO] [stderr]    |
[INFO] [stderr] 71 | impl S_Instr {
[INFO] [stderr]    | ------------ associated function in this implementation
[INFO] [stderr] 72 |     pub fn from_u32(inst: u32) -> S_Instr {
[INFO] [stderr]    |            ^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: struct `B_Instr` is never constructed
[INFO] [stderr]   --> src/emulator/instructions.rs:86:12
[INFO] [stderr]    |
[INFO] [stderr] 86 | pub struct B_Instr {
[INFO] [stderr]    |            ^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: associated function `from_u32` is never used
[INFO] [stderr]   --> src/emulator/instructions.rs:95:12
[INFO] [stderr]    |
[INFO] [stderr] 94 | impl B_Instr {
[INFO] [stderr]    | ------------ associated function in this implementation
[INFO] [stderr] 95 |     pub fn from_u32(inst: u32) -> B_Instr {
[INFO] [stderr]    |            ^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: struct `U_Instr` is never constructed
[INFO] [stderr]    --> src/emulator/instructions.rs:115:12
[INFO] [stderr]     |
[INFO] [stderr] 115 | pub struct U_Instr {
[INFO] [stderr]     |            ^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: associated function `from_u32` is never used
[INFO] [stderr]    --> src/emulator/instructions.rs:122:12
[INFO] [stderr]     |
[INFO] [stderr] 121 | impl U_Instr {
[INFO] [stderr]     | ------------ associated function in this implementation
[INFO] [stderr] 122 |     pub fn from_u32(inst: u32) -> U_Instr {
[INFO] [stderr]     |            ^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: struct `J_Instr` is never constructed
[INFO] [stderr]    --> src/emulator/instructions.rs:134:12
[INFO] [stderr]     |
[INFO] [stderr] 134 | pub struct J_Instr {
[INFO] [stderr]     |            ^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: associated function `from_u32` is never used
[INFO] [stderr]    --> src/emulator/instructions.rs:141:12
[INFO] [stderr]     |
[INFO] [stderr] 140 | impl J_Instr {
[INFO] [stderr]     | ------------ associated function in this implementation
[INFO] [stderr] 141 |     pub fn from_u32(inst: u32) -> J_Instr {
[INFO] [stderr]     |            ^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: struct `Plic` is never constructed
[INFO] [stderr]  --> src/emulator/plic.rs:6:12
[INFO] [stderr]   |
[INFO] [stderr] 6 | pub struct Plic {
[INFO] [stderr]   |            ^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: constant `PLIC_COMPLETED_ADDR` is never used
[INFO] [stderr]   --> src/emulator/plic.rs:18:11
[INFO] [stderr]    |
[INFO] [stderr] 18 | pub const PLIC_COMPLETED_ADDR: u64 = PLIC_CLAIM_ADDR + 4;
[INFO] [stderr]    |           ^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: constant `PLIC_END` is never used
[INFO] [stderr]   --> src/emulator/plic.rs:19:11
[INFO] [stderr]    |
[INFO] [stderr] 19 | pub const PLIC_END: u64 = PLIC_COMPLETED_ADDR;
[INFO] [stderr]    |           ^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: associated items `new`, `load`, and `store` are never used
[INFO] [stderr]   --> src/emulator/plic.rs:22:12
[INFO] [stderr]    |
[INFO] [stderr] 21 | impl Plic {
[INFO] [stderr]    | --------- associated items in this implementation
[INFO] [stderr] 22 |     pub fn new() -> Self {
[INFO] [stderr]    |            ^^^
[INFO] [stderr] ...
[INFO] [stderr] 32 |     pub fn load(&self, addr: u64) -> Result<u64, errors::Exception> {
[INFO] [stderr]    |            ^^^^
[INFO] [stderr] ...
[INFO] [stderr] 45 |     pub fn store(&mut self, addr: u64, value: u64) -> Result<(), errors::Exception> {
[INFO] [stderr]    |            ^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: constant `UART_LSR_THR_STATUS_FLAG` is never used
[INFO] [stderr]   --> src/emulator/uart.rs:26:11
[INFO] [stderr]    |
[INFO] [stderr] 26 | pub const UART_LSR_THR_STATUS_FLAG: u8 = 1 << 5;
[INFO] [stderr]    |           ^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: crate `Risc_V_Emulator` should have a snake case name
[INFO] [stderr]   |
[INFO] [stderr]   = help: convert the identifier to snake case: `risc_v_emulator`
[INFO] [stderr]   = note: `#[warn(non_snake_case)]` (part of `#[warn(nonstandard_style)]`) on by default
[INFO] [stderr] 
[INFO] [stderr] warning: unused `Result` that must be used
[INFO] [stderr]   --> src/lib.rs:20:5
[INFO] [stderr]    |
[INFO] [stderr] 20 |     file.read_to_end(&mut code);
[INFO] [stderr]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr]    |
[INFO] [stderr]    = note: this `Result` may be an `Err` variant, which should be handled
[INFO] [stderr]    = note: `#[warn(unused_must_use)]` (part of `#[warn(unused)]`) on by default
[INFO] [stderr] help: use `let _ = ...` to ignore the resulting value
[INFO] [stderr]    |
[INFO] [stderr] 20 |     let _ = file.read_to_end(&mut code);
[INFO] [stderr]    |     +++++++
[INFO] [stderr] 
[INFO] [stderr] warning: constant `User` should have an upper case name
[INFO] [stderr]   --> src/emulator.rs:14:7
[INFO] [stderr]    |
[INFO] [stderr] 14 | const User: Mode = 0; // 0b00
[INFO] [stderr]    |       ^^^^ help: convert the identifier to upper case: `USER`
[INFO] [stderr]    |
[INFO] [stderr]    = note: `#[warn(non_upper_case_globals)]` (part of `#[warn(nonstandard_style)]`) on by default
[INFO] [stderr] 
[INFO] [stderr] warning: constant `Supervisor` should have an upper case name
[INFO] [stderr]   --> src/emulator.rs:15:7
[INFO] [stderr]    |
[INFO] [stderr] 15 | const Supervisor: Mode = 1; // 0b01
[INFO] [stderr]    |       ^^^^^^^^^^
[INFO] [stderr]    |
[INFO] [stderr] help: convert the identifier to upper case
[INFO] [stderr]    |
[INFO] [stderr] 15 - const Supervisor: Mode = 1; // 0b01
[INFO] [stderr] 15 + const SUPERVISOR: Mode = 1; // 0b01
[INFO] [stderr]    |
[INFO] [stderr] 
[INFO] [stderr] warning: constant `Machine` should have an upper case name
[INFO] [stderr]   --> src/emulator.rs:16:7
[INFO] [stderr]    |
[INFO] [stderr] 16 | const Machine: Mode = 3; // 0b11
[INFO] [stderr]    |       ^^^^^^^
[INFO] [stderr]    |
[INFO] [stderr] help: convert the identifier to upper case
[INFO] [stderr]    |
[INFO] [stderr] 16 - const Machine: Mode = 3; // 0b11
[INFO] [stderr] 16 + const MACHINE: Mode = 3; // 0b11
[INFO] [stderr]    |
[INFO] [stderr] 
[INFO] [stderr] warning: variable `MEMORY_SIZE` should have a snake case name
[INFO] [stderr]   --> src/emulator.rs:41:13
[INFO] [stderr]    |
[INFO] [stderr] 41 |         let MEMORY_SIZE = 1024*1024*128; // Define 10MiB memory
[INFO] [stderr]    |             ^^^^^^^^^^^ help: convert the identifier to snake case: `memory_size`
[INFO] [stderr] 
[INFO] [stderr] warning: variable `SPP_FLAG_POS` should have a snake case name
[INFO] [stderr]    --> src/emulator.rs:354:29
[INFO] [stderr]     |
[INFO] [stderr] 354 |                         let SPP_FLAG_POS = 8; 
[INFO] [stderr]     |                             ^^^^^^^^^^^^ help: convert the identifier to snake case: `spp_flag_pos`
[INFO] [stderr] 
[INFO] [stderr] warning: variable `SPIE_FLAG_POS` should have a snake case name
[INFO] [stderr]    --> src/emulator.rs:359:29
[INFO] [stderr]     |
[INFO] [stderr] 359 |                         let SPIE_FLAG_POS = 5;
[INFO] [stderr]     |                             ^^^^^^^^^^^^^ help: convert the identifier to snake case: `spie_flag_pos`
[INFO] [stderr] 
[INFO] [stderr] warning: variable `SIE_FLAG_POS` should have a snake case name
[INFO] [stderr]    --> src/emulator.rs:360:29
[INFO] [stderr]     |
[INFO] [stderr] 360 |                         let SIE_FLAG_POS = 1;
[INFO] [stderr]     |                             ^^^^^^^^^^^^ help: convert the identifier to snake case: `sie_flag_pos`
[INFO] [stderr] 
[INFO] [stderr] warning: variable `SupervisorSoftwareInterrupt` should have a snake case name
[INFO] [stderr]   --> src/emulator/interrupt.rs:17:13
[INFO] [stderr]    |
[INFO] [stderr] 17 |             SupervisorSoftwareInterrupt => 1,
[INFO] [stderr]    |             ^^^^^^^^^^^^^^^^^^^^^^^^^^^ help: convert the identifier to snake case: `supervisor_software_interrupt`
[INFO] [stderr] 
[INFO] [stderr] warning: variable `MachineSoftwareInterrupt` should have a snake case name
[INFO] [stderr]   --> src/emulator/interrupt.rs:18:13
[INFO] [stderr]    |
[INFO] [stderr] 18 |             MachineSoftwareInterrupt => 3,
[INFO] [stderr]    |             ^^^^^^^^^^^^^^^^^^^^^^^^ help: convert the identifier to snake case: `machine_software_interrupt`
[INFO] [stderr] 
[INFO] [stderr] warning: variable `SupervisorTimerInterrupt` should have a snake case name
[INFO] [stderr]   --> src/emulator/interrupt.rs:19:13
[INFO] [stderr]    |
[INFO] [stderr] 19 |             SupervisorTimerInterrupt => 5,
[INFO] [stderr]    |             ^^^^^^^^^^^^^^^^^^^^^^^^ help: convert the identifier to snake case: `supervisor_timer_interrupt`
[INFO] [stderr] 
[INFO] [stderr] warning: variable `MachineTimerInterrupt` should have a snake case name
[INFO] [stderr]   --> src/emulator/interrupt.rs:20:13
[INFO] [stderr]    |
[INFO] [stderr] 20 |             MachineTimerInterrupt => 7,
[INFO] [stderr]    |             ^^^^^^^^^^^^^^^^^^^^^ help: convert the identifier to snake case: `machine_timer_interrupt`
[INFO] [stderr] 
[INFO] [stderr] warning: variable `SupervisorExternalInterrupt` should have a snake case name
[INFO] [stderr]   --> src/emulator/interrupt.rs:21:13
[INFO] [stderr]    |
[INFO] [stderr] 21 |             SupervisorExternalInterrupt => 9,
[INFO] [stderr]    |             ^^^^^^^^^^^^^^^^^^^^^^^^^^^ help: convert the identifier to snake case: `supervisor_external_interrupt`
[INFO] [stderr] 
[INFO] [stderr] warning: variable `MachineExternalInterrupt` should have a snake case name
[INFO] [stderr]   --> src/emulator/interrupt.rs:22:13
[INFO] [stderr]    |
[INFO] [stderr] 22 |             MachineExternalInterrupt => 11,
[INFO] [stderr]    |             ^^^^^^^^^^^^^^^^^^^^^^^^ help: convert the identifier to snake case: `machine_external_interrupt`
[INFO] [stderr] 
[INFO] [stderr] For more information about this error, try `rustc --explain E0170`.
[INFO] [stderr] warning: `Risc-V-Emulator` (lib) generated 112 warnings (run `cargo fix --lib -p Risc-V-Emulator` to apply 56 suggestions)
[INFO] [stderr] warning: unused import: `std::env`
[INFO] [stderr]  --> tests/test_add.rs:5:5
[INFO] [stderr]   |
[INFO] [stderr] 5 | use std::env;
[INFO] [stderr]   |     ^^^^^^^^
[INFO] [stderr]   |
[INFO] [stderr]   = note: `#[warn(unused_imports)]` (part of `#[warn(unused)]`) on by default
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `result`
[INFO] [stderr]   --> tests/test_add.rs:22:9
[INFO] [stderr]    |
[INFO] [stderr] 22 |     let result = read_binary(&mut code, &prog_file);
[INFO] [stderr]    |         ^^^^^^ help: if this is intentional, prefix it with an underscore: `_result`
[INFO] [stderr]    |
[INFO] [stderr]    = note: `#[warn(unused_variables)]` (part of `#[warn(unused)]`) on by default
[INFO] [stderr] 
[INFO] [stderr] warning: `Risc-V-Emulator` (test "test_add") generated 2 warnings (run `cargo fix --test "test_add"` to apply 1 suggestion)
[INFO] [stderr] warning: constant `User` is never used
[INFO] [stderr]   --> src/emulator.rs:14:7
[INFO] [stderr]    |
[INFO] [stderr] 14 | const User: Mode = 0; // 0b00
[INFO] [stderr]    |       ^^^^
[INFO] [stderr]    |
[INFO] [stderr]    = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default
[INFO] [stderr] 
[INFO] [stderr] warning: variable `MEMORY_SIZE` should have a snake case name
[INFO] [stderr]   --> src/emulator.rs:41:13
[INFO] [stderr]    |
[INFO] [stderr] 41 |         let MEMORY_SIZE = 1024*1024*128; // Define 10MiB memory
[INFO] [stderr]    |             ^^^^^^^^^^^ help: convert the identifier to snake case: `memory_size`
[INFO] [stderr]    |
[INFO] [stderr]    = note: `#[warn(non_snake_case)]` (part of `#[warn(nonstandard_style)]`) on by default
[INFO] [stderr] 
[INFO] [stderr] warning: function `test_R_instr_decode` should have a snake case name
[INFO] [stderr]    --> src/emulator/instructions.rs:158:8
[INFO] [stderr]     |
[INFO] [stderr] 158 |     fn test_R_instr_decode() {
[INFO] [stderr]     |        ^^^^^^^^^^^^^^^^^^^ help: convert the identifier to snake case: `test_r_instr_decode`
[INFO] [stderr] 
[INFO] [stderr] warning: function `test_I_instr_decode` should have a snake case name
[INFO] [stderr]    --> src/emulator/instructions.rs:172:8
[INFO] [stderr]     |
[INFO] [stderr] 172 |     fn test_I_instr_decode() {
[INFO] [stderr]     |        ^^^^^^^^^^^^^^^^^^^ help: convert the identifier to snake case (notice the capitalization): `test_i_instr_decode`
[INFO] [stderr] 
[INFO] [stderr] warning: function `test_S_instr_decode` should have a snake case name
[INFO] [stderr]    --> src/emulator/instructions.rs:186:8
[INFO] [stderr]     |
[INFO] [stderr] 186 |     fn test_S_instr_decode() {
[INFO] [stderr]     |        ^^^^^^^^^^^^^^^^^^^ help: convert the identifier to snake case (notice the capitalization): `test_s_instr_decode`
[INFO] [stderr] 
[INFO] [stderr] warning: function `test_B_instr_decode` should have a snake case name
[INFO] [stderr]    --> src/emulator/instructions.rs:200:8
[INFO] [stderr]     |
[INFO] [stderr] 200 |     fn test_B_instr_decode() {
[INFO] [stderr]     |        ^^^^^^^^^^^^^^^^^^^ help: convert the identifier to snake case: `test_b_instr_decode`
[INFO] [stderr] 
[INFO] [stderr] warning: function `test_U_instr_decode` should have a snake case name
[INFO] [stderr]    --> src/emulator/instructions.rs:215:8
[INFO] [stderr]     |
[INFO] [stderr] 215 |     fn test_U_instr_decode() {
[INFO] [stderr]     |        ^^^^^^^^^^^^^^^^^^^ help: convert the identifier to snake case (notice the capitalization): `test_u_instr_decode`
[INFO] [stderr] 
[INFO] [stderr] warning: function `test_J_instr_decode` should have a snake case name
[INFO] [stderr]    --> src/emulator/instructions.rs:229:8
[INFO] [stderr]     |
[INFO] [stderr] 229 |     fn test_J_instr_decode() {
[INFO] [stderr]     |        ^^^^^^^^^^^^^^^^^^^ help: convert the identifier to snake case: `test_j_instr_decode`
[INFO] [stderr] 
[INFO] [stderr] warning: unused `Result` that must be used
[INFO] [stderr]    --> src/emulator.rs:402:13
[INFO] [stderr]     |
[INFO] [stderr] 402 |             cpu.execute(d);
[INFO] [stderr]     |             ^^^^^^^^^^^^^^
[INFO] [stderr]     |
[INFO] [stderr]     = note: this `Result` may be an `Err` variant, which should be handled
[INFO] [stderr] help: use `let _ = ...` to ignore the resulting value
[INFO] [stderr]     |
[INFO] [stderr] 402 |             let _ = cpu.execute(d);
[INFO] [stderr]     |             +++++++
[INFO] [stderr] 
[INFO] [stderr] warning: unused `Result` that must be used
[INFO] [stderr]    --> src/emulator.rs:516:9
[INFO] [stderr]     |
[INFO] [stderr] 516 |         cpu.execute(inst_obj);
[INFO] [stderr]     |         ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr]     |
[INFO] [stderr]     = note: this `Result` may be an `Err` variant, which should be handled
[INFO] [stderr] help: use `let _ = ...` to ignore the resulting value
[INFO] [stderr]     |
[INFO] [stderr] 516 |         let _ = cpu.execute(inst_obj);
[INFO] [stderr]     |         +++++++
[INFO] [stderr] 
[INFO] [stderr] warning: `Risc-V-Emulator` (lib test) generated 107 warnings (97 duplicates)
[INFO] [stderr]     Finished `test` profile [unoptimized + debuginfo] target(s) in 0.08s
[INFO] [stderr]      Running unittests src/lib.rs (/opt/rustwide/target/debug/deps/Risc_V_Emulator-35afc1b01e01312c)
[INFO] [stdout] 
[INFO] [stdout] running 13 tests
[INFO] [stdout] test emulator::instructions::tests::test_B_instr_decode ... ok
[INFO] [stdout] test emulator::instructions::tests::test_S_instr_decode ... ok
[INFO] [stdout] test emulator::tests::test_execute_add_addi ... ok
[INFO] [stdout] test emulator::instructions::tests::test_U_instr_decode ... ok
[INFO] [stdout] test emulator::instructions::tests::test_J_instr_decode ... ok
[INFO] [stdout] test emulator::instructions::tests::test_R_instr_decode ... ok
[INFO] [stdout] test emulator::instructions::tests::test_I_instr_decode ... ok
[INFO] [stdout] test emulator::tests::test_execute_csrrc ... ok
[INFO] [stdout] test emulator::tests::test_execute_andi_ori_xori ... ok
[INFO] [stdout] test emulator::tests::test_execute_srai ... ok
[INFO] [stdout] test emulator::tests::test_execute_stli_stliu ... ok
[INFO] [stdout] test emulator::tests::test_execute_slli_srli ... ok
[INFO] [stdout] test emulator::tests::test_execute_lui ... ok
[INFO] [stdout] 
[INFO] [stdout] test result: ok. 13 passed; 0 failed; 0 ignored; 0 measured; 0 filtered out; finished in 0.01s
[INFO] [stdout] 
[INFO] [stderr]      Running tests/test_add.rs (/opt/rustwide/target/debug/deps/test_add-fe02f8220838a1c8)
[INFO] [stdout] 
[INFO] [stdout] running 1 test
[INFO] [stdout] test test_add ... FAILED
[INFO] [stdout] 
[INFO] [stdout] failures:
[INFO] [stdout] 
[INFO] [stdout] ---- test_add stdout ----
[INFO] [stdout] Result: [0, 80, 14, 147, 2, 80, 15, 19, 1, 223, 15, 179]
[INFO] [stdout] 
[INFO] [stdout] thread 'test_add' (37) panicked at src/emulator.rs:155:13:
[INFO] [stdout] Fatal exception!
[INFO] [stdout] stack backtrace:
[INFO] [stdout]    0:     0x5c65d7cf4a22 - std::backtrace_rs::backtrace::libunwind::trace::hcab59e1e990fdc24
[INFO] [stdout]                                at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/std/src/../../backtrace/src/backtrace/libunwind.rs:117:9
[INFO] [stdout]    1:     0x5c65d7cf4a22 - std::backtrace_rs::backtrace::trace_unsynchronized::he24cc57f3d2f47b7
[INFO] [stdout]                                at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/std/src/../../backtrace/src/backtrace/mod.rs:66:14
[INFO] [stdout]    2:     0x5c65d7cf4a22 - std::sys::backtrace::_print_fmt::hf8d65ede198eeb54
[INFO] [stdout]                                at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/std/src/sys/backtrace.rs:66:9
[INFO] [stdout]    3:     0x5c65d7cf4a22 - <std::sys::backtrace::BacktraceLock::print::DisplayBacktrace as core::fmt::Display>::fmt::h67edf0e4d33c343c
[INFO] [stdout]                                at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/std/src/sys/backtrace.rs:39:26
[INFO] [stdout]    4:     0x5c65d7d04e2f - core::fmt::rt::Argument::fmt::hef94184842aeafdd
[INFO] [stdout]                                at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/core/src/fmt/rt.rs:173:76
[INFO] [stdout]    5:     0x5c65d7d04e2f - core::fmt::write::hcf0c66b48a8fa606
[INFO] [stdout]                                at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/core/src/fmt/mod.rs:1468:25
[INFO] [stdout]    6:     0x5c65d7cc1a11 - std::io::default_write_fmt::h69967ac0ba93195f
[INFO] [stdout]                                at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/std/src/io/mod.rs:639:11
[INFO] [stdout]    7:     0x5c65d7cc1a11 - std::io::Write::write_fmt::h8db9396209deaa1c
[INFO] [stdout]                                at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/std/src/io/mod.rs:1954:13
[INFO] [stdout]    8:     0x5c65d7ccdb82 - std::sys::backtrace::BacktraceLock::print::h07e5435aa717b414
[INFO] [stdout]                                at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/std/src/sys/backtrace.rs:42:9
[INFO] [stdout]    9:     0x5c65d7cd27cf - std::panicking::default_hook::{{closure}}::h91001850288db5f7
[INFO] [stdout]                                at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/std/src/panicking.rs:301:27
[INFO] [stdout]   10:     0x5c65d7cd2661 - std::panicking::default_hook::h2346dbb704ef5512
[INFO] [stdout]                                at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/std/src/panicking.rs:325:9
[INFO] [stdout]   11:     0x5c65d7c83f3e - <alloc::boxed::Box<F,A> as core::ops::function::Fn<Args>>::call::h18383b2e29377420
[INFO] [stdout]                                at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/alloc/src/boxed.rs:1999:9
[INFO] [stdout]   12:     0x5c65d7c83f3e - test::test_main_with_exit_callback::{{closure}}::h272d7ef99aef06dc
[INFO] [stdout]                                at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/test/src/lib.rs:145:21
[INFO] [stdout]   13:     0x5c65d7cd2e8f - <alloc::boxed::Box<F,A> as core::ops::function::Fn<Args>>::call::h6dba6e441651a0d1
[INFO] [stdout]                                at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/alloc/src/boxed.rs:1999:9
[INFO] [stdout]   14:     0x5c65d7cd2e8f - std::panicking::panic_with_hook::hd2b063a6090d23a4
[INFO] [stdout]                                at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/std/src/panicking.rs:842:13
[INFO] [stdout]   15:     0x5c65d7cd2cb6 - std::panicking::panic_handler::{{closure}}::he666d95f139a333e
[INFO] [stdout]                                at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/std/src/panicking.rs:700:13
[INFO] [stdout]   16:     0x5c65d7ccdcb9 - std::sys::backtrace::__rust_end_short_backtrace::h631ad224854ebee5
[INFO] [stdout]                                at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/std/src/sys/backtrace.rs:174:18
[INFO] [stdout]   17:     0x5c65d7cb5eed - __rustc[1d67440d6e82e4f]::rust_begin_unwind
[INFO] [stdout]                                at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/std/src/panicking.rs:698:5
[INFO] [stdout]   18:     0x5c65d7d0c9d0 - core::panicking::panic_fmt::h420ddb7fd73daf53
[INFO] [stdout]                                at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/core/src/panicking.rs:75:14
[INFO] [stdout]   19:     0x5c65d7ca6e3f - Risc_V_Emulator::emulator::Cpu::handle_error::hde707ac31fff1e9d
[INFO] [stdout]                                at /opt/rustwide/workdir/src/emulator.rs:155:13
[INFO] [stdout]   20:     0x5c65d7ca7b8a - Risc_V_Emulator::emulator::Cpu::run::hb81a4b1c195bf0a2
[INFO] [stdout]                                at /opt/rustwide/workdir/src/emulator.rs:53:26
[INFO] [stdout]   21:     0x5c65d7c62ebe - test_add::test_add::hbfefe010f2b07c60
[INFO] [stdout]                                at /opt/rustwide/workdir/tests/test_add.rs:28:9
[INFO] [stdout]   22:     0x5c65d7c63077 - test_add::test_add::{{closure}}::h364f3e99919db70c
[INFO] [stdout]                                at /opt/rustwide/workdir/tests/test_add.rs:18:14
[INFO] [stdout]   23:     0x5c65d7c61b36 - core::ops::function::FnOnce::call_once::hbfc6a7a41d9e40ee
[INFO] [stdout]                                at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/core/src/ops/function.rs:250:5
[INFO] [stdout]   24:     0x5c65d7c83cfb - core::ops::function::FnOnce::call_once::h70887edf07a630ba
[INFO] [stdout]                                at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/core/src/ops/function.rs:250:5
[INFO] [stdout]   25:     0x5c65d7c83cfb - test::__rust_begin_short_backtrace::h27763c4cbbdb8601
[INFO] [stdout]                                at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/test/src/lib.rs:663:18
[INFO] [stdout]   26:     0x5c65d7c99965 - test::run_test_in_process::{{closure}}::h4dc8bc6d5e3924d3
[INFO] [stdout]                                at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/test/src/lib.rs:686:74
[INFO] [stdout]   27:     0x5c65d7c99965 - <core::panic::unwind_safe::AssertUnwindSafe<F> as core::ops::function::FnOnce<()>>::call_once::h75905e8ffe81974f
[INFO] [stdout]                                at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/core/src/panic/unwind_safe.rs:274:9
[INFO] [stdout]   28:     0x5c65d7c99965 - std::panicking::catch_unwind::do_call::h0bc60366ba66eba5
[INFO] [stdout]                                at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/std/src/panicking.rs:590:40
[INFO] [stdout]   29:     0x5c65d7c99965 - std::panicking::catch_unwind::hae1ec7bf94407afa
[INFO] [stdout]                                at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/std/src/panicking.rs:553:19
[INFO] [stdout]   30:     0x5c65d7c99965 - std::panic::catch_unwind::h0f4ff4773d84d3cd
[INFO] [stdout]                                at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/std/src/panic.rs:359:14
[INFO] [stdout]   31:     0x5c65d7c99965 - test::run_test_in_process::h03fbc77ae48b3f10
[INFO] [stdout]                                at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/test/src/lib.rs:686:27
[INFO] [stdout]   32:     0x5c65d7c99965 - test::run_test::{{closure}}::h83476a9c453dc4d3
[INFO] [stdout]                                at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/test/src/lib.rs:607:43
[INFO] [stdout]   33:     0x5c65d7c70154 - test::run_test::{{closure}}::h515482ad1e7fe7de
[INFO] [stdout]                                at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/test/src/lib.rs:637:41
[INFO] [stdout]   34:     0x5c65d7c70154 - std::sys::backtrace::__rust_begin_short_backtrace::hed09f6ac5fe9d647
[INFO] [stdout]                                at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/std/src/sys/backtrace.rs:158:18
[INFO] [stdout]   35:     0x5c65d7c73a1a - std::thread::Builder::spawn_unchecked_::{{closure}}::{{closure}}::h988e2cd969319888
[INFO] [stdout]                                at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/std/src/thread/mod.rs:559:17
[INFO] [stdout]   36:     0x5c65d7c73a1a - <core::panic::unwind_safe::AssertUnwindSafe<F> as core::ops::function::FnOnce<()>>::call_once::hd70e28dc46ec20be
[INFO] [stdout]                                at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/core/src/panic/unwind_safe.rs:274:9
[INFO] [stdout]   37:     0x5c65d7c73a1a - std::panicking::catch_unwind::do_call::hdc29e11311eb7655
[INFO] [stdout]                                at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/std/src/panicking.rs:590:40
[INFO] [stdout]   38:     0x5c65d7c73a1a - std::panicking::catch_unwind::h9e402d6a96fef41c
[INFO] [stdout]                                at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/std/src/panicking.rs:553:19
[INFO] [stdout]   39:     0x5c65d7c73a1a - std::panic::catch_unwind::h9213c0c54aec70e0
[INFO] [stdout]                                at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/std/src/panic.rs:359:14
[INFO] [stdout]   40:     0x5c65d7c73a1a - std::thread::Builder::spawn_unchecked_::{{closure}}::h6262965869ed2b87
[INFO] [stdout]                                at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/std/src/thread/mod.rs:557:30
[INFO] [stdout]   41:     0x5c65d7c73a1a - core::ops::function::FnOnce::call_once{{vtable.shim}}::h05c05ed02619e462
[INFO] [stdout]                                at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/core/src/ops/function.rs:250:5
[INFO] [stderr] error: test failed, to rerun pass `--test test_add`
[INFO] [stdout]   42:     0x5c65d7cc8e1f - <alloc::boxed::Box<F,A> as core::ops::function::FnOnce<Args>>::call_once::h2044e71c41d3958a
[INFO] [stdout]                                at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/alloc/src/boxed.rs:1985:9
[INFO] [stdout]   43:     0x5c65d7cc8e1f - std::sys::thread::unix::Thread::new::thread_start::hf277835320aa8e5a
[INFO] [stdout]                                at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/std/src/sys/thread/unix.rs:126:17
[INFO] [stdout]   44:     0x7ffbc8221aa4 - <unknown>
[INFO] [stdout]   45:     0x7ffbc82aea34 - clone
[INFO] [stdout]   46:                0x0 - <unknown>
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] failures:
[INFO] [stdout]     test_add
[INFO] [stdout] 
[INFO] [stdout] test result: FAILED. 0 passed; 1 failed; 0 ignored; 0 measured; 0 filtered out; finished in 0.07s
[INFO] [stdout] 
[INFO] running `Command { std: "docker" "inspect" "84a84b3b9d232a9936726de30dba2e07d9871b1de8d4ca6aa099cf8fa6be7056", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "84a84b3b9d232a9936726de30dba2e07d9871b1de8d4ca6aa099cf8fa6be7056", kill_on_drop: false }`
[INFO] [stdout] 84a84b3b9d232a9936726de30dba2e07d9871b1de8d4ca6aa099cf8fa6be7056
