redox/arch/x86_64/src/lib.rs

109 lines
2.2 KiB
Rust
Raw Normal View History

2016-08-14 19:45:47 +02:00
//! Architecture support for x86_64
#![feature(asm)]
#![feature(concat_idents)]
2016-08-14 19:45:47 +02:00
#![feature(const_fn)]
#![feature(core_intrinsics)]
#![feature(lang_items)]
2016-08-14 19:45:47 +02:00
#![feature(naked_functions)]
#![feature(unique)]
2016-08-14 19:45:47 +02:00
#![no_std]
2016-08-15 23:27:32 +02:00
extern crate hole_list_allocator as allocator;
2016-08-14 19:45:47 +02:00
#[macro_use]
extern crate bitflags;
extern crate x86;
2016-08-14 19:45:47 +02:00
/// Print to console
#[macro_export]
macro_rules! print {
($($arg:tt)*) => ({
use core::fmt::Write;
let _ = write!($crate::serial::SerialConsole::new(), $($arg)*);
});
}
/// Print with new line to console
#[macro_export]
macro_rules! println {
($fmt:expr) => (print!(concat!($fmt, "\n")));
($fmt:expr, $($arg:tt)*) => (print!(concat!($fmt, "\n"), $($arg)*));
}
/// Create an interrupt function that can safely run rust code
#[macro_export]
macro_rules! interrupt {
($name:ident, $func:block) => {
#[naked]
pub unsafe extern fn $name () {
unsafe fn inner() {
$func
}
asm!("xchg bx, bx" : : : : "intel", "volatile");
// Push scratch registers
asm!("push rax
push rcx
push rdx
push rdi
push rsi
push r8
push r9
push r10
push r11"
: : : : "intel", "volatile");
// Call inner rust function
inner();
// Pop scratch registers and return
asm!("pop r11
pop r10
pop r9
pop r8
pop rsi
pop rdi
pop rdx
pop rcx
pop rax
iretq"
: : : : "intel", "volatile");
}
};
}
/// Memcpy, memmove, etc.
pub mod externs;
2016-08-14 19:45:47 +02:00
/// Global descriptor table
pub mod gdt;
/// Interrupt descriptor table
pub mod idt;
/// IO Handling
pub mod io;
/// Interrupt instructions
pub mod interrupt;
/// Initialization and main function
pub mod main;
/// Memory management
pub mod memory;
/// Paging
pub mod paging;
2016-08-14 19:45:47 +02:00
/// Panic
pub mod panic;
2016-08-14 19:45:47 +02:00
/// Serial driver and print! support
pub mod serial;
/// Task state segment
pub mod tss;