capsules_extra/tutorials/
encryption_oracle_chkpt3.rsuse kernel::grant::{AllowRoCount, AllowRwCount, Grant, UpcallCount};
use kernel::hil::symmetric_encryption::{AES128Ctr, AES128};
use kernel::syscall::{CommandReturn, SyscallDriver};
use kernel::utilities::cells::OptionalCell;
use kernel::ErrorCode;
use kernel::ProcessId;
pub const DRIVER_NUM: usize = 0x99999;
pub static KEY: &[u8; kernel::hil::symmetric_encryption::AES128_KEY_SIZE] = b"InsecureAESKey12";
#[derive(Default)]
pub struct ProcessState {
request_pending: bool,
}
pub struct EncryptionOracleDriver<'a, A: AES128<'a> + AES128Ctr> {
aes: &'a A,
process_grants: Grant<ProcessState, UpcallCount<0>, AllowRoCount<0>, AllowRwCount<0>>,
current_process: OptionalCell<ProcessId>,
}
impl<'a, A: AES128<'a> + AES128Ctr> EncryptionOracleDriver<'a, A> {
pub fn new(
aes: &'a A,
_source_buffer: &'static mut [u8],
_dest_buffer: &'static mut [u8],
process_grants: Grant<ProcessState, UpcallCount<0>, AllowRoCount<0>, AllowRwCount<0>>,
) -> Self {
EncryptionOracleDriver {
process_grants,
aes,
current_process: OptionalCell::empty(),
}
}
fn next_pending(&self) -> Option<ProcessId> {
for process_grant in self.process_grants.iter() {
let processid = process_grant.processid();
if process_grant.enter(|grant, _| grant.request_pending) {
return Some(processid);
}
}
None
}
}
impl<'a, A: AES128<'a> + AES128Ctr> SyscallDriver for EncryptionOracleDriver<'a, A> {
fn command(
&self,
command_num: usize,
_data1: usize,
_data2: usize,
processid: ProcessId,
) -> CommandReturn {
match command_num {
0 => CommandReturn::success(),
1 => self
.process_grants
.enter(processid, |grant, _kernel_data| {
grant.request_pending = true;
CommandReturn::success()
})
.unwrap_or_else(|err| err.into()),
_ => CommandReturn::failure(ErrorCode::NOSUPPORT),
}
}
fn allocate_grant(&self, processid: ProcessId) -> Result<(), kernel::process::Error> {
self.process_grants.enter(processid, |_, _| {})
}
}