diff options
author | amylaar <amylaar@138bc75d-0d04-0410-961f-82ee72b054a4> | 2000-05-23 17:13:36 +0000 |
---|---|---|
committer | amylaar <amylaar@138bc75d-0d04-0410-961f-82ee72b054a4> | 2000-05-23 17:13:36 +0000 |
commit | 9c6db7b6ec66cdb6ee18e1957b420219e2b9dcab (patch) | |
tree | bb872e08aa14730493371ff27263c975c457431b /gcc/reload1.c | |
parent | 37688b6d0ee16583ee3370a31243f8324bcb0bc6 (diff) | |
download | gcc-9c6db7b6ec66cdb6ee18e1957b420219e2b9dcab.tar.gz |
* reload1.c (reload_cse_move2add): Honor TRULY_NOOP_TRUNCATION.
git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@34106 138bc75d-0d04-0410-961f-82ee72b054a4
Diffstat (limited to 'gcc/reload1.c')
-rw-r--r-- | gcc/reload1.c | 8 |
1 files changed, 6 insertions, 2 deletions
diff --git a/gcc/reload1.c b/gcc/reload1.c index e7da78b8a03..c0bf424a87f 100644 --- a/gcc/reload1.c +++ b/gcc/reload1.c @@ -8905,8 +8905,12 @@ reload_cse_move2add (first) /* ??? We don't know how zero / sign extension is handled, hence we can't go from a narrower to a wider mode. */ if (reg_set_luid[regno] > last_label_luid - && (GET_MODE_SIZE (GET_MODE (reg)) - <= GET_MODE_SIZE (reg_mode[regno])) + && ((GET_MODE_SIZE (GET_MODE (reg)) + == GET_MODE_SIZE (reg_mode[regno])) + || ((GET_MODE_SIZE (GET_MODE (reg)) + <= GET_MODE_SIZE (reg_mode[regno])) + && TRULY_NOOP_TRUNCATION (GET_MODE_BITSIZE (GET_MODE (reg)), + GET_MODE_BITSIZE (reg_mode[regno])))) && GET_CODE (reg_offset[regno]) == CONST_INT) { /* Try to transform (set (REGX) (CONST_INT A)) |