2023-03-18 09:10:33 +01:00
|
|
|
#include "fs/devices/DeviceRegistry.h"
|
|
|
|
#include "Log.h"
|
|
|
|
#include "fs/devices/ConsoleDevice.h"
|
|
|
|
#include "fs/devices/NullDevice.h"
|
2023-03-30 21:19:16 +02:00
|
|
|
#include "fs/devices/ZeroDevice.h"
|
2023-03-18 09:10:33 +01:00
|
|
|
#include <luna/Vector.h>
|
|
|
|
|
|
|
|
struct DeviceDescriptor
|
|
|
|
{
|
|
|
|
device_create_func_t initializer;
|
|
|
|
u32 major;
|
|
|
|
u32 minor;
|
|
|
|
};
|
|
|
|
|
|
|
|
Vector<DeviceDescriptor> g_available_devices = {};
|
|
|
|
|
|
|
|
namespace DeviceRegistry
|
|
|
|
{
|
|
|
|
Result<SharedPtr<Device>> create_special_device(u32 major, u32 minor)
|
|
|
|
{
|
|
|
|
for (const auto& descriptor : g_available_devices)
|
|
|
|
{
|
|
|
|
if (descriptor.major == major && descriptor.minor == minor) return descriptor.initializer();
|
|
|
|
}
|
|
|
|
|
|
|
|
return err(ENODEV);
|
|
|
|
}
|
|
|
|
|
|
|
|
Result<void> register_special_device(u32 major, u32 minor, device_create_func_t initializer)
|
|
|
|
{
|
|
|
|
for (const auto& descriptor : g_available_devices)
|
|
|
|
{
|
|
|
|
if (descriptor.major == major && descriptor.minor == minor) return err(EEXIST);
|
|
|
|
}
|
|
|
|
|
2023-04-14 21:10:38 +02:00
|
|
|
kdbgln("DeviceRegistry: registered new device type %u:%u", major, minor);
|
2023-03-18 09:10:33 +01:00
|
|
|
|
|
|
|
return g_available_devices.try_append(
|
|
|
|
DeviceDescriptor { .initializer = initializer, .major = major, .minor = minor });
|
|
|
|
}
|
|
|
|
|
|
|
|
Result<void> init()
|
|
|
|
{
|
|
|
|
// Hardcode default devices.
|
|
|
|
TRY(register_special_device(DeviceMajorTypes::Memory, 0, NullDevice::create));
|
2023-03-30 21:19:16 +02:00
|
|
|
TRY(register_special_device(DeviceMajorTypes::Memory, 1, ZeroDevice::create));
|
2023-03-18 09:10:33 +01:00
|
|
|
TRY(register_special_device(DeviceMajorTypes::Console, 0, ConsoleDevice::create));
|
|
|
|
|
|
|
|
return {};
|
|
|
|
}
|
|
|
|
}
|