From 4c03f90f6391bae6bdc9533f6cd5bf815fa27a02 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Axel=20D=C3=B6rfler?= Date: Wed, 21 Apr 2004 11:09:33 +0000 Subject: [PATCH] Now correctly translates the partition block offset into a byte offset. git-svn-id: file:///srv/svn/repos/haiku/trunk/current@7283 a95241bf-73f2-0310-859d-f6bbb57e9c96 --- src/kernel/boot/platform/bios_ia32/devices.cpp | 15 ++++++++++----- 1 file changed, 10 insertions(+), 5 deletions(-) diff --git a/src/kernel/boot/platform/bios_ia32/devices.cpp b/src/kernel/boot/platform/bios_ia32/devices.cpp index 1005f801cd..4998492058 100644 --- a/src/kernel/boot/platform/bios_ia32/devices.cpp +++ b/src/kernel/boot/platform/bios_ia32/devices.cpp @@ -100,6 +100,8 @@ class BIOSDrive : public Node { virtual off_t Size() const; + uint32 BlockSize() const { return fBlockSize; } + protected: uint8 fDriveID; bool fLBA; @@ -316,18 +318,21 @@ platform_get_boot_device(struct stage2_args *args, Node **_device) status_t -platform_get_boot_partition(struct stage2_args *args, NodeList *list, - boot::Partition **_partition) +platform_get_boot_partition(struct stage2_args *args, Node *bootDevice, + NodeList *list, boot::Partition **_partition) { - printf("boot partition offset: %lu\n", gBootPartitionOffset); + BIOSDrive *drive = static_cast(bootDevice); + off_t offset = (off_t)gBootPartitionOffset * drive->BlockSize(); + + printf("boot partition offset: %Ld\n", offset); NodeIterator iterator = list->Iterator(); boot::Partition *partition = NULL; while ((partition = (boot::Partition *)iterator.Next()) != NULL) { // search for the partition that contains the partition // offset as reported by the BFS boot block - if (gBootPartitionOffset >= partition->offset - && gBootPartitionOffset < partition->offset + partition->size) { + if (offset >= partition->offset + && offset < partition->offset + partition->size) { *_partition = partition; return B_OK; }