2016-08-17 16:39:05 +08:00
|
|
|
#![no_std]
|
2017-03-14 17:02:28 +08:00
|
|
|
#![feature(compiler_builtins_lib, repr_simd, lang_items, const_fn)]
|
2016-08-17 16:39:05 +08:00
|
|
|
|
2017-02-02 18:47:18 +08:00
|
|
|
extern crate compiler_builtins;
|
2017-02-03 19:46:45 +08:00
|
|
|
extern crate cslice;
|
2016-09-29 02:25:25 +08:00
|
|
|
#[macro_use]
|
|
|
|
extern crate log;
|
2016-09-27 21:36:55 +08:00
|
|
|
extern crate byteorder;
|
2016-10-02 12:37:24 +08:00
|
|
|
extern crate fringe;
|
2017-01-16 22:15:24 +08:00
|
|
|
extern crate smoltcp;
|
2017-02-26 01:54:14 +08:00
|
|
|
|
|
|
|
extern crate alloc_artiq;
|
|
|
|
#[macro_use]
|
|
|
|
extern crate std_artiq as std;
|
|
|
|
extern crate logger_artiq;
|
2017-01-25 05:55:51 +08:00
|
|
|
#[macro_use]
|
2016-12-31 21:32:50 +08:00
|
|
|
extern crate board;
|
2017-02-26 01:54:14 +08:00
|
|
|
extern crate proto;
|
|
|
|
extern crate amp;
|
2017-02-22 15:26:32 +08:00
|
|
|
#[cfg(has_drtio)]
|
|
|
|
extern crate drtioaux;
|
2016-08-17 16:39:05 +08:00
|
|
|
|
2017-01-16 22:15:24 +08:00
|
|
|
use std::boxed::Box;
|
2017-01-27 01:35:42 +08:00
|
|
|
use smoltcp::wire::{EthernetAddress, IpAddress};
|
2017-02-26 01:54:14 +08:00
|
|
|
use proto::{analyzer_proto, moninj_proto, rpc_proto, session_proto, kernel_proto};
|
|
|
|
use amp::{mailbox, rpc_queue};
|
2016-08-30 19:20:04 +08:00
|
|
|
|
2017-01-16 22:15:24 +08:00
|
|
|
macro_rules! borrow_mut {
|
|
|
|
($x:expr) => ({
|
|
|
|
match $x.try_borrow_mut() {
|
|
|
|
Ok(x) => x,
|
|
|
|
Err(_) => panic!("cannot borrow mutably at {}:{}", file!(), line!())
|
|
|
|
}
|
|
|
|
})
|
|
|
|
}
|
|
|
|
|
2016-09-30 04:56:35 +08:00
|
|
|
mod config;
|
2017-01-16 22:15:24 +08:00
|
|
|
mod ethmac;
|
2016-12-09 19:24:00 +08:00
|
|
|
mod rtio_mgt;
|
2016-09-30 04:56:35 +08:00
|
|
|
|
2016-10-02 12:37:24 +08:00
|
|
|
mod urc;
|
|
|
|
mod sched;
|
2016-10-02 02:24:53 +08:00
|
|
|
mod cache;
|
2017-02-26 10:50:20 +08:00
|
|
|
mod rtio_dma;
|
2016-10-01 12:20:27 +08:00
|
|
|
|
|
|
|
mod kernel;
|
2016-09-30 04:56:35 +08:00
|
|
|
mod session;
|
2017-02-25 12:07:00 +08:00
|
|
|
#[cfg(any(has_rtio_moninj, has_drtio))]
|
2016-10-04 20:38:52 +08:00
|
|
|
mod moninj;
|
2016-10-05 13:59:38 +08:00
|
|
|
#[cfg(has_rtio_analyzer)]
|
|
|
|
mod analyzer;
|
2016-09-07 00:42:13 +08:00
|
|
|
|
2017-01-16 22:15:24 +08:00
|
|
|
fn startup() {
|
|
|
|
board::clock::init();
|
2017-01-25 05:55:51 +08:00
|
|
|
info!("ARTIQ runtime starting...");
|
2017-01-27 01:40:18 +08:00
|
|
|
info!("software version {}", include_str!(concat!(env!("OUT_DIR"), "/git-describe")));
|
2017-01-16 22:15:24 +08:00
|
|
|
info!("gateware version {}", board::ident(&mut [0; 64]));
|
|
|
|
|
|
|
|
let t = board::clock::get_ms();
|
|
|
|
info!("press 'e' to erase startup and idle kernels...");
|
|
|
|
while board::clock::get_ms() < t + 1000 {
|
2017-02-03 20:12:41 +08:00
|
|
|
if unsafe { board::csr::uart::rxtx_read() == b'e' } {
|
2017-02-02 10:51:13 +08:00
|
|
|
config::remove("startup_kernel").unwrap();
|
|
|
|
config::remove("idle_kernel").unwrap();
|
2017-01-16 22:15:24 +08:00
|
|
|
info!("startup and idle kernels erased");
|
|
|
|
break
|
|
|
|
}
|
|
|
|
}
|
|
|
|
info!("continuing boot");
|
|
|
|
|
2017-03-07 15:28:24 +08:00
|
|
|
match config::read_str("log_level", |r| r?.parse()) {
|
|
|
|
Err(()) => (),
|
|
|
|
Ok(log_level_filter) => {
|
|
|
|
info!("log level set to {} in configuration", log_level_filter);
|
|
|
|
logger_artiq::BufferLogger::with_instance(|logger|
|
|
|
|
logger.set_max_log_level(log_level_filter));
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2017-01-16 22:15:24 +08:00
|
|
|
#[cfg(has_i2c)]
|
|
|
|
board::i2c::init();
|
|
|
|
#[cfg(has_ad9516)]
|
|
|
|
board::ad9516::init().expect("cannot initialize ad9516");
|
2017-01-30 11:03:55 +08:00
|
|
|
#[cfg(has_ad9154)]
|
2017-01-16 22:15:24 +08:00
|
|
|
board::ad9154::init().expect("cannot initialize ad9154");
|
|
|
|
|
2017-01-27 01:35:42 +08:00
|
|
|
let hardware_addr;
|
2017-03-07 15:25:00 +08:00
|
|
|
match config::read_str("mac", |r| r?.parse()) {
|
2017-01-27 01:35:42 +08:00
|
|
|
Err(()) => {
|
|
|
|
hardware_addr = EthernetAddress([0x02, 0x00, 0x00, 0x00, 0x00, 0x01]);
|
|
|
|
warn!("using default MAC address {}; consider changing it", hardware_addr);
|
|
|
|
}
|
|
|
|
Ok(addr) => {
|
|
|
|
hardware_addr = addr;
|
|
|
|
info!("using MAC address {}", hardware_addr);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
let protocol_addr;
|
2017-03-07 15:25:00 +08:00
|
|
|
match config::read_str("ip", |r| r?.parse()) {
|
2017-01-27 01:35:42 +08:00
|
|
|
Err(()) | Ok(IpAddress::Unspecified) => {
|
|
|
|
protocol_addr = IpAddress::v4(192, 168, 1, 50);
|
|
|
|
info!("using default IP address {}", protocol_addr);
|
|
|
|
}
|
|
|
|
Ok(addr) => {
|
|
|
|
protocol_addr = addr;
|
|
|
|
info!("using IP address {}", protocol_addr);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2017-01-16 22:15:24 +08:00
|
|
|
fn _net_trace_writer<U>(printer: smoltcp::wire::PrettyPrinter<U>)
|
|
|
|
where U: smoltcp::wire::pretty_print::PrettyPrint {
|
|
|
|
print!("\x1b[37m{}\x1b[0m", printer)
|
|
|
|
}
|
|
|
|
|
|
|
|
let net_device = ethmac::EthernetDevice;
|
|
|
|
// let net_device = smoltcp::phy::Tracer::<_, smoltcp::wire::EthernetFrame<&[u8]>>
|
|
|
|
// ::new(net_device, _net_trace_writer);
|
|
|
|
let arp_cache = smoltcp::iface::SliceArpCache::new([Default::default(); 8]);
|
|
|
|
let mut interface = smoltcp::iface::EthernetInterface::new(
|
|
|
|
Box::new(net_device), Box::new(arp_cache) as Box<smoltcp::iface::ArpCache>,
|
2017-01-27 01:35:42 +08:00
|
|
|
hardware_addr, [protocol_addr]);
|
2017-01-16 22:15:24 +08:00
|
|
|
|
|
|
|
let mut scheduler = sched::Scheduler::new();
|
|
|
|
let io = scheduler.io();
|
|
|
|
rtio_mgt::startup(&io);
|
|
|
|
io.spawn(16384, session::thread);
|
2017-02-25 12:07:00 +08:00
|
|
|
#[cfg(any(has_rtio_moninj, has_drtio))]
|
2017-01-16 22:15:24 +08:00
|
|
|
io.spawn(4096, moninj::thread);
|
|
|
|
#[cfg(has_rtio_analyzer)]
|
|
|
|
io.spawn(4096, analyzer::thread);
|
|
|
|
|
|
|
|
loop {
|
|
|
|
scheduler.run();
|
|
|
|
|
|
|
|
match interface.poll(&mut *borrow_mut!(scheduler.sockets()),
|
|
|
|
board::clock::get_ms()) {
|
|
|
|
Ok(()) => (),
|
|
|
|
Err(smoltcp::Error::Exhausted) => (),
|
|
|
|
Err(smoltcp::Error::Unrecognized) => (),
|
|
|
|
Err(e) => warn!("network error: {}", e)
|
|
|
|
}
|
|
|
|
}
|
2016-09-07 00:42:13 +08:00
|
|
|
}
|
|
|
|
|
2017-02-03 20:12:41 +08:00
|
|
|
#[no_mangle]
|
|
|
|
pub extern fn main() -> i32 {
|
|
|
|
unsafe {
|
|
|
|
extern {
|
|
|
|
static mut _fheap: u8;
|
|
|
|
static mut _eheap: u8;
|
|
|
|
}
|
|
|
|
alloc_artiq::seed(&mut _fheap as *mut u8,
|
|
|
|
&_eheap as *const u8 as usize - &_fheap as *const u8 as usize);
|
2016-09-30 06:04:52 +08:00
|
|
|
|
2017-02-03 20:12:41 +08:00
|
|
|
static mut LOG_BUFFER: [u8; 65536] = [0; 65536];
|
|
|
|
logger_artiq::BufferLogger::new(&mut LOG_BUFFER[..]).register(startup);
|
|
|
|
0
|
|
|
|
}
|
2016-10-30 05:34:25 +08:00
|
|
|
}
|
|
|
|
|
2016-08-17 16:39:05 +08:00
|
|
|
#[no_mangle]
|
2017-02-03 20:12:41 +08:00
|
|
|
pub extern fn exception_handler(vect: u32, _regs: *const u32, pc: u32, ea: u32) {
|
|
|
|
panic!("exception {:?} at PC 0x{:x}, EA 0x{:x}", vect, pc, ea)
|
2016-08-17 16:39:05 +08:00
|
|
|
}
|
2016-10-06 23:35:43 +08:00
|
|
|
|
2016-10-07 14:27:10 +08:00
|
|
|
#[no_mangle]
|
2017-02-03 20:12:41 +08:00
|
|
|
pub extern fn abort() {
|
|
|
|
panic!("aborted")
|
2016-10-07 14:27:10 +08:00
|
|
|
}
|
|
|
|
|
2017-03-14 17:02:28 +08:00
|
|
|
#[no_mangle]
|
|
|
|
#[lang = "panic_fmt"]
|
|
|
|
pub extern fn panic_fmt(args: core::fmt::Arguments, file: &'static str, line: u32) -> ! {
|
|
|
|
println!("panic at {}:{}: {}", file, line, args);
|
|
|
|
|
|
|
|
if config::read_str("panic_reboot", |r| r == Ok("1")) {
|
|
|
|
println!("rebooting...");
|
|
|
|
unsafe { board::boot::reboot() }
|
|
|
|
} else {
|
|
|
|
loop {}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2017-01-16 22:15:24 +08:00
|
|
|
// Allow linking with crates that are built as -Cpanic=unwind even if we use -Cpanic=abort.
|
|
|
|
// This is never called.
|
|
|
|
#[allow(non_snake_case)]
|
2016-10-06 23:35:43 +08:00
|
|
|
#[no_mangle]
|
2017-02-03 20:12:41 +08:00
|
|
|
pub extern fn _Unwind_Resume() -> ! {
|
2017-01-16 22:15:24 +08:00
|
|
|
loop {}
|
2016-10-06 23:35:43 +08:00
|
|
|
}
|