mirror of
https://github.com/SerenityOS/serenity.git
synced 2025-01-23 18:02:05 -05:00
500b7b08d6
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.
41 lines
1.4 KiB
C++
41 lines
1.4 KiB
C++
/*
|
|
* Copyright (c) 2023, the SerenityOS developers.
|
|
*
|
|
* SPDX-License-Identifier: BSD-2-Clause
|
|
*/
|
|
|
|
#include <Kernel/Bus/PCI/API.h>
|
|
#include <Kernel/Devices/Storage/SD/PCISDHostController.h>
|
|
|
|
namespace Kernel {
|
|
|
|
ErrorOr<NonnullRefPtr<PCISDHostController>> PCISDHostController::try_initialize(PCI::DeviceIdentifier const& device_identifier)
|
|
{
|
|
auto sdhc = TRY(adopt_nonnull_ref_or_enomem(new (nothrow) PCISDHostController(device_identifier)));
|
|
TRY(sdhc->initialize());
|
|
|
|
PCI::enable_bus_mastering(sdhc->device_identifier());
|
|
PCI::enable_memory_space(sdhc->device_identifier());
|
|
sdhc->try_enable_dma();
|
|
|
|
return sdhc;
|
|
}
|
|
|
|
PCISDHostController::PCISDHostController(PCI::DeviceIdentifier const& device_identifier)
|
|
: PCI::Device(device_identifier)
|
|
, SDHostController()
|
|
{
|
|
auto slot_information_register = read_slot_information();
|
|
|
|
if (slot_information_register.slots_available() != 1) {
|
|
// TODO: Support multiple slots
|
|
dmesgln("SD Host Controller has {} slots, but we currently only support using only one", slot_information_register.slots_available());
|
|
}
|
|
|
|
auto physical_address_of_sdhc_registers = PhysicalAddress {
|
|
PCI::get_BAR(device_identifier, static_cast<PCI::HeaderType0BaseRegister>(slot_information_register.first_bar_number))
|
|
};
|
|
m_registers = Memory::map_typed_writable<SD::HostControlRegisterMap volatile>(physical_address_of_sdhc_registers).release_value_but_fixme_should_propagate_errors();
|
|
}
|
|
|
|
}
|