mirror of
https://github.com/RGBCube/serenity
synced 2025-05-14 14:14:58 +00:00

The Storage subsystem, like the Audio and HID subsystems, exposes Unix device files (for example, in the /dev directory). To ensure consistency across the repository, we should make the Storage subsystem to reside in the Kernel/Devices directory like the two other mentioned subsystems.
95 lines
2.5 KiB
C++
95 lines
2.5 KiB
C++
/*
|
|
* Copyright (c) 2020-2022, Liav A. <liavalb@hotmail.co.il>
|
|
*
|
|
* SPDX-License-Identifier: BSD-2-Clause
|
|
*/
|
|
|
|
#include <AK/OwnPtr.h>
|
|
#include <AK/Types.h>
|
|
#include <Kernel/Bus/PCI/API.h>
|
|
#include <Kernel/Devices/Storage/ATA/ATADiskDevice.h>
|
|
#include <Kernel/Devices/Storage/ATA/GenericIDE/Channel.h>
|
|
#include <Kernel/Devices/Storage/ATA/GenericIDE/Controller.h>
|
|
#include <Kernel/Library/LockRefPtr.h>
|
|
#include <Kernel/Sections.h>
|
|
|
|
namespace Kernel {
|
|
|
|
ErrorOr<void> IDEController::reset()
|
|
{
|
|
return Error::from_errno(ENOTIMPL);
|
|
}
|
|
|
|
ErrorOr<void> IDEController::shutdown()
|
|
{
|
|
return Error::from_errno(ENOTIMPL);
|
|
}
|
|
|
|
size_t IDEController::devices_count() const
|
|
{
|
|
size_t count = 0;
|
|
for (u32 index = 0; index < 4; index++) {
|
|
if (!device(index).is_null())
|
|
count++;
|
|
}
|
|
return count;
|
|
}
|
|
|
|
void IDEController::start_request(ATADevice const& device, AsyncBlockDeviceRequest& request)
|
|
{
|
|
auto& address = device.ata_address();
|
|
VERIFY(address.subport < 2);
|
|
switch (address.port) {
|
|
case 0: {
|
|
auto result = m_channels[0]->start_request(device, request);
|
|
// FIXME: Propagate errors properly
|
|
VERIFY(!result.is_error());
|
|
return;
|
|
}
|
|
case 1: {
|
|
auto result = m_channels[1]->start_request(device, request);
|
|
// FIXME: Propagate errors properly
|
|
VERIFY(!result.is_error());
|
|
return;
|
|
}
|
|
}
|
|
VERIFY_NOT_REACHED();
|
|
}
|
|
|
|
void IDEController::complete_current_request(AsyncDeviceRequest::RequestResult)
|
|
{
|
|
VERIFY_NOT_REACHED();
|
|
}
|
|
|
|
UNMAP_AFTER_INIT IDEController::IDEController() = default;
|
|
UNMAP_AFTER_INIT IDEController::~IDEController() = default;
|
|
|
|
LockRefPtr<StorageDevice> IDEController::device_by_channel_and_position(u32 index) const
|
|
{
|
|
switch (index) {
|
|
case 0:
|
|
return m_channels[0]->connected_device(0);
|
|
case 1:
|
|
return m_channels[0]->connected_device(1);
|
|
case 2:
|
|
return m_channels[1]->connected_device(0);
|
|
case 3:
|
|
return m_channels[1]->connected_device(1);
|
|
}
|
|
VERIFY_NOT_REACHED();
|
|
}
|
|
|
|
LockRefPtr<StorageDevice> IDEController::device(u32 index) const
|
|
{
|
|
Vector<NonnullLockRefPtr<StorageDevice>> connected_devices;
|
|
for (size_t index = 0; index < 4; index++) {
|
|
auto checked_device = device_by_channel_and_position(index);
|
|
if (checked_device.is_null())
|
|
continue;
|
|
connected_devices.append(checked_device.release_nonnull());
|
|
}
|
|
if (index >= connected_devices.size())
|
|
return nullptr;
|
|
return connected_devices[index];
|
|
}
|
|
}
|