mirror of
https://git.savannah.gnu.org/git/guile.git
synced 2025-04-30 03:40:34 +02:00
Fix non-deterministic crash in 'finalization_thread_proc'.
Fixes <https://bugs.gnu.org/37757>. Reported by Jesse Gibbons <jgibbons2357@gmail.com>. * libguile/finalizers.c (finalization_thread_proc): Do not enter the "switch (data.byte)" condition when data.n <= 0.
This commit is contained in:
parent
659526d33b
commit
edf5aea7ac
1 changed files with 18 additions and 13 deletions
|
@ -1,4 +1,4 @@
|
|||
/* Copyright (C) 2012, 2013, 2014 Free Software Foundation, Inc.
|
||||
/* Copyright (C) 2012, 2013, 2014, 2019 Free Software Foundation, Inc.
|
||||
*
|
||||
* This library is free software; you can redistribute it and/or
|
||||
* modify it under the terms of the GNU Lesser General Public License
|
||||
|
@ -211,21 +211,26 @@ finalization_thread_proc (void *unused)
|
|||
|
||||
scm_without_guile (read_finalization_pipe_data, &data);
|
||||
|
||||
if (data.n <= 0 && data.err != EINTR)
|
||||
if (data.n <= 0)
|
||||
{
|
||||
perror ("error in finalization thread");
|
||||
return NULL;
|
||||
if (data.err != EINTR)
|
||||
{
|
||||
perror ("error in finalization thread");
|
||||
return NULL;
|
||||
}
|
||||
}
|
||||
|
||||
switch (data.byte)
|
||||
else
|
||||
{
|
||||
case 0:
|
||||
scm_run_finalizers ();
|
||||
break;
|
||||
case 1:
|
||||
return NULL;
|
||||
default:
|
||||
abort ();
|
||||
switch (data.byte)
|
||||
{
|
||||
case 0:
|
||||
scm_run_finalizers ();
|
||||
break;
|
||||
case 1:
|
||||
return NULL;
|
||||
default:
|
||||
abort ();
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue