mirror of
				https://github.com/winfsp/winfsp.git
				synced 2025-10-26 01:28:37 -05:00 
			
		
		
		
	Merge pull request #248 from JohnOberschelp/master
Airfs cleanup after persistence review
This commit is contained in:
		| @@ -1139,7 +1139,7 @@ void AirfsDelete(AIRFS_ Airfs) | |||||||
| ////////////////////////////////////////////////////////////////////// | ////////////////////////////////////////////////////////////////////// | ||||||
|  |  | ||||||
| NTSTATUS AirfsCreate( | NTSTATUS AirfsCreate( | ||||||
|     PWSTR VolumeName, |     PWSTR StorageFileName, | ||||||
|     PWSTR MapName, |     PWSTR MapName, | ||||||
|     ULONG Flags, |     ULONG Flags, | ||||||
|     ULONG FileInfoTimeout, |     ULONG FileInfoTimeout, | ||||||
| @@ -1160,12 +1160,12 @@ NTSTATUS AirfsCreate( | |||||||
|  |  | ||||||
|     *PAirfs = 0; |     *PAirfs = 0; | ||||||
|  |  | ||||||
|     boolean VolumeExists = *VolumeName && (_waccess(VolumeName, 0) != -1); |     boolean StorageFileExists = *StorageFileName && (_waccess(StorageFileName, 0) != -1); | ||||||
|  |  | ||||||
|     Result = StorageStartup(Airfs, MapName, VolumeName, VolumeSize); |     Result = StorageStartup(Airfs, MapName, StorageFileName, VolumeSize); | ||||||
|     if (Result) return Result; |     if (Result) return Result; | ||||||
|  |  | ||||||
|     boolean ShouldFormat = !VolumeExists || memcmp(Airfs->VolumeLabel, L"AIRFS", 10); |     boolean ShouldFormat = !StorageFileExists || memcmp(Airfs->Signature, "Airfs\0\0\0", 8); | ||||||
|  |  | ||||||
|     if (ShouldFormat) |     if (ShouldFormat) | ||||||
|     { |     { | ||||||
| @@ -1177,10 +1177,10 @@ NTSTATUS AirfsCreate( | |||||||
|             &RootSecurity, &RootSecuritySize)) |             &RootSecurity, &RootSecuritySize)) | ||||||
|             return GetLastErrorAsStatus(); |             return GetLastErrorAsStatus(); | ||||||
|  |  | ||||||
|         Airfs->VolumeName[0] = 0; |  | ||||||
|         Airfs->VolumeSize = ROUND_DOWN(VolumeSize, ALLOCATION_UNIT); |         Airfs->VolumeSize = ROUND_DOWN(VolumeSize, ALLOCATION_UNIT); | ||||||
|  |  | ||||||
|         Airfs->CaseInsensitive = CaseInsensitive; |         Airfs->CaseInsensitive = CaseInsensitive; | ||||||
|  |         Airfs->VolumeLabelLength = sizeof L"AIRFS" - sizeof WCHAR; | ||||||
|  |         memcpy(Airfs->VolumeLabel, L"AIRFS", Airfs->VolumeLabelLength); | ||||||
|  |  | ||||||
|         FSP_FSCTL_VOLUME_PARAMS V; |         FSP_FSCTL_VOLUME_PARAMS V; | ||||||
|         memset(&V, 0, sizeof V); |         memset(&V, 0, sizeof V); | ||||||
| @@ -1206,9 +1206,6 @@ NTSTATUS AirfsCreate( | |||||||
|             FileSystemName ? FileSystemName : L"-AIRFS"); |             FileSystemName ? FileSystemName : L"-AIRFS"); | ||||||
|         Airfs->VolumeParams = V; |         Airfs->VolumeParams = V; | ||||||
|  |  | ||||||
|         Airfs->VolumeLabelLength = sizeof L"AIRFS" - sizeof WCHAR; |  | ||||||
|         memcpy(Airfs->VolumeLabel, L"AIRFS", Airfs->VolumeLabelLength); |  | ||||||
|  |  | ||||||
|         //  Set up the available storage in chunks. |         //  Set up the available storage in chunks. | ||||||
|         Airfs->FreeSize = 0; |         Airfs->FreeSize = 0; | ||||||
|         Airfs->Available = 0; |         Airfs->Available = 0; | ||||||
| @@ -1278,7 +1275,7 @@ NTSTATUS SvcStart(FSP_SERVICE *Service, ULONG argc, PWSTR *argv) | |||||||
|     ULONG Flags = AirfsDisk; |     ULONG Flags = AirfsDisk; | ||||||
|     ULONG OtherFlags = 0; |     ULONG OtherFlags = 0; | ||||||
|     ULONG FileInfoTimeout = INFINITE; |     ULONG FileInfoTimeout = INFINITE; | ||||||
|     PWSTR VolumeName = L""; |     PWSTR StorageFileName = L""; | ||||||
|     PWSTR MapName = L""; |     PWSTR MapName = L""; | ||||||
|     UINT64 VolumeSize = 16LL * 1024 * 1024; |     UINT64 VolumeSize = 16LL * 1024 * 1024; | ||||||
|     PWSTR FileSystemName = 0; |     PWSTR FileSystemName = 0; | ||||||
| @@ -1302,7 +1299,7 @@ NTSTATUS SvcStart(FSP_SERVICE *Service, ULONG argc, PWSTR *argv) | |||||||
|         case L'F': ARG_TO_S(FileSystemName); break; |         case L'F': ARG_TO_S(FileSystemName); break; | ||||||
|         case L'i': OtherFlags = AirfsCaseInsensitive; break; |         case L'i': OtherFlags = AirfsCaseInsensitive; break; | ||||||
|         case L'm': ARG_TO_S(MountPoint); break; |         case L'm': ARG_TO_S(MountPoint); break; | ||||||
|         case L'N': ARG_TO_S(VolumeName);  break; |         case L'N': ARG_TO_S(StorageFileName);  break; | ||||||
|         case L'n': ARG_TO_S(MapName);  break; |         case L'n': ARG_TO_S(MapName);  break; | ||||||
|         case L'S': ARG_TO_S(RootSddl); break; |         case L'S': ARG_TO_S(RootSddl); break; | ||||||
|         case L's': ARG_TO_8(VolumeSize); break; |         case L's': ARG_TO_8(VolumeSize); break; | ||||||
| @@ -1345,7 +1342,7 @@ NTSTATUS SvcStart(FSP_SERVICE *Service, ULONG argc, PWSTR *argv) | |||||||
|     } |     } | ||||||
|  |  | ||||||
|     Result = AirfsCreate( |     Result = AirfsCreate( | ||||||
|         VolumeName, |         StorageFileName, | ||||||
|         MapName, |         MapName, | ||||||
|         Flags | OtherFlags, |         Flags | OtherFlags, | ||||||
|         FileInfoTimeout, |         FileInfoTimeout, | ||||||
| @@ -1386,7 +1383,7 @@ NTSTATUS SvcStart(FSP_SERVICE *Service, ULONG argc, PWSTR *argv) | |||||||
|     WCHAR buffer[1024]; |     WCHAR buffer[1024]; | ||||||
|     _snwprintf_s(buffer, 1024, L"%S%S%s%S%s -t %ld -s %lld%S%s%S%s%S%s", |     _snwprintf_s(buffer, 1024, L"%S%S%s%S%s -t %ld -s %lld%S%s%S%s%S%s", | ||||||
|         PROGNAME,  |         PROGNAME,  | ||||||
|         *VolumeName   ? " -N " : "", *VolumeName   ? VolumeName   : L"",  |         *StorageFileName ? " -N " : "", *StorageFileName ? StorageFileName : L"",  | ||||||
|         *MapName         ? " -n " : "", *MapName         ? MapName         : L"", |         *MapName         ? " -n " : "", *MapName         ? MapName         : L"", | ||||||
|         FileInfoTimeout, VolumeSize, |         FileInfoTimeout, VolumeSize, | ||||||
|         RootSddl         ? " -S " : "", RootSddl         ? RootSddl        : L"", |         RootSddl         ? " -S " : "", RootSddl         ? RootSddl        : L"", | ||||||
| @@ -1416,7 +1413,7 @@ NTSTATUS SvcStart(FSP_SERVICE *Service, ULONG argc, PWSTR *argv) | |||||||
|         "    -i                  [case insensitive file system]\n" |         "    -i                  [case insensitive file system]\n" | ||||||
|         "    -m MountPoint       [X:|* (required if no UNC prefix)]\n" |         "    -m MountPoint       [X:|* (required if no UNC prefix)]\n" | ||||||
|         "    -n MapName          [(ex) \"Local\\Airfs\"]\n" |         "    -n MapName          [(ex) \"Local\\Airfs\"]\n" | ||||||
|         "    -N VolumeName       [\"\": in memory only]\n" |         "    -N StorageFileName  [\"\": in memory only]\n" | ||||||
|         "    -s VolumeSize       [bytes]\n" |         "    -s VolumeSize       [bytes]\n" | ||||||
|         "    -S RootSddl         [file rights: FA, etc; NO generic rights: GA, etc.]\n" |         "    -S RootSddl         [file rights: FA, etc; NO generic rights: GA, etc.]\n" | ||||||
|         "    -t FileInfoTimeout  [millis]\n" |         "    -t FileInfoTimeout  [millis]\n" | ||||||
|   | |||||||
| @@ -80,7 +80,7 @@ static int64_t wcstoll_default(wchar_t *w, int64_t deflt) | |||||||
| //  Where<T> Class: This class manages an offset within our memory-mapped  | //  Where<T> Class: This class manages an offset within our memory-mapped  | ||||||
| //  volume to another location within our memory-mapped volume. Because it is | //  volume to another location within our memory-mapped volume. Because it is | ||||||
| //  a self-relative offset, this delta is constant regardless of where in | //  a self-relative offset, this delta is constant regardless of where in | ||||||
| //  memory the file system is mapped, so we can always reoptain its address.  | //  memory the file system is mapped, so we can always reobtain its address.  | ||||||
| //  A delta of 0 is the special case for "null". | //  A delta of 0 is the special case for "null". | ||||||
| // | // | ||||||
|  |  | ||||||
| @@ -130,8 +130,6 @@ typedef struct | |||||||
|     UINT16       filler1,filler2,filler3; |     UINT16       filler1,filler2,filler3; | ||||||
|     UINT32       CaseInsensitive; |     UINT32       CaseInsensitive; | ||||||
|     UINT32       filler4; |     UINT32       filler4; | ||||||
|     WCHAR        MapName[256]; |  | ||||||
|     WCHAR        VolumeName[256];  //  Use "" for a memory-only page file. |  | ||||||
|     int64_t      VolumeLength; |     int64_t      VolumeLength; | ||||||
|     FSP_FSCTL_VOLUME_PARAMS VolumeParams; |     FSP_FSCTL_VOLUME_PARAMS VolumeParams; | ||||||
|     FSP_FILE_SYSTEM *FileSystem; |     FSP_FILE_SYSTEM *FileSystem; | ||||||
| @@ -197,11 +195,11 @@ NODE_ Last   (NODE_ start); | |||||||
| NODE_ Next   (NODE_); | NODE_ Next   (NODE_); | ||||||
| NODE_ Prev   (NODE_); | NODE_ Prev   (NODE_); | ||||||
|  |  | ||||||
| NTSTATUS StorageStartup         (AIRFS_ &, WCHAR* MapName, WCHAR* VolumeName, int64_t Length); | NTSTATUS StorageStartup         (AIRFS_ &, WCHAR* MapName, WCHAR* StorageFileName, int64_t Length); | ||||||
| NTSTATUS StorageShutdown        (AIRFS_); | NTSTATUS StorageShutdown        (AIRFS_); | ||||||
| void*    StorageAllocate        (AIRFS_ Airfs, int64_t RequestedSize); | void*    StorageAllocate        (AIRFS_, int64_t RequestedSize); | ||||||
| void*    StorageReallocate      (AIRFS_ Airfs, void* Reallocate, int64_t RequestedSize); | void*    StorageReallocate      (AIRFS_, void* Reallocate, int64_t RequestedSize); | ||||||
| void     StorageFree            (AIRFS_ Airfs, void* Release); | void     StorageFree            (AIRFS_, void* Release); | ||||||
| NTSTATUS StorageSetFileCapacity (AIRFS_, NODE_, int64_t MinimumRequiredCapacity); | NTSTATUS StorageSetFileCapacity (AIRFS_, NODE_, int64_t MinimumRequiredCapacity); | ||||||
| void     StorageAccessFile      (StorageFileAccessType, NODE_, int64_t Offset, int64_t NumBytes, char* Address); | void     StorageAccessFile      (StorageFileAccessType, NODE_, int64_t Offset, int64_t NumBytes, char* Address); | ||||||
|  |  | ||||||
|   | |||||||
| @@ -84,11 +84,12 @@ void Airprint (const char * format, ...) | |||||||
| //  Rubbertree (because it is flexible!) | //  Rubbertree (because it is flexible!) | ||||||
| //  Implements a sorted set of elements, using a binary tree. | //  Implements a sorted set of elements, using a binary tree. | ||||||
| //  Has a function, Near, that finds nodes at or adjacent to a key. | //  Has a function, Near, that finds nodes at or adjacent to a key. | ||||||
| //  Has an equal branch for trees that require handling equivalent |  | ||||||
| //  nodes, like Airfs' memory heap manager. |  | ||||||
| //  Attach, Find, and Near use splay to improve random access times. | //  Attach, Find, and Near use splay to improve random access times. | ||||||
| //  First, Last, Next, and Prev do not, to improve sequential access times. | //  First, Last, Next, and Prev do not, to improve sequential access times. | ||||||
| //  Replacing Where<NODE_> with NODE_ would make it a pointer-based tree. | //  Replacing each Where<NODE_> with NODE_ would make this a pointer-based tree. | ||||||
|  | //  In addition to Left, Right, and Parent references, each node has an Equal | ||||||
|  | //  reference that may be used to keep "equivalent" nodes. This is used by | ||||||
|  | //  our memory heap manager's tree of available memory blocks, sorted by size. | ||||||
|  |  | ||||||
| //-------------------------------------------------------------------- | //-------------------------------------------------------------------- | ||||||
|  |  | ||||||
| @@ -531,15 +532,15 @@ NTSTATUS StorageSetFileCapacity(AIRFS_ Airfs, NODE_ Node, int64_t minimumRequire | |||||||
|  |  | ||||||
| //-------------------------------------------------------------------- | //-------------------------------------------------------------------- | ||||||
|  |  | ||||||
| NTSTATUS StorageStartup(AIRFS_ &Airfs, WCHAR* MapName, WCHAR* VolumeName, int64_t VolumeLength) | NTSTATUS StorageStartup(AIRFS_ &Airfs, WCHAR* MapName, WCHAR* StorageFileName, int64_t VolumeLength) | ||||||
| { | { | ||||||
|     HANDLE MapFileHandle = INVALID_HANDLE_VALUE; |     HANDLE MapFileHandle = INVALID_HANDLE_VALUE; | ||||||
|     Airfs = 0; |     Airfs = 0; | ||||||
|  |  | ||||||
|     //  Open. |     //  Open. | ||||||
|     if (*VolumeName) |     if (*StorageFileName) | ||||||
|     { |     { | ||||||
|         MapFileHandle = CreateFileW(VolumeName, GENERIC_READ|GENERIC_WRITE|GENERIC_EXECUTE, 0, NULL, OPEN_ALWAYS, NULL, NULL); |         MapFileHandle = CreateFileW(StorageFileName, GENERIC_READ|GENERIC_WRITE|GENERIC_EXECUTE, 0, NULL, OPEN_ALWAYS, NULL, NULL); | ||||||
|         if (MapFileHandle == INVALID_HANDLE_VALUE) return GetLastErrorAsStatus(); |         if (MapFileHandle == INVALID_HANDLE_VALUE) return GetLastErrorAsStatus(); | ||||||
|     } |     } | ||||||
|  |  | ||||||
| @@ -555,8 +556,6 @@ NTSTATUS StorageStartup(AIRFS_ &Airfs, WCHAR* MapName, WCHAR* VolumeName, int64_ | |||||||
|     Airfs = (AIRFS_) MappedAddress; |     Airfs = (AIRFS_) MappedAddress; | ||||||
|     Airfs->MapFileHandle = MapFileHandle; |     Airfs->MapFileHandle = MapFileHandle; | ||||||
|     Airfs->MapHandle = MapHandle; |     Airfs->MapHandle = MapHandle; | ||||||
|     wcscpy_s(Airfs->VolumeName, 256, VolumeName);  //  Use "" for a memory-only page file. |  | ||||||
|     wcscpy_s(Airfs->MapName, 256, MapName); |  | ||||||
|     Airfs->VolumeLength = VolumeLength; |     Airfs->VolumeLength = VolumeLength; | ||||||
|  |  | ||||||
|     return 0; |     return 0; | ||||||
| @@ -571,15 +570,13 @@ NTSTATUS StorageShutdown(AIRFS_ Airfs) | |||||||
|     HANDLE M = Airfs->MapHandle; |     HANDLE M = Airfs->MapHandle; | ||||||
|     HANDLE F = Airfs->MapFileHandle; |     HANDLE F = Airfs->MapFileHandle; | ||||||
|  |  | ||||||
|     if (Airfs) |  | ||||||
|     { |  | ||||||
|     Ok = FlushViewOfFile(Airfs, 0);  if (!Ok && !Result) Result = GetLastErrorAsStatus(); |     Ok = FlushViewOfFile(Airfs, 0);  if (!Ok && !Result) Result = GetLastErrorAsStatus(); | ||||||
|     if (F != INVALID_HANDLE_VALUE) |     if (F != INVALID_HANDLE_VALUE) | ||||||
|     { |     { | ||||||
|         Ok = FlushFileBuffers(F);    if (!Ok && !Result) Result = GetLastErrorAsStatus(); |         Ok = FlushFileBuffers(F);    if (!Ok && !Result) Result = GetLastErrorAsStatus(); | ||||||
|  |         //  TODO: Set and write a flag something like Airfs->UpdatesCompleted here? | ||||||
|     } |     } | ||||||
|     Ok = UnmapViewOfFile(Airfs);     if (!Ok && !Result) Result = GetLastErrorAsStatus(); |     Ok = UnmapViewOfFile(Airfs);     if (!Ok && !Result) Result = GetLastErrorAsStatus(); | ||||||
|     } |  | ||||||
|      |      | ||||||
|     if (M) |     if (M) | ||||||
|     { |     { | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user