From 8efb33ec2da91dba827bd966e5552db13f84f860 Mon Sep 17 00:00:00 2001 From: Steve Ellcey Date: Thu, 31 Oct 2002 20:43:07 +0000 Subject: * expmed.c (store_bit_field): Check FUNCTION_ARG_REG_LITTLE_ENDIAN. From-SVN: r58694 --- gcc/ChangeLog | 4 ++++ gcc/expmed.c | 1 + 2 files changed, 5 insertions(+) (limited to 'gcc') diff --git a/gcc/ChangeLog b/gcc/ChangeLog index 6591625..04ed853 100644 --- a/gcc/ChangeLog +++ b/gcc/ChangeLog @@ -1,5 +1,9 @@ 2002-10-31 Steve Ellcey + * expmed.c (store_bit_field): Check FUNCTION_ARG_REG_LITTLE_ENDIAN. + +2002-10-31 Steve Ellcey + * config/ia64/hpux.h (MEMBER_TYPE_FORCES_BLK): Set for non-floats. Thu Oct 31 Dale Johannesen diff --git a/gcc/expmed.c b/gcc/expmed.c index 730c4c1..6b365b9 100644 --- a/gcc/expmed.c +++ b/gcc/expmed.c @@ -404,6 +404,7 @@ store_bit_field (str_rtx, bitsize, bitnum, fieldmode, value, total_size) But as we have it, it counts within whatever size OP0 now has. On a bigendian machine, these are not the same, so convert. */ if (BYTES_BIG_ENDIAN + && !FUNCTION_ARG_REG_LITTLE_ENDIAN && GET_CODE (op0) != MEM && unit > GET_MODE_BITSIZE (GET_MODE (op0))) bitpos += unit - GET_MODE_BITSIZE (GET_MODE (op0)); -- cgit v1.1