NetBSD-Bugs archive

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

port-amiga/55233: Process hangs indefinitely if not calling syscalls for a while



>Number:         55233
>Category:       port-amiga
>Synopsis:       Process hangs indefinitely if not calling syscalls for a while
>Confidential:   no
>Severity:       critical
>Priority:       high
>Responsible:    port-amiga-maintainer
>State:          open
>Class:          sw-bug
>Submitter-Id:   net
>Arrival-Date:   Tue May 05 01:10:00 +0000 2020
>Originator:     Rin Okuyama
>Release:        9.99.59
>Organization:
Department of Physics, Meiji University
>Environment:
NetBSD a1200 9.99.59 NetBSD 9.99.59 (A1200) #17: Mon May  4 22:58:45 JST 2020  rin@latipes:/build/work/work/sys/arch/amiga/compile/A1200 amiga
Amiga 1200 with 68060
>Description:
Process not calling syscalls does not accept ^C:

----
% cat loop.c
int main(void) {
	for (;;) continue;
	return 0;
}
% cc loop.c && ./a.out
^C^C^C^C
----

Then, system gets stalled at this process, and I cannot do anything but
entering DDB from console. Trace for that process is not interesting:

----
~Stopped in pid 85.85 (a.out) at netbsd:cpu_Debugger+0x6:        unlk    a6
db> ps
PID    LID S CPU     FLAGS       STRUCT LWP *               NAME WAIT
85   >  85 7   0     40000             bf7c40              a.out
...
db> trace/a bf7c40
trace: pid 85 lid 85 at 0xbbf3db4
?(0,0,10,4f8398,0) at a
?() at bbf3f2a
db>
----

A similar failure occurs for a process which does not call syscalls for
a while. For example, this one:

----
#include <signal.h> /* for signal */
#include <string.h> /* for strstr */
#include <stdlib.h> /* for malloc */
#include <unistd.h> /* for alarm */
static void quit (int sig) { _exit (sig + 128); }

int
main ()
{

    int result = 0;
    size_t m = 1000000;
    char *haystack = (char *) malloc (2 * m + 2);
    char *needle = (char *) malloc (m + 2);
    /* Failure to compile this test due to missing alarm is okay,
       since all such platforms (mingw) also have quadratic strstr.  */
    signal (SIGALRM, quit);
    alarm (5);
    /* Check for quadratic performance.  */
    if (haystack && needle)
      {
        memset (haystack, 'A', 2 * m);
        haystack[2 * m] = 'B';
        haystack[2 * m + 1] = 0;
        memset (needle, 'A', m);
        needle[m] = 'B';
        needle[m + 1] = 0;
        if (!strstr (haystack, needle))
          result |= 1;
      }
    return result;

  ;
  return 0;
}
----

taken from "strstr works in linear time" check from configure script,
does not complete indefinitely and causes system freeze.

Note that this is on my amiga with 68060:

- amiga (68060; Amiga 1200)

whereas the failure does not occur for other m68k ports:

- sun3 (68020; TME)
- mac68k (68040; Quadra 840AV)
>How-To-Repeat:
Described above.
>Fix:
Bisectioning revealed that the failure starts with this commit:

http://www.nerv.org/netbsd/?q=id:20200326T201906Z.ba5eaa1d6fe1c81297a039db52867c4c67b65575

> Module Name:	src
> Committed By:	ad
> Date:		Thu Mar 26 20:19:06 UTC 2020
> 
> Modified Files:
> 	src/sys/kern: kern_lwp.c kern_softint.c
> 	src/sys/sys: intr.h userret.h
> 
> Log Message:
> softint_overlay() (slow case) gains ~nothing but creates potential headaches.
> In the interests of simplicity remove it and always use the kthreads.
> 
> To generate a diff of this commit:
> cvs rdiff -u -r1.229 -r1.230 src/sys/kern/kern_lwp.c
> cvs rdiff -u -r1.62 -r1.63 src/sys/kern/kern_softint.c
> cvs rdiff -u -r1.19 -r1.20 src/sys/sys/intr.h
> cvs rdiff -u -r1.32 -r1.33 src/sys/sys/userret.h

By reverting this commit, -current as of yesterday works fine without
this problem.



Home | Main Index | Thread Index | Old Index