delorie.com/archives/browse.cgi | search |
X-Recipient: | archive-cygwin AT delorie DOT com |
DomainKey-Signature: | a=rsa-sha1; c=nofws; d=sourceware.org; h=list-id |
:list-unsubscribe:list-subscribe:list-archive:list-post | |
:list-help:sender:message-id:date:from:mime-version:to:subject | |
:references:in-reply-to:content-type:content-transfer-encoding; | |
q=dns; s=default; b=hS9ykV1uLn8jRu2K0gqHvw6BYMp1Udb6mKacNSDnOmY | |
auJc2po79/FmHoGDNyIYaUOYasyG+Vz0CmQmZq8I44vusiahoITabKfwCKmX280p | |
bkJBoYddAfqD9f89b1JOXYZUWW8AyUsxlfXCmPiTYfUll+HVYbp1f3ZS2EDQe4MM | |
= | |
DKIM-Signature: | v=1; a=rsa-sha1; c=relaxed; d=sourceware.org; h=list-id |
:list-unsubscribe:list-subscribe:list-archive:list-post | |
:list-help:sender:message-id:date:from:mime-version:to:subject | |
:references:in-reply-to:content-type:content-transfer-encoding; | |
s=default; bh=BW5C3hwDThfnDxd7zKeCG7J6ozA=; b=ka3ElWa+2KHQ7C/3M | |
NLhpoxzEY/KF5QBqn6wca+1Pw5wikjIIVmIMj1OXl9TnMDpQ+XnCqEJnwWsu3R6E | |
Q5ULeUsd21yGt26/B+8AAShbAOdlN8r349QufydCcbLCaR+bkw2HAox9k0nn+IAe | |
EnEyS3ReX0C9iRrMRUjoiihLA4= | |
Mailing-List: | contact cygwin-help AT cygwin DOT com; run by ezmlm |
List-Id: | <cygwin.cygwin.com> |
List-Subscribe: | <mailto:cygwin-subscribe AT cygwin DOT com> |
List-Archive: | <http://sourceware.org/ml/cygwin/> |
List-Post: | <mailto:cygwin AT cygwin DOT com> |
List-Help: | <mailto:cygwin-help AT cygwin DOT com>, <http://sourceware.org/ml/#faqs> |
Sender: | cygwin-owner AT cygwin DOT com |
Mail-Followup-To: | cygwin AT cygwin DOT com |
Delivered-To: | mailing list cygwin AT cygwin DOT com |
Authentication-Results: | sourceware.org; auth=none |
X-Virus-Found: | No |
X-Spam-SWARE-Status: | No, score=1.3 required=5.0 tests=AWL,BAYES_50,SPF_HELO_PASS,SPF_PASS,T_RP_MATCHES_RCVD,URIBL_BLACK autolearn=no version=3.3.2 |
X-HELO: | limerock02.mail.cornell.edu |
X-CornellRouted: | This message has been Routed already. |
Message-ID: | <53A2E189.9080203@cornell.edu> |
Date: | Thu, 19 Jun 2014 09:11:37 -0400 |
From: | Ken Brown <kbrown AT cornell DOT edu> |
User-Agent: | Mozilla/5.0 (Windows NT 6.1; WOW64; rv:24.0) Gecko/20100101 Thunderbird/24.6.0 |
MIME-Version: | 1.0 |
To: | cygwin AT cygwin DOT com |
Subject: | Re: bzr emacs(24.4.50.1) crashes when using auto-revert-tail-mode |
References: | <86mwda6yv6 DOT fsf AT w2139spb DOT ru DOT yotateam DOT com> <53A1D076 DOT 8090109 AT cornell DOT edu> |
In-Reply-To: | <53A1D076.8090109@cornell.edu> |
X-IsSubscribed: | yes |
On 6/18/2014 1:46 PM, Ken Brown wrote: > On 6/18/2014 11:06 AM, Filipp Gunbin wrote: >> I'm not sure whether this is Cygwin-specific, but I'm not able to test >> it on other OS, so here are the steps to reproduce: >> >> emacs -Q >> C-x C-r <some_file> > > You mean C-x C-f > >> M-x auto-revert-tail-mode >> wait for few seconds -> emacs crashes > > I can confirm this, but on 32-bit Cygwin only; there's no crash on > 64-bit Cygwin. (This is a refreshing change from the emacs crashes > people have been reporting on 64-bit Cygwin.) > > Here's the backtrace: > > #0 0x00000000 in ?? () > No symbol table info available. > #1 0x610f842f in pthread_mutex::lock (this=0x0) > at /usr/src/debug/cygwin-1.7.30-1/winsup/cygwin/thread.cc:1745 > self = <optimized out> > result = <optimized out> > __PRETTY_FUNCTION__ = "int pthread_mutex::lock()" > #2 0x00000201 in ?? () > No symbol table info available. > > Lisp Backtrace: > "gfile-add-watch" (0x288dc8) > "file-notify-add-watch" (0x2890c8) > "byte-code" (0x289340) > "auto-revert-notify-add-watch" (0x289778) > "auto-revert-buffers" (0x289b4c) > "apply" (0x289b48) > "byte-code" (0x289dc0) > "timer-event-handler" (0x28a1fc) > > I'll look into this. In the meantime, you can work around it by > configuring --with-file-notification=no. I'm afraid I ran into a brick wall trying to debug this. I wanted to see what gfile-add-watch was doing, so I ran emacs under gdb with a breakpoint at Fgfile_add_watch and then a breakpoint at g_file_monitor (a Glib function called by Fgfile_add_watch). When I tried to step through this function, I hit an assertion violation in gdb. This is repeatable. A log of the gdb session is appended below. The problem occurs only on 32-bit Cygwin. On 64-bit Cygwin, I can step through Fgfile_add_watch without a problem. Filipp, do you want to try debugging this yourself? Maybe your debugging skills are better than mine. (You'll need to install glib2.0-debuginfo.) Ken $ gdb /usr/bin/emacs-w32.exe GNU gdb (GDB) 7.6.50.20130728-cvs (cygwin-special) [...] Reading symbols from /usr/bin/emacs-w32.exe...Reading symbols from /usr/lib/debug/usr/bin/emacs-w32.exe.dbg...done. done. (gdb) b Fgfile_add_watch Breakpoint 1 at 0x5f7a3f: file /usr/src/debug/emacs-24.3.91-2/src/gfilenotify.c, line 170. (gdb) r -Q Starting program: /usr/bin/emacs-w32.exe -Q [...] Breakpoint 1, Fgfile_add_watch (file=-2145740495, flags=13798510, callback=-2146880150) at /usr/src/debug/emacs-24.3.91-2/src/gfilenotify.c:170 170 GFileMonitorFlags gflags = G_FILE_MONITOR_NONE; (gdb) b g_file_monitor Breakpoint 2 at 0x6a357e50: file /usr/src/debug/glib2.0-2.38.2-2/gio/gfile.c, line 5338. (gdb) c Continuing. [...] Breakpoint 2, g_file_monitor (file=0x80061530, flags=(G_FILE_MONITOR_WATCH_MOUNTS | G_FILE_MONITOR_SEND_MOVED), cancellable=0x0, error=0x0) at /usr/src/debug/glib2.0-2.38.2-2/gio/gfile.c:5338 5338 { (gdb) n 5339 if (g_file_query_file_type (file, 0, cancellable) == G_FILE_TYPE_DIRECTORY) (gdb) n 5338 { (gdb) n 5339 if (g_file_query_file_type (file, 0, cancellable) == G_FILE_TYPE_DIRECTORY) (gdb) n 5340 return g_file_monitor_directory (file, (gdb) n 5339 if (g_file_query_file_type (file, 0, cancellable) == G_FILE_TYPE_DIRECTORY) (gdb) n 5341 flags & ~G_FILE_MONITOR_WATCH_HARD_LINKS, (gdb) n 5340 return g_file_monitor_directory (file, (gdb) n 5345 } (gdb) n 5340 return g_file_monitor_directory (file, (gdb) n g_file_monitor_directory (file=0x80061530, flags=(G_FILE_MONITOR_WATCH_MOUNTS | G_FILE_MONITOR_SEND_MOVED), cancellable=0x0, error=0x0) at /usr/src/debug/glib2.0-2.38.2-2/gio/gfile.c:5235 5235 { (gdb) n 5238 g_return_val_if_fail (G_IS_FILE (file), NULL); (gdb) n /netrel/src/gdb-7.6.50-4/gdb/infrun.c:1942: internal-error: resume: Assertion `pc_in_thread_step_range (pc, tp)' failed. A problem internal to GDB has been detected, further debugging may prove unreliable. Quit this debugging session? (y or n) y -- Problem reports: http://cygwin.com/problems.html FAQ: http://cygwin.com/faq/ Documentation: http://cygwin.com/docs.html Unsubscribe info: http://cygwin.com/ml/#unsubscribe-simple
webmaster | delorie software privacy |
Copyright © 2019 by DJ Delorie | Updated Jul 2019 |