From: "Alex Riesen" <raa.lkml@gmail.com>
To: "Johannes Schindelin" <Johannes.Schindelin@gmx.de>
Cc: junkio@cox.net, git@vger.kernel.org
Subject: Re: [PATCH] Seek back to current filepos when mmap()ing with NO_MMAP
Date: Wed, 15 Nov 2006 20:06:01 +0100 [thread overview]
Message-ID: <81b0412b0611151106k45ee03ekd8a3a04173f618c3@mail.gmail.com> (raw)
In-Reply-To: <Pine.LNX.4.63.0611151727000.13772@wbgn013.biozentrum.uni-wuerzburg.de>
[-- Attachment #1: Type: text/plain, Size: 450 bytes --]
On 11/15/06, Johannes Schindelin <Johannes.Schindelin@gmx.de> wrote:
>
> "git-index-pack --fix-thin" relies on mmap() not changing the current
> file position (otherwise the pack will be corrupted when writing the
> final SHA1). Meet that expectation.
>
Thanks! I was wondering for some considerable time why the
hell t5500-fetch-pack fails.
BTW, I extended error handling in that mmap. Dunno why.
Signed-off-by: Alex Riesen <raa.lkml@gmail.com>
[-- Warning: decoded text below may be mangled, UTF-8 assumed --]
[-- Attachment #2: lseek-compatmmap.patch --]
[-- Type: text/x-diff; name="lseek-compatmmap.patch", Size: 1527 bytes --]
commit 40ed0644ca8d250f716f49a5c3e027aa2c1d3167
Author: Alex Riesen <raa.lkml@gmail.com>
Date: Wed Nov 15 19:55:06 2006 +0100
Seek back to current filepos when mmap()ing with NO_MMAP, eh improved
"git-index-pack --fix-thin" relies on mmap() not changing the current
file position (otherwise the pack will be corrupted when writing the
final SHA1). Meet that expectation.
Signed-off-by: Johannes Schindelin <Johannes.Schindelin@gmx.de>
Signed-off-by: Alex Riesen <raa.lkml@gmail.com>
diff --git a/compat/mmap.c b/compat/mmap.c
index 55cb120..c6d5cfe 100644
--- a/compat/mmap.c
+++ b/compat/mmap.c
@@ -6,7 +6,8 @@
void *gitfakemmap(void *start, size_t length, int prot , int flags, int fd, off_t offset)
{
- int n = 0;
+ int n = 0, err = 0;
+ off_t current_offset = lseek(fd, 0, SEEK_CUR);
if (start != NULL || !(flags & MAP_PRIVATE))
die("Invalid usage of gitfakemmap.");
@@ -18,8 +19,8 @@ void *gitfakemmap(void *start, size_t le
start = xmalloc(length);
if (start == NULL) {
- errno = ENOMEM;
- return MAP_FAILED;
+ err = ENOMEM;
+ goto unseek;
}
while (n < length) {
@@ -31,14 +32,22 @@ void *gitfakemmap(void *start, size_t le
}
if (count < 0) {
- free(start);
- errno = EACCES;
- return MAP_FAILED;
+ err = EACCES;
+ goto unseek;
}
n += count;
}
+unseek:
+ if (current_offset != lseek(fd, current_offset, SEEK_SET))
+ err = EINVAL;
+
+ if (err) {
+ free(start);
+ start = MAP_FAILED;
+ errno = err;
+ }
return start;
}
prev parent reply other threads:[~2006-11-15 19:06 UTC|newest]
Thread overview: 4+ messages / expand[flat|nested] mbox.gz Atom feed top
2006-11-15 16:27 [PATCH] Seek back to current filepos when mmap()ing with NO_MMAP Johannes Schindelin
2006-11-15 18:26 ` Morten Welinder
2006-11-15 18:32 ` Johannes Schindelin
2006-11-15 19:06 ` Alex Riesen [this message]
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=81b0412b0611151106k45ee03ekd8a3a04173f618c3@mail.gmail.com \
--to=raa.lkml@gmail.com \
--cc=Johannes.Schindelin@gmx.de \
--cc=git@vger.kernel.org \
--cc=junkio@cox.net \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).