bug-gnu-emacs
[Top][All Lists]
Advanced

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

bug#45159: 28.0.50; crash when no space on disk


From: Jean Louis
Subject: bug#45159: 28.0.50; crash when no space on disk
Date: Sat, 12 Dec 2020 04:36:20 +0300
User-agent: Mutt/2.0 (3d08634) (2020-11-07)

* Eli Zaretskii <eliz@gnu.org> [2020-12-11 11:13]:
> > Date: Fri, 11 Dec 2020 00:23:23 +0300
> > From: Jean Louis <bugs@gnu.support>
> > Cc: 45159@debbugs.gnu.org
> > 
> > > > Additionally I can see that if there is any package like
> > > > persistent-scratch, Emacs cannot be killed with C-x C-c as package
> > > > asked to be saved. There is no way to exit Emacs is disk space is full
> > > > and some package want to save data on exit.
> > > 
> > > That is also a bug.
> > 
> > Business of debugging makes my computer frozen. This time I have
> > attached gdb to Emacs and it did not crash. I could not do
> > anything. Operation interrupted and I could not do just nothin with
> > Emacs. xkilled it, and madde bt full which is attached. I will try
> > tomorrow again.
> 
> What Emacs command triggered the problem which happened before you
> attached GDB?  Above, you are talking about not being able to kill
> Emacs with "C-x C-c" when persistent-scratch is used -- is that what
> you did there before attaching GDB?

I use persistent scratch all the time. In few first attempts, Emacs
crashed when hard disk was not enough. It was working full time
without user interactions as it was handling the database processing
for many minutes iterating over 200000+ numbers and for each number
looking into how many emails belong to specific person and how many
SMS, chat and other interactions each person have got and recording it
to the database by using dynamic module emacs-libpq.

In the subsequent attempt to crash Emacs and find the bug instead of
crushing it stopped its job or work, debugge opened, but I was not
able to do anything like using keyboard, or C-g multiple times or
similar.

> > #0  0x00007f15991dedb0 in raise () at /lib/libpthread.so.0
> > #1  0x0000000000418ccd in terminate_due_to_signal (sig=sig@entry=6, 
> > backtrace_limit=backtrace_limit@entry=40) at emacs.c:408
> > #2  0x0000000000418ea0 in emacs_abort () at sysdep.c:2282
> > #3  0x000000000045a4ec in redisplay_internal () at xdisp.c:15474
> 
> What do you have on line 15474 of xdisp.c in the source tree from
> which this binary was produced?  I don't think I understand how
> redisplay_internal called emacs_abort in this case.

  /* No redisplay if running in batch mode or frame is not yet fully
15474     initialized, or redisplay is explicitly turned off by setting
     Vinhibit_redisplay.  */
  if ((FRAME_INITIAL_P (SELECTED_FRAME ())
       && redisplay_skip_initial_frame)
      || !NILP (Vinhibit_redisplay))
    return;

By the way, when opening xdisp.c I got this error:

