123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103 |
- using System;
- using System.Collections.Generic;
- using System.Text;
- namespace DiskAccessLibrary.LogicalDiskManager
- {
- public class PrivateRegionHelper
- {
- public static long FindUnusedSector(PrivateHeader privateHeader, TOCBlock tocBlock)
- {
- return FindUnusedRegion(privateHeader, tocBlock, 1);
- }
- public static long FindUnusedRegion(PrivateHeader privateHeader, TOCBlock tocBlock, int sectorCount)
- {
- bool[] bitmap = GetPrivateRegionUsageBitmap(privateHeader, tocBlock);
-
- bitmap[0] = true;
- bitmap[1] = true;
- bitmap[2] = true;
- bitmap[privateHeader.PrivateRegionSizeLBA - 3] = true;
- bitmap[privateHeader.PrivateRegionSizeLBA - 2] = true;
- int startIndex = 0;
- int freeCount = 0;
- for (int index = 0; index < bitmap.Length; index++)
- {
- if (bitmap[index] == false)
- {
- if (freeCount == 0)
- {
- startIndex = index;
- }
- freeCount++;
- if (freeCount == sectorCount)
- {
- return (long)privateHeader.PrivateRegionStartLBA + startIndex;
- }
- }
- else
- {
- freeCount = 0;
- }
- }
- return -1;
- }
-
-
- public static long FindUnusedLBAForPrimaryToc(PrivateHeader privateHeader, TOCBlock tocBlock)
- {
- bool[] bitmap = GetPrivateRegionUsageBitmap(privateHeader, tocBlock);
- for (int index = 0; index < bitmap.Length; index++)
- {
- if (bitmap[index] == false)
- {
- return (long)privateHeader.PrivateRegionStartLBA + index;
- }
- }
- return -1;
- }
-
- public static long FindUnusedLBAForSecondaryToc(PrivateHeader privateHeader, TOCBlock tocBlock)
- {
- bool[] bitmap = GetPrivateRegionUsageBitmap(privateHeader, tocBlock);
- for (int index = bitmap.Length - 1; index >= 0; index--)
- {
- if (bitmap[index] == false)
- {
- return (long)privateHeader.PrivateRegionStartLBA + index;
- }
- }
- return -1;
- }
- private static bool[] GetPrivateRegionUsageBitmap(PrivateHeader privateHeader, TOCBlock tocBlock)
- {
-
- bool[] bitmap = new bool[privateHeader.PrivateRegionSizeLBA];
- bitmap[privateHeader.PrimaryPrivateHeaderLBA] = true;
- bitmap[privateHeader.SecondaryPrivateHeaderLBA] = true;
- bitmap[privateHeader.PrimaryTocLBA] = true;
- bitmap[privateHeader.SecondaryTocLBA] = true;
- foreach (TOCRegion region in tocBlock.Regions)
- {
- for (int index = 0; index < (int)region.SizeLBA; index++)
- {
- bitmap[(int)region.StartLBA + index] = true;
- }
- }
- return bitmap;
- }
- }
- }
|