- From d9f7059595896341dbde2bffbabcc645c7e1b308 Mon Sep 17 00:00:00 2001
- From: Roland Mainz <roland.mainz@nrubsig.org>
- Date: Tue, 28 Jan 2025 11:26:26 +0100
- Subject: [PATCH 1/7] build.v19: Remove ARM 32bit support
- Remove ARM 32bit support, because:
- - Visual Studio 2019 cannot build kernel modules for ARM/32bit kernels
- for Win10/Desktop targets
- - Windows 10/Desktop does not support ARM/32bit
- - Cygwin (which is required by our idmapper) does not run on ARM/32bit
- - We have no test machine for ARM/32bit
- Support can be restored if we somehow magically get a test machine
- and users who need it.
- Signed-off-by: Cedric Blancher <cedric.blancher@gmail.com>
- ---
- build.vc19/nfs41-client.sln | 28 ----------
- build.vc19/nfs41_driver/nfs41_driver.vcxproj | 56 --------------------
- 2 files changed, 84 deletions(-)
- diff --git a/build.vc19/nfs41-client.sln b/build.vc19/nfs41-client.sln
- index 15dea16..df40a34 100644
- --- a/build.vc19/nfs41-client.sln
- +++ b/build.vc19/nfs41-client.sln
- @@ -22,9 +22,7 @@ Global
- GlobalSection(SolutionConfigurationPlatforms) = preSolution
- Debug|x64 = Debug|x64
- Debug|x86 = Debug|x86
- - Debug|ARM = Debug|ARM
- Debug|ARM64 = Debug|ARM64
- - Release|ARM = Release|ARM
- Release|ARM64 = Release|ARM64
- Release|x64 = Release|x64
- Release|x86 = Release|x86
- @@ -36,16 +34,12 @@ Global
- {D99CCE56-FF7D-44D3-8E75-EB6D8F47CFA1}.Debug|x86.Build.0 = Debug|Win32
- {D99CCE56-FF7D-44D3-8E75-EB6D8F47CFA1}.Debug|ARM64.ActiveCfg = Debug|ARM64
- {D99CCE56-FF7D-44D3-8E75-EB6D8F47CFA1}.Debug|ARM64.Build.0 = Debug|ARM64
- - {D99CCE56-FF7D-44D3-8E75-EB6D8F47CFA1}.Debug|ARM.ActiveCfg = Debug|ARM
- - {D99CCE56-FF7D-44D3-8E75-EB6D8F47CFA1}.Debug|ARM.Build.0 = Debug|ARM
- {D99CCE56-FF7D-44D3-8E75-EB6D8F47CFA1}.Release|x64.ActiveCfg = Release|x64
- {D99CCE56-FF7D-44D3-8E75-EB6D8F47CFA1}.Release|x64.Build.0 = Release|x64
- {D99CCE56-FF7D-44D3-8E75-EB6D8F47CFA1}.Release|x86.ActiveCfg = Release|Win32
- {D99CCE56-FF7D-44D3-8E75-EB6D8F47CFA1}.Release|x86.Build.0 = Release|Win32
- {D99CCE56-FF7D-44D3-8E75-EB6D8F47CFA1}.Release|ARM64.ActiveCfg = Release|ARM64
- {D99CCE56-FF7D-44D3-8E75-EB6D8F47CFA1}.Release|ARM64.Build.0 = Release|ARM64
- - {D99CCE56-FF7D-44D3-8E75-EB6D8F47CFA1}.Release|ARM.ActiveCfg = Release|ARM
- - {D99CCE56-FF7D-44D3-8E75-EB6D8F47CFA1}.Release|ARM.Build.0 = Release|ARM
- {896D812D-B4AC-4661-A9ED-7DE94BB68365}.Debug|x64.ActiveCfg = Debug|x64
- {896D812D-B4AC-4661-A9ED-7DE94BB68365}.Debug|x64.Build.0 = Debug|x64
- {896D812D-B4AC-4661-A9ED-7DE94BB68365}.Debug|x86.ActiveCfg = Debug|Win32
- @@ -56,12 +50,8 @@ Global
- {896D812D-B4AC-4661-A9ED-7DE94BB68365}.Release|x86.Build.0 = Release|Win32
- {896D812D-B4AC-4661-A9ED-7DE94BB68365}.Debug|ARM64.ActiveCfg = Debug|ARM64
- {896D812D-B4AC-4661-A9ED-7DE94BB68365}.Debug|ARM64.Build.0 = Debug|ARM64
- - {896D812D-B4AC-4661-A9ED-7DE94BB68365}.Debug|ARM.ActiveCfg = Debug|ARM
- - {896D812D-B4AC-4661-A9ED-7DE94BB68365}.Debug|ARM.Build.0 = Debug|ARM
- {896D812D-B4AC-4661-A9ED-7DE94BB68365}.Release|ARM64.ActiveCfg = Release|ARM64
- {896D812D-B4AC-4661-A9ED-7DE94BB68365}.Release|ARM64.Build.0 = Release|ARM64
- - {896D812D-B4AC-4661-A9ED-7DE94BB68365}.Release|ARM.ActiveCfg = Release|ARM
- - {896D812D-B4AC-4661-A9ED-7DE94BB68365}.Release|ARM.Build.0 = Release|ARM
- {833F4171-5B96-4BB0-8D9D-BB926ECA8976}.Debug|x64.ActiveCfg = Debug|x64
- {833F4171-5B96-4BB0-8D9D-BB926ECA8976}.Debug|x64.Build.0 = Debug|x64
- {833F4171-5B96-4BB0-8D9D-BB926ECA8976}.Debug|x86.ActiveCfg = Debug|Win32
- @@ -72,12 +62,8 @@ Global
- {833F4171-5B96-4BB0-8D9D-BB926ECA8976}.Release|x86.Build.0 = Release|Win32
- {833F4171-5B96-4BB0-8D9D-BB926ECA8976}.Debug|ARM64.ActiveCfg = Debug|ARM64
- {833F4171-5B96-4BB0-8D9D-BB926ECA8976}.Debug|ARM64.Build.0 = Debug|ARM64
- - {833F4171-5B96-4BB0-8D9D-BB926ECA8976}.Debug|ARM.ActiveCfg = Debug|ARM
- - {833F4171-5B96-4BB0-8D9D-BB926ECA8976}.Debug|ARM.Build.0 = Debug|ARM
- {833F4171-5B96-4BB0-8D9D-BB926ECA8976}.Release|ARM64.ActiveCfg = Release|ARM64
- {833F4171-5B96-4BB0-8D9D-BB926ECA8976}.Release|ARM64.Build.0 = Release|ARM64
- - {833F4171-5B96-4BB0-8D9D-BB926ECA8976}.Release|ARM.ActiveCfg = Release|ARM
- - {833F4171-5B96-4BB0-8D9D-BB926ECA8976}.Release|ARM.Build.0 = Release|ARM
- {78E2A6FE-05E7-40F8-AE1E-29BC3C307859}.Debug|x64.ActiveCfg = Debug|x64
- {78E2A6FE-05E7-40F8-AE1E-29BC3C307859}.Debug|x64.Build.0 = Debug|x64
- {78E2A6FE-05E7-40F8-AE1E-29BC3C307859}.Debug|x86.ActiveCfg = Debug|Win32
- @@ -90,14 +76,8 @@ Global
- {78E2A6FE-05E7-40F8-AE1E-29BC3C307859}.Release|x86.Deploy.0 = Release|Win32
- {78E2A6FE-05E7-40F8-AE1E-29BC3C307859}.Debug|ARM64.ActiveCfg = Debug|ARM64
- {78E2A6FE-05E7-40F8-AE1E-29BC3C307859}.Debug|ARM64.Build.0 = Debug|ARM64
- - {78E2A6FE-05E7-40F8-AE1E-29BC3C307859}.Debug|ARM.ActiveCfg = Debug|ARM
- - {78E2A6FE-05E7-40F8-AE1E-29BC3C307859}.Debug|ARM.Build.0 = Debug|ARM
- - {78E2A6FE-05E7-40F8-AE1E-29BC3C307859}.Debug|ARM.Deploy.0 = Debug|ARM
- {78E2A6FE-05E7-40F8-AE1E-29BC3C307859}.Release|ARM64.ActiveCfg = Release|ARM64
- {78E2A6FE-05E7-40F8-AE1E-29BC3C307859}.Release|ARM64.Build.0 = Release|ARM64
- - {78E2A6FE-05E7-40F8-AE1E-29BC3C307859}.Release|ARM.ActiveCfg = Release|ARM
- - {78E2A6FE-05E7-40F8-AE1E-29BC3C307859}.Release|ARM.Build.0 = Release|ARM
- - {78E2A6FE-05E7-40F8-AE1E-29BC3C307859}.Release|ARM.Deploy.0 = Release|ARM
- {FAE57101-F0EE-46CB-986D-E19A796693F7}.Debug|x64.ActiveCfg = Debug|x64
- {FAE57101-F0EE-46CB-986D-E19A796693F7}.Debug|x64.Build.0 = Debug|x64
- {FAE57101-F0EE-46CB-986D-E19A796693F7}.Debug|x86.ActiveCfg = Debug|Win32
- @@ -108,12 +88,8 @@ Global
- {FAE57101-F0EE-46CB-986D-E19A796693F7}.Release|x86.Build.0 = Release|Win32
- {FAE57101-F0EE-46CB-986D-E19A796693F7}.Debug|ARM64.ActiveCfg = Debug|ARM64
- {FAE57101-F0EE-46CB-986D-E19A796693F7}.Debug|ARM64.Build.0 = Debug|ARM64
- - {FAE57101-F0EE-46CB-986D-E19A796693F7}.Debug|ARM.ActiveCfg = Debug|ARM
- - {FAE57101-F0EE-46CB-986D-E19A796693F7}.Debug|ARM.Build.0 = Debug|ARM
- {FAE57101-F0EE-46CB-986D-E19A796693F7}.Release|ARM64.ActiveCfg = Release|ARM64
- {FAE57101-F0EE-46CB-986D-E19A796693F7}.Release|ARM64.Build.0 = Release|ARM64
- - {FAE57101-F0EE-46CB-986D-E19A796693F7}.Release|ARM.ActiveCfg = Release|ARM
- - {FAE57101-F0EE-46CB-986D-E19A796693F7}.Release|ARM.Build.0 = Release|ARM
- {3B0A10FB-7CF3-4A91-9767-3BA6FEDE7FFE}.Debug|x64.ActiveCfg = Debug|x64
- {3B0A10FB-7CF3-4A91-9767-3BA6FEDE7FFE}.Debug|x64.Build.0 = Debug|x64
- {3B0A10FB-7CF3-4A91-9767-3BA6FEDE7FFE}.Debug|x86.ActiveCfg = Debug|Win32
- @@ -124,12 +100,8 @@ Global
- {3B0A10FB-7CF3-4A91-9767-3BA6FEDE7FFE}.Release|x86.Build.0 = Release|Win32
- {3B0A10FB-7CF3-4A91-9767-3BA6FEDE7FFE}.Debug|ARM64.ActiveCfg = Debug|ARM64
- {3B0A10FB-7CF3-4A91-9767-3BA6FEDE7FFE}.Debug|ARM64.Build.0 = Debug|ARM64
- - {3B0A10FB-7CF3-4A91-9767-3BA6FEDE7FFE}.Debug|ARM.ActiveCfg = Debug|ARM
- - {3B0A10FB-7CF3-4A91-9767-3BA6FEDE7FFE}.Debug|ARM.Build.0 = Debug|ARM
- {3B0A10FB-7CF3-4A91-9767-3BA6FEDE7FFE}.Release|ARM64.ActiveCfg = Release|ARM64
- {3B0A10FB-7CF3-4A91-9767-3BA6FEDE7FFE}.Release|ARM64.Build.0 = Release|ARM64
- - {3B0A10FB-7CF3-4A91-9767-3BA6FEDE7FFE}.Release|ARM.ActiveCfg = Release|ARM
- - {3B0A10FB-7CF3-4A91-9767-3BA6FEDE7FFE}.Release|ARM.Build.0 = Release|ARM
- EndGlobalSection
- GlobalSection(SolutionProperties) = preSolution
- diff --git a/build.vc19/nfs41_driver/nfs41_driver.vcxproj b/build.vc19/nfs41_driver/nfs41_driver.vcxproj
- index 0affe23..fd46b2e 100644
- --- a/build.vc19/nfs41_driver/nfs41_driver.vcxproj
- +++ b/build.vc19/nfs41_driver/nfs41_driver.vcxproj
- @@ -17,14 +17,6 @@
- <Configuration>Release</Configuration>
- <Platform>x64</Platform>
- </ProjectConfiguration>
- - <ProjectConfiguration Include="Debug|ARM">
- - <Configuration>Debug</Configuration>
- - <Platform>ARM</Platform>
- - </ProjectConfiguration>
- - <ProjectConfiguration Include="Release|ARM">
- - <Configuration>Release</Configuration>
- - <Platform>ARM</Platform>
- - </ProjectConfiguration>
- <ProjectConfiguration Include="Debug|ARM64">
- <Configuration>Debug</Configuration>
- <Platform>ARM64</Platform>
- @@ -73,20 +65,6 @@
- <ConfigurationType>Driver</ConfigurationType>
- <DriverType>WDM</DriverType>
- </PropertyGroup>
- - <PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Debug|ARM'" Label="Configuration">
- - <TargetVersion>Windows10</TargetVersion>
- - <UseDebugLibraries>true</UseDebugLibraries>
- - <PlatformToolset>WindowsKernelModeDriver10.0</PlatformToolset>
- - <ConfigurationType>Driver</ConfigurationType>
- - <DriverType>WDM</DriverType>
- - </PropertyGroup>
- - <PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Release|ARM'" Label="Configuration">
- - <TargetVersion>Windows10</TargetVersion>
- - <UseDebugLibraries>false</UseDebugLibraries>
- - <PlatformToolset>WindowsKernelModeDriver10.0</PlatformToolset>
- - <ConfigurationType>Driver</ConfigurationType>
- - <DriverType>WDM</DriverType>
- - </PropertyGroup>
- <PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Debug|ARM64'" Label="Configuration">
- <TargetVersion>Windows10</TargetVersion>
- <UseDebugLibraries>true</UseDebugLibraries>
- @@ -121,12 +99,6 @@
- <PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Release|x64'">
- <DebuggerFlavor>DbgengKernelDebugger</DebuggerFlavor>
- </PropertyGroup>
- - <PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Debug|ARM'">
- - <DebuggerFlavor>DbgengKernelDebugger</DebuggerFlavor>
- - </PropertyGroup>
- - <PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Release|ARM'">
- - <DebuggerFlavor>DbgengKernelDebugger</DebuggerFlavor>
- - </PropertyGroup>
- <PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Debug|ARM64'">
- <DebuggerFlavor>DbgengKernelDebugger</DebuggerFlavor>
- </PropertyGroup>
- @@ -195,34 +167,6 @@
- <FileDigestAlgorithm>sha256</FileDigestAlgorithm>
- </DriverSign>
- </ItemDefinitionGroup>
- - <ItemDefinitionGroup Condition="'$(Configuration)|$(Platform)'=='Debug|ARM'">
- - <ClCompile>
- - <AdditionalIncludeDirectories>..\..\include;..\..\dll;..\..;$(DDK_INC_PATH);%(AdditionalIncludeDirectories)</AdditionalIncludeDirectories>
- - <WarningLevel>Level4</WarningLevel>
- - <Optimization>Disabled</Optimization>
- - <PreprocessorDefinitions>EXPLODE_POOLTAGS;MONOLITHIC_MINIRDR;_DEBUG;%(PreprocessorDefinitions)</PreprocessorDefinitions>
- - <LanguageStandard_C>stdc17</LanguageStandard_C>
- - <StringPooling>true</StringPooling>
- - <AdditionalOptions>/std:c17 /Zc:preprocessor- /kernel /wd4100 /wd4201 /wd5104</AdditionalOptions>
- - </ClCompile>
- - <Link>
- - <AdditionalDependencies>$(DDK_LIB_PATH)\ntoskrnl.lib;$(DDK_LIB_PATH)\hal.lib;$(DDK_LIB_PATH)\BufferOverflowfastfailK.lib;$(DDK_LIB_PATH)\ksecdd.lib;$(DDK_LIB_PATH)\rxce.lib;$(DDK_LIB_PATH)\rdbsslib.lib</AdditionalDependencies>
- - </Link>
- - </ItemDefinitionGroup>
- - <ItemDefinitionGroup Condition="'$(Configuration)|$(Platform)'=='Release|ARM'">
- - <ClCompile>
- - <AdditionalIncludeDirectories>..\..\include;..\..\dll;..\..;$(DDK_INC_PATH);%(AdditionalIncludeDirectories)</AdditionalIncludeDirectories>
- - <WarningLevel>Level4</WarningLevel>
- - <Optimization>MaxSpeed</Optimization>
- - <PreprocessorDefinitions>EXPLODE_POOLTAGS;MONOLITHIC_MINIRDR;NDEBUG;%(PreprocessorDefinitions)</PreprocessorDefinitions>
- - <LanguageStandard_C>stdc17</LanguageStandard_C>
- - <StringPooling>true</StringPooling>
- - <AdditionalOptions>/std:c17 /Zc:preprocessor- /kernel /wd4100 /wd4201 /wd5104</AdditionalOptions>
- - </ClCompile>
- - <Link>
- - <AdditionalDependencies>$(DDK_LIB_PATH)\ntoskrnl.lib;$(DDK_LIB_PATH)\hal.lib;$(DDK_LIB_PATH)\BufferOverflowfastfailK.lib;$(DDK_LIB_PATH)\ksecdd.lib;$(DDK_LIB_PATH)\rxce.lib;$(DDK_LIB_PATH)\rdbsslib.lib</AdditionalDependencies>
- - </Link>
- - </ItemDefinitionGroup>
- <ItemDefinitionGroup Condition="'$(Configuration)|$(Platform)'=='Debug|x64'">
- <ClCompile>
- <AdditionalIncludeDirectories>..\..\include;..\..\dll;..\..;$(DDK_INC_PATH);%(AdditionalIncludeDirectories)</AdditionalIncludeDirectories>
- --
- 2.45.1
- From 0286fd087048fb3b6ab1da3a86f9b35d93d0518d Mon Sep 17 00:00:00 2001
- From: Roland Mainz <roland.mainz@nrubsig.org>
- Date: Tue, 28 Jan 2025 11:35:09 +0100
- Subject: [PATCH 2/7] build.vc19: Set OmitFramePointers=false for accurate
- drmemory stack traces
- Set OmitFramePointers=false for accurate drmemory stack traces
- Signed-off-by: Cedric Blancher <cedric.blancher@gmail.com>
- ---
- build.vc19/libtirpc/libtirpc.vcxproj | 2 ++
- build.vc19/nfsd/nfsd.vcxproj | 2 ++
- 2 files changed, 4 insertions(+)
- diff --git a/build.vc19/libtirpc/libtirpc.vcxproj b/build.vc19/libtirpc/libtirpc.vcxproj
- index 2da4efa..3e79ad7 100644
- --- a/build.vc19/libtirpc/libtirpc.vcxproj
- +++ b/build.vc19/libtirpc/libtirpc.vcxproj
- @@ -152,6 +152,7 @@
- <RuntimeLibrary>MultiThreadedDebugDLL</RuntimeLibrary>
- <AdditionalOptions>/wd4100 /wd4131 /wd4389</AdditionalOptions>
- <SupportJustMyCode>false</SupportJustMyCode>
- + <OmitFramePointers>false</OmitFramePointers>
- </ClCompile>
- <Link>
- <SubSystem>Windows</SubSystem>
- @@ -223,6 +224,7 @@
- <BufferSecurityCheck>false</BufferSecurityCheck>
- <RuntimeLibrary>MultiThreadedDLL</RuntimeLibrary>
- <AdditionalOptions>/wd4100 /wd4131 /wd4389</AdditionalOptions>
- + <OmitFramePointers>false</OmitFramePointers>
- </ClCompile>
- <Link>
- <SubSystem>Windows</SubSystem>
- diff --git a/build.vc19/nfsd/nfsd.vcxproj b/build.vc19/nfsd/nfsd.vcxproj
- index 5551617..51bbba0 100644
- --- a/build.vc19/nfsd/nfsd.vcxproj
- +++ b/build.vc19/nfsd/nfsd.vcxproj
- @@ -157,6 +157,7 @@
- <RuntimeLibrary>MultiThreadedDebugDLL</RuntimeLibrary>
- <AdditionalOptions>/wd4100</AdditionalOptions>
- <SupportJustMyCode>false</SupportJustMyCode>
- + <OmitFramePointers>false</OmitFramePointers>
- </ClCompile>
- <Link>
- <SubSystem>Console</SubSystem>
- @@ -225,6 +226,7 @@
- <StringPooling>true</StringPooling>
- <RuntimeLibrary>MultiThreadedDLL</RuntimeLibrary>
- <AdditionalOptions>/wd4100</AdditionalOptions>
- + <OmitFramePointers>false</OmitFramePointers>
- </ClCompile>
- <Link>
- <SubSystem>Console</SubSystem>
- --
- 2.45.1
- From 33fa4a2b642702f9f93182e92bcc4c63ac4da202 Mon Sep 17 00:00:00 2001
- From: Roland Mainz <roland.mainz@nrubsig.org>
- Date: Tue, 28 Jan 2025 11:47:25 +0100
- Subject: [PATCH 3/7] build.vc19: Sync "Release" build options across all
- platform
- Sync "Release" build options across all platform, e.g. use this on all
- "Release" builds:
- Optimization=MaxSpeed
- IntrinsicFunctions=true
- WholeProgramOptimization=true
- Signed-off-by: Cedric Blancher <cedric.blancher@gmail.com>
- ---
- build.vc19/nfsd/nfsd.vcxproj | 4 +++-
- 1 file changed, 3 insertions(+), 1 deletion(-)
- diff --git a/build.vc19/nfsd/nfsd.vcxproj b/build.vc19/nfsd/nfsd.vcxproj
- index 51bbba0..50fd24b 100644
- --- a/build.vc19/nfsd/nfsd.vcxproj
- +++ b/build.vc19/nfsd/nfsd.vcxproj
- @@ -170,7 +170,7 @@
- <PrecompiledHeader>
- </PrecompiledHeader>
- <WarningLevel>Level4</WarningLevel>
- - <Optimization>Disabled</Optimization>
- + <Optimization>MaxSpeed</Optimization>
- <PreprocessorDefinitions>WIN32_LEAN_AND_MEAN;FD_SETSIZE=1024;INET6;NO_CB_4_KRB5P;STANDALONE_NFSD;_CRT_SECURE_NO_WARNINGS;_WINSOCK_DEPRECATED_NO_WARNINGS;WIN32;_CRT_STDIO_ISO_WIDE_SPECIFIERS=1;UNICODE;_UNICODE;_DEBUG;_CONSOLE;%(PreprocessorDefinitions)</PreprocessorDefinitions>
- <AdditionalIncludeDirectories>..\..\include;..\..\libtirpc\tirpc;..\..\dll;..\..;$(IntermediateOutputPath);%(AdditionalIncludeDirectories)</AdditionalIncludeDirectories>
- <LanguageStandard_C>stdc17</LanguageStandard_C>
- @@ -180,6 +180,8 @@
- <RuntimeLibrary>MultiThreadedDebugDLL</RuntimeLibrary>
- <AdditionalOptions>/wd4100</AdditionalOptions>
- <SupportJustMyCode>false</SupportJustMyCode>
- + <IntrinsicFunctions>true</IntrinsicFunctions>
- + <WholeProgramOptimization>true</WholeProgramOptimization>
- </ClCompile>
- <Link>
- <SubSystem>Console</SubSystem>
- --
- 2.45.1
- From f3e4910c8b25cf9d49d9e659073dd443464cfead Mon Sep 17 00:00:00 2001
- From: Roland Mainz <roland.mainz@nrubsig.org>
- Date: Tue, 28 Jan 2025 14:50:13 +0100
- Subject: [PATCH 4/7] daemon,include,sys: Add support for volume query
- |FileFsSectorSizeInformation|
- Add support for volume query |FileFsSectorSizeInformation|,
- because |FILE_FS_SECTOR_SIZE_INFORMATION.Flags| field bit
- |SSINFO_FLAGS_NO_SEEK_PENALTY| is required by Cygwin, MSYS2, mingw
- etc for sparse file support.
- Signed-off-by: Cedric Blancher <cedric.blancher@gmail.com>
- ---
- daemon/upcall.h | 3 ++-
- daemon/volume.c | 22 ++++++++++++++++++++++
- include/from_kernel.h | 17 +++++++++++++++++
- sys/nfs41sys_volinfo.c | 1 +
- 4 files changed, 42 insertions(+), 1 deletion(-)
- diff --git a/daemon/upcall.h b/daemon/upcall.h
- index 97d60f3..b17ec71 100644
- --- a/daemon/upcall.h
- +++ b/daemon/upcall.h
- @@ -169,8 +169,9 @@ typedef struct __volume_upcall_args {
- int len;
- union {
- FILE_FS_SIZE_INFORMATION size;
- - FILE_FS_FULL_SIZE_INFORMATION fullsize;
- FILE_FS_ATTRIBUTE_INFORMATION attribute;
- + FILE_FS_FULL_SIZE_INFORMATION fullsize;
- + FILE_FS_SECTOR_SIZE_INFORMATION sector_size;
- } info;
- } volume_upcall_args;
- diff --git a/daemon/volume.c b/daemon/volume.c
- index e019b61..406cddf 100644
- --- a/daemon/volume.c
- +++ b/daemon/volume.c
- @@ -148,6 +148,28 @@ static int handle_volume(void *daemon_context, nfs41_upcall *upcall)
- &args->info.attribute);
- break;
- + case FileFsSectorSizeInformation:
- + args->len = sizeof(args->info.sector_size);
- +
- + args->info.sector_size.LogicalBytesPerSector = BYTES_PER_SECTOR;
- + args->info.sector_size.PhysicalBytesPerSectorForAtomicity =
- + BYTES_PER_SECTOR;
- + args->info.sector_size.PhysicalBytesPerSectorForPerformance =
- + BYTES_PER_SECTOR;
- + args->info.sector_size.FileSystemEffectivePhysicalBytesPerSectorForAtomicity =
- + BYTES_PER_SECTOR;
- + /*
- + * |SSINFO_FLAGS_NO_SEEK_PENALTY| is required by
- + * Cygwin/MSYS2/mingw to support sparse files
- + */
- + args->info.sector_size.Flags =
- + SSINFO_FLAGS_ALIGNED_DEVICE |
- + SSINFO_FLAGS_PARTITION_ALIGNED_ON_DEVICE |
- + SSINFO_FLAGS_NO_SEEK_PENALTY;
- + args->info.sector_size.ByteOffsetForSectorAlignment = 0;
- + args->info.sector_size.ByteOffsetForPartitionAlignment = 0;
- + break;
- +
- default:
- eprintf("unhandled fs query class %d\n", args->query);
- status = ERROR_INVALID_PARAMETER;
- diff --git a/include/from_kernel.h b/include/from_kernel.h
- index ebd89d0..3c754c9 100644
- --- a/include/from_kernel.h
- +++ b/include/from_kernel.h
- @@ -378,6 +378,23 @@ typedef struct _FILE_FS_FULL_SIZE_INFORMATION {
- ULONG BytesPerSector;
- } FILE_FS_FULL_SIZE_INFORMATION, *PFILE_FS_FULL_SIZE_INFORMATION;
- +#define SSINFO_FLAGS_ALIGNED_DEVICE 0x00000001
- +#define SSINFO_FLAGS_PARTITION_ALIGNED_ON_DEVICE 0x00000002
- +#define SSINFO_FLAGS_NO_SEEK_PENALTY 0x00000004
- +#define SSINFO_FLAGS_TRIM_ENABLED 0x00000008
- +#define SSINFO_FLAGS_BYTE_ADDRESSABLE 0x00000010
- +#define SSINFO_OFFSET_UNKNOWN (0xffffffff)
- +
- +typedef struct _FILE_FS_SECTOR_SIZE_INFORMATION {
- + ULONG LogicalBytesPerSector;
- + ULONG PhysicalBytesPerSectorForAtomicity;
- + ULONG PhysicalBytesPerSectorForPerformance;
- + ULONG FileSystemEffectivePhysicalBytesPerSectorForAtomicity;
- + ULONG Flags;
- + ULONG ByteOffsetForSectorAlignment;
- + ULONG ByteOffsetForPartitionAlignment;
- +} FILE_FS_SECTOR_SIZE_INFORMATION, *PFILE_FS_SECTOR_SIZE_INFORMATION;
- +
- typedef struct _FILE_INTERNAL_INFORMATION {
- LARGE_INTEGER IndexNumber;
- } FILE_INTERNAL_INFORMATION, *PFILE_INTERNAL_INFORMATION;
- diff --git a/sys/nfs41sys_volinfo.c b/sys/nfs41sys_volinfo.c
- index a3efb33..d4a0eeb 100644
- --- a/sys/nfs41sys_volinfo.c
- +++ b/sys/nfs41sys_volinfo.c
- @@ -231,6 +231,7 @@ NTSTATUS nfs41_QueryVolumeInformation(
- /* else fall through and send the upcall */
- case FileFsSizeInformation:
- case FileFsFullSizeInformation:
- + case FileFsSectorSizeInformation:
- break;
- default:
- --
- 2.45.1
- From 5dadcc95d3dcf592cdcfbe1a47d51f28a8ed6eed Mon Sep 17 00:00:00 2001
- From: Roland Mainz <roland.mainz@nrubsig.org>
- Date: Tue, 28 Jan 2025 14:54:22 +0100
- Subject: [PATCH 5/7] tests: Add winfsinfo "getfilefssectorsizeinformation"
- subcmd
- Add winfsinfo "getfilefssectorsizeinformation" subcmd to do
- a |FileFsSectorSizeInformation| volume query.
- Signed-off-by: Cedric Blancher <cedric.blancher@gmail.com>
- ---
- tests/winfsinfo1/winfsinfo.c | 166 ++++++++++++++++++++++++++++++++---
- 1 file changed, 155 insertions(+), 11 deletions(-)
- diff --git a/tests/winfsinfo1/winfsinfo.c b/tests/winfsinfo1/winfsinfo.c
- index 06cbc2e..5decfe4 100644
- --- a/tests/winfsinfo1/winfsinfo.c
- +++ b/tests/winfsinfo1/winfsinfo.c
- @@ -147,6 +147,153 @@ done:
- return res;
- }
- +typedef struct _IO_STATUS_BLOCK {
- + union {
- + NTSTATUS Status;
- + PVOID Pointer;
- + } DUMMYUNIONNAME;
- + ULONG_PTR Information;
- +} IO_STATUS_BLOCK, *PIO_STATUS_BLOCK;
- +
- +#ifdef _WIN64
- +#define NTDLL_HAS_ZWQUERYVOLUMEINFORMATIONFILE 1
- +#endif
- +
- +#define SSINFO_FLAGS_ALIGNED_DEVICE 0x00000001
- +#define SSINFO_FLAGS_PARTITION_ALIGNED_ON_DEVICE 0x00000002
- +#define SSINFO_FLAGS_NO_SEEK_PENALTY 0x00000004
- +#define SSINFO_FLAGS_TRIM_ENABLED 0x00000008
- +#define SSINFO_FLAGS_BYTE_ADDRESSABLE 0x00000010
- +#define SSINFO_OFFSET_UNKNOWN (0xffffffff)
- +
- +typedef struct _FILE_FS_SECTOR_SIZE_INFORMATION {
- + ULONG LogicalBytesPerSector;
- + ULONG PhysicalBytesPerSectorForAtomicity;
- + ULONG PhysicalBytesPerSectorForPerformance;
- + ULONG FileSystemEffectivePhysicalBytesPerSectorForAtomicity;
- + ULONG Flags;
- + ULONG ByteOffsetForSectorAlignment;
- + ULONG ByteOffsetForPartitionAlignment;
- +} FILE_FS_SECTOR_SIZE_INFORMATION, *PFILE_FS_SECTOR_SIZE_INFORMATION;
- +
- +#define STATUS_SUCCESS ((NTSTATUS)0x00000000)
- +#define STATUS_NO_EAS_ON_FILE ((NTSTATUS)0xC0000052)
- +
- +typedef enum _FSINFOCLASS {
- + FileFsVolumeInformation = 1,
- + FileFsLabelInformation, // 2
- + FileFsSizeInformation, // 3
- + FileFsDeviceInformation, // 4
- + FileFsAttributeInformation, // 5
- + FileFsControlInformation, // 6
- + FileFsFullSizeInformation, // 7
- + FileFsObjectIdInformation, // 8
- + FileFsDriverPathInformation, // 9
- + FileFsVolumeFlagsInformation, // 10
- + FileFsSectorSizeInformation, // 11
- + FileFsDataCopyInformation, // 12
- + FileFsMetadataSizeInformation, // 13
- + FileFsFullSizeInformationEx, // 14
- + FileFsMaximumInformation
- +} FS_INFORMATION_CLASS, *PFS_INFORMATION_CLASS;
- +
- +#ifdef NTDLL_HAS_ZWQUERYVOLUMEINFORMATIONFILE
- +NTSYSAPI
- +NTSTATUS
- +ZwQueryVolumeInformationFile(
- + HANDLE FileHandle,
- + PIO_STATUS_BLOCK IoStatusBlock,
- + PVOID FsInformation,
- + ULONG Length,
- + FS_INFORMATION_CLASS FsInformationClass
- +);
- +
- +static
- +bool getfilefssectorsizeinformation(const char *progname, const char *filename)
- +{
- + int res = EXIT_FAILURE;
- +
- + HANDLE fileHandle = CreateFileA(filename,
- + GENERIC_READ, FILE_SHARE_READ, NULL, OPEN_EXISTING,
- + FILE_FLAG_BACKUP_SEMANTICS, NULL);
- + if (fileHandle == INVALID_HANDLE_VALUE) {
- + (void)fprintf(stderr,
- + "%s: Error opening file '%s'. Last error was %d.\n",
- + progname,
- + filename,
- + (int)GetLastError());
- + return EXIT_FAILURE;
- + }
- +
- + FILE_FS_SECTOR_SIZE_INFORMATION ffssi = { 0 };
- + NTSTATUS status;
- + IO_STATUS_BLOCK io;
- +
- + status = ZwQueryVolumeInformationFile(fileHandle, &io, &ffssi, sizeof ffssi,
- + FileFsSectorSizeInformation);
- +
- + switch (status) {
- + case STATUS_SUCCESS:
- + break;
- + default:
- + (void)fprintf(stderr, "ZwQueryVolumeInformationFile() failed with 0x%lx\n", (long)status);
- + res = EXIT_FAILURE;
- + goto done;
- + }
- +
- + (void)printf("(\n");
- + (void)printf("\tfilename='%s'\n", filename);
- +
- + (void)printf("\tLogicalBytesPerSector=%lu\n",
- + (unsigned long)ffssi.LogicalBytesPerSector);
- + (void)printf("\tPhysicalBytesPerSectorForAtomicity=%lu\n",
- + (unsigned long)ffssi.PhysicalBytesPerSectorForAtomicity);
- + (void)printf("\tPhysicalBytesPerSectorForPerformance=%lu\n",
- + (unsigned long)ffssi.PhysicalBytesPerSectorForPerformance);
- + (void)printf("\t"
- + "FileSystemEffectivePhysicalBytesPerSectorForAtomicity=%lu\n",
- + (unsigned long)ffssi.FileSystemEffectivePhysicalBytesPerSectorForAtomicity);
- +
- +
- + DWORD fssiflags = ffssi.Flags;
- +
- + (void)printf("\ttypeset -a Flags=(\n");
- +
- +#define TESTFSSI(s) \
- + if (fssiflags & (s)) { \
- + (void)puts("\t\t"#s); \
- + fssiflags &= ~(s); \
- + }
- + TESTFSSI(SSINFO_FLAGS_ALIGNED_DEVICE);
- + TESTFSSI(SSINFO_FLAGS_PARTITION_ALIGNED_ON_DEVICE);
- + TESTFSSI(SSINFO_FLAGS_NO_SEEK_PENALTY);
- + TESTFSSI(SSINFO_FLAGS_TRIM_ENABLED);
- + TESTFSSI(SSINFO_FLAGS_BYTE_ADDRESSABLE);
- +
- + (void)printf("\t)\n");
- +
- + /*
- + * print any leftover flags not covered by |TESTFBIA(FILE_*)|
- + * above
- + */
- + if (fssiflags) {
- + (void)printf("\tFlags=0x%lx\n", (long)fssiflags);
- + }
- +
- + (void)printf("\tByteOffsetForSectorAlignment=%lu\n",
- + (unsigned long)ffssi.ByteOffsetForSectorAlignment);
- + (void)printf("\tByteOffsetForPartitionAlignment=%lu\n",
- + (unsigned long)ffssi.ByteOffsetForPartitionAlignment);
- +
- + (void)printf(")\n");
- + res = EXIT_SUCCESS;
- +
- +done:
- + (void)CloseHandle(fileHandle);
- + return res;
- +}
- +#endif /* NTDLL_HAS_ZWQUERYVOLUMEINFORMATIONFILE */
- +
- static
- bool get_file_basic_info(const char *progname, const char *filename)
- @@ -642,17 +789,6 @@ typedef struct _FILE_FULL_EA_INFORMATION {
- CHAR EaName[1];
- } FILE_FULL_EA_INFORMATION, *PFILE_FULL_EA_INFORMATION;
- -typedef struct _IO_STATUS_BLOCK {
- - union {
- - NTSTATUS Status;
- - PVOID Pointer;
- - } DUMMYUNIONNAME;
- - ULONG_PTR Information;
- -} IO_STATUS_BLOCK, *PIO_STATUS_BLOCK;
- -
- -#define STATUS_SUCCESS ((NTSTATUS)0x00000000)
- -#define STATUS_NO_EAS_ON_FILE ((NTSTATUS)0xC0000052)
- -
- NTSYSAPI
- NTSTATUS
- NTAPI
- @@ -772,6 +908,9 @@ void usage(void)
- {
- (void)fprintf(stderr, "winfsinfo <"
- "getvolumeinfo|"
- +#ifdef NTDLL_HAS_ZWQUERYVOLUMEINFORMATIONFILE
- + "getfilefssectorsizeinformation|"
- +#endif /* NTDLL_HAS_ZWQUERYVOLUMEINFORMATIONFILE */
- "filebasicinfo|"
- "fileexinfostandard|"
- "filestandardinfo|"
- @@ -797,6 +936,11 @@ int main(int ac, char *av[])
- if (!strcmp(subcmd, "getvolumeinfo")) {
- return getvolumeinfo(av[0], av[2]);
- }
- +#ifdef NTDLL_HAS_ZWQUERYVOLUMEINFORMATIONFILE
- + if (!strcmp(subcmd, "getfilefssectorsizeinformation")) {
- + return getfilefssectorsizeinformation(av[0], av[2]);
- + }
- +#endif /* NTDLL_HAS_ZWQUERYVOLUMEINFORMATIONFILE */
- else if (!strcmp(subcmd, "filebasicinfo")) {
- return get_file_basic_info(av[0], av[2]);
- }
- --
- 2.45.1
- From 61aaf37140e4dcd8ee21958064771202c845c9d8 Mon Sep 17 00:00:00 2001
- From: Roland Mainz <roland.mainz@nrubsig.org>
- Date: Tue, 28 Jan 2025 15:10:43 +0100
- Subject: [PATCH 6/7] include,tests: winfsinfo should use include/from_kernel.h
- cleanup: winfsinfo should use the "include/from_kernel.h" header to
- avoid code duplication.
- Signed-off-by: Cedric Blancher <cedric.blancher@gmail.com>
- ---
- include/from_kernel.h | 4 +++
- tests/winfsinfo1/winfsinfo.c | 54 +-----------------------------------
- 2 files changed, 5 insertions(+), 53 deletions(-)
- diff --git a/include/from_kernel.h b/include/from_kernel.h
- index 3c754c9..c750239 100644
- --- a/include/from_kernel.h
- +++ b/include/from_kernel.h
- @@ -224,6 +224,10 @@ typedef struct _FILE_LINK_INFORMATION {
- WCHAR FileName[1];
- } FILE_LINK_INFORMATION, *PFILE_LINK_INFORMATION;
- +typedef struct _FILE_EA_INFORMATION {
- + ULONG EaSize;
- +} FILE_EA_INFORMATION, *PFILE_EA_INFORMATION;
- +
- typedef struct _FILE_FULL_EA_INFORMATION {
- ULONG NextEntryOffset;
- UCHAR Flags;
- diff --git a/tests/winfsinfo1/winfsinfo.c b/tests/winfsinfo1/winfsinfo.c
- index 5decfe4..e9c098f 100644
- --- a/tests/winfsinfo1/winfsinfo.c
- +++ b/tests/winfsinfo1/winfsinfo.c
- @@ -39,6 +39,7 @@
- #include <stdbool.h>
- #include "nfs_ea.h"
- +#include "from_kernel.h"
- static
- bool filetime2localsystemtime(const FILETIME *ft, SYSTEMTIME *st)
- @@ -159,44 +160,9 @@ typedef struct _IO_STATUS_BLOCK {
- #define NTDLL_HAS_ZWQUERYVOLUMEINFORMATIONFILE 1
- #endif
- -#define SSINFO_FLAGS_ALIGNED_DEVICE 0x00000001
- -#define SSINFO_FLAGS_PARTITION_ALIGNED_ON_DEVICE 0x00000002
- -#define SSINFO_FLAGS_NO_SEEK_PENALTY 0x00000004
- -#define SSINFO_FLAGS_TRIM_ENABLED 0x00000008
- -#define SSINFO_FLAGS_BYTE_ADDRESSABLE 0x00000010
- -#define SSINFO_OFFSET_UNKNOWN (0xffffffff)
- -
- -typedef struct _FILE_FS_SECTOR_SIZE_INFORMATION {
- - ULONG LogicalBytesPerSector;
- - ULONG PhysicalBytesPerSectorForAtomicity;
- - ULONG PhysicalBytesPerSectorForPerformance;
- - ULONG FileSystemEffectivePhysicalBytesPerSectorForAtomicity;
- - ULONG Flags;
- - ULONG ByteOffsetForSectorAlignment;
- - ULONG ByteOffsetForPartitionAlignment;
- -} FILE_FS_SECTOR_SIZE_INFORMATION, *PFILE_FS_SECTOR_SIZE_INFORMATION;
- -
- #define STATUS_SUCCESS ((NTSTATUS)0x00000000)
- #define STATUS_NO_EAS_ON_FILE ((NTSTATUS)0xC0000052)
- -typedef enum _FSINFOCLASS {
- - FileFsVolumeInformation = 1,
- - FileFsLabelInformation, // 2
- - FileFsSizeInformation, // 3
- - FileFsDeviceInformation, // 4
- - FileFsAttributeInformation, // 5
- - FileFsControlInformation, // 6
- - FileFsFullSizeInformation, // 7
- - FileFsObjectIdInformation, // 8
- - FileFsDriverPathInformation, // 9
- - FileFsVolumeFlagsInformation, // 10
- - FileFsSectorSizeInformation, // 11
- - FileFsDataCopyInformation, // 12
- - FileFsMetadataSizeInformation, // 13
- - FileFsFullSizeInformationEx, // 14
- - FileFsMaximumInformation
- -} FS_INFORMATION_CLASS, *PFS_INFORMATION_CLASS;
- -
- #ifdef NTDLL_HAS_ZWQUERYVOLUMEINFORMATIONFILE
- NTSYSAPI
- NTSTATUS
- @@ -771,24 +737,6 @@ done:
- return res;
- }
- -typedef struct _FILE_EA_INFORMATION {
- - ULONG EaSize;
- -} FILE_EA_INFORMATION, *PFILE_EA_INFORMATION;
- -
- -typedef struct _FILE_GET_EA_INFORMATION {
- - ULONG NextEntryOffset;
- - UCHAR EaNameLength;
- - CHAR EaName[1];
- -} FILE_GET_EA_INFORMATION, *PFILE_GET_EA_INFORMATION;
- -
- -typedef struct _FILE_FULL_EA_INFORMATION {
- - ULONG NextEntryOffset;
- - UCHAR Flags;
- - UCHAR EaNameLength;
- - USHORT EaValueLength;
- - CHAR EaName[1];
- -} FILE_FULL_EA_INFORMATION, *PFILE_FULL_EA_INFORMATION;
- -
- NTSYSAPI
- NTSTATUS
- NTAPI
- --
- 2.45.1
- From 48608572e113c4e95536e6f0e15fe2c7a58fd72a Mon Sep 17 00:00:00 2001
- From: Roland Mainz <roland.mainz@nrubsig.org>
- Date: Tue, 28 Jan 2025 16:35:55 +0100
- Subject: [PATCH 7/7] daemon: Enable |FILE_ATTRIBUTE_SPARSE_FILE| for regular
- files by default
- Enable |FILE_ATTRIBUTE_SPARSE_FILE| for regular files by default.
- Signed-off-by: Cedric Blancher <cedric.blancher@gmail.com>
- ---
- daemon/fileinfoutil.c | 31 ++++++++++++++++++++++++-------
- daemon/getattr.c | 28 ++++++++++++++++++++++------
- daemon/nfs41.h | 1 +
- daemon/nfs41_superblock.c | 6 +++++-
- daemon/open.c | 27 +++++++++++++++++++++------
- daemon/readdir.c | 22 +++++++++++++---------
- daemon/util.h | 8 ++++++++
- 7 files changed, 94 insertions(+), 29 deletions(-)
- diff --git a/daemon/fileinfoutil.c b/daemon/fileinfoutil.c
- index f86aa5a..93fbde5 100644
- --- a/daemon/fileinfoutil.c
- +++ b/daemon/fileinfoutil.c
- @@ -1,6 +1,6 @@
- /* NFSv4.1 client for Windows
- * Copyright (C) 2012 The Regents of the University of Michigan
- - * Copyright (C) 2023-2024 Roland Mainz <roland.mainz@nrubsig.org>
- + * Copyright (C) 2023-2025 Roland Mainz <roland.mainz@nrubsig.org>
- *
- * Olga Kornievskaia <aglo@umich.edu>
- * Casey Bodley <cbodley@umich.edu>
- @@ -35,6 +35,7 @@
- ULONG nfs_file_info_to_attributes(
- + IN const nfs41_superblock *restrict superblock,
- IN const nfs41_file_info *restrict info)
- {
- ULONG attrs = 0;
- @@ -46,7 +47,13 @@ ULONG nfs_file_info_to_attributes(
- if (info->symlink_dir)
- attrs |= FILE_ATTRIBUTE_DIRECTORY;
- }
- - else if (info->type != NF4REG) {
- + else if (info->type == NF4REG) {
- + if (superblock->sparse_file_support) {
- + /* FIXME: What about pNFS ? */
- + attrs |= FILE_ATTRIBUTE_SPARSE_FILE;
- + }
- + }
- + else {
- DPRINTF(1,
- ("nfs_file_info_to_attributes: "
- "unhandled file type %d, defaulting to NF4REG\n",
- @@ -75,6 +82,7 @@ ULONG nfs_file_info_to_attributes(
- void nfs_to_basic_info(
- IN const char *restrict name,
- + IN const nfs41_superblock *restrict superblock,
- IN const nfs41_file_info *restrict info,
- OUT PFILE_BASIC_INFO basic_out)
- {
- @@ -117,14 +125,17 @@ void nfs_to_basic_info(
- basic_out->ChangeTime.QuadPart = FILE_INFO_TIME_NOT_SET;
- }
- - basic_out->FileAttributes = nfs_file_info_to_attributes(info);
- + basic_out->FileAttributes =
- + nfs_file_info_to_attributes(superblock, info);
- }
- void nfs_to_standard_info(
- + IN const nfs41_superblock *restrict superblock,
- IN const nfs41_file_info *restrict info,
- OUT PFILE_STANDARD_INFO restrict std_out)
- {
- - const ULONG FileAttributes = nfs_file_info_to_attributes(info);
- + const ULONG FileAttributes =
- + nfs_file_info_to_attributes(superblock, info);
- EASSERT(info->attrmask.arr[0] & FATTR4_WORD0_SIZE);
- EASSERT((info->attrmask.count > 0) &&
- @@ -140,6 +151,7 @@ void nfs_to_standard_info(
- void nfs_to_network_openinfo(
- IN const char *restrict name,
- + IN const nfs41_superblock *restrict superblock,
- IN const nfs41_file_info *restrict info,
- OUT PFILE_NETWORK_OPEN_INFORMATION restrict net_out)
- {
- @@ -184,12 +196,14 @@ void nfs_to_network_openinfo(
- net_out->AllocationSize.QuadPart =
- net_out->EndOfFile.QuadPart = (LONGLONG)info->size;
- - net_out->FileAttributes = nfs_file_info_to_attributes(info);
- + net_out->FileAttributes =
- + nfs_file_info_to_attributes(superblock, info);
- }
- #ifdef NFS41_DRIVER_WSL_SUPPORT
- void nfs_to_stat_info(
- IN const char *restrict name,
- + IN const nfs41_superblock *restrict superblock,
- IN const nfs41_file_info *restrict info,
- OUT PFILE_STAT_INFORMATION restrict stat_out)
- {
- @@ -237,7 +251,8 @@ void nfs_to_stat_info(
- stat_out->AllocationSize.QuadPart =
- stat_out->EndOfFile.QuadPart = (LONGLONG)info->size;
- - stat_out->FileAttributes = nfs_file_info_to_attributes(info);
- + stat_out->FileAttributes =
- + nfs_file_info_to_attributes(superblock, info);
- stat_out->ReparseTag = (info->type == NF4LNK)?
- IO_REPARSE_TAG_SYMLINK : 0;
- @@ -250,6 +265,7 @@ void nfs_to_stat_info(
- void nfs_to_stat_lx_info(
- IN void *daemon_context,
- IN const char *restrict name,
- + IN const nfs41_superblock *restrict superblock,
- IN const nfs41_file_info *restrict info,
- OUT PFILE_STAT_LX_INFORMATION restrict stat_lx_out)
- {
- @@ -303,7 +319,8 @@ void nfs_to_stat_lx_info(
- stat_lx_out->AllocationSize.QuadPart =
- stat_lx_out->EndOfFile.QuadPart = (LONGLONG)info->size;
- - stat_lx_out->FileAttributes = nfs_file_info_to_attributes(info);
- + stat_lx_out->FileAttributes =
- + nfs_file_info_to_attributes(superblock, info);
- stat_lx_out->ReparseTag = (info->type == NF4LNK)?
- IO_REPARSE_TAG_SYMLINK : 0;
- diff --git a/daemon/getattr.c b/daemon/getattr.c
- index 8356062..95cb36e 100644
- --- a/daemon/getattr.c
- +++ b/daemon/getattr.c
- @@ -171,13 +171,20 @@ static int handle_getattr(void *daemon_context, nfs41_upcall *upcall)
- switch (args->query_class) {
- case FileBasicInformation:
- - nfs_to_basic_info(state->file.name.name, &info, &args->basic_info);
- + nfs_to_basic_info(state->file.name.name,
- + state->file.fh.superblock,
- + &info,
- + &args->basic_info);
- break;
- case FileStandardInformation:
- - nfs_to_standard_info(&info, &args->std_info);
- + nfs_to_standard_info(state->file.fh.superblock,
- + &info,
- + &args->std_info);
- break;
- case FileAttributeTagInformation:
- - args->tag_info.FileAttributes = nfs_file_info_to_attributes(&info);
- + args->tag_info.FileAttributes =
- + nfs_file_info_to_attributes(state->file.fh.superblock,
- + &info);
- args->tag_info.ReparseTag = info.type == NF4LNK ?
- IO_REPARSE_TAG_SYMLINK : 0;
- break;
- @@ -185,15 +192,24 @@ static int handle_getattr(void *daemon_context, nfs41_upcall *upcall)
- args->intr_info.IndexNumber.QuadPart = info.fileid;
- break;
- case FileNetworkOpenInformation:
- - nfs_to_network_openinfo(state->file.name.name, &info, &args->network_info);
- + nfs_to_network_openinfo(state->file.name.name,
- + state->file.fh.superblock,
- + &info,
- + &args->network_info);
- break;
- #ifdef NFS41_DRIVER_WSL_SUPPORT
- case FileStatInformation:
- - nfs_to_stat_info(state->file.name.name, &info, &args->stat_info);
- + nfs_to_stat_info(state->file.name.name,
- + state->file.fh.superblock,
- + &info,
- + &args->stat_info);
- break;
- case FileStatLxInformation:
- nfs_to_stat_lx_info(daemon_context,
- - state->file.name.name, &info, &args->stat_lx_info);
- + state->file.name.name,
- + state->file.fh.superblock,
- + &info,
- + &args->stat_lx_info);
- break;
- #endif /* NFS41_DRIVER_WSL_SUPPORT */
- default:
- diff --git a/daemon/nfs41.h b/daemon/nfs41.h
- index 5168901..38ede22 100644
- --- a/daemon/nfs41.h
- +++ b/daemon/nfs41.h
- @@ -58,6 +58,7 @@ typedef struct __nfs41_superblock {
- unsigned int ea_support : 1;
- unsigned int case_preserving : 1;
- unsigned int case_insensitive : 1;
- + unsigned int sparse_file_support : 1;
- /* variable filesystem attributes */
- uint64_t space_avail;
- diff --git a/daemon/nfs41_superblock.c b/daemon/nfs41_superblock.c
- index c30d0e2..0a8992b 100644
- --- a/daemon/nfs41_superblock.c
- +++ b/daemon/nfs41_superblock.c
- @@ -1,8 +1,10 @@
- /* NFSv4.1 client for Windows
- - * Copyright (C) 2012 The Regents of the University of Michigan
- + * Copyright (C) 2012 The Regents of the University of Michigan
- + * Copyright (C) 2023-2025 Roland Mainz <roland.mainz@nrubsig.org>
- *
- * Olga Kornievskaia <aglo@umich.edu>
- * Casey Bodley <cbodley@umich.edu>
- + * Roland Mainz <roland.mainz@nrubsig.org>
- *
- * This library is free software; you can redistribute it and/or modify it
- * under the terms of the GNU Lesser General Public License as published by
- @@ -122,6 +124,7 @@ static int get_superblock_attrs(
- superblock->ea_support = supports_named_attrs;
- superblock->case_preserving = info.case_preserving;
- superblock->case_insensitive = info.case_insensitive;
- + superblock->sparse_file_support = 1; /* always ON for now */
- if (bitmap_isset(&info.attrmask, 0, FATTR4_WORD0_CANSETTIME))
- superblock->cansettime = info.cansettime;
- @@ -167,6 +170,7 @@ void nfs41_superblock_fs_attributes(
- OUT PFILE_FS_ATTRIBUTE_INFORMATION FsAttrs)
- {
- FsAttrs->FileSystemAttributes = 0;
- + FsAttrs->FileSystemAttributes |= FILE_SUPPORTS_SPARSE_FILES;
- FsAttrs->FileSystemAttributes |= FILE_SUPPORTS_REMOTE_STORAGE;
- /* NFSv4 protocol uses Unicode by default */
- FsAttrs->FileSystemAttributes |= FILE_UNICODE_ON_DISK;
- diff --git a/daemon/open.c b/daemon/open.c
- index 1c8b568..58e1348 100644
- --- a/daemon/open.c
- +++ b/daemon/open.c
- @@ -778,8 +778,13 @@ static int handle_open(void *daemon_context, nfs41_upcall *upcall)
- status = map_symlink_errors(status);
- goto out_free_state;
- }
- - nfs_to_basic_info(state->file.name.name, &info, &args->basic_info);
- - nfs_to_standard_info(&info, &args->std_info);
- + nfs_to_basic_info(state->file.name.name,
- + state->file.fh.superblock,
- + &info,
- + &args->basic_info);
- + nfs_to_standard_info(state->file.fh.superblock,
- + &info,
- + &args->std_info);
- EASSERT((info.attrmask.count > 0) &&
- (info.attrmask.arr[0] & FATTR4_WORD0_FILEID));
- args->fileid = info.fileid;
- @@ -800,8 +805,13 @@ static int handle_open(void *daemon_context, nfs41_upcall *upcall)
- goto out_free_state;
- }
- - nfs_to_basic_info(state->file.name.name, &info, &args->basic_info);
- - nfs_to_standard_info(&info, &args->std_info);
- + nfs_to_basic_info(state->file.name.name,
- + state->file.fh.superblock,
- + &info,
- + &args->basic_info);
- + nfs_to_standard_info(state->file.fh.superblock,
- + &info,
- + &args->std_info);
- EASSERT((info.attrmask.count > 0) &&
- (info.attrmask.arr[0] & FATTR4_WORD0_FILEID));
- args->fileid = info.fileid;
- @@ -1039,8 +1049,13 @@ create_chgrp_out:
- }
- #endif /* NFS41_DRIVER_SETGID_NEWGRP_SUPPORT */
- - nfs_to_basic_info(state->file.name.name, &info, &args->basic_info);
- - nfs_to_standard_info(&info, &args->std_info);
- + nfs_to_basic_info(state->file.name.name,
- + state->file.fh.superblock,
- + &info,
- + &args->basic_info);
- + nfs_to_standard_info(state->file.fh.superblock,
- + &info,
- + &args->std_info);
- EASSERT((info.attrmask.count > 0) &&
- (info.attrmask.arr[0] & FATTR4_WORD0_FILEID));
- args->fileid = info.fileid;
- diff --git a/daemon/readdir.c b/daemon/readdir.c
- index fd7d257..e7f7706 100644
- --- a/daemon/readdir.c
- +++ b/daemon/readdir.c
- @@ -322,6 +322,7 @@ static uint32_t readdir_size_for_entry(
- static void readdir_copy_dir_info(
- IN nfs41_readdir_entry *entry,
- + IN const nfs41_superblock *restrict superblock,
- IN PFILE_DIR_INFO_UNION info)
- {
- info->fdi.FileIndex = (ULONG)entry->attr_info.fileid;
- @@ -372,8 +373,8 @@ static void readdir_copy_dir_info(
- info->fdi.EndOfFile.QuadPart =
- info->fdi.AllocationSize.QuadPart =
- entry->attr_info.size;
- - info->fdi.FileAttributes = nfs_file_info_to_attributes(
- - &entry->attr_info);
- + info->fdi.FileAttributes =
- + nfs_file_info_to_attributes(superblock, &entry->attr_info);
- }
- #ifndef NFS41_DRIVER_DISABLE_8DOT3_SHORTNAME_GENERATION
- @@ -393,9 +394,10 @@ static void readdir_copy_shortname(
- static void readdir_copy_full_dir_info(
- IN nfs41_readdir_entry *entry,
- + IN const nfs41_superblock *restrict superblock,
- IN PFILE_DIR_INFO_UNION info)
- {
- - readdir_copy_dir_info(entry, info);
- + readdir_copy_dir_info(entry, superblock, info);
- /* for files with the FILE_ATTRIBUTE_REPARSE_POINT attribute,
- * EaSize is used instead to specify its reparse tag. this makes
- * the 'dir' command to show files as <SYMLINK>, and triggers a
- @@ -408,9 +410,10 @@ static void readdir_copy_full_dir_info(
- static void readdir_copy_both_dir_info(
- IN nfs41_readdir_entry *entry,
- IN LPWSTR wname,
- + IN const nfs41_superblock *restrict superblock,
- IN PFILE_DIR_INFO_UNION info)
- {
- - readdir_copy_full_dir_info(entry, info);
- + readdir_copy_full_dir_info(entry, superblock, info);
- #ifdef NFS41_DRIVER_DISABLE_8DOT3_SHORTNAME_GENERATION
- info->fbdi.ShortName[0] = L'\0';
- info->fbdi.ShortNameLength = 0;
- @@ -512,6 +515,7 @@ static int readdir_copy_entry(
- WCHAR wname[NFS4_OPAQUE_LIMIT];
- uint32_t wname_len, wname_size, needed;
- PFILE_DIR_INFO_UNION info;
- + const nfs41_superblock *superblock = args->state->file.fh.superblock;
- wname_len = MultiByteToWideChar(CP_UTF8, MB_ERR_INVALID_CHARS,
- entry->name, entry->name_len, wname, NFS4_OPAQUE_LIMIT);
- @@ -552,28 +556,28 @@ static int readdir_copy_entry(
- info->fni.FileName, &info->fni.FileNameLength);
- break;
- case FileDirectoryInformation:
- - readdir_copy_dir_info(entry, info);
- + readdir_copy_dir_info(entry, superblock, info);
- readdir_copy_filename(wname, wname_size,
- info->fdi.FileName, &info->fdi.FileNameLength);
- break;
- case FileFullDirectoryInformation:
- - readdir_copy_full_dir_info(entry, info);
- + readdir_copy_full_dir_info(entry, superblock, info);
- readdir_copy_filename(wname, wname_size,
- info->ffdi.FileName, &info->ffdi.FileNameLength);
- break;
- case FileIdFullDirectoryInformation:
- - readdir_copy_full_dir_info(entry, info);
- + readdir_copy_full_dir_info(entry, superblock, info);
- info->fibdi.FileId.QuadPart = (LONGLONG)entry->attr_info.fileid;
- readdir_copy_filename(wname, wname_size,
- info->fifdi.FileName, &info->fifdi.FileNameLength);
- break;
- case FileBothDirectoryInformation:
- - readdir_copy_both_dir_info(entry, wname, info);
- + readdir_copy_both_dir_info(entry, wname, superblock, info);
- readdir_copy_filename(wname, wname_size,
- info->fbdi.FileName, &info->fbdi.FileNameLength);
- break;
- case FileIdBothDirectoryInformation:
- - readdir_copy_both_dir_info(entry, wname, info);
- + readdir_copy_both_dir_info(entry, wname, superblock, info);
- info->fibdi.FileId.QuadPart = (LONGLONG)entry->attr_info.fileid;
- readdir_copy_filename(wname, wname_size,
- info->fibdi.FileName, &info->fibdi.FileNameLength);
- diff --git a/daemon/util.h b/daemon/util.h
- index 46d64b8..a5d0d73 100644
- --- a/daemon/util.h
- +++ b/daemon/util.h
- @@ -33,6 +33,8 @@
- extern DWORD NFS41D_VERSION;
- struct __nfs41_session;
- struct __nfs41_write_verf;
- +typedef struct __nfs41_file_info nfs41_file_info;
- +typedef struct __nfs41_superblock nfs41_superblock;
- enum stable_how4;
- /*
- @@ -174,26 +176,32 @@ static __inline void open_delegation4_cpy(
- }
- ULONG nfs_file_info_to_attributes(
- + IN const nfs41_superblock *restrict superblock,
- IN const nfs41_file_info *restrict info);
- void nfs_to_basic_info(
- IN const char *restrict name,
- + IN const nfs41_superblock *restrict superblock,
- IN const nfs41_file_info *restrict info,
- OUT PFILE_BASIC_INFO restrict basic_out);
- void nfs_to_standard_info(
- + IN const nfs41_superblock *restrict superblock,
- IN const nfs41_file_info *restrict info,
- OUT PFILE_STANDARD_INFO restrict std_out);
- void nfs_to_network_openinfo(
- IN const char *restrict name,
- + IN const nfs41_superblock *restrict superblock,
- IN const nfs41_file_info *restrict info,
- OUT PFILE_NETWORK_OPEN_INFORMATION restrict std_out);
- #ifdef NFS41_DRIVER_WSL_SUPPORT
- void nfs_to_stat_info(
- IN const char *restrict name,
- + IN const nfs41_superblock *restrict superblock,
- IN const nfs41_file_info *restrict info,
- OUT PFILE_STAT_INFORMATION restrict stat_out);
- void nfs_to_stat_lx_info(
- IN void *daemon_context,
- IN const char *restrict name,
- + IN const nfs41_superblock *restrict superblock,
- IN const nfs41_file_info *restrict info,
- OUT PFILE_STAT_LX_INFORMATION restrict stat_lx_out);
- #endif /* NFS41_DRIVER_WSL_SUPPORT */
- --
- 2.45.1
msnfs41client: Win32 flag |FILE_ATTRIBUTE_SPARSE_FILE| by default, volume query+winfsinfo+debug+misc, 2025-01-28
Posted by Anonymous on Tue 28th Jan 2025 15:50
raw | new post
Submit a correction or amendment below (click here to make a fresh posting)
After submitting an amendment, you'll be able to view the differences between the old and new posts easily.