From mboxrd@z Thu Jan 1 00:00:00 1970 Path: news.gmane.org!not-for-mail From: Eli Zaretskii Newsgroups: gmane.emacs.devel Subject: Re: Dynamic modules: MODULE_HANDLE_SIGNALS etc. Date: Sun, 03 Jan 2016 21:15:01 +0200 Message-ID: <83poxi8oga.fsf@gnu.org> References: <83mvu1x6t3.fsf@gnu.org> <56772054.8010401@cs.ucla.edu> <83zix4scgf.fsf@gnu.org> <5677DBC9.6030307@cs.ucla.edu> <83io3rst2r.fsf@gnu.org> <567841A6.4090408@cs.ucla.edu> <567844B9.2050308@dancol.org> <5678CD07.8080209@cs.ucla.edu> <5678D3AF.7030101@dancol.org> <5678D620.6070000@cs.ucla.edu> <83mvt2qxm1.fsf@gnu.org> <56797CD9.8010706@cs.ucla.edu> <8337uuqsux.fsf@gnu.org> <5679DC83.70405@cs.ucla.edu> <83oadhp2mj.fsf@gnu.org> <567AD556.6020202@cs.ucla.edu> <567AD766.3060608@dancol.org> <567B5DAB.2000900@cs.ucla.edu> <83fuyromig.fsf@gnu.org> <567C25B1.3020101@dancol.org> <56892FD6.8040708@dancol.org> <56894CE7.7090301@cs.ucla.edu> <8337uea8ix.fsf@gnu.org> <568958D8.5060505@dancol.org> <83ziwm8sv2.fsf@gnu.org> <56895F0F.3050904@dancol.org> <83wprq8riy.fsf@gnu.org> <5689675A.70500@dancol.org> <83twmu8pjj.fsf@gnu.org> <568970A8.8000305@dancol.org> Reply-To: Eli Zaretskii NNTP-Posting-Host: plane.gmane.org X-Trace: ger.gmane.org 1451848519 8376 80.91.229.3 (3 Jan 2016 19:15:19 GMT) X-Complaints-To: usenet@ger.gmane.org NNTP-Posting-Date: Sun, 3 Jan 2016 19:15:19 +0000 (UTC) Cc: eggert@cs.ucla.edu, Emacs-devel@gnu.org To: Daniel Colascione Original-X-From: emacs-devel-bounces+ged-emacs-devel=m.gmane.org@gnu.org Sun Jan 03 20:15:14 2016 Return-path: Envelope-to: ged-emacs-devel@m.gmane.org Original-Received: from lists.gnu.org ([208.118.235.17]) by plane.gmane.org with esmtp (Exim 4.69) (envelope-from ) id 1aFo7S-0005qw-Jy for ged-emacs-devel@m.gmane.org; Sun, 03 Jan 2016 20:15:10 +0100 Original-Received: from localhost ([::1]:42587 helo=lists.gnu.org) by lists.gnu.org with esmtp (Exim 4.71) (envelope-from ) id 1aFo7R-0001wu-JO for ged-emacs-devel@m.gmane.org; Sun, 03 Jan 2016 14:15:09 -0500 Original-Received: from eggs.gnu.org ([2001:4830:134:3::10]:43455) by lists.gnu.org with esmtp (Exim 4.71) (envelope-from ) id 1aFo7M-0001wa-TV for Emacs-devel@gnu.org; Sun, 03 Jan 2016 14:15:05 -0500 Original-Received: from Debian-exim by eggs.gnu.org with spam-scanned (Exim 4.71) (envelope-from ) id 1aFo7J-0008AW-NK for Emacs-devel@gnu.org; Sun, 03 Jan 2016 14:15:04 -0500 Original-Received: from fencepost.gnu.org ([2001:4830:134:3::e]:47195) by eggs.gnu.org with esmtp (Exim 4.71) (envelope-from ) id 1aFo7J-0008AJ-Kh; Sun, 03 Jan 2016 14:15:01 -0500 Original-Received: from 84.94.185.246.cable.012.net.il ([84.94.185.246]:2586 helo=HOME-C4E4A596F7) by fencepost.gnu.org with esmtpsa (TLS1.2:RSA_AES_128_CBC_SHA1:128) (Exim 4.82) (envelope-from ) id 1aFo7I-0008Mi-MU; Sun, 03 Jan 2016 14:15:01 -0500 In-reply-to: <568970A8.8000305@dancol.org> (message from Daniel Colascione on Sun, 3 Jan 2016 11:04:08 -0800) X-detected-operating-system: by eggs.gnu.org: GNU/Linux 2.2.x-3.x [generic] X-Received-From: 2001:4830:134:3::e X-BeenThere: emacs-devel@gnu.org X-Mailman-Version: 2.1.14 Precedence: list List-Id: "Emacs development discussions." List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , Errors-To: emacs-devel-bounces+ged-emacs-devel=m.gmane.org@gnu.org Original-Sender: emacs-devel-bounces+ged-emacs-devel=m.gmane.org@gnu.org Xref: news.gmane.org gmane.emacs.devel:197487 Archived-At: > Cc: eggert@cs.ucla.edu, Emacs-devel@gnu.org > From: Daniel Colascione > Date: Sun, 3 Jan 2016 11:04:08 -0800 > > > Yes, it is. You would like us to crash rather than try recovering. > > That is a very heavy price in Emacs. > > Why is it uniquely unacceptable in Emacs? Why do other programs that > fill the same niche not employ this strategy? Not many other programs run for so long and have so much precious data for their users. Besides, who says there are no other programs that do this? libsigsegv wasn't written as an academic exercise. > Why do we not try to mitigate NULL pointer dereferences (to which > all the same arguments apply)? We do: we catch SIGSEGV and try to save what can be salvaged. > >> My point isn't that memory leaks are disastrous. It's that the > >> consequences of this code weren't given due consideration at the time it > >> was committed. > > > > You have absolutely no evidence that this wasn't considered. It's > > factually incorrect. You don't have to know that it's incorrect, but > > I would expect you to give more credit to our collective knowledge and > > experience than you evidently do. > > I searched the mailing list and saw no discussion of the points I > raised. Who said that considerations must be in public discussions? On the contrary, I'd rather take the lack of discussions as an indication that this was considered and no one saw any problem with it. > >>> You are not objective, so you exaggerate the risks and dismiss the > >>> benefits. > >> > >> I disagree that there *are* significant benefits. > > > > Of course, you do. Like I said: your bias affects your judgment. > > So does yours. No, I acknowledge the risks. You don't acknowledge the benefits. > > It's not undefined behavior, not in practice. We know quite well what > > can and cannot happen. > > No you don't, because we can longjmp out of third-party code FUD. What "third-party code"? Any code we use in Emacs has its sources open for scrutiny. > > Anyway, saying that "unpleasant things can happen" _is_ FUD. I want > > to see a single bug report about these unpleasant things happening in > > real use, then I'll start thinking whether I should reconsider. > > And I want to see a real bug report about the stack overflow we're > trying to defend against. We've been through that already: if stack overflow never happens, the recovery code can never cause any problems. > The failure mode here wouldn't be obvious either: Emacs could just > silently crash, hang, or write a wrong byte or two to a file. Neither of which is a disaster. > You have no idea what might happen, which is especially concerning > because Emacs is frequently an internet-facing network program parsing > untrusted data. All I want is to take every measure to avoid losing work. Every other problem was already there before stack-overflow recovery was added.