Make clippy happy
This commit is contained in:
parent
578904198c
commit
6da5f5c956
@ -34,7 +34,7 @@ pub struct SerialPort {
|
|||||||
line_status: Port<u8>, // 5
|
line_status: Port<u8>, // 5
|
||||||
|
|
||||||
/// Modem Status Register.
|
/// Modem Status Register.
|
||||||
modem_status: Port<u8>, // 6
|
//modem_status: Port<u8>, // 6
|
||||||
|
|
||||||
/// Scratch Register.
|
/// Scratch Register.
|
||||||
scratch: Port<u8>, // 7
|
scratch: Port<u8>, // 7
|
||||||
@ -70,7 +70,7 @@ impl SerialPort {
|
|||||||
line_ctrl: Port::new(base + 3),
|
line_ctrl: Port::new(base + 3),
|
||||||
modem_ctrl: Port::new(base + 4),
|
modem_ctrl: Port::new(base + 4),
|
||||||
line_status: Port::new(base + 5),
|
line_status: Port::new(base + 5),
|
||||||
modem_status: Port::new(base + 6),
|
//modem_status: Port::new(base + 6),
|
||||||
scratch: Port::new(base + 7),
|
scratch: Port::new(base + 7),
|
||||||
};
|
};
|
||||||
|
|
||||||
@ -139,7 +139,7 @@ impl fmt::Write for SerialPort {
|
|||||||
|
|
||||||
lazy_static! {
|
lazy_static! {
|
||||||
pub static ref SERIAL1: Mutex<SerialPort> = {
|
pub static ref SERIAL1: Mutex<SerialPort> = {
|
||||||
let mut serial_port = unsafe { SerialPort::init_new(0x3F8).unwrap() };
|
let serial_port = unsafe { SerialPort::init_new(0x3F8).unwrap() };
|
||||||
Mutex::new(serial_port)
|
Mutex::new(serial_port)
|
||||||
};
|
};
|
||||||
}
|
}
|
||||||
|
@ -18,8 +18,7 @@ lazy_static! {
|
|||||||
static mut STACK: [u8; STACK_SIZE] = [0; STACK_SIZE];
|
static mut STACK: [u8; STACK_SIZE] = [0; STACK_SIZE];
|
||||||
let stack_start = VirtAddr::from_ptr(unsafe { &STACK });
|
let stack_start = VirtAddr::from_ptr(unsafe { &STACK });
|
||||||
// FIXME once we have page allocation available.
|
// FIXME once we have page allocation available.
|
||||||
let stack_end = stack_start + STACK_SIZE;
|
stack_start + STACK_SIZE
|
||||||
stack_end
|
|
||||||
};
|
};
|
||||||
tss
|
tss
|
||||||
};
|
};
|
||||||
|
@ -4,7 +4,7 @@ use x86_64::structures::idt::{InterruptDescriptorTable, InterruptStackFrame};
|
|||||||
use crate::gdt;
|
use crate::gdt;
|
||||||
use crate::hlt_loop;
|
use crate::hlt_loop;
|
||||||
use polling_serial::serial_println;
|
use polling_serial::serial_println;
|
||||||
use vga_buffer::{print, println, set_colors, Color, ForegroundColor};
|
use vga_buffer::println;
|
||||||
|
|
||||||
lazy_static! {
|
lazy_static! {
|
||||||
static ref IDT: InterruptDescriptorTable = {
|
static ref IDT: InterruptDescriptorTable = {
|
||||||
@ -40,7 +40,7 @@ extern "x86-interrupt" fn double_fault_handler(sf: &mut InterruptStackFrame, e:
|
|||||||
|
|
||||||
unsafe {
|
unsafe {
|
||||||
asm!("push rax" :::: "intel");
|
asm!("push rax" :::: "intel");
|
||||||
let s = (sf as *mut InterruptStackFrame);
|
let s = sf as *mut InterruptStackFrame;
|
||||||
stack_frame = &mut *((s as *mut u64).offset(1) as *mut InterruptStackFrame);
|
stack_frame = &mut *((s as *mut u64).offset(1) as *mut InterruptStackFrame);
|
||||||
error_code = *(&e as *const u64).offset(1);
|
error_code = *(&e as *const u64).offset(1);
|
||||||
}
|
}
|
||||||
@ -72,7 +72,7 @@ extern "x86-interrupt" fn page_fault_handler(sf: &mut InterruptStackFrame, e: Pa
|
|||||||
|
|
||||||
unsafe {
|
unsafe {
|
||||||
asm!("push rax" :::: "intel");
|
asm!("push rax" :::: "intel");
|
||||||
let s = (sf as *mut InterruptStackFrame);
|
let s = sf as *mut InterruptStackFrame;
|
||||||
stack_frame = &mut *((s as *mut u64).offset(1) as *mut InterruptStackFrame);
|
stack_frame = &mut *((s as *mut u64).offset(1) as *mut InterruptStackFrame);
|
||||||
error_code = *(&e as *const PageFaultErrorCode).offset(1) as PageFaultErrorCode;
|
error_code = *(&e as *const PageFaultErrorCode).offset(1) as PageFaultErrorCode;
|
||||||
}
|
}
|
||||||
|
10
src/lib.rs
10
src/lib.rs
@ -8,8 +8,8 @@
|
|||||||
|
|
||||||
use core::panic::PanicInfo;
|
use core::panic::PanicInfo;
|
||||||
|
|
||||||
use polling_serial::{serial_print, serial_println};
|
use polling_serial::serial_println;
|
||||||
use vga_buffer::{print, println};
|
use vga_buffer::println;
|
||||||
use x86_64::instructions::bochs_breakpoint;
|
use x86_64::instructions::bochs_breakpoint;
|
||||||
|
|
||||||
pub mod gdt;
|
pub mod gdt;
|
||||||
@ -38,7 +38,9 @@ pub fn exit_qemu(exit_code: QemuExitCode) -> ! {
|
|||||||
let mut port = Port::new(0xf4);
|
let mut port = Port::new(0xf4);
|
||||||
port.write(exit_code as u32);
|
port.write(exit_code as u32);
|
||||||
}
|
}
|
||||||
loop {}
|
loop {
|
||||||
|
bochs_breakpoint();
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
pub fn test_runner(tests: &[&dyn Fn()]) {
|
pub fn test_runner(tests: &[&dyn Fn()]) {
|
||||||
@ -89,6 +91,6 @@ fn trivial_assertion() {
|
|||||||
fn printf_test() {
|
fn printf_test() {
|
||||||
serial_print!("Testing VGA print/println... ");
|
serial_print!("Testing VGA print/println... ");
|
||||||
println!("Are frogs blue?");
|
println!("Are frogs blue?");
|
||||||
print!("Yes\n");
|
println!("Yes");
|
||||||
serial_println!("[ok]");
|
serial_println!("[ok]");
|
||||||
}
|
}
|
||||||
|
@ -7,10 +7,9 @@
|
|||||||
#![test_runner(dendrobates_tinctoreus_azureus::test_runner)]
|
#![test_runner(dendrobates_tinctoreus_azureus::test_runner)]
|
||||||
#![reexport_test_harness_main = "test_main"]
|
#![reexport_test_harness_main = "test_main"]
|
||||||
|
|
||||||
use polling_serial::{serial_print, serial_println};
|
use polling_serial::serial_println;
|
||||||
use vga_buffer::{print, println, set_colors, Color, ForegroundColor};
|
use vga_buffer::{println, set_colors, Color, ForegroundColor};
|
||||||
|
|
||||||
use core::fmt::Write;
|
|
||||||
use core::panic::PanicInfo;
|
use core::panic::PanicInfo;
|
||||||
use vga_buffer; // required for custom panic handler
|
use vga_buffer; // required for custom panic handler
|
||||||
|
|
||||||
@ -63,7 +62,7 @@ fn kernel_main(boot_info: &'static BootInfo) -> ! {
|
|||||||
|
|
||||||
serial_println!("Preparing nasty fault...");
|
serial_println!("Preparing nasty fault...");
|
||||||
unsafe {
|
unsafe {
|
||||||
*(0xdeadbeef as *mut u64) = 42;
|
*(0xdead_beef as *mut u64) = 42;
|
||||||
}
|
}
|
||||||
|
|
||||||
serial_println!("Survived ? oO");
|
serial_println!("Survived ? oO");
|
||||||
|
@ -57,17 +57,16 @@ use x86_64::structures::idt::InterruptStackFrame;
|
|||||||
extern "x86-interrupt" fn test_double_fault_handler(sf: &mut InterruptStackFrame, e: u64) {
|
extern "x86-interrupt" fn test_double_fault_handler(sf: &mut InterruptStackFrame, e: u64) {
|
||||||
// LLVM bug causing misaligned stacks when error codes are present.
|
// LLVM bug causing misaligned stacks when error codes are present.
|
||||||
// This code realigns the stack and then grabs the correct values by doing some pointer arithmetic
|
// This code realigns the stack and then grabs the correct values by doing some pointer arithmetic
|
||||||
let stack_frame: &mut InterruptStackFrame;
|
let _stack_frame: &mut InterruptStackFrame;
|
||||||
let error_code: u64;
|
let _error_code: u64;
|
||||||
|
|
||||||
unsafe {
|
unsafe {
|
||||||
asm!("push rax" :::: "intel");
|
asm!("push rax" :::: "intel");
|
||||||
let s = (sf as *mut InterruptStackFrame);
|
let s = sf as *mut InterruptStackFrame;
|
||||||
stack_frame = &mut *((s as *mut u64).offset(1) as *mut InterruptStackFrame);
|
_stack_frame = &mut *((s as *mut u64).offset(1) as *mut InterruptStackFrame);
|
||||||
error_code = *(&e as *const u64).offset(1);
|
_error_code = *(&e as *const u64).offset(1);
|
||||||
}
|
}
|
||||||
// End Hack
|
// End Hack
|
||||||
serial_println!("[ok]");
|
serial_println!("[ok]");
|
||||||
exit_qemu(QemuExitCode::Success);
|
exit_qemu(QemuExitCode::Success);
|
||||||
loop {}
|
|
||||||
}
|
}
|
||||||
|
@ -116,8 +116,8 @@ impl Writer {
|
|||||||
let mut w = Writer {
|
let mut w = Writer {
|
||||||
column_position: 0,
|
column_position: 0,
|
||||||
row_position: 0,
|
row_position: 0,
|
||||||
color_code: color_code,
|
color_code,
|
||||||
buffer: buffer,
|
buffer,
|
||||||
};
|
};
|
||||||
w.clear_screen();
|
w.clear_screen();
|
||||||
w
|
w
|
||||||
|
Loading…
Reference in New Issue
Block a user