Debugger entered--Lisp error: (error "Invalid face" font-lock-warning-face)
  internal-copy-lisp-face(font-lock-warning-face c-nonbreakable-space-face 
#<frame Movies - GNU Emacs at protected.rcdrun.com 0x33040b8> nil)
  copy-face(font-lock-warning-face c-nonbreakable-space-face #<frame Movies - 
GNU Emacs at protected.rcdrun.com 0x33040b8>)
  copy-face(font-lock-warning-face c-nonbreakable-space-face)
  c-make-inverse-face(font-lock-warning-face c-nonbreakable-space-face)
  (if (c-face-name-p 'c-nonbreakable-space-face) nil (c-make-inverse-face 
'font-lock-warning-face 'c-nonbreakable-space-face))
  (unless (c-face-name-p 'c-nonbreakable-space-face) (c-make-inverse-face 
'font-lock-warning-face 'c-nonbreakable-space-face))
  (progn (unless (c-face-name-p 'c-nonbreakable-space-face) 
(c-make-inverse-face 'font-lock-warning-face 'c-nonbreakable-space-face)) 
''c-nonbreakable-space-face)
  (list "\240" 0 (progn (unless (c-face-name-p 'c-nonbreakable-space-face) 
(c-make-inverse-face 'font-lock-warning-face 'c-nonbreakable-space-face)) 
''c-nonbreakable-space-face))
  eval((list "\240" 0 (progn (unless (c-face-name-p 'c-nonbreakable-space-face) 
(c-make-inverse-face 'font-lock-warning-face 'c-nonbreakable-space-face)) 
''c-nonbreakable-space-face)))
  font-lock-compile-keyword((eval list "\240" 0 (progn (unless (c-face-name-p 
'c-nonbreakable-space-face) (c-make-inverse-face 'font-lock-warning-face 
'c-nonbreakable-space-face)) ''c-nonbreakable-space-face)))
  mapcar(font-lock-compile-keyword (c-font-lock-complex-decl-prepare 
(#f(compiled-function (limit) #<bytecode -0x143bb8fede1d832c>)) 
c-maybe-font-lock-wrong-style-comments 
("\\(\\=\\|\\(\\=\\|[^\\]\\)[\n\15]\\)\\s *#\\s *\\(\\(?:error\\|warn..." 4 
font-lock-string-face t) (#f(compiled-function (limit) #<bytecode 
-0x14cccc421df0d645>)) (#f(compiled-function (limit) #<bytecode 
0x78b9b911fe031d6>)) (#f(compiled-function (limit) #<bytecode 
-0x8049f0b1d573359>)) (#f(compiled-function (limit) #<bytecode 
-0x90b56485ecd0475>)) (eval list #f(compiled-function (limit) #<bytecode 
0x8ea6a5044794d01>) 3 c-negation-char-face-name 'append) (eval list "\240" 0 
(progn (unless (c-face-name-p 'c-nonbreakable-space-face) (c-make-inverse-face 
'font-lock-warning-face 'c-nonbreakable-space-face)) 
''c-nonbreakable-space-face)) ("\\s|" 0 font-lock-warning-face t nil) 
c-font-lock-invalid-single-quotes (eval list 
"\\<\\(\\(?:NULL\\|\\(?:fals\\|tru\\)e\\)\\)\\>" 1 c-constant-face-name) 
("\\<\\(\\(?:__\\(?:a\\(?:\\(?:sm\\|ttribute\\)__\\)\\|declspe..." 1 
font-lock-keyword-face) (eval list "\\(!\\)[^=]" 1 c-negation-char-face-name) 
c-font-lock-cut-off-declarators c-font-lock-declarations 
c-font-lock-enclosing-decls c-font-lock-c++-using 
("\\<\\(\\(?:_\\(?:Bool\\|Complex\\|Imaginary\\)\\|char\\|dou..." 1 
'font-lock-type-face) c-font-lock-enum-tail c-font-lock-enum-body (eval list 
"\\<\\(\\(?:goto\\)\\)\\>\\s *\\([[:alpha:]_][[:alnum:]_$]*..." (list 2 
c-label-face-name nil t))))
  font-lock-compile-keywords((c-font-lock-complex-decl-prepare 
(#f(compiled-function (limit) #<bytecode -0x143bb8fede1d832c>)) 
c-maybe-font-lock-wrong-style-comments 
("\\(\\=\\|\\(\\=\\|[^\\]\\)[\n\15]\\)\\s *#\\s *\\(\\(?:error\\|warn..." 4 
font-lock-string-face t) (#f(compiled-function (limit) #<bytecode 
-0x14cccc421df0d645>)) (#f(compiled-function (limit) #<bytecode 
0x78b9b911fe031d6>)) (#f(compiled-function (limit) #<bytecode 
-0x8049f0b1d573359>)) (#f(compiled-function (limit) #<bytecode 
-0x90b56485ecd0475>)) (eval list #f(compiled-function (limit) #<bytecode 
0x8ea6a5044794d01>) 3 c-negation-char-face-name 'append) (eval list "\240" 0 
(progn (unless (c-face-name-p 'c-nonbreakable-space-face) (c-make-inverse-face 
'font-lock-warning-face 'c-nonbreakable-space-face)) 
''c-nonbreakable-space-face)) ("\\s|" 0 font-lock-warning-face t nil) 
c-font-lock-invalid-single-quotes (eval list 
"\\<\\(\\(?:NULL\\|\\(?:fals\\|tru\\)e\\)\\)\\>" 1 c-constant-face-name) 
("\\<\\(\\(?:__\\(?:a\\(?:\\(?:sm\\|ttribute\\)__\\)\\|declspe..." 1 
font-lock-keyword-face) (eval list "\\(!\\)[^=]" 1 c-negation-char-face-name) 
c-font-lock-cut-off-declarators c-font-lock-declarations 
c-font-lock-enclosing-decls c-font-lock-c++-using 
("\\<\\(\\(?:_\\(?:Bool\\|Complex\\|Imaginary\\)\\|char\\|dou..." 1 
'font-lock-type-face) c-font-lock-enum-tail c-font-lock-enum-body (eval list 
"\\<\\(\\(?:goto\\)\\)\\>\\s *\\([[:alpha:]_][[:alnum:]_$]*..." (list 2 
c-label-face-name nil t))))
  font-lock-set-defaults()
  font-lock-mode-internal(t)
  font-lock-default-function(t)
  font-lock-mode()
  turn-on-font-lock()
  turn-on-font-lock-if-desired()
  global-font-lock-mode-enable-in-buffers()
  run-hooks(after-change-major-mode-hook)
  run-mode-hooks(c-mode-hook)
  c-mode()
  set-auto-mode-0(c-mode nil)
  set-auto-mode()
  normal-mode(t)
  after-find-file(nil t)
  find-file-noselect-1(#<buffer xdisp.c> 
"~/Programming/Software/emacs/src/xdisp.c" nil nil 
"~/Programming/Software/emacs/src/xdisp.c" (55584502 65024))
  find-file-noselect("/home/data1/protected/Programming/Software/emacs/s..." 
nil nil nil)
  find-file("/home/data1/protected/Programming/Software/emacs/s...")
  dired-find-file()
  funcall-interactively(dired-find-file)
  call-interactively(dired-find-file nil nil)
  command-execute(dired-find-file)
> 
> > #7  0x00000000004f3223 in shut_down_emacs (sig=sig@entry=6, 
> > stuff=stuff@entry=0x0) at emacs.c:2450
> >         tpgrp = <optimized out>
> > #8  0x0000000000418c9e in terminate_due_to_signal (sig=sig@entry=6, 
> > backtrace_limit=backtrace_limit@entry=40) at emacs.c:391
> > #9  0x0000000000418ea0 in emacs_abort () at sysdep.c:2282
> > #10 0x000000000045c2a2 in message3_nolog (m=m@entry=0x4ccd694) at 
> > xdisp.c:11117
> >         sf = <optimized out>
> 
> Likewise here: what do you have on line 11117 of xdisp.c, in
> message3_nolog function?  I don't understand how emacs_abort got
> called here, either.

