mirror of
				https://github.com/RGBCube/serenity
				synced 2025-10-31 01:02:45 +00:00 
			
		
		
		
	 500b7b08d6
			
		
	
	
		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();
 | |
| }
 | |
| 
 | |
| }
 |