GNU bug report logs -
#7082
24.0.50; Bug in src/doc.c (Fsnarf_documentation)
Previous Next
Reported by: Ari Roponen <ari.roponen <at> gmail.com>
Date: Tue, 21 Sep 2010 14:38:02 UTC
Severity: normal
Found in version 24.0.50
Done: Andreas Schwab <schwab <at> linux-m68k.org>
Bug is archived. No further changes may be made.
Full log
View this message in rfc822 format
[Message part 1 (text/plain, inline)]
Your message dated Tue, 21 Sep 2010 21:37:29 +0200
with message-id <m28w2ukhvq.fsf <at> igel.home>
and subject line Re: bug#7082: 24.0.50; Bug in src/doc.c (Fsnarf_documentation)
has caused the GNU bug report #7082,
regarding 24.0.50; Bug in src/doc.c (Fsnarf_documentation)
to be marked as done.
(If you believe you have received this mail in error, please contact
help-debbugs <at> gnu.org.)
--
7082: http://debbugs.gnu.org/cgi/bugreport.cgi?bug=7082
GNU Bug Tracking System
Contact help-debbugs <at> gnu.org with problems
[Message part 2 (message/rfc822, inline)]
Hi,
recently compiling Emacs has not worked for me. The compilation always
aborts with this error:
Loading emacs-lisp/float-sup...
Loading vc/vc-hooks...
Loading vc/ediff-hook...
Loading tooltip...
Finding pointers to doc strings...
/bin/sh: line 8: 10391 Segmentation fault (core dumped) LC_ALL=C `/bin/pwd`/temacs -batch -l loadup dump
make[1]: *** [emacs] Error 1
make[1]: Leaving directory `/usr/local/repos/emacs.git/src'
make: *** [src] Error 2
After some debugging, I may have found the cause. I added an assert to
Fsnarf_documentation in src/doc.c just before the memcpy and it failed:
Assertion `buf + filled < end' failed.
This means we should use memmove instead, as it can handle overlapping
regions properly.
2010-09-21 Ari Roponen <ari.roponen <at> gmail.com> (tiny change)
* doc.c (Fsnarf_documentation): Use memmove instead of memcpy as
the regions may overlap.
diff --git a/src/doc.c b/src/doc.c
index f8ab9d0..36f7c0e 100644
--- a/src/doc.c
+++ b/src/doc.c
@@ -678,7 +678,7 @@ the same file name is found in the `doc-directory'. */)
}
pos += end - buf;
filled -= end - buf;
- memcpy (buf, end, filled);
+ memmove (buf, end, filled);
}
emacs_close (fd);
return Qnil;
In GNU Emacs 24.0.50.1 (x86_64-unknown-linux-gnu, GTK+ Version 2.90.5)
of 2010-09-21 on arirop
Windowing system distributor `Fedora Project', version 11.0.10899905
configured using `configure '--with-x-toolkit=gtk3' '--with-imagemagick''
--
Ari Roponen
[Message part 3 (message/rfc822, inline)]
Ari Roponen <ari.roponen <at> gmail.com> writes:
> 2010-09-21 Ari Roponen <ari.roponen <at> gmail.com> (tiny change)
>
> * doc.c (Fsnarf_documentation): Use memmove instead of memcpy as
> the regions may overlap.
Thanks, installed.
Andreas.
--
Andreas Schwab, schwab <at> linux-m68k.org
GPG Key fingerprint = 58CA 54C7 6D53 942B 1756 01D3 44D5 214B 8276 4ED5
"And now for something completely different."
This bug report was last modified 14 years and 303 days ago.
Previous Next
GNU bug tracking system
Copyright (C) 1999 Darren O. Benham,
1997,2003 nCipher Corporation Ltd,
1994-97 Ian Jackson.