From: Jan Hubicka Date: Mon, 12 Aug 2002 10:50:02 +0000 (+0200) Subject: i386.md (tablejump): Sign extend the operand. X-Git-Tag: releases/gcc-3.3.0~3326 X-Git-Url: http://git.ipfire.org/cgi-bin/gitweb.cgi?a=commitdiff_plain;h=c16576e6c602529410942d7aa5e445bce3e58748;p=thirdparty%2Fgcc.git i386.md (tablejump): Sign extend the operand. * i386.md (tablejump): Sign extend the operand. * i386.c (classify_argument): Fix missed case from previous patch. From-SVN: r56231 --- diff --git a/gcc/ChangeLog b/gcc/ChangeLog index e5ec9300449d..360b4a77e6e5 100644 --- a/gcc/ChangeLog +++ b/gcc/ChangeLog @@ -1,3 +1,8 @@ +Mon Aug 12 12:48:20 CEST 2002 Jan Hubicka + + * i386.md (tablejump): Sign extend the operand. + * i386.c (classify_argument): Fix missed case from previous patch. + 2002-08-12 Neil Booth * c-common.c (STDC_0_IN_SYSTEM_HEADERS, c_common_init): Move diff --git a/gcc/config/i386/i386.c b/gcc/config/i386/i386.c index 1010bb819481..663e7677a4e2 100644 --- a/gcc/config/i386/i386.c +++ b/gcc/config/i386/i386.c @@ -1727,7 +1727,7 @@ classify_argument (mode, type, classes, bit_offset) return 0; for (i = 0; i < num; i++) { - int pos = (offset + bit_offset) / 8 / 8; + int pos = (offset + (bit_offset % 64)) / 8 / 8; classes[i + pos] = merge_classes (subclasses[i], classes[i + pos]); } diff --git a/gcc/config/i386/i386.md b/gcc/config/i386/i386.md index 653583bfe3ee..01e03c3a8116 100644 --- a/gcc/config/i386/i386.md +++ b/gcc/config/i386/i386.md @@ -13154,7 +13154,7 @@ op1 = operands[0]; } - operands[0] = expand_simple_binop (Pmode, code, op0, op1, NULL_RTX, 1, + operands[0] = expand_simple_binop (Pmode, code, op0, op1, NULL_RTX, 0, OPTAB_DIRECT); } })