https://gcc.gnu.org/bugzilla/show_bug.cgi?id=109303

Martin Jambor <jamborm at gcc dot gnu.org> changed:

           What    |Removed                     |Added
----------------------------------------------------------------------------
             Status|NEW                         |ASSIGNED
           Assignee|unassigned at gcc dot gnu.org      |jamborm at gcc dot 
gnu.org

--- Comment #8 from Martin Jambor <jamborm at gcc dot gnu.org> ---
Thanks a lot for the testcase.  The divisions must always be exact.

After having one more look, I moved the check a bit earlier still and am
currently testing this:

--- a/gcc/ipa-prop.cc
+++ b/gcc/ipa-prop.cc
@@ -2086,7 +2086,9 @@ determine_known_aggregate_parts (struct
ipa_func_body_info *fbi,
             whether its value is clobbered any other dominating one.  */
          if ((content->value.pass_through.formal_id >= 0
               || content->value.pass_through.operand)
-             && !clobber_by_agg_contents_list_p (all_list, content))
+             && !clobber_by_agg_contents_list_p (all_list, content)
+             && (content->offset + content->size - arg_offset
+                 <= (HOST_WIDE_INT) UINT_MAX * BITS_PER_UNIT))
            {
              struct ipa_known_agg_contents_list *copy
                        = XALLOCA (struct ipa_known_agg_contents_list);

Reply via email to