[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 1.94.0 for beta-1.95-1
[INFO] running `Command { std: "git" "clone" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2Fenathang%2FRisc-V-Emulator" "/workspace/builds/worker-1-tc1/source", kill_on_drop: false }`
[INFO] [stderr] Cloning into '/workspace/builds/worker-1-tc1/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-1-tc1/source/Cargo.toml
[INFO] validating manifest of git repo https://github.com/enathang/Risc-V-Emulator on toolchain 1.94.0
[INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+1.94.0" "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" "+1.94.0" "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] [stderr]  Downloading crates ...
[INFO] [stderr]   Downloaded asm_riscv v0.1.0
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-1-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-1-tc1/source:/opt/rustwide/workdir:ro,Z" "-v" "/var/lib/crater-agent-workspace/cargo-home:/opt/rustwide/cargo-home:ro,Z" "-v" "/var/lib/crater-agent-workspace/rustup-home:/opt/rustwide/rustup-home:ro,Z" "-e" "SOURCE_DIR=/opt/rustwide/workdir" "-e" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_HOME=/opt/rustwide/cargo-home" "-e" "RUSTUP_HOME=/opt/rustwide/rustup-home" "-w" "/opt/rustwide/workdir" "-m" "1610612736" "--user" "0:0" "--network" "none" "ghcr.io/rust-lang/crates-build-env/linux@sha256:d429b63d4308055ea97f60fb1d3dfca48854a00942f1bd2ad806beaf015945ec" "/opt/rustwide/cargo-home/bin/cargo" "+1.94.0" "metadata" "--no-deps" "--format-version=1", kill_on_drop: false }`
[INFO] [stdout] 653990374c299854c05dbe2525d0aaca4c40b4a7c69bdaaa50c2fbe050e9c9d8
[INFO] running `Command { std: "docker" "start" "-a" "653990374c299854c05dbe2525d0aaca4c40b4a7c69bdaaa50c2fbe050e9c9d8", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "inspect" "653990374c299854c05dbe2525d0aaca4c40b4a7c69bdaaa50c2fbe050e9c9d8", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "653990374c299854c05dbe2525d0aaca4c40b4a7c69bdaaa50c2fbe050e9c9d8", kill_on_drop: false }`
[INFO] [stdout] 653990374c299854c05dbe2525d0aaca4c40b4a7c69bdaaa50c2fbe050e9c9d8
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-1-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-1-tc1/source:/opt/rustwide/workdir:ro,Z" "-v" "/var/lib/crater-agent-workspace/cargo-home:/opt/rustwide/cargo-home:ro,Z" "-v" "/var/lib/crater-agent-workspace/rustup-home:/opt/rustwide/rustup-home:ro,Z" "-e" "SOURCE_DIR=/opt/rustwide/workdir" "-e" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_INCREMENTAL=0" "-e" "RUST_BACKTRACE=full" "-e" "RUSTFLAGS=--cap-lints=warn" "-e" "RUSTDOCFLAGS=--cap-lints=warn" "-e" "CARGO_HOME=/opt/rustwide/cargo-home" "-e" "RUSTUP_HOME=/opt/rustwide/rustup-home" "-w" "/opt/rustwide/workdir" "-m" "1610612736" "--user" "0:0" "--network" "none" "ghcr.io/rust-lang/crates-build-env/linux@sha256:d429b63d4308055ea97f60fb1d3dfca48854a00942f1bd2ad806beaf015945ec" "/opt/rustwide/cargo-home/bin/cargo" "+1.94.0" "build" "--frozen" "--message-format=json", kill_on_drop: false }`
[INFO] [stdout] b96f303ec48df91ab768603e8aa6d70d1af0a3e5084aaadb759ed7ee3255b7a5
[INFO] running `Command { std: "docker" "start" "-a" "b96f303ec48df91ab768603e8aa6d70d1af0a3e5084aaadb759ed7ee3255b7a5", 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: 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] help: if this is intentional, prefix it with an underscore
[INFO] [stdout]    |
[INFO] [stdout] 17 |             _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: 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] help: if this is intentional, prefix it with an underscore
[INFO] [stdout]    |
[INFO] [stdout] 18 |             _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: 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] help: if this is intentional, prefix it with an underscore
[INFO] [stdout]    |
[INFO] [stdout] 19 |             _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: 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] help: if this is intentional, prefix it with an underscore
[INFO] [stdout]    |
[INFO] [stdout] 20 |             _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: 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] help: if this is intentional, prefix it with an underscore
[INFO] [stdout]    |
[INFO] [stdout] 21 |             _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: 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] help: if this is intentional, prefix it with an underscore
[INFO] [stdout]    |
[INFO] [stdout] 22 |             _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]    |                                   ^^^^ help: if this is intentional, prefix it with an underscore: `_size`
[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]    |                                        ^^^^ help: if this is intentional, prefix it with an underscore: `_size`
[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: 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.61s
[INFO] running `Command { std: "docker" "inspect" "b96f303ec48df91ab768603e8aa6d70d1af0a3e5084aaadb759ed7ee3255b7a5", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "b96f303ec48df91ab768603e8aa6d70d1af0a3e5084aaadb759ed7ee3255b7a5", kill_on_drop: false }`
[INFO] [stdout] b96f303ec48df91ab768603e8aa6d70d1af0a3e5084aaadb759ed7ee3255b7a5
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-1-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-1-tc1/source:/opt/rustwide/workdir:ro,Z" "-v" "/var/lib/crater-agent-workspace/cargo-home:/opt/rustwide/cargo-home:ro,Z" "-v" "/var/lib/crater-agent-workspace/rustup-home:/opt/rustwide/rustup-home:ro,Z" "-e" "SOURCE_DIR=/opt/rustwide/workdir" "-e" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_INCREMENTAL=0" "-e" "RUST_BACKTRACE=full" "-e" "RUSTFLAGS=--cap-lints=warn" "-e" "RUSTDOCFLAGS=--cap-lints=warn" "-e" "CARGO_HOME=/opt/rustwide/cargo-home" "-e" "RUSTUP_HOME=/opt/rustwide/rustup-home" "-w" "/opt/rustwide/workdir" "-m" "1610612736" "--user" "0:0" "--network" "none" "ghcr.io/rust-lang/crates-build-env/linux@sha256:d429b63d4308055ea97f60fb1d3dfca48854a00942f1bd2ad806beaf015945ec" "/opt/rustwide/cargo-home/bin/cargo" "+1.94.0" "test" "--frozen" "--no-run" "--message-format=json", kill_on_drop: false }`
[INFO] [stdout] fa477012aaf60fd43a6256e817678f4519f82871d7db52277028df59cf4ab305
[INFO] running `Command { std: "docker" "start" "-a" "fa477012aaf60fd43a6256e817678f4519f82871d7db52277028df59cf4ab305", 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: 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] help: if this is intentional, prefix it with an underscore
[INFO] [stdout]    |
[INFO] [stdout] 17 |             _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: 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] help: if this is intentional, prefix it with an underscore
[INFO] [stdout]    |
[INFO] [stdout] 18 |             _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: 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] help: if this is intentional, prefix it with an underscore
[INFO] [stdout]    |
[INFO] [stdout] 19 |             _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: 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] help: if this is intentional, prefix it with an underscore
[INFO] [stdout]    |
[INFO] [stdout] 20 |             _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: 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] help: if this is intentional, prefix it with an underscore
[INFO] [stdout]    |
[INFO] [stdout] 21 |             _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: 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] help: if this is intentional, prefix it with an underscore
[INFO] [stdout]    |
[INFO] [stdout] 22 |             _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]    |                                   ^^^^ help: if this is intentional, prefix it with an underscore: `_size`
[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]    |                                        ^^^^ help: if this is intentional, prefix it with an underscore: `_size`
[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: 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] [stderr]    Compiling Risc-V-Emulator v0.1.0 (/opt/rustwide/workdir)
[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: 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: 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: 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] help: if this is intentional, prefix it with an underscore
[INFO] [stdout]    |
[INFO] [stdout] 17 |             _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: 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] help: if this is intentional, prefix it with an underscore
[INFO] [stdout]    |
[INFO] [stdout] 18 |             _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: 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] help: if this is intentional, prefix it with an underscore
[INFO] [stdout]    |
[INFO] [stdout] 19 |             _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: 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] help: if this is intentional, prefix it with an underscore
[INFO] [stdout]    |
[INFO] [stdout] 20 |             _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: 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] help: if this is intentional, prefix it with an underscore
[INFO] [stdout]    |
[INFO] [stdout] 21 |             _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: 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] help: if this is intentional, prefix it with an underscore
[INFO] [stdout]    |
[INFO] [stdout] 22 |             _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]    |                                   ^^^^ help: if this is intentional, prefix it with an underscore: `_size`
[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]    |                                        ^^^^ help: if this is intentional, prefix it with an underscore: `_size`
[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: 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.88s
[INFO] running `Command { std: "docker" "inspect" "fa477012aaf60fd43a6256e817678f4519f82871d7db52277028df59cf4ab305", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "fa477012aaf60fd43a6256e817678f4519f82871d7db52277028df59cf4ab305", kill_on_drop: false }`
[INFO] [stdout] fa477012aaf60fd43a6256e817678f4519f82871d7db52277028df59cf4ab305
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-1-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-1-tc1/source:/opt/rustwide/workdir:ro,Z" "-v" "/var/lib/crater-agent-workspace/cargo-home:/opt/rustwide/cargo-home:ro,Z" "-v" "/var/lib/crater-agent-workspace/rustup-home:/opt/rustwide/rustup-home:ro,Z" "-e" "SOURCE_DIR=/opt/rustwide/workdir" "-e" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_INCREMENTAL=0" "-e" "RUST_BACKTRACE=full" "-e" "RUSTFLAGS=--cap-lints=warn" "-e" "RUSTDOCFLAGS=--cap-lints=warn" "-e" "CARGO_HOME=/opt/rustwide/cargo-home" "-e" "RUSTUP_HOME=/opt/rustwide/rustup-home" "-w" "/opt/rustwide/workdir" "-m" "1610612736" "--user" "0:0" "--network" "none" "ghcr.io/rust-lang/crates-build-env/linux@sha256:d429b63d4308055ea97f60fb1d3dfca48854a00942f1bd2ad806beaf015945ec" "/opt/rustwide/cargo-home/bin/cargo" "+1.94.0" "test" "--frozen", kill_on_drop: false }`
[INFO] [stdout] b69a13c41c31ead7b79f27c95dc8c9b5b1fb2a5912bf51d5891aed12bd070fb7
[INFO] running `Command { std: "docker" "start" "-a" "b69a13c41c31ead7b79f27c95dc8c9b5b1fb2a5912bf51d5891aed12bd070fb7", 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: 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] help: if this is intentional, prefix it with an underscore
[INFO] [stderr]    |
[INFO] [stderr] 17 |             _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: 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] help: if this is intentional, prefix it with an underscore
[INFO] [stderr]    |
[INFO] [stderr] 18 |             _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: 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] help: if this is intentional, prefix it with an underscore
[INFO] [stderr]    |
[INFO] [stderr] 19 |             _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: 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] help: if this is intentional, prefix it with an underscore
[INFO] [stderr]    |
[INFO] [stderr] 20 |             _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: 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] help: if this is intentional, prefix it with an underscore
[INFO] [stderr]    |
[INFO] [stderr] 21 |             _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: 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] help: if this is intentional, prefix it with an underscore
[INFO] [stderr]    |
[INFO] [stderr] 22 |             _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]    |                                   ^^^^ help: if this is intentional, prefix it with an underscore: `_size`
[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]    |                                        ^^^^ help: if this is intentional, prefix it with an underscore: `_size`
[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: 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 57 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" -p Risc-V-Emulator` to apply 2 suggestions)
[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.12s
[INFO] [stderr]      Running unittests src/lib.rs (/opt/rustwide/target/debug/deps/Risc_V_Emulator-8b5c2bb6e5e1d6bf)
[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_I_instr_decode ... ok
[INFO] [stdout] test emulator::instructions::tests::test_J_instr_decode ... ok
[INFO] [stdout] test emulator::instructions::tests::test_S_instr_decode ... ok
[INFO] [stdout] test emulator::instructions::tests::test_R_instr_decode ... ok
[INFO] [stdout] test emulator::instructions::tests::test_U_instr_decode ... ok
[INFO] [stdout] test emulator::tests::test_execute_add_addi ... ok
[INFO] [stderr]      Running tests/test_add.rs (/opt/rustwide/target/debug/deps/test_add-f065675410630254)
[INFO] [stdout] test emulator::tests::test_execute_srai ... ok
[INFO] [stdout] test emulator::tests::test_execute_slli_srli ... 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_stli_stliu ... 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] [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' (38) panicked at src/emulator.rs:155:13:
[INFO] [stdout] Fatal exception!
[INFO] [stdout] stack backtrace:
[INFO] [stdout]    0:     0x5a6f60130f12 - std::backtrace_rs::backtrace::libunwind::trace::hff358a60abf734fc
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/../../backtrace/src/backtrace/libunwind.rs:117:9
[INFO] [stdout]    1:     0x5a6f60130f12 - std::backtrace_rs::backtrace::trace_unsynchronized::h3b121f916dd95ec6
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/../../backtrace/src/backtrace/mod.rs:66:14
[INFO] [stdout]    2:     0x5a6f60130f12 - std::sys::backtrace::_print_fmt::hde0a62ded68798e9
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/sys/backtrace.rs:74:9
[INFO] [stdout]    3:     0x5a6f60130f12 - <std::sys::backtrace::BacktraceLock::print::DisplayBacktrace as core::fmt::Display>::fmt::h93773fc827e3113d
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/sys/backtrace.rs:44:26
[INFO] [stdout]    4:     0x5a6f6014116a - core::fmt::rt::Argument::fmt::h01eff69902dad97f
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/core/src/fmt/rt.rs:152:76
[INFO] [stdout]    5:     0x5a6f6014116a - core::fmt::write::hed7b5c73d82ecb7c
[INFO] [stdout]    6:     0x5a6f600ff706 - std::io::default_write_fmt::h2f696ff5b8bbaa4b
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/io/mod.rs:639:11
[INFO] [stdout]    7:     0x5a6f600ff706 - std::io::Write::write_fmt::h5e66814db8a9cfce
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/io/mod.rs:1994:13
[INFO] [stdout]    8:     0x5a6f601100a9 - std::sys::backtrace::BacktraceLock::print::h8b1d6fcc5a56d1a3
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/sys/backtrace.rs:47:9
[INFO] [stdout]    9:     0x5a6f601100a9 - std::panicking::default_hook::{{closure}}::h2be84df4f189ae36
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/panicking.rs:292:27
[INFO] [stdout]   10:     0x5a6f6010ff41 - std::panicking::default_hook::hf0ea8939246f43a9
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/panicking.rs:316:9
[INFO] [stdout]   11:     0x5a6f600c6b0e - <alloc::boxed::Box<F,A> as core::ops::function::Fn<Args>>::call::h02d35e3888986252
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/alloc/src/boxed.rs:2220:9
[INFO] [stdout]   12:     0x5a6f600c6b0e - test::test_main_with_exit_callback::{{closure}}::h939640a27d647173
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/test/src/lib.rs:145:21
[INFO] [stdout]   13:     0x5a6f60110322 - <alloc::boxed::Box<F,A> as core::ops::function::Fn<Args>>::call::hc9df09ff391af3e7
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/alloc/src/boxed.rs:2220:9
[INFO] [stdout]   14:     0x5a6f60110322 - std::panicking::panic_with_hook::hb4bd9ac1123582a0
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/panicking.rs:833:13
[INFO] [stdout]   15:     0x5a6f6011019a - std::panicking::panic_handler::{{closure}}::hde00dd15f5637fe2
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/panicking.rs:691:13
[INFO] [stdout]   16:     0x5a6f6010b609 - std::sys::backtrace::__rust_end_short_backtrace::hb72197fa777c1785
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/sys/backtrace.rs:182:18
[INFO] [stdout]   17:     0x5a6f600f453d - __rustc[4425a7e20b4c8619]::rust_begin_unwind
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/panicking.rs:689:5
[INFO] [stdout]   18:     0x5a6f601486ac - core::panicking::panic_fmt::ha59b517dd231f4da
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/core/src/panicking.rs:80:14
[INFO] [stdout]   19:     0x5a6f600e6c2f - Risc_V_Emulator::emulator::Cpu::handle_error::h889852b26bad4d51
[INFO] [stdout]                                at /opt/rustwide/workdir/src/emulator.rs:155:13
[INFO] [stdout]   20:     0x5a6f600e796a - Risc_V_Emulator::emulator::Cpu::run::h660d5bd9443c85a4
[INFO] [stdout]                                at /opt/rustwide/workdir/src/emulator.rs:53:26
[INFO] [stdout]   21:     0x5a6f600a7b46 - test_add::test_add::h0c91f4815869c9be
[INFO] [stdout]                                at /opt/rustwide/workdir/tests/test_add.rs:28:9
[INFO] [stdout]   22:     0x5a6f600a7ce7 - test_add::test_add::{{closure}}::h7a6626b084c2a4af
[INFO] [stdout]                                at /opt/rustwide/workdir/tests/test_add.rs:18:14
[INFO] [stdout]   23:     0x5a6f600a6d36 - core::ops::function::FnOnce::call_once::hc182fa49dd7aa577
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/core/src/ops/function.rs:250:5
[INFO] [stdout]   24:     0x5a6f600c68cb - core::ops::function::FnOnce::call_once::hddb3cd395c36bfbb
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/core/src/ops/function.rs:250:5
[INFO] [stdout]   25:     0x5a6f600c68cb - test::__rust_begin_short_backtrace::h0b6a7601d9750bfa
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/test/src/lib.rs:663:18
[INFO] [stdout]   26:     0x5a6f600da2da - test::run_test_in_process::{{closure}}::h444209903f00b347
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/test/src/lib.rs:686:74
[INFO] [stdout]   27:     0x5a6f600da2da - <core::panic::unwind_safe::AssertUnwindSafe<F> as core::ops::function::FnOnce<()>>::call_once::hfb3ba8f46e537649
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/core/src/panic/unwind_safe.rs:274:9
[INFO] [stdout]   28:     0x5a6f600da2da - std::panicking::catch_unwind::do_call::h1672a45911fcf9dc
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/panicking.rs:581:40
[INFO] [stdout]   29:     0x5a6f600da2da - std::panicking::catch_unwind::h0fadaee22787a6dd
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/panicking.rs:544:19
[INFO] [stdout]   30:     0x5a6f600da2da - std::panic::catch_unwind::hc47ad190f2c8e188
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/panic.rs:359:14
[INFO] [stdout]   31:     0x5a6f600da2da - test::run_test_in_process::hcd7faaf934f29999
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/test/src/lib.rs:686:27
[INFO] [stdout]   32:     0x5a6f600da2da - test::run_test::{{closure}}::hddc4550da4871867
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/test/src/lib.rs:607:43
[INFO] [stdout]   33:     0x5a6f600b4734 - test::run_test::{{closure}}::h98ae26689f13ed94
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/test/src/lib.rs:637:41
[INFO] [stdout]   34:     0x5a6f600b4734 - std::sys::backtrace::__rust_begin_short_backtrace::h3ec4d1f21ad44588
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/sys/backtrace.rs:166:18
[INFO] [stdout]   35:     0x5a6f600b80d2 - std::thread::lifecycle::spawn_unchecked::{{closure}}::{{closure}}::hd8bf2c73d479939f
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/thread/lifecycle.rs:91:13
[INFO] [stdout]   36:     0x5a6f600b80d2 - <core::panic::unwind_safe::AssertUnwindSafe<F> as core::ops::function::FnOnce<()>>::call_once::h3b4248f358af2491
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/core/src/panic/unwind_safe.rs:274:9
[INFO] [stdout]   37:     0x5a6f600b80d2 - std::panicking::catch_unwind::do_call::hda10a64f4b8daebe
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/panicking.rs:581:40
[INFO] [stdout]   38:     0x5a6f600b80d2 - std::panicking::catch_unwind::h659e5ee8336ec8c7
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/panicking.rs:544:19
[INFO] [stdout]   39:     0x5a6f600b80d2 - std::panic::catch_unwind::h9d4d66a538912c18
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/panic.rs:359:14
[INFO] [stdout]   40:     0x5a6f600b80d2 - std::thread::lifecycle::spawn_unchecked::{{closure}}::h7557906bb51d79f1
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/thread/lifecycle.rs:89:26
[INFO] [stdout]   41:     0x5a6f600b80d2 - core::ops::function::FnOnce::call_once{{vtable.shim}}::h9e460d1d7fc83d35
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/core/src/ops/function.rs:250:5
[INFO] [stdout]   42:     0x5a6f6010689f - <alloc::boxed::Box<F,A> as core::ops::function::FnOnce<Args>>::call_once::h61282da819d64ea9
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/alloc/src/boxed.rs:2206:9
[INFO] [stdout]   43:     0x5a6f6010689f - std::sys::thread::unix::Thread::new::thread_start::h982f9ea829d1b5fb
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/sys/thread/unix.rs:127:17
[INFO] [stdout]   44:     0x71b2a98a7aa4 - <unknown>
[INFO] [stdout]   45:     0x71b2a9934a64 - 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.02s
[INFO] [stdout] 
[INFO] [stderr] error: test failed, to rerun pass `--test test_add`
[INFO] running `Command { std: "docker" "inspect" "b69a13c41c31ead7b79f27c95dc8c9b5b1fb2a5912bf51d5891aed12bd070fb7", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "b69a13c41c31ead7b79f27c95dc8c9b5b1fb2a5912bf51d5891aed12bd070fb7", kill_on_drop: false }`
[INFO] [stdout] b69a13c41c31ead7b79f27c95dc8c9b5b1fb2a5912bf51d5891aed12bd070fb7
