aboutsummaryrefslogtreecommitdiff
path: root/gcc/tree-inline.c
diff options
context:
space:
mode:
authorJan Hubicka <hubicka@ucw.cz>2017-11-09 15:05:14 +0100
committerJan Hubicka <hubicka@gcc.gnu.org>2017-11-09 14:05:14 +0000
commite4373d41d67060e14bab0c984fb9f7cbc4c93f1b (patch)
treefb9d5143e4e5fd9e929fbb4c13e3bd4b71aaaa40 /gcc/tree-inline.c
parenta3a6d41f4610c67b9905b3796e441397cc240178 (diff)
downloadgcc-e4373d41d67060e14bab0c984fb9f7cbc4c93f1b.zip
gcc-e4373d41d67060e14bab0c984fb9f7cbc4c93f1b.tar.gz
gcc-e4373d41d67060e14bab0c984fb9f7cbc4c93f1b.tar.bz2
re PR ipa/82879 (ICE in max, at profile-count.h:889)
PR ipa/82879 * ipa-inline-transform.c (update_noncloned_frequencies): Use profile_count::adjust_for_ipa_scaling. * tree-inline.c (copy_bb, copy_cfg_body): Likewise. * profile-count.c (profile_count::adjust_for_ipa_scaling): New member function. * profile-count.h (profile_count::adjust_for_ipa_scaling): Declare. From-SVN: r254582
Diffstat (limited to 'gcc/tree-inline.c')
-rw-r--r--gcc/tree-inline.c24
1 files changed, 2 insertions, 22 deletions
diff --git a/gcc/tree-inline.c b/gcc/tree-inline.c
index 7ef1072..fc5d2c7 100644
--- a/gcc/tree-inline.c
+++ b/gcc/tree-inline.c
@@ -1771,17 +1771,7 @@ copy_bb (copy_body_data *id, basic_block bb,
tree decl;
basic_block prev;
- /* We always must scale to be sure counters end up compatible.
- If den is zero, just force it nonzero and hope for reasonable
- approximation.
- When num is forced nonzero, also update den, so we do not scale profile
- to 0. */
- if (!(num == den)
- && !(den.force_nonzero () == den))
- {
- den = den.force_nonzero ();
- num = num.force_nonzero ();
- }
+ profile_count::adjust_for_ipa_scaling (&num, &den);
/* Search for previous copied basic block. */
prev = bb->prev_bb;
@@ -2698,17 +2688,7 @@ copy_cfg_body (copy_body_data * id, profile_count,
profile_count den = ENTRY_BLOCK_PTR_FOR_FN (src_cfun)->count;
profile_count num = entry_block_map->count;
- /* We always must scale to be sure counters end up compatible.
- If den is zero, just force it nonzero and hope for reasonable
- approximation.
- When num is forced nonzero, also update den, so we do not scale profile
- to 0. */
- if (!(num == den)
- && !(den.force_nonzero () == den))
- {
- den = den.force_nonzero ();
- num = num.force_nonzero ();
- }
+ profile_count::adjust_for_ipa_scaling (&num, &den);
cfun_to_copy = id->src_cfun = DECL_STRUCT_FUNCTION (callee_fndecl);