forked from M-Labs/artiq-zynq
start kernel
This commit is contained in:
parent
2be09719f3
commit
d8d09e219f
|
@ -143,6 +143,10 @@ async fn handle_connection(stream: &TcpStream, control: Rc<RefCell<kernel::Contr
|
||||||
write_header(&stream, Reply::LoadFailed).await?;
|
write_header(&stream, Reply::LoadFailed).await?;
|
||||||
write_chunk(&stream, b"kernel is too large").await?;
|
write_chunk(&stream, b"kernel is too large").await?;
|
||||||
}
|
}
|
||||||
|
},
|
||||||
|
Request::RunKernel => {
|
||||||
|
let mut control = control.borrow_mut();
|
||||||
|
control.tx.async_send(kernel::Message::StartRequest).await;
|
||||||
}
|
}
|
||||||
_ => return Err(Error::UnrecognizedPacket)
|
_ => return Err(Error::UnrecognizedPacket)
|
||||||
}
|
}
|
||||||
|
|
|
@ -1,3 +1,4 @@
|
||||||
|
use core::{ptr, mem};
|
||||||
use log::{debug, error};
|
use log::{debug, error};
|
||||||
use alloc::{vec, vec::Vec, sync::Arc};
|
use alloc::{vec, vec::Vec, sync::Arc};
|
||||||
|
|
||||||
|
@ -14,6 +15,7 @@ pub enum Message {
|
||||||
LoadRequest(Arc<Vec<u8>>),
|
LoadRequest(Arc<Vec<u8>>),
|
||||||
LoadCompleted,
|
LoadCompleted,
|
||||||
LoadFailed,
|
LoadFailed,
|
||||||
|
StartRequest,
|
||||||
}
|
}
|
||||||
|
|
||||||
static CHANNEL_0TO1: Mutex<Option<sync_channel::Receiver<Message>>> = Mutex::new(None);
|
static CHANNEL_0TO1: Mutex<Option<sync_channel::Receiver<Message>>> = Mutex::new(None);
|
||||||
|
@ -84,6 +86,8 @@ fn resolve(required: &[u8]) -> Option<u32> {
|
||||||
api!(rtio_input_timestamp = rtio::input_timestamp),
|
api!(rtio_input_timestamp = rtio::input_timestamp),
|
||||||
api!(rtio_input_data = rtio::input_data),
|
api!(rtio_input_data = rtio::input_data),
|
||||||
api!(rtio_input_timestamped_data = rtio::input_timestamped_data),
|
api!(rtio_input_timestamped_data = rtio::input_timestamped_data),
|
||||||
|
|
||||||
|
api!(__artiq_personality = 0), // HACK
|
||||||
];
|
];
|
||||||
api.iter()
|
api.iter()
|
||||||
.find(|&&(exported, _)| exported.as_bytes() == required)
|
.find(|&&(exported, _)| exported.as_bytes() == required)
|
||||||
|
@ -108,11 +112,19 @@ pub fn main_core1() {
|
||||||
let core1_rx = core1_rx.unwrap();
|
let core1_rx = core1_rx.unwrap();
|
||||||
|
|
||||||
let mut image = vec![0; 1024*1024];
|
let mut image = vec![0; 1024*1024];
|
||||||
|
let mut current_modinit: Option<u32> = None;
|
||||||
for message in core1_rx {
|
for message in core1_rx {
|
||||||
match *message {
|
match *message {
|
||||||
Message::LoadRequest(data) => {
|
Message::LoadRequest(data) => {
|
||||||
match dyld::Library::load(&data, &mut image, &resolve) {
|
match dyld::Library::load(&data, &mut image, &resolve) {
|
||||||
Ok(library) => {
|
Ok(library) => {
|
||||||
|
let __bss_start = library.lookup(b"__bss_start").unwrap();
|
||||||
|
let _end = library.lookup(b"_end").unwrap();
|
||||||
|
let __modinit__ = library.lookup(b"__modinit__").unwrap();
|
||||||
|
unsafe {
|
||||||
|
ptr::write_bytes(__bss_start as *mut u8, 0, (_end - __bss_start) as usize);
|
||||||
|
}
|
||||||
|
current_modinit = Some(__modinit__);
|
||||||
core1_tx.send(Message::LoadCompleted)
|
core1_tx.send(Message::LoadCompleted)
|
||||||
},
|
},
|
||||||
Err(error) => {
|
Err(error) => {
|
||||||
|
@ -121,6 +133,15 @@ pub fn main_core1() {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
|
Message::StartRequest => {
|
||||||
|
debug!("starting");
|
||||||
|
if let Some(__modinit__) = current_modinit {
|
||||||
|
unsafe {
|
||||||
|
(mem::transmute::<u32, fn()>(__modinit__))();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
debug!("stopping");
|
||||||
|
}
|
||||||
_ => error!("Core1 received unexpected message: {:?}", message),
|
_ => error!("Core1 received unexpected message: {:?}", message),
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue