PARTENTRY,
ListEntry);
- for (i=0; i<3; i++)
+ for (i=0; i<4; i++)
PartEntry->DriveLetter[i] = 0;
if (PartEntry->Unpartitioned == FALSE)
{
- for (i=0; i<3; i++)
+ for (i=0; i<4; i++)
{
if (IsContainerPartition (PartEntry->PartInfo[i].PartitionType))
continue;
PartEntry->PartInfo[j].StartingOffset.QuadPart -
(LastStartingOffset + LastPartitionLength);
- if (LastUnusedPartitionLength >= DiskEntry->CylinderSize)
+ if (PartEntry->PartInfo[j].StartingOffset.QuadPart > (LastStartingOffset + LastPartitionLength) &&
+ LastUnusedPartitionLength >= DiskEntry->CylinderSize)
{
DPRINT ("Unpartitioned disk space %I64u\n", LastUnusedPartitionLength);
return;
}
- if (DiskGeometry.MediaType != FixedMedia)
+ if (DiskGeometry.MediaType != FixedMedia &&
+ DiskGeometry.MediaType != RemovableMedia)
{
return;
}
if (!DiskEntry->BiosFound)
{
+#if 0
RtlFreeHeap(ProcessHeap, 0, DiskEntry);
return;
+#else
+ DPRINT1("WARNING: Setup could not find a matching BIOS disk entry. Disk %d is not be bootable by the BIOS!\n", DiskNumber);
+#endif
}
InitializeListHead (&DiskEntry->PartListHead);
GetDriverName (DiskEntry);
- InsertAscendingList(&List->DiskListHead, DiskEntry, DISKENTRY, ListEntry, BiosDiskNumber);
+ InsertAscendingList(&List->DiskListHead, DiskEntry, DISKENTRY, ListEntry, DiskNumber);
/*
* Allocate a buffer for 26 logical drives (2 entries each == 52)
PDISKENTRY DiskEntry)
{
PPARTENTRY PartEntry;
+ PLIST_ENTRY Entry;
CHAR LineBuffer[128];
COORD coPos;
DWORD Written;
PrintEmptyLine (List);
/* Print partition lines*/
- LIST_FOR_EACH(PartEntry, &DiskEntry->PartListHead, PARTENTRY, ListEntry)
+ Entry = DiskEntry->PartListHead.Flink;
+ while (Entry != &DiskEntry->PartListHead)
{
+ PartEntry = CONTAINING_RECORD(Entry, PARTENTRY, ListEntry);
+
/* Print disk entry */
for (i=0; i<4; i++)
{
0);
}
+ Entry = Entry->Flink;
}
/* Print separator line */
/* print list entries */
List->Line = - List->Offset;
- LIST_FOR_EACH(DiskEntry, &List->DiskListHead, DISKENTRY, ListEntry)
+ Entry = List->DiskListHead.Flink;
+ while (Entry != &List->DiskListHead)
{
+ DiskEntry = CONTAINING_RECORD (Entry, DISKENTRY, ListEntry);
+
/* Print disk entry */
PrintDiskData (List,
DiskEntry);
+
+ Entry = Entry->Flink;
}
}
}
#endif
- DiskEntry = CONTAINING_RECORD (List->DiskListHead.Flink,
- DISKENTRY,
- ListEntry);
+ /* Choose the currently selected disk */
+ DiskEntry = List->CurrentDisk;
/* Check for empty partition list */
if (IsListEmpty (&DiskEntry->PartListHead))
List->ActiveBootPartitionNumber = i;
DPRINT("Found bootable partition disk %d, drive letter %c\n",
- DiskEntry->BiosDiskNumber, PartEntry->DriveLetter[i]);
+ DiskEntry->DiskNumber, PartEntry->DriveLetter[i]);
break;
}