aboutsummaryrefslogtreecommitdiff
path: root/gcc/combine.c
diff options
context:
space:
mode:
authorAdrian Straetling <straetling@de.ibm.com>2005-10-12 20:30:46 +0000
committerIan Lance Taylor <ian@gcc.gnu.org>2005-10-12 20:30:46 +0000
commit8adac33500f774ff06f2900186eb09b42cb5e9c5 (patch)
tree7660ea507d7f2bb6251942eadcbc1293734cb064 /gcc/combine.c
parent949d5b72e23ff9df61d122d367bbf334b9004f46 (diff)
downloadgcc-8adac33500f774ff06f2900186eb09b42cb5e9c5.zip
gcc-8adac33500f774ff06f2900186eb09b42cb5e9c5.tar.gz
gcc-8adac33500f774ff06f2900186eb09b42cb5e9c5.tar.bz2
combine.c (make_extraction): Correct offset computation.
* combine.c (make_extraction): Correct offset computation. * gcc.c-torture/execute/20051012-1.c: New test. From-SVN: r105330
Diffstat (limited to 'gcc/combine.c')
-rw-r--r--gcc/combine.c5
1 files changed, 3 insertions, 2 deletions
diff --git a/gcc/combine.c b/gcc/combine.c
index 3be34e4..ff10663 100644
--- a/gcc/combine.c
+++ b/gcc/combine.c
@@ -6512,11 +6512,12 @@ make_extraction (enum machine_mode mode, rtx inner, HOST_WIDE_INT pos,
offset -= GET_MODE_SIZE (is_mode) - GET_MODE_SIZE (inner_mode);
/* If this is a constant position, we can move to the desired byte.
- Be careful not to go beyond the original object. */
+ Be careful not to go beyond the original object and maintain the
+ natural alignment of the memory. */
if (pos_rtx == 0)
{
enum machine_mode bfmode = smallest_mode_for_size (len, MODE_INT);
- offset += pos / GET_MODE_BITSIZE (bfmode);
+ offset += (pos / GET_MODE_BITSIZE (bfmode)) * GET_MODE_SIZE (bfmode);
pos %= GET_MODE_BITSIZE (bfmode);
}