From de7d059c2bc43f76e33a5407772ab9cc0fc00f10 Mon Sep 17 00:00:00 2001 From: zack Date: Fri, 24 Aug 2001 16:01:42 +0000 Subject: * expmed.c: Default-#define HAVE_insv, HAVE_extv, and HAVE_extzv to zero. (mode_for_extraction): No need for #ifdefs. Add default-case abort to switch. (store_bit_field): Eliminate insv_bitsize variable. Put HAVE_insv in if controlling use of insv. (extract_bit_field): Likewise, for extv and extzv. git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@45150 138bc75d-0d04-0410-961f-82ee72b054a4 --- gcc/expmed.c | 51 ++++++++++++++++++--------------------------------- 1 file changed, 18 insertions(+), 33 deletions(-) (limited to 'gcc/expmed.c') diff --git a/gcc/expmed.c b/gcc/expmed.c index 7c1e0f6a383..7cbc8573f7d 100644 --- a/gcc/expmed.c +++ b/gcc/expmed.c @@ -77,14 +77,17 @@ static int sdiv_pow2_cheap, smod_pow2_cheap; /* Reduce conditional compilation elsewhere. */ #ifndef HAVE_insv +#define HAVE_insv 0 #define CODE_FOR_insv CODE_FOR_nothing #define gen_insv(a,b,c,d) NULL_RTX #endif #ifndef HAVE_extv +#define HAVE_extv 0 #define CODE_FOR_extv CODE_FOR_nothing #define gen_extv(a,b,c,d) NULL_RTX #endif #ifndef HAVE_extzv +#define HAVE_extzv 0 #define CODE_FOR_extzv CODE_FOR_nothing #define gen_extzv(a,b,c,d) NULL_RTX #endif @@ -232,34 +235,31 @@ mode_for_extraction (pattern, opno) switch (pattern) { case EP_insv: -#ifdef HAVE_insv if (HAVE_insv) { data = &insn_data[CODE_FOR_insv]; break; } -#endif return MAX_MACHINE_MODE; case EP_extv: -#ifdef HAVE_extv if (HAVE_extv) { data = &insn_data[CODE_FOR_extv]; break; } -#endif return MAX_MACHINE_MODE; case EP_extzv: -#ifdef HAVE_extzv if (HAVE_extzv) { data = &insn_data[CODE_FOR_extzv]; break; } -#endif return MAX_MACHINE_MODE; + + default: + abort (); } if (opno == -1) @@ -304,12 +304,7 @@ store_bit_field (str_rtx, bitsize, bitnum, fieldmode, value, align, total_size) unsigned HOST_WIDE_INT bitpos = bitnum % unit; register rtx op0 = str_rtx; - unsigned HOST_WIDE_INT insv_bitsize; - enum machine_mode op_mode; - - op_mode = mode_for_extraction (EP_insv, 3); - if (op_mode != MAX_MACHINE_MODE) - insv_bitsize = GET_MODE_BITSIZE (op_mode); + enum machine_mode op_mode = mode_for_extraction (EP_insv, 3); /* It is wrong to have align==0, since every object is aligned at least at a bit boundary. This usually means a bug elsewhere. */ @@ -542,13 +537,13 @@ store_bit_field (str_rtx, bitsize, bitnum, fieldmode, value, align, total_size) /* Now OFFSET is nonzero only if OP0 is memory and is therefore always measured in bytes. */ - if (op_mode != MAX_MACHINE_MODE + if (HAVE_insv && GET_MODE (value) != BLKmode && !(bitsize == 1 && GET_CODE (value) == CONST_INT) /* Ensure insv's size is wide enough for this field. */ - && (insv_bitsize >= bitsize) + && (GET_MODE_BITSIZE (op_mode) >= bitsize) && ! ((GET_CODE (op0) == REG || GET_CODE (op0) == SUBREG) - && (bitsize + bitpos > insv_bitsize))) + && (bitsize + bitpos > GET_MODE_BITSIZE (op_mode)))) { int xbitpos = bitpos; rtx value1; @@ -1042,18 +1037,8 @@ extract_bit_field (str_rtx, bitsize, bitnum, unsignedp, rtx spec_target = target; rtx spec_target_subreg = 0; enum machine_mode int_mode; - unsigned HOST_WIDE_INT extv_bitsize; - enum machine_mode extv_mode; - unsigned HOST_WIDE_INT extzv_bitsize; - enum machine_mode extzv_mode; - - extv_mode = mode_for_extraction (EP_extv, 0); - if (extv_mode != MAX_MACHINE_MODE) - extv_bitsize = GET_MODE_BITSIZE (extv_mode); - - extzv_mode = mode_for_extraction (EP_extzv, 0); - if (extzv_mode != MAX_MACHINE_MODE) - extzv_bitsize = GET_MODE_BITSIZE (extzv_mode); + enum machine_mode extv_mode = mode_for_extraction (EP_extv, 0); + enum machine_mode extzv_mode = mode_for_extraction (EP_extzv, 0); /* Discount the part of the structure before the desired byte. We need to know how many bytes are safe to reference after it. */ @@ -1287,10 +1272,10 @@ extract_bit_field (str_rtx, bitsize, bitnum, unsignedp, if (unsignedp) { - if (extzv_mode != MAX_MACHINE_MODE - && (extzv_bitsize >= bitsize) + if (HAVE_extzv + && (GET_MODE_BITSIZE (extzv_mode) >= bitsize) && ! ((GET_CODE (op0) == REG || GET_CODE (op0) == SUBREG) - && (bitsize + bitpos > extzv_bitsize))) + && (bitsize + bitpos > GET_MODE_BITSIZE (extzv_mode)))) { unsigned HOST_WIDE_INT xbitpos = bitpos, xoffset = offset; rtx bitsize_rtx, bitpos_rtx; @@ -1420,10 +1405,10 @@ extract_bit_field (str_rtx, bitsize, bitnum, unsignedp, } else { - if (extv_mode != MAX_MACHINE_MODE - && (extv_bitsize >= bitsize) + if (HAVE_extv + && (GET_MODE_BITSIZE (extv_mode) >= bitsize) && ! ((GET_CODE (op0) == REG || GET_CODE (op0) == SUBREG) - && (bitsize + bitpos > extv_bitsize))) + && (bitsize + bitpos > GET_MODE_BITSIZE (extv_mode)))) { int xbitpos = bitpos, xoffset = offset; rtx bitsize_rtx, bitpos_rtx; -- cgit v1.2.1