mirror of
https://github.com/LadybirdBrowser/ladybird.git
synced 2025-07-28 11:49:44 +00:00
Kernel/Storage: Restore booting from MBR partitions functionality
We had such functionality in the past, but it was regressed and now is restored.
This commit is contained in:
parent
cf4fa936be
commit
ed5a4f2938
Notes:
sideshowbarker
2024-07-18 00:36:29 +09:00
Author: https://github.com/supercomputer7
Commit: ed5a4f2938
Pull-request: https://github.com/SerenityOS/serenity/pull/11095
2 changed files with 16 additions and 1 deletions
|
@ -128,6 +128,21 @@ UNMAP_AFTER_INIT void StorageManagement::determine_boot_device()
|
|||
for (auto& storage_device : m_storage_devices) {
|
||||
if (storage_device.early_storage_name() == storage_name) {
|
||||
m_boot_block_device = storage_device;
|
||||
break;
|
||||
}
|
||||
auto start_storage_name = storage_name.substring_view(0, min(storage_device.early_storage_name().length(), storage_name.length()));
|
||||
|
||||
if (storage_device.early_storage_name().starts_with(start_storage_name)) {
|
||||
StringView partition_sign = storage_name.substring_view(start_storage_name.length());
|
||||
auto possible_partition_number = partition_sign.to_uint<size_t>();
|
||||
if (!possible_partition_number.has_value())
|
||||
break;
|
||||
if (possible_partition_number.value() == 0)
|
||||
break;
|
||||
if (storage_device.partitions().size() < possible_partition_number.value())
|
||||
break;
|
||||
m_boot_block_device = storage_device.partitions()[possible_partition_number.value() - 1];
|
||||
break;
|
||||
}
|
||||
}
|
||||
}
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue