2016-10-23 23:26:36 +02:00
|
|
|
extern crate event;
|
2016-10-21 01:49:54 +02:00
|
|
|
extern crate netutils;
|
Orbital (#16)
* 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
2016-10-14 01:21:42 +02:00
|
|
|
extern crate syscall;
|
|
|
|
|
2016-10-23 23:26:36 +02:00
|
|
|
use event::EventQueue;
|
|
|
|
use std::cell::RefCell;
|
Orbital (#16)
* 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
2016-10-14 01:21:42 +02:00
|
|
|
use std::fs::File;
|
2016-10-23 23:26:36 +02:00
|
|
|
use std::io::{Result, Read, Write};
|
|
|
|
use std::os::unix::io::FromRawFd;
|
2017-02-08 04:23:41 +01:00
|
|
|
use std::process;
|
2016-10-23 23:26:36 +02:00
|
|
|
use std::rc::Rc;
|
Orbital (#16)
* 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
2016-10-14 01:21:42 +02:00
|
|
|
|
2016-10-23 23:26:36 +02:00
|
|
|
use syscall::{Packet, SchemeMut, EWOULDBLOCK};
|
Orbital (#16)
* 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
2016-10-14 01:21:42 +02:00
|
|
|
|
|
|
|
use scheme::EthernetScheme;
|
|
|
|
|
2016-10-21 01:49:54 +02:00
|
|
|
mod scheme;
|
Orbital (#16)
* 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
2016-10-14 01:21:42 +02:00
|
|
|
|
2017-02-08 04:23:41 +01:00
|
|
|
fn daemon(network_fd: usize, socket_fd: usize) {
|
|
|
|
let network = unsafe { File::from_raw_fd(network_fd) };
|
|
|
|
let socket = Rc::new(RefCell::new(unsafe { File::from_raw_fd(socket_fd) }));
|
|
|
|
let scheme = Rc::new(RefCell::new(EthernetScheme::new(network)));
|
|
|
|
let todo = Rc::new(RefCell::new(Vec::<Packet>::new()));
|
|
|
|
|
|
|
|
let mut event_queue = EventQueue::<()>::new().expect("ethernetd: failed to create event queue");
|
|
|
|
|
|
|
|
let socket_net = socket.clone();
|
|
|
|
let scheme_net = scheme.clone();
|
|
|
|
let todo_net = todo.clone();
|
|
|
|
event_queue.add(network_fd, move |_count: usize| -> Result<Option<()>> {
|
|
|
|
if scheme_net.borrow_mut().input()? > 0 {
|
|
|
|
let mut todo = todo_net.borrow_mut();
|
|
|
|
let mut i = 0;
|
|
|
|
while i < todo.len() {
|
|
|
|
let a = todo[i].a;
|
|
|
|
scheme_net.borrow_mut().handle(&mut todo[i]);
|
|
|
|
if todo[i].a == (-EWOULDBLOCK) as usize {
|
|
|
|
todo[i].a = a;
|
|
|
|
i += 1;
|
|
|
|
} else {
|
|
|
|
socket_net.borrow_mut().write(&mut todo[i])?;
|
|
|
|
todo.remove(i);
|
2016-10-23 23:26:36 +02:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2017-02-08 04:23:41 +01:00
|
|
|
for (id, handle) in scheme_net.borrow_mut().handles.iter() {
|
|
|
|
if let Some(frame) = handle.frames.get(0) {
|
|
|
|
socket_net.borrow_mut().write(&Packet {
|
|
|
|
id: 0,
|
|
|
|
pid: 0,
|
|
|
|
uid: 0,
|
|
|
|
gid: 0,
|
|
|
|
a: syscall::number::SYS_FEVENT,
|
|
|
|
b: *id,
|
|
|
|
c: syscall::flag::EVENT_READ,
|
|
|
|
d: frame.data.len()
|
|
|
|
})?;
|
2016-10-26 21:19:56 +02:00
|
|
|
}
|
2017-02-08 04:23:41 +01:00
|
|
|
}
|
|
|
|
}
|
|
|
|
Ok(None)
|
|
|
|
}).expect("ethernetd: failed to listen for network events");
|
|
|
|
|
|
|
|
event_queue.add(socket_fd, move |_count: usize| -> Result<Option<()>> {
|
|
|
|
loop {
|
|
|
|
let mut packet = Packet::default();
|
|
|
|
if socket.borrow_mut().read(&mut packet)? == 0 {
|
|
|
|
break;
|
|
|
|
}
|
2016-10-26 21:19:56 +02:00
|
|
|
|
2017-02-08 04:23:41 +01:00
|
|
|
let a = packet.a;
|
|
|
|
scheme.borrow_mut().handle(&mut packet);
|
|
|
|
if packet.a == (-EWOULDBLOCK) as usize {
|
|
|
|
packet.a = a;
|
|
|
|
todo.borrow_mut().push(packet);
|
|
|
|
} else {
|
|
|
|
socket.borrow_mut().write(&mut packet)?;
|
2016-10-23 23:26:36 +02:00
|
|
|
}
|
2017-02-08 04:23:41 +01:00
|
|
|
}
|
2016-10-23 23:26:36 +02:00
|
|
|
|
2017-02-08 04:23:41 +01:00
|
|
|
Ok(None)
|
|
|
|
}).expect("ethernetd: failed to listen for scheme events");
|
2016-10-23 23:26:36 +02:00
|
|
|
|
2017-02-08 04:23:41 +01:00
|
|
|
event_queue.trigger_all(0).expect("ethernetd: failed to trigger events");
|
2016-10-26 21:19:56 +02:00
|
|
|
|
2017-02-08 04:23:41 +01:00
|
|
|
event_queue.run().expect("ethernetd: failed to run event loop");
|
|
|
|
}
|
|
|
|
|
|
|
|
fn main() {
|
|
|
|
match syscall::open("network:", syscall::O_RDWR | syscall::O_NONBLOCK) {
|
2017-02-08 06:34:23 +01:00
|
|
|
Ok(network_fd) => {
|
|
|
|
// Daemonize
|
|
|
|
if unsafe { syscall::clone(0).unwrap() } == 0 {
|
|
|
|
match syscall::open(":ethernet", syscall::O_RDWR | syscall::O_CREAT | syscall::O_NONBLOCK) {
|
|
|
|
Ok(socket_fd) => {
|
|
|
|
daemon(network_fd, socket_fd);
|
|
|
|
},
|
|
|
|
Err(err) => {
|
|
|
|
println!("ethernetd: failed to create ethernet scheme: {}", err);
|
|
|
|
process::exit(1);
|
|
|
|
}
|
2017-02-08 04:23:41 +01:00
|
|
|
}
|
|
|
|
}
|
|
|
|
},
|
|
|
|
Err(err) => {
|
|
|
|
println!("ethernetd: failed to open network: {}", err);
|
|
|
|
process::exit(1);
|
|
|
|
}
|
2016-11-11 04:02:51 +01:00
|
|
|
}
|
Orbital (#16)
* 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
2016-10-14 01:21:42 +02:00
|
|
|
}
|