aboutsummaryrefslogtreecommitdiff
path: root/gcc
diff options
context:
space:
mode:
authorJanne Blomqvist <jb@gcc.gnu.org>2018-11-23 22:42:03 +0200
committerJanne Blomqvist <jb@gcc.gnu.org>2018-11-23 22:42:03 +0200
commitf4c0f888817ee7c593b56a5fe47b4acfbc83c7d3 (patch)
tree4ab252c7af94ffd81381887e7c0c7777d36818c4 /gcc
parent70c70369ce868fd8b049f710c01a899e502f6f68 (diff)
downloadgcc-f4c0f888817ee7c593b56a5fe47b4acfbc83c7d3.zip
gcc-f4c0f888817ee7c593b56a5fe47b4acfbc83c7d3.tar.gz
gcc-f4c0f888817ee7c593b56a5fe47b4acfbc83c7d3.tar.bz2
Make recursion_check work for multiple threads
With multiple threads, using an unprotected static variable to check whether recursion has occured isn't valid, as one thread might have modified the variable, thus causing another thread to incorrectly conclude that recursion has occured. This patch avoids this problem by using a thread-specific variable for the recursion check. Regtested on x86_64-pc-linux-gnu. libgfortran/ChangeLog: 2018-11-23 Janne Blomqvist <jb@gcc.gnu.org> * runtime/error.c (MAGIC): Remove. (recursion_key): New variable. (recursion_check): Use thread-specific variable for recursion check if threads are active. (constructor_recursion_check): New function. (destructor_recursion_check): New funcion. From-SVN: r266419
Diffstat (limited to 'gcc')
0 files changed, 0 insertions, 0 deletions