IDEController.h 1.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748
  1. /*
  2. * Copyright (c) 2020, Liav A. <liavalb@hotmail.co.il>
  3. *
  4. * SPDX-License-Identifier: BSD-2-Clause
  5. */
  6. #pragma once
  7. #include <AK/OwnPtr.h>
  8. #include <AK/RefPtr.h>
  9. #include <AK/Types.h>
  10. #include <Kernel/Storage/IDEChannel.h>
  11. #include <Kernel/Storage/StorageController.h>
  12. #include <Kernel/Storage/StorageDevice.h>
  13. namespace Kernel {
  14. class AsyncBlockDeviceRequest;
  15. class IDEController final : public StorageController
  16. , public PCI::Device {
  17. AK_MAKE_ETERNAL
  18. public:
  19. static NonnullRefPtr<IDEController> initialize(PCI::Address address, bool force_pio);
  20. virtual ~IDEController() override;
  21. virtual RefPtr<StorageDevice> device(u32 index) const override;
  22. virtual bool reset() override;
  23. virtual bool shutdown() override;
  24. virtual size_t devices_count() const override;
  25. virtual void start_request(const StorageDevice&, AsyncBlockDeviceRequest&) override;
  26. virtual void complete_current_request(AsyncDeviceRequest::RequestResult) override;
  27. bool is_bus_master_capable() const;
  28. bool is_pci_native_mode_enabled() const;
  29. private:
  30. bool is_pci_native_mode_enabled_on_primary_channel() const;
  31. bool is_pci_native_mode_enabled_on_secondary_channel() const;
  32. IDEController(PCI::Address address, bool force_pio);
  33. RefPtr<StorageDevice> device_by_channel_and_position(u32 index) const;
  34. void initialize(bool force_pio);
  35. void detect_disks();
  36. NonnullRefPtrVector<IDEChannel> m_channels;
  37. };
  38. }