2016-10-17 00:24:25 +08:00
|
|
|
use core::fmt;
|
2017-02-25 02:57:29 +08:00
|
|
|
use dyld;
|
2016-10-17 00:24:25 +08:00
|
|
|
|
2016-11-01 02:13:15 +08:00
|
|
|
pub const KERNELCPU_EXEC_ADDRESS: usize = 0x40800000;
|
2016-10-30 05:34:25 +08:00
|
|
|
pub const KERNELCPU_PAYLOAD_ADDRESS: usize = 0x40840000;
|
2016-10-17 00:24:25 +08:00
|
|
|
pub const KERNELCPU_LAST_ADDRESS: usize = 0x4fffffff;
|
|
|
|
pub const KSUPPORT_HEADER_SIZE: usize = 0x80;
|
|
|
|
|
|
|
|
#[derive(Debug, Clone)]
|
2016-10-01 12:20:27 +08:00
|
|
|
pub struct Exception<'a> {
|
2017-02-03 19:46:45 +08:00
|
|
|
pub name: &'a str,
|
|
|
|
pub file: &'a str,
|
2016-10-01 12:20:27 +08:00
|
|
|
pub line: u32,
|
|
|
|
pub column: u32,
|
2017-02-03 19:46:45 +08:00
|
|
|
pub function: &'a str,
|
|
|
|
pub message: &'a str,
|
|
|
|
pub param: [i64; 3]
|
2016-10-01 12:20:27 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
#[derive(Debug)]
|
|
|
|
pub enum Message<'a> {
|
|
|
|
LoadRequest(&'a [u8]),
|
2017-02-25 02:57:29 +08:00
|
|
|
LoadReply(Result<(), dyld::Error<'a>>),
|
2016-10-01 12:20:27 +08:00
|
|
|
|
|
|
|
NowInitRequest,
|
|
|
|
NowInitReply(u64),
|
|
|
|
NowSave(u64),
|
|
|
|
|
2017-02-26 06:34:11 +08:00
|
|
|
RtioInitRequest,
|
2016-12-09 14:16:55 +08:00
|
|
|
|
2017-02-26 10:50:20 +08:00
|
|
|
DmaRecordStart,
|
2017-04-15 15:26:18 +08:00
|
|
|
DmaRecordAppend(&'a [u8]),
|
2017-04-06 02:34:08 +08:00
|
|
|
DmaRecordStop {
|
|
|
|
name: &'a str,
|
|
|
|
duration: u64
|
|
|
|
},
|
2017-02-26 10:50:20 +08:00
|
|
|
|
2017-04-06 02:34:08 +08:00
|
|
|
DmaEraseRequest {
|
|
|
|
name: &'a str
|
|
|
|
},
|
2017-03-01 05:28:27 +08:00
|
|
|
|
2017-04-06 02:34:08 +08:00
|
|
|
DmaPlaybackRequest {
|
|
|
|
name: &'a str
|
|
|
|
},
|
|
|
|
DmaPlaybackReply {
|
|
|
|
trace: Option<&'a [u8]>,
|
|
|
|
duration: u64
|
|
|
|
},
|
2017-03-01 05:28:27 +08:00
|
|
|
|
2017-02-26 06:34:11 +08:00
|
|
|
DrtioChannelStateRequest { channel: u32 },
|
|
|
|
DrtioChannelStateReply { fifo_space: u16, last_timestamp: u64 },
|
|
|
|
DrtioResetChannelStateRequest { channel: u32 },
|
|
|
|
DrtioGetFifoSpaceRequest { channel: u32 },
|
|
|
|
DrtioPacketCountRequest,
|
|
|
|
DrtioPacketCountReply { tx_cnt: u32, rx_cnt: u32 },
|
|
|
|
DrtioFifoSpaceReqCountRequest,
|
|
|
|
DrtioFifoSpaceReqCountReply { cnt: u32 },
|
2017-01-09 05:06:14 +08:00
|
|
|
|
2016-10-01 12:20:27 +08:00
|
|
|
RunFinished,
|
|
|
|
RunException {
|
|
|
|
exception: Exception<'a>,
|
2016-10-06 21:42:35 +08:00
|
|
|
backtrace: &'a [usize]
|
2016-10-01 12:20:27 +08:00
|
|
|
},
|
2016-10-17 00:24:25 +08:00
|
|
|
RunAborted,
|
2016-10-01 12:20:27 +08:00
|
|
|
|
|
|
|
WatchdogSetRequest { ms: u64 },
|
|
|
|
WatchdogSetReply { id: usize },
|
|
|
|
WatchdogClear { id: usize },
|
|
|
|
|
|
|
|
RpcSend {
|
2016-10-30 05:34:25 +08:00
|
|
|
async: bool,
|
2016-10-01 12:20:27 +08:00
|
|
|
service: u32,
|
|
|
|
tag: &'a [u8],
|
|
|
|
data: *const *const ()
|
|
|
|
},
|
2016-10-17 00:24:25 +08:00
|
|
|
RpcRecvRequest(*mut ()),
|
|
|
|
RpcRecvReply(Result<usize, Exception<'a>>),
|
2016-10-01 12:20:27 +08:00
|
|
|
|
|
|
|
CacheGetRequest { key: &'a str },
|
2016-11-24 00:28:05 +08:00
|
|
|
CacheGetReply { value: &'static [i32] },
|
|
|
|
CachePutRequest { key: &'a str, value: &'a [i32] },
|
2016-10-01 12:20:27 +08:00
|
|
|
CachePutReply { succeeded: bool },
|
|
|
|
|
2017-02-26 06:34:11 +08:00
|
|
|
I2cStartRequest { busno: u8 },
|
|
|
|
I2cStopRequest { busno: u8 },
|
|
|
|
I2cWriteRequest { busno: u8, data: u8 },
|
|
|
|
I2cWriteReply { ack: bool },
|
|
|
|
I2cReadRequest { busno: u8, ack: bool },
|
|
|
|
I2cReadReply { data: u8 },
|
2017-01-05 04:04:38 +08:00
|
|
|
|
2016-10-17 00:24:25 +08:00
|
|
|
Log(fmt::Arguments<'a>),
|
|
|
|
LogSlice(&'a str)
|
2016-10-01 12:20:27 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
pub use self::Message::*;
|