diff options
author | Jakub Jelinek <jakub@redhat.com> | 2012-01-23 10:25:52 +0100 |
---|---|---|
committer | Jakub Jelinek <jakub@gcc.gnu.org> | 2012-01-23 10:25:52 +0100 |
commit | b57cca0bb0336092479d84249e8d4824deede3f5 (patch) | |
tree | d52514dd33f5fb5fc05c9acbf852a7e2836de4aa /gcc/version.c | |
parent | b3aa0ca8345ecadca2f3482bc78074b634557164 (diff) | |
download | gcc-b57cca0bb0336092479d84249e8d4824deede3f5.zip gcc-b57cca0bb0336092479d84249e8d4824deede3f5.tar.gz gcc-b57cca0bb0336092479d84249e8d4824deede3f5.tar.bz2 |
re PR rtl-optimization/51933 (wrong code due to -free)
PR rtl-optimization/51933
* ree.c (transform_ifelse): Return true right away if dstreg is
already wider or equal to cand->mode.
(enum ext_modified_kind, struct ext_modified, ext_state): New types.
(make_defs_and_copies_lists): Remove defs_list and copies_list
arguments, add state argument, just truncate state->work_list
instead of always allocating and freeing the vector. Assert that
get_defs succeeds instead of returning 2. Changed return type to
bool.
(merge_def_and_ext): Add state argument. If SET_DEST doesn't
have ext_src_mode, see if it has been modified already with the
right kind of extension and has been extended before from the
ext_src_mode. If SET_DEST is already wider or equal to cand->mode,
just return true. Remember the original mode in state->modified
array.
(combine_reaching_defs): Add state argument. Don't allocate and
free here def_list, copied_list and vec vectors, instead just
VEC_truncate the vectors in *state. Don't handle outcome == 2
here.
(find_and_remove_re): Set DF_DEFER_INSN_RESCAN df flag.
Add state variable, clear vectors in it, initialize state.modified
if needed. Free all the vectors at the end and state.modified too.
Don't skip a candidate if the extension expression has been modified.
* gcc.c-torture/execute/pr51933.c: New test.
From-SVN: r183416
Diffstat (limited to 'gcc/version.c')
0 files changed, 0 insertions, 0 deletions