Implement FAT12 reading.

This commit is contained in:
2019-04-27 02:26:31 +01:00
parent bdd18cef45
commit ffa5a4ceb7
3 changed files with 26 additions and 5 deletions

View File

@@ -166,8 +166,6 @@ namespace DiscImageChef.Filesystems.FAT
uint nextCluster = startCluster;
if(fat12) return null;
ulong nextSector = nextCluster / fatEntriesPerSector + fatFirstSector + (useFirstFat ? 0 : sectorsPerFat);
int nextEntry = (int)(nextCluster % fatEntriesPerSector);
@@ -175,7 +173,7 @@ namespace DiscImageChef.Filesystems.FAT
byte[] fatData = image.ReadSector(currentSector);
if(fat32)
while((nextCluster & FAT32_MASK) > 0 && (nextCluster & FAT32_MASK) <= FAT32_BAD)
while((nextCluster & FAT32_MASK) > 0 && (nextCluster & FAT32_MASK) <= FAT32_FORMATTED)
{
clusters.Add(nextCluster);
@@ -191,7 +189,7 @@ namespace DiscImageChef.Filesystems.FAT
nextEntry = (int)(nextCluster % fatEntriesPerSector);
}
else if(fat16)
while(nextCluster > 0 && nextCluster <= FAT16_BAD)
while(nextCluster > 0 && nextCluster <= FAT16_FORMATTED)
{
clusters.Add(nextCluster);
@@ -206,6 +204,12 @@ namespace DiscImageChef.Filesystems.FAT
(useFirstFat ? 0 : sectorsPerFat);
nextEntry = (int)(nextCluster % fatEntriesPerSector);
}
else
while(nextCluster > 0 && nextCluster <= FAT12_FORMATTED)
{
clusters.Add(nextCluster);
nextCluster = fatEntries[nextCluster];
}
return clusters.ToArray();
}