2016-10-01 12:20:27 +08:00
|
|
|
use core::ptr;
|
2016-12-31 21:32:50 +08:00
|
|
|
use board::csr;
|
2016-10-01 12:20:27 +08:00
|
|
|
use mailbox;
|
2016-11-01 14:51:44 +08:00
|
|
|
use rpc_queue;
|
2016-10-01 12:20:27 +08:00
|
|
|
|
2016-10-17 00:24:25 +08:00
|
|
|
use kernel_proto::{KERNELCPU_EXEC_ADDRESS, KERNELCPU_LAST_ADDRESS, KSUPPORT_HEADER_SIZE};
|
2016-10-01 12:20:27 +08:00
|
|
|
|
2017-11-04 00:04:17 +08:00
|
|
|
#[cfg(has_kernel_cpu)]
|
2016-10-01 12:20:27 +08:00
|
|
|
pub unsafe fn start() {
|
2016-10-01 15:56:34 +08:00
|
|
|
if csr::kernel_cpu::reset_read() == 0 {
|
2016-10-01 12:20:27 +08:00
|
|
|
panic!("attempted to start kernel CPU when it is already running")
|
|
|
|
}
|
|
|
|
|
|
|
|
stop();
|
|
|
|
|
2017-01-17 13:36:07 +08:00
|
|
|
extern {
|
2017-02-03 20:53:25 +08:00
|
|
|
static _binary____ksupport_ksupport_elf_start: u8;
|
|
|
|
static _binary____ksupport_ksupport_elf_end: u8;
|
2017-01-17 13:36:07 +08:00
|
|
|
}
|
2017-02-03 20:53:25 +08:00
|
|
|
let ksupport_start = &_binary____ksupport_ksupport_elf_start as *const _;
|
|
|
|
let ksupport_end = &_binary____ksupport_ksupport_elf_end as *const _;
|
2017-01-17 13:36:07 +08:00
|
|
|
ptr::copy_nonoverlapping(ksupport_start,
|
|
|
|
(KERNELCPU_EXEC_ADDRESS - KSUPPORT_HEADER_SIZE) as *mut u8,
|
|
|
|
ksupport_end as usize - ksupport_start as usize);
|
2016-10-01 12:20:27 +08:00
|
|
|
|
2016-10-01 15:56:34 +08:00
|
|
|
csr::kernel_cpu::reset_write(0);
|
2016-11-01 14:51:44 +08:00
|
|
|
|
|
|
|
rpc_queue::init();
|
2016-10-01 12:20:27 +08:00
|
|
|
}
|
|
|
|
|
2017-11-04 00:04:17 +08:00
|
|
|
#[cfg(not(has_kernel_cpu))]
|
|
|
|
pub unsafe fn start() {
|
|
|
|
unimplemented!("not(has_kernel_cpu)")
|
|
|
|
}
|
|
|
|
|
2016-11-29 22:00:43 +08:00
|
|
|
pub unsafe fn stop() {
|
2017-11-04 00:04:17 +08:00
|
|
|
#[cfg(has_kernel_cpu)]
|
2016-11-29 22:00:43 +08:00
|
|
|
csr::kernel_cpu::reset_write(1);
|
|
|
|
|
2016-10-01 12:20:27 +08:00
|
|
|
mailbox::acknowledge();
|
2016-11-29 22:00:43 +08:00
|
|
|
rpc_queue::init();
|
2016-10-01 12:20:27 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
pub fn validate(ptr: usize) -> bool {
|
|
|
|
ptr >= KERNELCPU_EXEC_ADDRESS && ptr <= KERNELCPU_LAST_ADDRESS
|
|
|
|
}
|