diff options
| -rw-r--r-- | gcc/ChangeLog | 5 | ||||
| -rw-r--r-- | gcc/config/i386/i386.c | 2 | ||||
| -rw-r--r-- | gcc/config/i386/i386.md | 2 |
3 files changed, 7 insertions, 2 deletions
diff --git a/gcc/ChangeLog b/gcc/ChangeLog index e5ec930..360b4a7 100644 --- a/gcc/ChangeLog +++ b/gcc/ChangeLog @@ -1,3 +1,8 @@ +Mon Aug 12 12:48:20 CEST 2002 Jan Hubicka <jh@suse.cz> + + * i386.md (tablejump): Sign extend the operand. + * i386.c (classify_argument): Fix missed case from previous patch. + 2002-08-12 Neil Booth <neil@daikokuya.co.uk> * 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 1010bb8..663e767 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 653583b..01e03c3 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); } }) |
