diff --git a/kernel/kernel/Storage/ATA/ATABus.cpp b/kernel/kernel/Storage/ATA/ATABus.cpp index eb9d28a6..cd499312 100644 --- a/kernel/kernel/Storage/ATA/ATABus.cpp +++ b/kernel/kernel/Storage/ATA/ATABus.cpp @@ -73,6 +73,14 @@ namespace Kernel select_delay(); } + static bool identify_all_ones(BAN::Span identify_data) + { + for (size_t i = 0; i < 256; i++) + if (identify_data[i] != 0xFFFF) + return false; + return true; + } + BAN::ErrorOr ATABus::identify(bool secondary, BAN::Span buffer) { select_device(secondary); @@ -117,6 +125,9 @@ namespace Kernel ASSERT(buffer.size() >= 256); read_buffer(ATA_PORT_DATA, buffer.data(), 256); + if (identify_all_ones(buffer)) + return BAN::Error::from_errno(ENODEV); + return type; } diff --git a/kernel/kernel/Storage/ATA/ATADevice.cpp b/kernel/kernel/Storage/ATA/ATADevice.cpp index 81cced96..0eacead6 100644 --- a/kernel/kernel/Storage/ATA/ATADevice.cpp +++ b/kernel/kernel/Storage/ATA/ATADevice.cpp @@ -71,7 +71,7 @@ namespace Kernel while (model_len > 0 && m_model[model_len - 1] == ' ') model_len--; - dprintln("Initialized disk '{}' {} MB", BAN::StringView(m_model, model_len), total_size() / 1024 / 1024); + dprintln("Initialized disk '{}' {} MiB", BAN::StringView(m_model, model_len), total_size() / 1024 / 1024); add_disk_cache();