diff options
author | Xinliang David Li <davidxl@google.com> | 2011-04-29 17:13:23 +0000 |
---|---|---|
committer | Xinliang David Li <davidxl@gcc.gnu.org> | 2011-04-29 17:13:23 +0000 |
commit | d984c8ef7d4c467e80159dc010358c703dfa7fce (patch) | |
tree | 59d3c54a746b457f6cb108cccbb5acecb2d38909 | |
parent | 12578be73d300173f75624b75d1336d17d97c116 (diff) | |
download | gcc-d984c8ef7d4c467e80159dc010358c703dfa7fce.zip gcc-d984c8ef7d4c467e80159dc010358c703dfa7fce.tar.gz gcc-d984c8ef7d4c467e80159dc010358c703dfa7fce.tar.bz2 |
use tls for ic vars
From-SVN: r173177
-rw-r--r-- | gcc/ChangeLog | 7 | ||||
-rw-r--r-- | gcc/coverage.c | 2 | ||||
-rw-r--r-- | gcc/tree-profile.c | 10 |
3 files changed, 18 insertions, 1 deletions
diff --git a/gcc/ChangeLog b/gcc/ChangeLog index b1ee31f..ced5c1f 100644 --- a/gcc/ChangeLog +++ b/gcc/ChangeLog @@ -1,3 +1,10 @@ +2011-04-27 Xinliang David Li <davidxl@google.com> + + * tree-profile.c (init_ic_make_global_vars): Set + tls attribute on ic vars. + * coverage.c (coverage_end_function): Initialize + function_list with zero. + 2011-04-29 Richard Guenther <rguenther@suse.de> * builtins.c (fold_builtin_classify_type): Use integer_type_node diff --git a/gcc/coverage.c b/gcc/coverage.c index 1efd714..cf045d5 100644 --- a/gcc/coverage.c +++ b/gcc/coverage.c @@ -647,7 +647,7 @@ coverage_end_function (unsigned lineno_checksum, unsigned cfg_checksum) { struct function_list *item; - item = XNEW (struct function_list); + item = XCNEW (struct function_list); *functions_tail = item; functions_tail = &item->next; diff --git a/gcc/tree-profile.c b/gcc/tree-profile.c index c296dff..69d77f0 100644 --- a/gcc/tree-profile.c +++ b/gcc/tree-profile.c @@ -44,6 +44,8 @@ along with GCC; see the file COPYING3. If not see #include "value-prof.h" #include "cgraph.h" #include "profile.h" +#include "target.h" +#include "output.h" static GTY(()) tree gcov_type_node; static GTY(()) tree gcov_type_tmp_var; @@ -80,6 +82,10 @@ init_ic_make_global_vars (void) TREE_PUBLIC (ic_void_ptr_var) = 0; DECL_ARTIFICIAL (ic_void_ptr_var) = 1; DECL_INITIAL (ic_void_ptr_var) = NULL; + if (targetm.have_tls) + DECL_TLS_MODEL (ic_void_ptr_var) = + decl_default_tls_model (ic_void_ptr_var); + varpool_finalize_decl (ic_void_ptr_var); varpool_mark_needed_node (varpool_node (ic_void_ptr_var)); @@ -92,6 +98,10 @@ init_ic_make_global_vars (void) TREE_PUBLIC (ic_gcov_type_ptr_var) = 0; DECL_ARTIFICIAL (ic_gcov_type_ptr_var) = 1; DECL_INITIAL (ic_gcov_type_ptr_var) = NULL; + if (targetm.have_tls) + DECL_TLS_MODEL (ic_gcov_type_ptr_var) = + decl_default_tls_model (ic_gcov_type_ptr_var); + varpool_finalize_decl (ic_gcov_type_ptr_var); varpool_mark_needed_node (varpool_node (ic_gcov_type_ptr_var)); } |