-
Notifications
You must be signed in to change notification settings - Fork 2.6k
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Better mmap() emulation #486
Conversation
It is not really helpful when a `git fetch` fails with the message: fatal: mmap failed: No error In the particular instance encountered by a colleague of yours truly, the Win32 error code was ERROR_COMMITMENT_LIMIT which means that the page file is not big enough. Let's make the message fatal: mmap failed: File too large instead, which is only marginally better, but which can be associated with the appropriate work-around: setting `core.packedGitWindowSize` to a relatively small value. Signed-off-by: Johannes Schindelin <[email protected]>
Often we are mmap()ing read-only. In those cases, it is wasteful to map in copy-on-write mode. Even worse: it can cause errors where we run out of space in the page file. So let's be extra careful to map files in read-only mode whenever possible. Signed-off-by: Johannes Schindelin <[email protected]>
On Windows, we have to emulate the fstat() call to fill out information that takes extra effort to obtain, such as the file permissions/type. If all we want is the file size, we can use the much cheaper GetFileSizeEx() function (available since Windows XP). Suggested by Philip Kelley. Signed-off-by: Johannes Schindelin <[email protected]>
hmap = CreateFileMapping((HANDLE)_get_osfhandle(fd), NULL, | ||
PAGE_WRITECOPY, 0, 0, NULL); | ||
hmap = CreateFileMapping(osfhandle, NULL, | ||
prot == PROT_READ ? PAGE_READONLY : PAGE_WRITECOPY, 0, 0, NULL); |
This comment was marked as off-topic.
This comment was marked as off-topic.
Sorry, something went wrong.
This comment was marked as off-topic.
This comment was marked as off-topic.
Sorry, something went wrong.
This comment was marked as off-topic.
This comment was marked as off-topic.
Sorry, something went wrong.
This comment was marked as off-topic.
This comment was marked as off-topic.
Sorry, something went wrong.
This comment was marked as off-topic.
This comment was marked as off-topic.
Sorry, something went wrong.
Git for Windows » git #14 SUCCESS |
... aaaand the test suite passed here, too. |
@dscho Is this planned to be passed upstream? |
@csware yes, of course ;-) Thanks for the reminder. |
Kevin David provided access to his VM where a simple
git fetch
would produce this error output:The reason was that several bits of our
mmap()
emulation left room for improvement. This Pull Request tries to close the gap.