diff options
author | dalej <dalej@138bc75d-0d04-0410-961f-82ee72b054a4> | 2002-09-19 18:54:56 +0000 |
---|---|---|
committer | dalej <dalej@138bc75d-0d04-0410-961f-82ee72b054a4> | 2002-09-19 18:54:56 +0000 |
commit | 3f7dbe8d71e43cbbf41f8f09049cdf36dea123a4 (patch) | |
tree | 270549d85262425a9fa64b04afb48d51d3f798c0 /gcc/combine.c | |
parent | bd5d180582ec1a96440ca667885ec38df28b0c93 (diff) | |
download | gcc-3f7dbe8d71e43cbbf41f8f09049cdf36dea123a4.tar.gz |
Remove creation of invalid subreg. PR 7705, 7339, 7720.
git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@57315 138bc75d-0d04-0410-961f-82ee72b054a4
Diffstat (limited to 'gcc/combine.c')
-rw-r--r-- | gcc/combine.c | 5 |
1 files changed, 5 insertions, 0 deletions
diff --git a/gcc/combine.c b/gcc/combine.c index e1518817ca6..c72d81e891c 100644 --- a/gcc/combine.c +++ b/gcc/combine.c @@ -6124,6 +6124,11 @@ make_extraction (mode, inner, pos, pos_rtx, len, final_word += (GET_MODE_SIZE (inner_mode) - GET_MODE_SIZE (tmode)) % UNITS_PER_WORD; + /* Avoid creating invalid subregs, for example when + simplifying (x>>32)&255. */ + if (final_word >= GET_MODE_SIZE (inner_mode)) + return NULL_RTX; + new = gen_rtx_SUBREG (tmode, inner, final_word); } else |