public inbox for gcc-patches@gcc.gnu.org
 help / color / mirror / Atom feed
* Regression with recent change
@ 2021-04-29 15:52 Jeff Law
  0 siblings, 0 replies; 9+ messages in thread
From: Jeff Law @ 2021-04-29 15:52 UTC (permalink / raw)
  To: H.J. Lu; +Cc: GCC Patches

This change:

985b3a6837dee7001e6b618f073ed74f0edf5787 is the first bad commit
commit 985b3a6837dee7001e6b618f073ed74f0edf5787
Author: H.J. Lu <hjl.tools@gmail.com>
Date:   Mon Jun 10 09:57:15 2019 -0700

     Generate offset adjusted operation for op_by_pieces operations

     Add an overlap_op_by_pieces_p target hook for op_by_pieces operations
     between two areas of memory to generate one offset adjusted operation
     in the smallest integer mode for the remaining bytes on the last piece
     operation of a memory region to avoid doing more than one smaller
     operations.

     Pass the RTL information from the previous iteration to m_constfn in
     op_by_pieces operation so that builtin_memset_[read|gen]_str can
     generate the new RTL from the previous RTL.

     Tested on Linux/x86-64.

     gcc/

             PR middle-end/90773
             * builtins.c (builtin_memcpy_read_str): Add a dummy argument.
             (builtin_strncpy_read_str): Likewise.
             (builtin_memset_read_str): Add an argument for the previous RTL
             information and generate the new RTL from the previous RTL 
info.
             (builtin_memset_gen_str): Likewise.
             * builtins.h (builtin_strncpy_read_str): Update the prototype.
             (builtin_memset_read_str): Likewise.
             * expr.c (by_pieces_ninsns): If 
targetm.overlap_op_by_pieces_p()
             returns true, round up size and alignment to the widest integer
             mode for maximum size.
             (pieces_addr::adjust): Add a pointer to by_pieces_prev argument
             and pass it to m_constfn.
             (op_by_pieces_d): Add m_push and m_overlap_op_by_pieces.
             (op_by_pieces_d::op_by_pieces_d): Add a bool argument to
             initialize m_push.  Initialize m_overlap_op_by_pieces with
             targetm.overlap_op_by_pieces_p ().
             (op_by_pieces_d::run): Pass the previous RTL information to
             pieces_addr::adjust and generate overlapping operations if
             m_overlap_op_by_pieces is true.
             (PUSHG_P): New.
             (move_by_pieces_d::move_by_pieces_d): Updated for 
op_by_pieces_d
             change.
             (store_by_pieces_d::store_by_pieces_d): Updated for 
op_by_pieces_d
             change.
             (can_store_by_pieces): Use by_pieces_constfn on constfun.
             (store_by_pieces): Use by_pieces_constfn on constfun. Updated
             for op_by_pieces_d change.
             (clear_by_pieces_1): Add a dummy argument.
             (clear_by_pieces): Updated for op_by_pieces_d change.
             (compare_by_pieces_d::compare_by_pieces_d): Likewise.
             (string_cst_read_str): Add a dummy argument.
             * expr.h (by_pieces_constfn): Add a dummy argument.
             (by_pieces_prev): New.
             * target.def (overlap_op_by_pieces_p): New target hook.
             * config/i386/i386.c (TARGET_OVERLAP_OP_BY_PIECES_P): New.
             * doc/tm.texi.in: Add TARGET_OVERLAP_OP_BY_PIECES_P.
             * doc/tm.texi: Regenerated.


Is causing regressions on the fr30-elf port:


fr30-sim: gcc.dg/Wstringop-overflow-27.c  (test for warnings, line 168)
fr30-sim: gcc.dg/Wstringop-overflow-27.c  (test for warnings, line 174)
fr30-sim: gcc.dg/Wstringop-overflow-27.c  (test for warnings, line 180)
fr30-sim: gcc.dg/Wstringop-overflow-27.c  (test for warnings, line 186)
fr30-sim: gcc.dg/Wstringop-overflow-27.c  (test for warnings, line 193)
fr30-sim: gcc.dg/Wstringop-overflow-27.c  (test for warnings, line 201)
fr30-sim: gcc.dg/Wstringop-overflow-27.c  (test for warnings, line 265)
fr30-sim: gcc.dg/Wstringop-overflow-27.c  (test for warnings, line 274)
fr30-sim: gcc.dg/Wstringop-overflow-27.c  (test for warnings, line 282)
fr30-sim: gcc.dg/Wstringop-overflow-27.c  (test for warnings, line 289)
fr30-sim: gcc.dg/Wstringop-overflow-27.c (test for excess errors)
fr30-sim: gcc.dg/Wstringop-overflow-27.c malloc note (test for warnings, 
line 288)
fr30-sim: gcc.dg/Wstringop-overflow-27.c note (test for warnings, line 264)
fr30-sim: gcc.dg/Wstringop-overflow-27.c note (test for warnings, line 273)
fr30-sim: gcc.dg/Wstringop-overflow-27.c vla note (test for warnings, 
line 281)


I haven't done any analysis other then bisecting the regression.


Full logs are here:

http://3.14.90.209:8080/job/fr30-elf/1258/console


Thanks,

Jeff


^ permalink raw reply	[flat|nested] 9+ messages in thread

end of thread, other threads:[~2021-09-14 15:59 UTC | newest]

Thread overview: 9+ messages (download: mbox.gz / follow: Atom feed)
-- links below jump to the message on this page --
     [not found] <889cbb03-3a02-65e4-7790-c903293bacf7@gmail.com>
2021-09-13 13:29 ` Regression with recent change Aldy Hernandez
2021-09-13 13:40   ` Jeff Law
2021-09-13 14:18     ` Michael Matz
2021-09-13 14:33       ` Jeff Law
2021-09-13 17:03       ` Aldy Hernandez
2021-09-14 14:13         ` Michael Matz
2021-09-14 14:53           ` Aldy Hernandez
2021-09-14 15:59             ` Jeff Law
2021-04-29 15:52 Jeff Law

This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for read-only IMAP folder(s) and NNTP newsgroup(s).