mirror of
https://github.com/SerenityOS/serenity.git
synced 2025-01-23 18:02:05 -05:00
b97a00d4b1
The `#pragma GCC diagnostic` part is needed because the class has virtual methods with the same name but different arguments, and Clang tries to warn us that we are not actually overriding anything with these. Weirdly enough, GCC does not seem to care.
55 lines
1.7 KiB
C++
55 lines
1.7 KiB
C++
/*
|
|
* Copyright (c) 2021, Liav A. <liavalb@hotmail.co.il>
|
|
*
|
|
* SPDX-License-Identifier: BSD-2-Clause
|
|
*/
|
|
|
|
#pragma once
|
|
|
|
#include <AK/OwnPtr.h>
|
|
#include <Kernel/Storage/IDEChannel.h>
|
|
|
|
namespace Kernel {
|
|
|
|
class AsyncBlockDeviceRequest;
|
|
|
|
struct [[gnu::packed]] PhysicalRegionDescriptor {
|
|
u32 offset;
|
|
u16 size { 0 };
|
|
u16 end_of_table { 0 };
|
|
};
|
|
|
|
class IDEController;
|
|
class BMIDEChannel final : public IDEChannel {
|
|
friend class IDEController;
|
|
friend class PATADiskDevice;
|
|
|
|
public:
|
|
static NonnullRefPtr<BMIDEChannel> create(const IDEController&, IDEChannel::IOAddressGroup, IDEChannel::ChannelType type);
|
|
static NonnullRefPtr<BMIDEChannel> create(const IDEController&, u8 irq, IDEChannel::IOAddressGroup, IDEChannel::ChannelType type);
|
|
virtual ~BMIDEChannel() override {};
|
|
|
|
virtual bool is_dma_enabled() const override { return true; };
|
|
|
|
private:
|
|
BMIDEChannel(const IDEController&, IDEChannel::IOAddressGroup, IDEChannel::ChannelType type);
|
|
BMIDEChannel(const IDEController&, u8 irq, IDEChannel::IOAddressGroup, IDEChannel::ChannelType type);
|
|
void initialize();
|
|
|
|
void complete_current_request(AsyncDeviceRequest::RequestResult);
|
|
|
|
//^ IRQHandler
|
|
virtual bool handle_irq(const RegisterState&) override;
|
|
|
|
//* IDEChannel
|
|
virtual void send_ata_io_command(LBAMode lba_mode, Direction direction) const override;
|
|
virtual void ata_read_sectors(bool, u16) override;
|
|
virtual void ata_write_sectors(bool, u16) override;
|
|
|
|
PhysicalRegionDescriptor& prdt() { return *reinterpret_cast<PhysicalRegionDescriptor*>(m_prdt_region->vaddr().as_ptr()); }
|
|
OwnPtr<Region> m_prdt_region;
|
|
OwnPtr<Region> m_dma_buffer_region;
|
|
RefPtr<PhysicalPage> m_prdt_page;
|
|
RefPtr<PhysicalPage> m_dma_buffer_page;
|
|
};
|
|
}
|