aboutsummaryrefslogtreecommitdiff
path: root/gcc/c
diff options
context:
space:
mode:
authorBin Bin Lv <shlb@linux.ibm.com>2020-03-11 22:25:31 -0400
committerBin Bin Lv <shlb@linux.ibm.com>2020-03-11 22:25:31 -0400
commitf457ae2218c74c9816d98d695058619a67ded6ba (patch)
tree1ff5d71d96b26d6cf855fb150f8ec17a5c76e7a5 /gcc/c
parent9c1281d98639e8291570fd367c9d22f350509513 (diff)
downloadgcc-f457ae2218c74c9816d98d695058619a67ded6ba.zip
gcc-f457ae2218c74c9816d98d695058619a67ded6ba.tar.gz
gcc-f457ae2218c74c9816d98d695058619a67ded6ba.tar.bz2
[rs6000] Fix a wrong GC issue
The source file rs6000.c was split up into several smaller source files through commit 1acf024. However, variable "altivec_builtin_mask_for_load" and "builtin_mode_to_type[MAX_MACHINE_MODE][2]" were marked with the wrong syntax "GTY(([options])) type name", which led these two variables were not marked as roots correctly and wrongly GCed. And when "altivec_builtin_mask_for_load" was wrongly GCed, the compiling for openJDK is failed with ICEs enabling precompiled header under mcpu=power7. So roots must be declared using one of the following syntaxes: "extern GTY(([options])) type name;" and "static GTY(([options])) type name;". And the following patch adds variable "altivec_builtin_mask_for_load" and "builtin_mode_to_type[MAX_MACHINE_MODE][2]" into the roots array. Bootstrap and regression tests were done on powerpc64le-linux-gnu (LE) with no regressions. gcc/ChangeLog 2020-03-11 Bin Bin Lv <shlb@linux.ibm.com> * config/rs6000/rs6000-internal.h (altivec_builtin_mask_for_load, builtin_mode_to_type): Remove the declaration. * config/rs6000/rs6000.h (altivec_builtin_mask_for_load, builtin_mode_to_type): Add an extern GTY(()) declaration. * config/rs6000/rs6000.c (altivec_builtin_mask_for_load, builtin_mode_to_type): Remove the GTY(()) declaration.
Diffstat (limited to 'gcc/c')
0 files changed, 0 insertions, 0 deletions