:: commit 96fe1aa2e0df7c0599a2adf7b0e0bd6cdd606929

mintsuki <mintsuki@protonmail.com> — 2022-10-09 08:52

parents: d265cad7b6

disk: Only use BLOCK_IO as fallback to DISK_IO when determining optical

diff --git a/common/drivers/disk.s2.c b/common/drivers/disk.s2.c
index 188f5ff0..55c82a69 100644
--- a/common/drivers/disk.s2.c
+++ b/common/drivers/disk.s2.c
@@ -537,6 +537,14 @@ fail:
             break;
         }
 
+        EFI_GUID disk_io_guid = DISK_IO_PROTOCOL;
+        EFI_DISK_IO *disk_io = NULL;
+
+        status = gBS->HandleProtocol(handles[i], &disk_io_guid, (void **)&disk_io);
+        if (status) {
+            disk_io = NULL;
+        }
+
         EFI_BLOCK_IO *drive = NULL;
 
         status = gBS->HandleProtocol(handles[i], &block_io_guid, (void **)&drive);
@@ -547,12 +555,21 @@ fail:
         if (drive->Media->LogicalPartition)
             continue;
 
-        status = drive->ReadBlocks(drive, drive->Media->MediaId, 0, 4096, unique_sector_pool);
+        uint64_t orig;
+        if (disk_io != NULL) {
+            status = disk_io->ReadDisk(disk_io, drive->Media->MediaId, 0, sizeof(uint64_t), &orig);
+        } else {
+            status = drive->ReadBlocks(drive, drive->Media->MediaId, 0, 4096, unique_sector_pool);
+        }
         if (status) {
             continue;
         }
 
-        status = drive->WriteBlocks(drive, drive->Media->MediaId, 0, 4096, unique_sector_pool);
+        if (disk_io != NULL) {
+            status = disk_io->WriteDisk(disk_io, drive->Media->MediaId, 0, sizeof(uint64_t), &orig);
+        } else {
+            status = drive->WriteBlocks(drive, drive->Media->MediaId, 0, 4096, unique_sector_pool);
+        }
 
         struct volume *block = ext_mem_alloc(sizeof(struct volume));
 
tab: 248 wrap: offon