On 12/22/2025 8:57 AM, Jakob Bohm via Cygwin wrote:

As a longtime aficionado of these issues, Cygwin/MSYS2 stat() function is
inherently slower than native Linux/WSL stat() syscall, because the native
stat returns data already kept and cached for each file system inode/MFTE,
while the Cygwin emulation goes through a lot of hoops to synthesize similar
information from a variety of file system data .  The call path that uses
GetFileInformationByHandle() is the closest to a native fast implementation,
but unfortunately, most 21st century antivirus solutions tend to initiate a
full "scan file on open to prevent passing infected data to vulnerable
applications" cost when doing the proforma file open to get the file handle
needed for the GetFileInformationByHandle() call or other low risk checks .

Another set of hoops in the stat() code is the synthesis of a simulated set
of mode bits, which tends to bring in the entire ACL reinterpretation logic
as well as detection of various symlink approximations (it would be faster
to simply treat all "reparse points" as symlinks and add logic to readlink()
that deals with the various native types, but that would loose the ability
to create file system symlinks without the Administrator privilege of
creating the more dangerous system objects also named "symlink" ).

If the false triggering of AV scanning can be avoided, streamlining the
Cygwin stat() code could greatly speed up heavy users of stat() such as the
find and du commands .

Thank you, Jakob!  That gives me some interesting ideas.  First, one of my
mount lines indicates noacl, so I may be avoiding that cost.  (I am still a
little confused about having two mount lines and wonder which one takes
precedence (or some combination?).)  Concerning antivirus, maybe I can turn it
off for that drive.  It stores only tings I explicitly put there, which should
not need scanning for safety.

Regards - Eliot

--
Problem reports:      https://cygwin.com/problems.html
FAQ:                  https://cygwin.com/faq/
Documentation:        https://cygwin.com/docs.html
Unsubscribe info:     https://cygwin.com/ml/#unsubscribe-simple

Reply via email to