/* * \brief Integration of the Consistent Block Encrypter (CBE) * \author Martin Stein * \author Josef Soentgen * \date 2020-11-10 */ /* * Copyright (C) 2020 Genode Labs GmbH * * This file is part of the Genode OS framework, which is distributed * under the terms of the GNU Affero General Public License version 3. */ #ifndef _INCLUDE__CBE__CRYPTO__INTERFACE_H_ #define _INCLUDE__CBE__CRYPTO__INTERFACE_H_ /* Genode includes */ #include #include namespace Cbe_crypto { using uint32_t = Genode::uint32_t; using uint64_t = Genode::uint64_t; using size_t = Genode::size_t; using Byte_range_ptr = Genode::Byte_range_ptr; using Const_byte_range_ptr = Genode::Const_byte_range_ptr; struct Interface; Interface &get_interface(); enum { BLOCK_SIZE = 4096u }; } /* namespace Cbe_crypto */ struct Cbe_crypto::Interface { struct Buffer_too_small : Genode::Exception { }; struct Key_value_size_mismatch : Genode::Exception { }; struct Complete_request { bool const valid; uint64_t const block_number; }; struct Slots { enum { NUM_SLOTS = 2, }; uint32_t _store[NUM_SLOTS] { }; bool store(uint32_t const id) { for (uint32_t &slot : _store) { if (slot == 0) { slot = id; return true; } } return false; } void remove(uint32_t const id) { for (uint32_t &slot : _store) { if (slot == id) { slot = 0; return; } } } template void for_each_key(FN const &func) { for (uint32_t const slot : _store) { if (slot != 0) { func(slot); } } } }; Slots _slots { }; virtual ~Interface() { } template void for_each_key(FN const &func) { _slots.for_each_key(func); } virtual bool execute() = 0; virtual bool add_key(uint32_t const id, char const *value, size_t value_len) = 0; virtual bool remove_key(uint32_t const id) = 0; virtual bool submit_encryption_request(uint64_t const block_number, uint32_t const key_id, Const_byte_range_ptr const &src) = 0; virtual Complete_request encryption_request_complete(Byte_range_ptr const &dst) = 0; virtual bool submit_decryption_request(uint64_t const block_number, uint32_t const key_id, Const_byte_range_ptr const &src) = 0; virtual Complete_request decryption_request_complete(Byte_range_ptr const &dst) = 0; }; #endif /* _INCLUDE__CBE__CRYPTO__INTERFACE_H_ */