/* The non-logging version of message3.
   This does not cancel echoing, because it is used for echoing.
   Perhaps we need to make a separate function for echoing
   and make this cancel echoing.  */

void
11117: message3_nolog (Lisp_Object m)
{
  struct frame *sf = SELECTED_FRAME ();

  if (FRAME_INITIAL_P (sf))
    message_to_stderr (m);
  /* Error messages get reported properly by cmd_error, so this must be just an
     informative message; if the frame hasn't really been initialized yet, just
     toss it.  */
  else if (INTERACTIVE && sf->glyphs_initialized_p)
    {
      /* Get the frame containing the mini-buffer
         that the selected frame is using.  */
      Lisp_Object mini_window = FRAME_MINIBUF_WINDOW (sf);
      Lisp_Object frame = XWINDOW (mini_window)->frame;
      struct frame *f = XFRAME (frame);

      if (FRAME_VISIBLE_P (sf) && !FRAME_VISIBLE_P (f))
        Fmake_frame_visible (frame);

      if (STRINGP (m) && SCHARS (m) > 0)
        {
          set_message (m);
          if (minibuffer_auto_raise)
            Fraise_frame (frame);
          /* Assume we are not echoing.
             (If we are, echo_now will override this.)  */
          echo_message_buffer = Qnil;
        }
      else
        clear_message (true, true);

      do_pending_window_change (false);
      echo_area_display (true);
      do_pending_window_change (false);
      if (FRAME_TERMINAL (f)->frame_up_to_date_hook)
        (*FRAME_TERMINAL (f)->frame_up_to_date_hook) (f);
    }
}






reply via email to

[Prev in Thread] Current Thread [Next in Thread]