2020-01-18 11:38:21 +03:00
|
|
|
/*
|
|
|
|
* Copyright (c) 2018-2020, Andreas Kling <kling@serenityos.org>
|
|
|
|
*
|
2021-04-22 11:24:48 +03:00
|
|
|
* SPDX-License-Identifier: BSD-2-Clause
|
2020-01-18 11:38:21 +03:00
|
|
|
*/
|
|
|
|
|
2020-01-03 14:36:30 +03:00
|
|
|
#include <Kernel/Devices/RandomDevice.h>
|
|
|
|
#include <Kernel/Random.h>
|
2018-10-15 01:44:54 +03:00
|
|
|
|
2020-02-16 03:27:42 +03:00
|
|
|
namespace Kernel {
|
|
|
|
|
2021-02-19 20:41:50 +03:00
|
|
|
UNMAP_AFTER_INIT RandomDevice::RandomDevice()
|
2018-10-30 15:59:29 +03:00
|
|
|
: CharacterDevice(1, 8)
|
2018-10-15 01:44:54 +03:00
|
|
|
{
|
|
|
|
}
|
|
|
|
|
2021-02-19 20:41:50 +03:00
|
|
|
UNMAP_AFTER_INIT RandomDevice::~RandomDevice()
|
2018-10-15 01:44:54 +03:00
|
|
|
{
|
|
|
|
}
|
|
|
|
|
2020-04-10 12:44:42 +03:00
|
|
|
bool RandomDevice::can_read(const FileDescription&, size_t) const
|
2018-10-25 14:07:59 +03:00
|
|
|
{
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
|
2021-03-17 15:18:51 +03:00
|
|
|
KResultOr<size_t> RandomDevice::read(FileDescription&, u64, UserOrKernelBuffer& buffer, size_t size)
|
2018-10-15 01:44:54 +03:00
|
|
|
{
|
2020-09-12 06:11:07 +03:00
|
|
|
bool success = buffer.write_buffered<256>(size, [&](u8* data, size_t data_size) {
|
|
|
|
get_good_random_bytes(data, data_size);
|
|
|
|
return (ssize_t)data_size;
|
|
|
|
});
|
|
|
|
if (!success)
|
2021-01-21 01:11:17 +03:00
|
|
|
return EFAULT;
|
2020-01-03 14:36:30 +03:00
|
|
|
return size;
|
2018-10-15 01:44:54 +03:00
|
|
|
}
|
|
|
|
|
2021-03-17 15:18:51 +03:00
|
|
|
KResultOr<size_t> RandomDevice::write(FileDescription&, u64, const UserOrKernelBuffer&, size_t size)
|
2018-10-15 01:44:54 +03:00
|
|
|
{
|
|
|
|
// FIXME: Use input for entropy? I guess that could be a neat feature?
|
2020-08-04 19:02:23 +03:00
|
|
|
return min(static_cast<size_t>(PAGE_SIZE), size);
|
2018-10-15 01:44:54 +03:00
|
|
|
}
|
2020-02-16 03:27:42 +03:00
|
|
|
|
|
|
|
}
|