WinFsp enables developers to write their own file systems (i.e. "Windows drives") as user mode programs and without any knowledge of Windows kernel programming.
It is similar to FUSE (Filesystem in Userspace) for Linux and other UNIX-like computers.
WinFsp 2023: Empowering Custom File Systems on Windows
Primary Purpose:
WinFsp 2023 is a system software designed to enable developers to create custom file systems on Windows computers as user-mode applications, eliminating the need for kernel programming knowledge. It offers functionality akin to FUSE but tailored for Windows environments.
Key Features:
Mature and Stable: Trusted by leading companies, WinFsp 2023 is robust with millions of installations, ensuring reliability and performance.
Semantically Correct: Ensures file system compatibility with NTFS, maintaining accurate semantics.
High Performance: Often outperforms competitors, matching the speed of NTFS in many scenarios.
Ease of Use: Features a comprehensive API for C, C++, .NET, and more, simplifying development.
Open Source Flexibility: Available under GPLv3 with commercial licensing options, offering transparency and adaptability.
Audience & Benefits:
Ideal for developers, software companies, cloud services, and financial institutions, WinFsp 2023 empowers the creation of custom file systems efficiently. Developers benefit from accessing standard Windows APIs, enabling seamless integration and deployment across various applications. The software's stability and performance make it a reliable choice for mission-critical environments.
WinFsp 2023 is a powerful tool that simplifies file system development on Windows, offering flexibility, speed, and ease of use to meet diverse project needs.
README
WinFsp · Windows File System Proxy
<i>WinFsp enables developers to write their own file systems (i.e. "Windows drives") as user mode programs and without any knowledge of Windows kernel programming. It is similar to FUSE (Filesystem in Userspace) for Linux and other UNIX-like computers.</i>
<a href="https://winfsp.dev"><b>winfsp.dev</b></a>
<a href="https://github.com/winfsp/winfsp/releases/latest"><img src="https://img.shields.io/github/release/winfsp/winfsp.svg?label=stable&style=for-the-badge&logo=data:image/svg%2bxml;base64,PHN2ZyB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHZpZXdCb3g9IjAgMCA0ODAgNDgwIj48cGF0aCBkPSJNMzg3LjAwMiAyMDEuMDAxQzM3Mi45OTggMTMyLjAwMiAzMTIuOTk4IDgwIDI0MCA4MGMtNTcuOTk4IDAtMTA3Ljk5OCAzMi45OTgtMTMyLjk5OCA4MS4wMDFDNDcuMDAyIDE2Ny4wMDIgMCAyMTcuOTk4IDAgMjgwYzAgNjUuOTk2IDUzLjk5OSAxMjAgMTIwIDEyMGgyNjBjNTUgMCAxMDAtNDUgMTAwLTEwMCAwLTUyLjk5OC00MC45OTYtOTYuMDAxLTkyLjk5OC05OC45OTl6TTIwOCAyNTJ2LTc2aDY0djc2aDY4TDI0MCAzNTIgMTQwIDI1Mmg2OHoiIGZpbGw9IiNmZmYiLz48L3N2Zz4=" /></a>
<a href="https://github.com/winfsp/winfsp/releases"><img src="https://img.shields.io/github/release/winfsp/winfsp/all.svg?label=latest&colorB=e52e4b&style=for-the-badge&logo=data:image/svg%2bxml;base64,PHN2ZyB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHZpZXdCb3g9IjAgMCA0ODAgNDgwIj48cGF0aCBkPSJNMzg3LjAwMiAyMDEuMDAxQzM3Mi45OTggMTMyLjAwMiAzMTIuOTk4IDgwIDI0MCA4MGMtNTcuOTk4IDAtMTA3Ljk5OCAzMi45OTgtMTMyLjk5OCA4MS4wMDFDNDcuMDAyIDE2Ny4wMDIgMCAyMTcuOTk4IDAgMjgwYzAgNjUuOTk2IDUzLjk5OSAxMjAgMTIwIDEyMGgyNjBjNTUgMCAxMDAtNDUgMTAwLTEwMCAwLTUyLjk5OC00MC45OTYtOTYuMDAxLTkyLjk5OC05OC45OTl6TTIwOCAyNTJ2LTc2aDY0djc2aDY4TDI0MCAzNTIgMTQwIDI1Mmg2OHoiIGZpbGw9IiNmZmYiLz48L3N2Zz4=" /></a>
<a href="https://chocolatey.org/packages/winfsp"><img src="https://img.shields.io/badge/choco-install%20winfsp-black.svg?style=for-the-badge" /></a>
<img src="doc/cap.gif" width="75%" height="75%" />
Overview
WinFsp is a platform that provides development and runtime support for custom file systems on Windows computers. Typically any information or storage may be organized and presented as a file system via WinFsp, with the benefit being that the information can be accessed via the standand Windows file API’s by any Windows application.
The core WinFsp consists of a kernel mode file system driver (FSD) and a user mode DLL. The FSD interfaces with the Windows kernel and handles all interactions necessary to present itself as a file system driver. The DLL interfaces with the FSD and presents an API that can be used to handle file system functions. For example, when an application attempts to open a file, the file system receives an Open call with the necessary information.
Using WinFsp to build a file system has many benefits:
Easy development: Developing kernel mode file systems for Windows is a notoriously difficult task. WinFsp makes file system development relatively painless. This explains how to build a file system.
Stability: Stable software without any known kernel mode crashes, resource leaks or similar problems. WinFsp owes this stability to its Design and its rigorous Testing Regime.
Correctness: Strives for file system correctness and compatibility with NTFS. For details see the Compatibility document.
Performance: Has excellent performance that rivals or exceeds that of NTFS in many file system scenarios. Read more about its Performance.
Wide support: Supports Windows 7 to Windows 11 and the x86, x64 and ARM64 architectures.
Flexible API: Includes Native, FUSE2, FUSE3 and .NET API's.
Shell integration: Provides facilities to integrate user mode file systems with the Windows shell. See the Service Architecture document.
Self-contained: Self-contained software without external dependencies.
Widely used: Used in many open-source and commercial applications with millions of installations (estimated: the WinFsp project does not track its users).
Flexible licensing: Available under the GPLv3 license with a special exception for Free/Libre and Open Source Software. A commercial license is also available. Please contact Bill Zissimopoulos \ for more details.
Installation
Download and run the WinFsp installer. In the installer select the option to install the "Developer" files. These include the MEMFS sample file system, but also header and library files that let you develop your own user-mode file system.
Launch a file system for testing
You can test WinFsp by launching MEMFS from the command line:
billziss@xps ⟩ ~ ⟩ net use X: \\memfs64\test
The command completed successfully.
billziss@xps ⟩ ~ ⟩ X:
billziss@xps ⟩ X:\ ⟩ echo "hello world" > hello.txt
billziss@xps ⟩ X:\ ⟩ dir
Directory: X:\
Mode LastWriteTime Length Name
---- ------------- ------ ----
-a---- 6/12/2022 5:15 PM 28 hello.txt
billziss@xps ⟩ X:\ ⟩ type hello.txt
hello world
billziss@xps ⟩ X:\ ⟩ cd ~
billziss@xps ⟩ ~ ⟩ net use X: /delete
X: was deleted successfully.
MEMFS (and all file systems that use the WinFsp Launcher as documented in the Service Architecture document) can also be launched from Explorer using the "Map Network Drive" functionality.