mirror of
https://github.com/RGBCube/serenity
synced 2025-07-26 22:57:34 +00:00
Kernel: Propagate properly errors from PCI IDE Controller initialization
This commit is contained in:
parent
735aa01b58
commit
cf3b75e2e6
3 changed files with 44 additions and 42 deletions
|
@ -19,7 +19,7 @@ class AsyncBlockDeviceRequest;
|
|||
class PCIIDELegacyModeController final : public IDEController
|
||||
, public PCI::Device {
|
||||
public:
|
||||
static NonnullLockRefPtr<PCIIDELegacyModeController> initialize(PCI::DeviceIdentifier const&, bool force_pio);
|
||||
static ErrorOr<NonnullLockRefPtr<PCIIDELegacyModeController>> initialize(PCI::DeviceIdentifier const&, bool force_pio);
|
||||
|
||||
bool is_bus_master_capable() const;
|
||||
bool is_pci_native_mode_enabled() const;
|
||||
|
@ -27,10 +27,10 @@ public:
|
|||
private:
|
||||
bool is_pci_native_mode_enabled_on_primary_channel() const;
|
||||
bool is_pci_native_mode_enabled_on_secondary_channel() const;
|
||||
PCIIDELegacyModeController(PCI::DeviceIdentifier const&, bool force_pio);
|
||||
explicit PCIIDELegacyModeController(PCI::DeviceIdentifier const&);
|
||||
|
||||
LockRefPtr<StorageDevice> device_by_channel_and_position(u32 index) const;
|
||||
void initialize(bool force_pio);
|
||||
ErrorOr<void> initialize_and_enumerate_channels(bool force_pio);
|
||||
|
||||
// FIXME: Find a better way to get the ProgrammingInterface
|
||||
PCI::ProgrammingInterface m_prog_if;
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue