
* Port previous ethernet scheme * Add ipd * Fix initfs rebuilds, use QEMU user networking addresses in ipd * Add tcp/udp, netutils, dns, and network config * Add fsync to network driver * Add dns, router, subnet by default * Fix e1000 driver. Make ethernet and IP non-blocking to avoid deadlocks * Add orbital server, WIP * Add futex * Add orbutils and orbital * Update libstd, orbutils, and orbital Move ANSI key encoding to vesad * Add orbital assets * Update orbital * Update to add login manager * Add blocking primitives, block for most things except waitpid, update orbital * Wait in waitpid and IRQ, improvements for other waits * Fevent in root scheme * WIP: Switch to using fevent * Reorganize * Event based e1000d driver * Superuser-only access to some network schemes, display, and disk * Superuser root and irq schemes * Fix orbital
90 lines
1.9 KiB
Rust
90 lines
1.9 KiB
Rust
use core::marker::PhantomData;
|
|
|
|
use super::io::Io;
|
|
|
|
/// Generic PIO
|
|
#[derive(Copy, Clone)]
|
|
pub struct Pio<T> {
|
|
port: u16,
|
|
value: PhantomData<T>,
|
|
}
|
|
|
|
impl<T> Pio<T> {
|
|
/// Create a PIO from a given port
|
|
pub const fn new(port: u16) -> Self {
|
|
Pio::<T> {
|
|
port: port,
|
|
value: PhantomData,
|
|
}
|
|
}
|
|
}
|
|
|
|
/// Read/Write for byte PIO
|
|
impl Io for Pio<u8> {
|
|
type Value = u8;
|
|
|
|
/// Read
|
|
#[inline(always)]
|
|
fn read(&self) -> u8 {
|
|
let value: u8;
|
|
unsafe {
|
|
asm!("in $0, $1" : "={al}"(value) : "{dx}"(self.port) : "memory" : "intel", "volatile");
|
|
}
|
|
value
|
|
}
|
|
|
|
/// Write
|
|
#[inline(always)]
|
|
fn write(&mut self, value: u8) {
|
|
unsafe {
|
|
asm!("out $1, $0" : : "{al}"(value), "{dx}"(self.port) : "memory" : "intel", "volatile");
|
|
}
|
|
}
|
|
}
|
|
|
|
/// Read/Write for word PIO
|
|
impl Io for Pio<u16> {
|
|
type Value = u16;
|
|
|
|
/// Read
|
|
#[inline(always)]
|
|
fn read(&self) -> u16 {
|
|
let value: u16;
|
|
unsafe {
|
|
asm!("in $0, $1" : "={ax}"(value) : "{dx}"(self.port) : "memory" : "intel", "volatile");
|
|
}
|
|
value
|
|
}
|
|
|
|
/// Write
|
|
#[inline(always)]
|
|
fn write(&mut self, value: u16) {
|
|
unsafe {
|
|
asm!("out $1, $0" : : "{ax}"(value), "{dx}"(self.port) : "memory" : "intel", "volatile");
|
|
}
|
|
}
|
|
}
|
|
|
|
/// Read/Write for doubleword PIO
|
|
impl Io for Pio<u32> {
|
|
type Value = u32;
|
|
|
|
/// Read
|
|
#[inline(always)]
|
|
fn read(&self) -> u32 {
|
|
let value: u32;
|
|
unsafe {
|
|
asm!("in $0, $1" : "={eax}"(value) : "{dx}"(self.port) : "memory" : "intel", "volatile");
|
|
}
|
|
value
|
|
}
|
|
|
|
/// Write
|
|
#[inline(always)]
|
|
fn write(&mut self, value: u32) {
|
|
unsafe {
|
|
asm!("out $1, $0" : : "{eax}"(value), "{dx}"(self.port) : "memory" : "intel", "volatile");
|
|
}
|
|
}
|
|
}
|