4.1.2-14
This commit is contained in:
parent
1c109062ac
commit
cdb0987e55
@ -1 +1 @@
|
||||
gcc-4.1.2-20070615.tar.bz2
|
||||
gcc-4.1.2-20070626.tar.bz2
|
||||
|
3619
gcc41-amdfam10.patch
3619
gcc41-amdfam10.patch
File diff suppressed because it is too large
Load Diff
@ -1,104 +0,0 @@
|
||||
--- libcpp/configure.ac.jj 2005-10-28 23:13:40.000000000 +0200
|
||||
+++ libcpp/configure.ac 2005-11-25 14:34:31.000000000 +0100
|
||||
@@ -112,6 +112,8 @@ fi
|
||||
|
||||
m4_changequote(,)
|
||||
case $target in
|
||||
+ powerpc-*-linux*)
|
||||
+ need_64bit_hwint=no ;;
|
||||
alpha*-*-* | \
|
||||
arm*-*-*eabi* | \
|
||||
arm*-*-symbianelf* | \
|
||||
--- libcpp/configure.jj 2005-10-28 23:13:40.000000000 +0200
|
||||
+++ libcpp/configure 2005-11-25 14:34:40.000000000 +0100
|
||||
@@ -8217,6 +8217,8 @@ fi
|
||||
|
||||
|
||||
case $target in
|
||||
+ powerpc-*-linux*)
|
||||
+ need_64bit_hwint=no ;;
|
||||
alpha*-*-* | \
|
||||
arm*-*-*eabi* | \
|
||||
arm*-*-symbianelf* | \
|
||||
--- gcc/config.gcc.jj 2005-11-19 09:27:16.000000000 +0100
|
||||
+++ gcc/config.gcc 2005-11-25 14:29:30.000000000 +0100
|
||||
@@ -294,7 +294,10 @@ mips*-*-*)
|
||||
powerpc*-*-*)
|
||||
cpu_type=rs6000
|
||||
extra_headers="ppc-asm.h altivec.h spe.h"
|
||||
- need_64bit_hwint=yes
|
||||
+ case ${target} in
|
||||
+ powerpc-*-linux*) ;;
|
||||
+ *) need_64bit_hwint=yes ;;
|
||||
+ esac
|
||||
case x$with_cpu in
|
||||
xpowerpc64|xdefault64|x6[23]0|x970|xG5|xpower[345]|xrs64a)
|
||||
cpu_is_64bit=yes
|
||||
--- gcc/gcc.c.jj 2005-11-19 21:16:39.000000000 +0100
|
||||
+++ gcc/gcc.c 2005-11-28 13:00:58.000000000 +0100
|
||||
@@ -3154,6 +3154,8 @@ process_command (int argc, const char **
|
||||
const char *spec_lang = 0;
|
||||
int last_language_n_infiles;
|
||||
int lang_n_infiles = 0;
|
||||
+ int hack32 = 1;
|
||||
+ int used_B = 0;
|
||||
#ifdef MODIFY_TARGET_NAME
|
||||
int is_modify_target_name;
|
||||
int j;
|
||||
@@ -3680,6 +3682,7 @@ warranty; not even for MERCHANTABILITY o
|
||||
PREFIX_PRIORITY_B_OPT, 0, 0);
|
||||
add_prefix (&include_prefixes, value, NULL,
|
||||
PREFIX_PRIORITY_B_OPT, 0, 0);
|
||||
+ used_B = 1;
|
||||
n_switches++;
|
||||
}
|
||||
break;
|
||||
@@ -3742,6 +3745,21 @@ warranty; not even for MERCHANTABILITY o
|
||||
#endif
|
||||
goto normal_switch;
|
||||
|
||||
+ /* HACK START */
|
||||
+ case 'm':
|
||||
+ if ((p[1] == '6' && p[2] == '4')
|
||||
+ || (p[1] == 'a' && strncmp (p + 2, "ltivec", 6) == 0)
|
||||
+ || (p[1] == 'c' && strncmp (p + 2, "pu=", 3) == 0
|
||||
+ && (strncmp (p + 5, "7400", 4) == 0
|
||||
+ || strncmp (p + 5, "7450", 4) == 0
|
||||
+ || strncmp (p + 5, "G4", 2) == 0
|
||||
+ || strncmp (p + 5, "970", 3) == 0
|
||||
+ || strncmp (p + 5, "G5", 2) == 0))
|
||||
+ || (p[1] == 'p' && strncmp (p + 2, "owerpc64", 8) == 0))
|
||||
+ hack32 = 0;
|
||||
+ /* FALLTHROUGH */
|
||||
+ /* HACK END */
|
||||
+
|
||||
default:
|
||||
normal_switch:
|
||||
|
||||
@@ -3812,6 +3830,26 @@ warranty; not even for MERCHANTABILITY o
|
||||
/* Use 2 as fourth arg meaning try just the machine as a suffix,
|
||||
as well as trying the machine and the version. */
|
||||
#ifndef OS2
|
||||
+ /* HACK START */
|
||||
+ if (hack32 && !used_B && !strncmp (spec_machine, "sparc64-", 8))
|
||||
+ {
|
||||
+ const char *sparc32_exec_prefix =
|
||||
+ concat (standard_libexec_prefix, "sparc-", spec_machine + 8,
|
||||
+ dir_separator_str, spec_version, dir_separator_str, NULL);
|
||||
+ add_prefix (&exec_prefixes, sparc32_exec_prefix, "GCC",
|
||||
+ PREFIX_PRIORITY_LAST, 0, 0);
|
||||
+ }
|
||||
+ /* HACK END */
|
||||
+ /* HACK START */
|
||||
+ if (hack32 && !used_B && !strncmp (spec_machine, "ppc64-", 6))
|
||||
+ {
|
||||
+ const char *ppc32_exec_prefix =
|
||||
+ concat (standard_libexec_prefix, "ppc-", spec_machine + 6,
|
||||
+ dir_separator_str, spec_version, dir_separator_str, NULL);
|
||||
+ add_prefix (&exec_prefixes, ppc32_exec_prefix, "GCC",
|
||||
+ PREFIX_PRIORITY_LAST, 0, 0);
|
||||
+ }
|
||||
+ /* HACK END */
|
||||
add_prefix (&exec_prefixes, standard_libexec_prefix, "GCC",
|
||||
PREFIX_PRIORITY_LAST, 1, 0);
|
||||
add_prefix (&exec_prefixes, standard_libexec_prefix, "BINUTILS",
|
@ -1,28 +0,0 @@
|
||||
2006-04-06 Jakub Jelinek <jakub@redhat.com>
|
||||
|
||||
* objc/compile/20060406-1.m: New test.
|
||||
|
||||
--- gcc/testsuite/objc/compile/20060406-1.m.jj 2006-04-06 17:25:59.000000000 +0200
|
||||
+++ gcc/testsuite/objc/compile/20060406-1.m 2006-04-06 17:20:48.000000000 +0200
|
||||
@@ -0,0 +1,21 @@
|
||||
+typedef struct
|
||||
+{
|
||||
+ void *p;
|
||||
+} *S;
|
||||
+
|
||||
+@protocol O
|
||||
+- (unsigned)j;
|
||||
+@end
|
||||
+
|
||||
+@interface I
|
||||
++ (unsigned char)T:(S<O>[2])p v:(S<O>)h;
|
||||
+@end
|
||||
+
|
||||
+@implementation I
|
||||
++ (unsigned char)T:(S<O>[2])p v:(S<O>)h
|
||||
+{
|
||||
+ p[0] = (S) 0;
|
||||
+ p[1] = (S) 0;
|
||||
+ return 0;
|
||||
+}
|
||||
+@end
|
@ -1,302 +0,0 @@
|
||||
2006-12-21 Jakub Jelinek <jakub@redhat.com>
|
||||
|
||||
Revert:
|
||||
2006-12-16 Joseph Myers <joseph@codesourcery.com>
|
||||
David Edelsohn <edelsohn@gnu.org>
|
||||
PR target/24036
|
||||
* doc/tm.texi (HARD_REGNO_NREGS_HAS_PADDING,
|
||||
HARD_REGNO_NREGS_WITH_PADDING): Document new target macros.
|
||||
* defaults.h (HARD_REGNO_NREGS_HAS_PADDING,
|
||||
HARD_REGNO_NREGS_WITH_PADDING): Define.
|
||||
* config/i386/i386.h (HARD_REGNO_NREGS_HAS_PADDING,
|
||||
HARD_REGNO_NREGS_WITH_PADDING): Define.
|
||||
* rtlanal.c (subreg_regno_offset, subreg_offset_representable_p):
|
||||
Use new macros to detect modes with holes; do not look at integer
|
||||
units.
|
||||
(subreg_offset_representable_p): Check for and disallow cases
|
||||
where the modes use different numbers of bits from registers.
|
||||
* config/rs6000/rs6000.c (rs6000_emit_move): Handle TFmode
|
||||
constant for soft-float.
|
||||
(rs6000_hard_regno_nregs): Use UNITS_PER_FP_WORD for e500 GPRs
|
||||
containing doubles.
|
||||
(rs6000_split_multireg_move): Use DFmode reg_mode for TFmode moves
|
||||
in E500 double case.
|
||||
* config/rs6000/rs6000.md (movtf): Allow soft-float.
|
||||
(movtf_softfloat): New.
|
||||
|
||||
--- gcc/doc/tm.texi (revision 119967)
|
||||
+++ gcc/doc/tm.texi (revision 119966)
|
||||
@@ -1937,33 +1937,6 @@ definition of this macro is
|
||||
@end smallexample
|
||||
@end defmac
|
||||
|
||||
-@defmac HARD_REGNO_NREGS_HAS_PADDING (@var{regno}, @var{mode})
|
||||
-A C expression that is nonzero if a value of mode @var{mode}, stored
|
||||
-in memory, ends with padding that causes it to take up more space than
|
||||
-in registers starting at register number @var{regno} (as determined by
|
||||
-multiplying GCC's notion of the size of the register when containing
|
||||
-this mode by the number of registers returned by
|
||||
-@code{HARD_REGNO_NREGS}). By default this is zero.
|
||||
-
|
||||
-For example, if a floating-point value is stored in three 32-bit
|
||||
-registers but takes up 128 bits in memory, then this would be
|
||||
-nonzero.
|
||||
-
|
||||
-This macros only needs to be defined if there are cases where
|
||||
-@code{subreg_regno_offset} and @code{subreg_offset_representable_p}
|
||||
-would otherwise wrongly determine that a @code{subreg} can be
|
||||
-represented by an offset to the register number, when in fact such a
|
||||
-@code{subreg} would contain some of the padding not stored in
|
||||
-registers and so not be representable.
|
||||
-@end defmac
|
||||
-
|
||||
-@defmac HARD_REGNO_NREGS_WITH_PADDING (@var{regno}, @var{mode})
|
||||
-For values of @var{regno} and @var{mode} for which
|
||||
-@code{HARD_REGNO_NREGS_HAS_PADDING} returns nonzero, a C expression
|
||||
-returning the greater number of registers required to hold the value
|
||||
-including any padding. In the example above, the value would be four.
|
||||
-@end defmac
|
||||
-
|
||||
@defmac REGMODE_NATURAL_SIZE (@var{mode})
|
||||
Define this macro if the natural size of registers that hold values
|
||||
of mode @var{mode} is not the word size. It is a C expression that
|
||||
--- gcc/defaults.h (revision 119967)
|
||||
+++ gcc/defaults.h (revision 119966)
|
||||
@@ -867,9 +867,4 @@ Software Foundation, 51 Franklin Street,
|
||||
#define INCOMING_FRAME_SP_OFFSET 0
|
||||
#endif
|
||||
|
||||
-#ifndef HARD_REGNO_NREGS_HAS_PADDING
|
||||
-#define HARD_REGNO_NREGS_HAS_PADDING(REGNO, MODE) 0
|
||||
-#define HARD_REGNO_NREGS_WITH_PADDING(REGNO, MODE) -1
|
||||
-#endif
|
||||
-
|
||||
#endif /* ! GCC_DEFAULTS_H */
|
||||
--- gcc/rtlanal.c (revision 119967)
|
||||
+++ gcc/rtlanal.c (revision 119966)
|
||||
@@ -3138,15 +3138,34 @@ unsigned int
|
||||
subreg_regno_offset (unsigned int xregno, enum machine_mode xmode,
|
||||
unsigned int offset, enum machine_mode ymode)
|
||||
{
|
||||
- int nregs_xmode, nregs_ymode;
|
||||
+ int nregs_xmode, nregs_ymode, nregs_xmode_unit_int;
|
||||
int mode_multiple, nregs_multiple;
|
||||
int y_offset;
|
||||
+ enum machine_mode xmode_unit, xmode_unit_int;
|
||||
|
||||
gcc_assert (xregno < FIRST_PSEUDO_REGISTER);
|
||||
|
||||
+ if (GET_MODE_INNER (xmode) == VOIDmode)
|
||||
+ xmode_unit = xmode;
|
||||
+ else
|
||||
+ xmode_unit = GET_MODE_INNER (xmode);
|
||||
+
|
||||
+ if (FLOAT_MODE_P (xmode_unit))
|
||||
+ {
|
||||
+ xmode_unit_int = int_mode_for_mode (xmode_unit);
|
||||
+ if (xmode_unit_int == BLKmode)
|
||||
+ /* It's probably bad to be here; a port should have an integer mode
|
||||
+ that's the same size as anything of which it takes a SUBREG. */
|
||||
+ xmode_unit_int = xmode_unit;
|
||||
+ }
|
||||
+ else
|
||||
+ xmode_unit_int = xmode_unit;
|
||||
+
|
||||
+ nregs_xmode_unit_int = hard_regno_nregs[xregno][xmode_unit_int];
|
||||
+
|
||||
/* Adjust nregs_xmode to allow for 'holes'. */
|
||||
- if (HARD_REGNO_NREGS_HAS_PADDING (xregno, xmode))
|
||||
- nregs_xmode = HARD_REGNO_NREGS_WITH_PADDING (xregno, xmode);
|
||||
+ if (nregs_xmode_unit_int != hard_regno_nregs[xregno][xmode_unit])
|
||||
+ nregs_xmode = nregs_xmode_unit_int * GET_MODE_NUNITS (xmode);
|
||||
else
|
||||
nregs_xmode = hard_regno_nregs[xregno][xmode];
|
||||
|
||||
@@ -3184,31 +3203,38 @@ bool
|
||||
subreg_offset_representable_p (unsigned int xregno, enum machine_mode xmode,
|
||||
unsigned int offset, enum machine_mode ymode)
|
||||
{
|
||||
- int nregs_xmode, nregs_ymode;
|
||||
+ int nregs_xmode, nregs_ymode, nregs_xmode_unit, nregs_xmode_unit_int;
|
||||
int mode_multiple, nregs_multiple;
|
||||
int y_offset;
|
||||
- int regsize_xmode, regsize_ymode;
|
||||
+ enum machine_mode xmode_unit, xmode_unit_int;
|
||||
|
||||
gcc_assert (xregno < FIRST_PSEUDO_REGISTER);
|
||||
|
||||
+ if (GET_MODE_INNER (xmode) == VOIDmode)
|
||||
+ xmode_unit = xmode;
|
||||
+ else
|
||||
+ xmode_unit = GET_MODE_INNER (xmode);
|
||||
+
|
||||
+ if (FLOAT_MODE_P (xmode_unit))
|
||||
+ {
|
||||
+ xmode_unit_int = int_mode_for_mode (xmode_unit);
|
||||
+ if (xmode_unit_int == BLKmode)
|
||||
+ /* It's probably bad to be here; a port should have an integer mode
|
||||
+ that's the same size as anything of which it takes a SUBREG. */
|
||||
+ xmode_unit_int = xmode_unit;
|
||||
+ }
|
||||
+ else
|
||||
+ xmode_unit_int = xmode_unit;
|
||||
+
|
||||
+ nregs_xmode_unit = hard_regno_nregs[xregno][xmode_unit];
|
||||
+ nregs_xmode_unit_int = hard_regno_nregs[xregno][xmode_unit_int];
|
||||
+
|
||||
/* If there are holes in a non-scalar mode in registers, we expect
|
||||
that it is made up of its units concatenated together. */
|
||||
- if (HARD_REGNO_NREGS_HAS_PADDING (xregno, xmode))
|
||||
+ if (nregs_xmode_unit != nregs_xmode_unit_int)
|
||||
{
|
||||
- enum machine_mode xmode_unit;
|
||||
-
|
||||
- nregs_xmode = HARD_REGNO_NREGS_WITH_PADDING (xregno, xmode);
|
||||
- if (GET_MODE_INNER (xmode) == VOIDmode)
|
||||
- xmode_unit = xmode;
|
||||
- else
|
||||
- xmode_unit = GET_MODE_INNER (xmode);
|
||||
- gcc_assert (HARD_REGNO_NREGS_HAS_PADDING (xregno, xmode_unit));
|
||||
- gcc_assert (nregs_xmode
|
||||
- == (GET_MODE_NUNITS (xmode)
|
||||
- * HARD_REGNO_NREGS_WITH_PADDING (xregno, xmode_unit)));
|
||||
- gcc_assert (hard_regno_nregs[xregno][xmode]
|
||||
- == (hard_regno_nregs[xregno][xmode_unit]
|
||||
- * GET_MODE_NUNITS (xmode)));
|
||||
+ gcc_assert (nregs_xmode_unit * GET_MODE_NUNITS (xmode)
|
||||
+ == hard_regno_nregs[xregno][xmode]);
|
||||
|
||||
/* You can only ask for a SUBREG of a value with holes in the middle
|
||||
if you don't cross the holes. (Such a SUBREG should be done by
|
||||
@@ -3218,12 +3244,15 @@ subreg_offset_representable_p (unsigned
|
||||
3 for each part, but in memory it's two 128-bit parts.
|
||||
Padding is assumed to be at the end (not necessarily the 'high part')
|
||||
of each unit. */
|
||||
- if ((offset / GET_MODE_SIZE (xmode_unit) + 1
|
||||
- < GET_MODE_NUNITS (xmode))
|
||||
- && (offset / GET_MODE_SIZE (xmode_unit)
|
||||
+ if (nregs_xmode_unit != nregs_xmode_unit_int
|
||||
+ && (offset / GET_MODE_SIZE (xmode_unit_int) + 1
|
||||
+ < GET_MODE_NUNITS (xmode))
|
||||
+ && (offset / GET_MODE_SIZE (xmode_unit_int)
|
||||
!= ((offset + GET_MODE_SIZE (ymode) - 1)
|
||||
- / GET_MODE_SIZE (xmode_unit))))
|
||||
+ / GET_MODE_SIZE (xmode_unit_int))))
|
||||
return false;
|
||||
+
|
||||
+ nregs_xmode = nregs_xmode_unit_int * GET_MODE_NUNITS (xmode);
|
||||
}
|
||||
else
|
||||
nregs_xmode = hard_regno_nregs[xregno][xmode];
|
||||
@@ -3237,15 +3266,6 @@ subreg_offset_representable_p (unsigned
|
||||
? WORDS_BIG_ENDIAN : BYTES_BIG_ENDIAN))
|
||||
return true;
|
||||
|
||||
- /* If registers store different numbers of bits in the different
|
||||
- modes, we cannot generally form this subreg. */
|
||||
- regsize_xmode = GET_MODE_SIZE (xmode) / nregs_xmode;
|
||||
- regsize_ymode = GET_MODE_SIZE (ymode) / nregs_ymode;
|
||||
- if (regsize_xmode > regsize_ymode && nregs_ymode > 1)
|
||||
- return false;
|
||||
- if (regsize_ymode > regsize_xmode && nregs_xmode > 1)
|
||||
- return false;
|
||||
-
|
||||
/* Lowpart subregs are otherwise valid. */
|
||||
if (offset == subreg_lowpart_offset (ymode, xmode))
|
||||
return true;
|
||||
--- gcc/config/i386/i386.h (revision 119967)
|
||||
+++ gcc/config/i386/i386.h (revision 119966)
|
||||
@@ -827,15 +827,6 @@ do { \
|
||||
? (TARGET_64BIT ? 4 : 6) \
|
||||
: ((GET_MODE_SIZE (MODE) + UNITS_PER_WORD - 1) / UNITS_PER_WORD)))
|
||||
|
||||
-#define HARD_REGNO_NREGS_HAS_PADDING(REGNO, MODE) \
|
||||
- ((TARGET_128BIT_LONG_DOUBLE && !TARGET_64BIT) \
|
||||
- ? (FP_REGNO_P (REGNO) || SSE_REGNO_P (REGNO) || MMX_REGNO_P (REGNO) \
|
||||
- ? 0 \
|
||||
- : ((MODE) == XFmode || (MODE) == XCmode)) \
|
||||
- : 0)
|
||||
-
|
||||
-#define HARD_REGNO_NREGS_WITH_PADDING(REGNO, MODE) ((MODE) == XFmode ? 4 : 8)
|
||||
-
|
||||
#define VALID_SSE2_REG_MODE(MODE) \
|
||||
((MODE) == V16QImode || (MODE) == V8HImode || (MODE) == V2DFmode \
|
||||
|| (MODE) == V2DImode || (MODE) == DFmode)
|
||||
--- gcc/config/rs6000/rs6000.c (revision 119967)
|
||||
+++ gcc/config/rs6000/rs6000.c (revision 119966)
|
||||
@@ -3573,6 +3573,9 @@ rs6000_hard_regno_nregs (int regno, enum
|
||||
if (FP_REGNO_P (regno))
|
||||
return (GET_MODE_SIZE (mode) + UNITS_PER_FP_WORD - 1) / UNITS_PER_FP_WORD;
|
||||
|
||||
+ if (TARGET_E500_DOUBLE && mode == DFmode)
|
||||
+ return 1;
|
||||
+
|
||||
if (SPE_SIMD_REGNO_P (regno) && TARGET_SPE && SPE_VECTOR_MODE (mode))
|
||||
return (GET_MODE_SIZE (mode) + UNITS_PER_SPE_WORD - 1) / UNITS_PER_SPE_WORD;
|
||||
|
||||
@@ -3580,14 +3583,6 @@ rs6000_hard_regno_nregs (int regno, enum
|
||||
return
|
||||
(GET_MODE_SIZE (mode) + UNITS_PER_ALTIVEC_WORD - 1) / UNITS_PER_ALTIVEC_WORD;
|
||||
|
||||
- /* The value returned for SCmode in the E500 double case is 2 for
|
||||
- ABI compatibility; storing an SCmode value in a single register
|
||||
- would require function_arg and rs6000_spe_function_arg to handle
|
||||
- SCmode so as to pass the value correctly in a pair of
|
||||
- registers. */
|
||||
- if (TARGET_E500_DOUBLE && FLOAT_MODE_P (mode) && mode != SCmode)
|
||||
- return (GET_MODE_SIZE (mode) + UNITS_PER_FP_WORD - 1) / UNITS_PER_FP_WORD;
|
||||
-
|
||||
return (GET_MODE_SIZE (mode) + UNITS_PER_WORD - 1) / UNITS_PER_WORD;
|
||||
}
|
||||
|
||||
@@ -3956,7 +3951,8 @@ rs6000_emit_move (rtx dest, rtx source,
|
||||
|
||||
/* 128-bit constant floating-point values on Darwin should really be
|
||||
loaded as two parts. */
|
||||
- if (!TARGET_IEEEQUAD && TARGET_LONG_DOUBLE_128
|
||||
+ if (!TARGET_IEEEQUAD
|
||||
+ && TARGET_HARD_FLOAT && TARGET_FPRS && TARGET_LONG_DOUBLE_128
|
||||
&& mode == TFmode && GET_CODE (operands[1]) == CONST_DOUBLE)
|
||||
{
|
||||
/* DImode is used, not DFmode, because simplify_gen_subreg doesn't
|
||||
@@ -12402,8 +12398,6 @@ rs6000_split_multireg_move (rtx dst, rtx
|
||||
reg_mode = DFmode;
|
||||
else if (ALTIVEC_REGNO_P (reg))
|
||||
reg_mode = V16QImode;
|
||||
- else if (TARGET_E500_DOUBLE && mode == TFmode)
|
||||
- reg_mode = DFmode;
|
||||
else
|
||||
reg_mode = word_mode;
|
||||
reg_mode_size = GET_MODE_SIZE (reg_mode);
|
||||
--- gcc/config/rs6000/rs6000.md (revision 119967)
|
||||
+++ gcc/config/rs6000/rs6000.md (revision 119966)
|
||||
@@ -7789,7 +7789,8 @@ (define_insn "*movdf_softfloat64"
|
||||
(define_expand "movtf"
|
||||
[(set (match_operand:TF 0 "general_operand" "")
|
||||
(match_operand:TF 1 "any_operand" ""))]
|
||||
- "!TARGET_IEEEQUAD && TARGET_LONG_DOUBLE_128"
|
||||
+ "!TARGET_IEEEQUAD
|
||||
+ && TARGET_HARD_FLOAT && TARGET_FPRS && TARGET_LONG_DOUBLE_128"
|
||||
"{ rs6000_emit_move (operands[0], operands[1], TFmode); DONE; }")
|
||||
|
||||
; It's important to list the o->f and f->o moves before f->f because
|
||||
@@ -7808,19 +7809,6 @@ (define_insn_and_split "*movtf_internal"
|
||||
{ rs6000_split_multireg_move (operands[0], operands[1]); DONE; }
|
||||
[(set_attr "length" "8,8,8,20,20,16")])
|
||||
|
||||
-(define_insn_and_split "*movtf_softfloat"
|
||||
- [(set (match_operand:TF 0 "nonimmediate_operand" "=r,Y,r")
|
||||
- (match_operand:TF 1 "input_operand" "YGHF,r,r"))]
|
||||
- "!TARGET_IEEEQUAD
|
||||
- && (TARGET_SOFT_FLOAT || !TARGET_FPRS) && TARGET_LONG_DOUBLE_128
|
||||
- && (gpc_reg_operand (operands[0], TFmode)
|
||||
- || gpc_reg_operand (operands[1], TFmode))"
|
||||
- "#"
|
||||
- "&& reload_completed"
|
||||
- [(pc)]
|
||||
-{ rs6000_split_multireg_move (operands[0], operands[1]); DONE; }
|
||||
- [(set_attr "length" "20,20,16")])
|
||||
-
|
||||
(define_expand "extenddftf2"
|
||||
[(parallel [(set (match_operand:TF 0 "nonimmediate_operand" "")
|
||||
(float_extend:TF (match_operand:DF 1 "input_operand" "")))
|
@ -1,439 +0,0 @@
|
||||
2006-09-01 Jakub Jelinek <jakub@redhat.com>
|
||||
|
||||
PR middle-end/27567
|
||||
* builtins.c (fold_builtin_memcpy, fold_builtin_memmove): Remove.
|
||||
(fold_builtin_mempcpy): Rename to...
|
||||
(fold_builtin_memory_op): ... this. Optimize one element copy
|
||||
into an assignment.
|
||||
(fold_builtin_memset, fold_builtin_bzero, fold_builtin_bcopy): New
|
||||
functions.
|
||||
(expand_builtin_strcpy, expand_builtin_strncpy): Handle COMPOUND_EXPR.
|
||||
(expand_builtin_memcpy, expand_builtin_mempcpy,
|
||||
expand_builtin_memmove): Likewise. Use fold_builtin_memory_op.
|
||||
(fold_builtin_1): Handle BUILT_IN_MEMSET, BUILT_IN_BZERO and
|
||||
BUILT_IN_BCOPY. Use fold_builtin_memory_op for
|
||||
BUILT_IN_MEM{CPY,PCPY,MOVE}.
|
||||
|
||||
--- gcc/builtins.c.jj 2006-08-28 13:00:23.000000000 +0200
|
||||
+++ gcc/builtins.c 2006-09-01 11:55:51.000000000 +0200
|
||||
@@ -160,9 +160,7 @@ static tree fold_builtin_ceil (tree, tre
|
||||
static tree fold_builtin_round (tree, tree);
|
||||
static tree fold_builtin_int_roundingfn (tree, tree);
|
||||
static tree fold_builtin_bitop (tree, tree);
|
||||
-static tree fold_builtin_memcpy (tree, tree);
|
||||
-static tree fold_builtin_mempcpy (tree, tree, int);
|
||||
-static tree fold_builtin_memmove (tree, tree);
|
||||
+static tree fold_builtin_memory_op (tree, tree, bool, int);
|
||||
static tree fold_builtin_strchr (tree, tree);
|
||||
static tree fold_builtin_memcmp (tree);
|
||||
static tree fold_builtin_strcmp (tree);
|
||||
@@ -2890,10 +2888,19 @@ expand_builtin_memcpy (tree exp, rtx tar
|
||||
unsigned int dest_align
|
||||
= get_pointer_alignment (dest, BIGGEST_ALIGNMENT);
|
||||
rtx dest_mem, src_mem, dest_addr, len_rtx;
|
||||
- tree result = fold_builtin_memcpy (fndecl, arglist);
|
||||
+ tree result = fold_builtin_memory_op (arglist, TREE_TYPE (TREE_TYPE (fndecl)),
|
||||
+ false, /*endp=*/0);
|
||||
|
||||
if (result)
|
||||
- return expand_expr (result, target, mode, EXPAND_NORMAL);
|
||||
+ {
|
||||
+ while (TREE_CODE (result) == COMPOUND_EXPR)
|
||||
+ {
|
||||
+ expand_expr (TREE_OPERAND (result, 0), const0_rtx, VOIDmode,
|
||||
+ EXPAND_NORMAL);
|
||||
+ result = TREE_OPERAND (result, 1);
|
||||
+ }
|
||||
+ return expand_expr (result, target, mode, EXPAND_NORMAL);
|
||||
+ }
|
||||
|
||||
/* If DEST is not a pointer type, call the normal function. */
|
||||
if (dest_align == 0)
|
||||
@@ -2979,11 +2986,19 @@ expand_builtin_mempcpy (tree arglist, tr
|
||||
unsigned int dest_align
|
||||
= get_pointer_alignment (dest, BIGGEST_ALIGNMENT);
|
||||
rtx dest_mem, src_mem, len_rtx;
|
||||
- tree result = fold_builtin_mempcpy (arglist, type, endp);
|
||||
+ tree result = fold_builtin_memory_op (arglist, type, false, endp);
|
||||
|
||||
if (result)
|
||||
- return expand_expr (result, target, mode, EXPAND_NORMAL);
|
||||
-
|
||||
+ {
|
||||
+ while (TREE_CODE (result) == COMPOUND_EXPR)
|
||||
+ {
|
||||
+ expand_expr (TREE_OPERAND (result, 0), const0_rtx, VOIDmode,
|
||||
+ EXPAND_NORMAL);
|
||||
+ result = TREE_OPERAND (result, 1);
|
||||
+ }
|
||||
+ return expand_expr (result, target, mode, EXPAND_NORMAL);
|
||||
+ }
|
||||
+
|
||||
/* If either SRC or DEST is not a pointer type, don't do this
|
||||
operation in-line. */
|
||||
if (dest_align == 0 || src_align == 0)
|
||||
@@ -3053,10 +3068,18 @@ expand_builtin_memmove (tree arglist, tr
|
||||
unsigned int src_align = get_pointer_alignment (src, BIGGEST_ALIGNMENT);
|
||||
unsigned int dest_align
|
||||
= get_pointer_alignment (dest, BIGGEST_ALIGNMENT);
|
||||
- tree result = fold_builtin_memmove (arglist, type);
|
||||
+ tree result = fold_builtin_memory_op (arglist, type, false, /*endp=*/3);
|
||||
|
||||
if (result)
|
||||
- return expand_expr (result, target, mode, EXPAND_NORMAL);
|
||||
+ {
|
||||
+ while (TREE_CODE (result) == COMPOUND_EXPR)
|
||||
+ {
|
||||
+ expand_expr (TREE_OPERAND (result, 0), const0_rtx, VOIDmode,
|
||||
+ EXPAND_NORMAL);
|
||||
+ result = TREE_OPERAND (result, 1);
|
||||
+ }
|
||||
+ return expand_expr (result, target, mode, EXPAND_NORMAL);
|
||||
+ }
|
||||
|
||||
/* If DEST is not a pointer type, call the normal function. */
|
||||
if (dest_align == 0)
|
||||
@@ -3204,7 +3227,15 @@ expand_builtin_strcpy (tree fndecl, tree
|
||||
{
|
||||
tree result = fold_builtin_strcpy (fndecl, arglist, 0);
|
||||
if (result)
|
||||
- return expand_expr (result, target, mode, EXPAND_NORMAL);
|
||||
+ {
|
||||
+ while (TREE_CODE (result) == COMPOUND_EXPR)
|
||||
+ {
|
||||
+ expand_expr (TREE_OPERAND (result, 0), const0_rtx, VOIDmode,
|
||||
+ EXPAND_NORMAL);
|
||||
+ result = TREE_OPERAND (result, 1);
|
||||
+ }
|
||||
+ return expand_expr (result, target, mode, EXPAND_NORMAL);
|
||||
+ }
|
||||
|
||||
return expand_movstr (TREE_VALUE (arglist),
|
||||
TREE_VALUE (TREE_CHAIN (arglist)),
|
||||
@@ -3330,7 +3361,15 @@ expand_builtin_strncpy (tree exp, rtx ta
|
||||
tree result = fold_builtin_strncpy (fndecl, arglist, slen);
|
||||
|
||||
if (result)
|
||||
- return expand_expr (result, target, mode, EXPAND_NORMAL);
|
||||
+ {
|
||||
+ while (TREE_CODE (result) == COMPOUND_EXPR)
|
||||
+ {
|
||||
+ expand_expr (TREE_OPERAND (result, 0), const0_rtx, VOIDmode,
|
||||
+ EXPAND_NORMAL);
|
||||
+ result = TREE_OPERAND (result, 1);
|
||||
+ }
|
||||
+ return expand_expr (result, target, mode, EXPAND_NORMAL);
|
||||
+ }
|
||||
|
||||
/* We must be passed a constant len and src parameter. */
|
||||
if (!host_integerp (len, 1) || !slen || !host_integerp (slen, 1))
|
||||
@@ -7982,78 +8021,121 @@ fold_builtin_exponent (tree fndecl, tree
|
||||
return 0;
|
||||
}
|
||||
|
||||
-/* Fold function call to builtin memcpy. Return
|
||||
+/* Fold function call to builtin memset. Return
|
||||
NULL_TREE if no simplification can be made. */
|
||||
|
||||
static tree
|
||||
-fold_builtin_memcpy (tree fndecl, tree arglist)
|
||||
+fold_builtin_memset (tree arglist, tree type, bool ignore)
|
||||
{
|
||||
- tree dest, src, len;
|
||||
+ tree dest, c, len, var, ret;
|
||||
+ unsigned HOST_WIDE_INT length, cval;
|
||||
|
||||
if (!validate_arglist (arglist,
|
||||
- POINTER_TYPE, POINTER_TYPE, INTEGER_TYPE, VOID_TYPE))
|
||||
+ POINTER_TYPE, INTEGER_TYPE, INTEGER_TYPE, VOID_TYPE))
|
||||
return 0;
|
||||
|
||||
dest = TREE_VALUE (arglist);
|
||||
- src = TREE_VALUE (TREE_CHAIN (arglist));
|
||||
+ c = TREE_VALUE (TREE_CHAIN (arglist));
|
||||
len = TREE_VALUE (TREE_CHAIN (TREE_CHAIN (arglist)));
|
||||
|
||||
+ if (! host_integerp (len, 1))
|
||||
+ return 0;
|
||||
+
|
||||
/* If the LEN parameter is zero, return DEST. */
|
||||
if (integer_zerop (len))
|
||||
- return omit_one_operand (TREE_TYPE (TREE_TYPE (fndecl)), dest, src);
|
||||
+ return omit_one_operand (type, dest, c);
|
||||
|
||||
- /* If SRC and DEST are the same (and not volatile), return DEST. */
|
||||
- if (operand_equal_p (src, dest, 0))
|
||||
- return omit_one_operand (TREE_TYPE (TREE_TYPE (fndecl)), dest, len);
|
||||
+ if (! host_integerp (c, 1) || TREE_SIDE_EFFECTS (dest))
|
||||
+ return 0;
|
||||
|
||||
- return 0;
|
||||
+ var = dest;
|
||||
+ STRIP_NOPS (var);
|
||||
+ if (TREE_CODE (var) != ADDR_EXPR)
|
||||
+ return 0;
|
||||
+
|
||||
+ var = TREE_OPERAND (var, 0);
|
||||
+ if (TREE_THIS_VOLATILE (var))
|
||||
+ return 0;
|
||||
+
|
||||
+ if (!INTEGRAL_TYPE_P (TREE_TYPE (var))
|
||||
+ && !POINTER_TYPE_P (TREE_TYPE (var)))
|
||||
+ return 0;
|
||||
+
|
||||
+ length = tree_low_cst (len, 1);
|
||||
+ if (GET_MODE_SIZE (TYPE_MODE (TREE_TYPE (var))) != length
|
||||
+ || get_pointer_alignment (dest, BIGGEST_ALIGNMENT) / BITS_PER_UNIT
|
||||
+ < (int) length)
|
||||
+ return 0;
|
||||
+
|
||||
+ if (length > HOST_BITS_PER_WIDE_INT / BITS_PER_UNIT)
|
||||
+ return 0;
|
||||
+
|
||||
+ if (integer_zerop (c))
|
||||
+ cval = 0;
|
||||
+ else
|
||||
+ {
|
||||
+ if (CHAR_BIT != 8 || BITS_PER_UNIT != 8 || HOST_BITS_PER_WIDE_INT > 64)
|
||||
+ return 0;
|
||||
+
|
||||
+ cval = tree_low_cst (c, 1);
|
||||
+ cval &= 0xff;
|
||||
+ cval |= cval << 8;
|
||||
+ cval |= cval << 16;
|
||||
+ cval |= (cval << 31) << 1;
|
||||
+ }
|
||||
+
|
||||
+ ret = build_int_cst_type (TREE_TYPE (var), cval);
|
||||
+ ret = build2 (MODIFY_EXPR, TREE_TYPE (var), var, ret);
|
||||
+ if (ignore)
|
||||
+ return ret;
|
||||
+
|
||||
+ return omit_one_operand (type, dest, ret);
|
||||
}
|
||||
|
||||
-/* Fold function call to builtin mempcpy. Return
|
||||
+/* Fold function call to builtin memset. Return
|
||||
NULL_TREE if no simplification can be made. */
|
||||
|
||||
static tree
|
||||
-fold_builtin_mempcpy (tree arglist, tree type, int endp)
|
||||
+fold_builtin_bzero (tree arglist, bool ignore)
|
||||
{
|
||||
- if (validate_arglist (arglist,
|
||||
- POINTER_TYPE, POINTER_TYPE, INTEGER_TYPE, VOID_TYPE))
|
||||
- {
|
||||
- tree dest = TREE_VALUE (arglist);
|
||||
- tree src = TREE_VALUE (TREE_CHAIN (arglist));
|
||||
- tree len = TREE_VALUE (TREE_CHAIN (TREE_CHAIN (arglist)));
|
||||
+ tree dest, size, newarglist;
|
||||
|
||||
- /* If the LEN parameter is zero, return DEST. */
|
||||
- if (integer_zerop (len))
|
||||
- return omit_one_operand (type, dest, src);
|
||||
+ if (!validate_arglist (arglist, POINTER_TYPE, INTEGER_TYPE, VOID_TYPE))
|
||||
+ return 0;
|
||||
|
||||
- /* If SRC and DEST are the same (and not volatile), return DEST+LEN. */
|
||||
- if (operand_equal_p (src, dest, 0))
|
||||
- {
|
||||
- if (endp == 0)
|
||||
- return omit_one_operand (type, dest, len);
|
||||
+ if (!ignore)
|
||||
+ return 0;
|
||||
|
||||
- if (endp == 2)
|
||||
- len = fold_build2 (MINUS_EXPR, TREE_TYPE (len), len,
|
||||
- ssize_int (1));
|
||||
-
|
||||
- len = fold_convert (TREE_TYPE (dest), len);
|
||||
- len = fold_build2 (PLUS_EXPR, TREE_TYPE (dest), dest, len);
|
||||
- return fold_convert (type, len);
|
||||
- }
|
||||
- }
|
||||
- return 0;
|
||||
+ dest = TREE_VALUE (arglist);
|
||||
+ size = TREE_VALUE (TREE_CHAIN (arglist));
|
||||
+
|
||||
+ /* New argument list transforming bzero(ptr x, int y) to
|
||||
+ memset(ptr x, int 0, size_t y). This is done this way
|
||||
+ so that if it isn't expanded inline, we fallback to
|
||||
+ calling bzero instead of memset. */
|
||||
+
|
||||
+ newarglist = build_tree_list (NULL_TREE, fold_convert (sizetype, size));
|
||||
+ newarglist = tree_cons (NULL_TREE, integer_zero_node, newarglist);
|
||||
+ newarglist = tree_cons (NULL_TREE, dest, newarglist);
|
||||
+ return fold_builtin_memset (newarglist, void_type_node, ignore);
|
||||
}
|
||||
|
||||
-/* Fold function call to builtin memmove. Return
|
||||
- NULL_TREE if no simplification can be made. */
|
||||
+/* Fold function call to builtin mem{{,p}cpy,move}. Return
|
||||
+ NULL_TREE if no simplification can be made.
|
||||
+ If ENDP is 0, return DEST (like memcpy).
|
||||
+ If ENDP is 1, return DEST+LEN (like mempcpy).
|
||||
+ If ENDP is 2, return DEST+LEN-1 (like stpcpy).
|
||||
+ If ENDP is 3, return DEST, additionally *SRC and *DEST may overlap
|
||||
+ (memmove). */
|
||||
|
||||
static tree
|
||||
-fold_builtin_memmove (tree arglist, tree type)
|
||||
+fold_builtin_memory_op (tree arglist, tree type, bool ignore, int endp)
|
||||
{
|
||||
- tree dest, src, len;
|
||||
+ tree dest, src, len, destvar, srcvar, expr;
|
||||
+ unsigned HOST_WIDE_INT length;
|
||||
|
||||
- if (!validate_arglist (arglist,
|
||||
- POINTER_TYPE, POINTER_TYPE, INTEGER_TYPE, VOID_TYPE))
|
||||
+ if (! validate_arglist (arglist,
|
||||
+ POINTER_TYPE, POINTER_TYPE, INTEGER_TYPE, VOID_TYPE))
|
||||
return 0;
|
||||
|
||||
dest = TREE_VALUE (arglist);
|
||||
@@ -8064,11 +8146,115 @@ fold_builtin_memmove (tree arglist, tree
|
||||
if (integer_zerop (len))
|
||||
return omit_one_operand (type, dest, src);
|
||||
|
||||
- /* If SRC and DEST are the same (and not volatile), return DEST. */
|
||||
+ /* If SRC and DEST are the same (and not volatile), return
|
||||
+ DEST{,+LEN,+LEN-1}. */
|
||||
if (operand_equal_p (src, dest, 0))
|
||||
- return omit_one_operand (type, dest, len);
|
||||
+ expr = len;
|
||||
+ else
|
||||
+ {
|
||||
+ if (! host_integerp (len, 1))
|
||||
+ return 0;
|
||||
|
||||
- return 0;
|
||||
+ if (TREE_SIDE_EFFECTS (dest) || TREE_SIDE_EFFECTS (src))
|
||||
+ return 0;
|
||||
+
|
||||
+ destvar = dest;
|
||||
+ STRIP_NOPS (destvar);
|
||||
+ if (TREE_CODE (destvar) != ADDR_EXPR)
|
||||
+ return 0;
|
||||
+
|
||||
+ destvar = TREE_OPERAND (destvar, 0);
|
||||
+ if (TREE_THIS_VOLATILE (destvar))
|
||||
+ return 0;
|
||||
+
|
||||
+ if (!INTEGRAL_TYPE_P (TREE_TYPE (destvar))
|
||||
+ && !POINTER_TYPE_P (TREE_TYPE (destvar))
|
||||
+ && !SCALAR_FLOAT_TYPE_P (TREE_TYPE (destvar)))
|
||||
+ return 0;
|
||||
+
|
||||
+ srcvar = src;
|
||||
+ STRIP_NOPS (srcvar);
|
||||
+ if (TREE_CODE (srcvar) != ADDR_EXPR)
|
||||
+ return 0;
|
||||
+
|
||||
+ srcvar = TREE_OPERAND (srcvar, 0);
|
||||
+ if (TREE_THIS_VOLATILE (srcvar))
|
||||
+ return 0;
|
||||
+
|
||||
+ if (!INTEGRAL_TYPE_P (TREE_TYPE (srcvar))
|
||||
+ && !POINTER_TYPE_P (TREE_TYPE (srcvar))
|
||||
+ && !SCALAR_FLOAT_TYPE_P (TREE_TYPE (srcvar)))
|
||||
+ return 0;
|
||||
+
|
||||
+ length = tree_low_cst (len, 1);
|
||||
+ if (GET_MODE_SIZE (TYPE_MODE (TREE_TYPE (destvar))) != length
|
||||
+ || get_pointer_alignment (dest, BIGGEST_ALIGNMENT) / BITS_PER_UNIT
|
||||
+ < (int) length
|
||||
+ || GET_MODE_SIZE (TYPE_MODE (TREE_TYPE (srcvar))) != length
|
||||
+ || get_pointer_alignment (src, BIGGEST_ALIGNMENT) / BITS_PER_UNIT
|
||||
+ < (int) length)
|
||||
+ return 0;
|
||||
+
|
||||
+ if ((INTEGRAL_TYPE_P (TREE_TYPE (srcvar))
|
||||
+ || POINTER_TYPE_P (TREE_TYPE (srcvar)))
|
||||
+ && (INTEGRAL_TYPE_P (TREE_TYPE (destvar))
|
||||
+ || POINTER_TYPE_P (TREE_TYPE (destvar))))
|
||||
+ expr = fold_convert (TREE_TYPE (destvar), srcvar);
|
||||
+ else
|
||||
+ expr = fold_build1 (VIEW_CONVERT_EXPR, TREE_TYPE (destvar), srcvar);
|
||||
+ expr = build2 (MODIFY_EXPR, TREE_TYPE (destvar), destvar, expr);
|
||||
+ }
|
||||
+
|
||||
+ if (ignore)
|
||||
+ return expr;
|
||||
+
|
||||
+ if (endp == 0 || endp == 3)
|
||||
+ return omit_one_operand (type, dest, expr);
|
||||
+
|
||||
+ if (expr == len)
|
||||
+ expr = 0;
|
||||
+
|
||||
+ if (endp == 2)
|
||||
+ len = fold_build2 (MINUS_EXPR, TREE_TYPE (len), len,
|
||||
+ ssize_int (1));
|
||||
+
|
||||
+ len = fold_convert (TREE_TYPE (dest), len);
|
||||
+ dest = fold_build2 (PLUS_EXPR, TREE_TYPE (dest), dest, len);
|
||||
+ dest = fold_convert (type, dest);
|
||||
+ if (expr)
|
||||
+ dest = omit_one_operand (type, dest, expr);
|
||||
+ return dest;
|
||||
+}
|
||||
+
|
||||
+/* Fold function call to builtin bcopy. Return NULL_TREE if no
|
||||
+ simplification can be made. */
|
||||
+
|
||||
+static tree
|
||||
+fold_builtin_bcopy (tree arglist, bool ignore)
|
||||
+{
|
||||
+ tree src, dest, size, newarglist;
|
||||
+
|
||||
+ if (!validate_arglist (arglist,
|
||||
+ POINTER_TYPE, POINTER_TYPE, INTEGER_TYPE, VOID_TYPE))
|
||||
+ return 0;
|
||||
+
|
||||
+ if (! ignore)
|
||||
+ return 0;
|
||||
+
|
||||
+ src = TREE_VALUE (arglist);
|
||||
+ dest = TREE_VALUE (TREE_CHAIN (arglist));
|
||||
+ size = TREE_VALUE (TREE_CHAIN (TREE_CHAIN (arglist)));
|
||||
+
|
||||
+ /* New argument list transforming bcopy(ptr x, ptr y, int z) to
|
||||
+ memmove(ptr y, ptr x, size_t z). This is done this way
|
||||
+ so that if it isn't expanded inline, we fallback to
|
||||
+ calling bcopy instead of memmove. */
|
||||
+
|
||||
+ newarglist = build_tree_list (NULL_TREE, fold_convert (sizetype, size));
|
||||
+ newarglist = tree_cons (NULL_TREE, src, newarglist);
|
||||
+ newarglist = tree_cons (NULL_TREE, dest, newarglist);
|
||||
+
|
||||
+ return fold_builtin_memory_op (newarglist, void_type_node, true, /*endp=*/3);
|
||||
}
|
||||
|
||||
/* Fold function call to builtin strcpy. If LEN is not NULL, it represents
|
||||
@@ -9039,14 +9225,23 @@ fold_builtin_1 (tree fndecl, tree arglis
|
||||
case BUILT_IN_PARITYLL:
|
||||
return fold_builtin_bitop (fndecl, arglist);
|
||||
|
||||
+ case BUILT_IN_MEMSET:
|
||||
+ return fold_builtin_memset (arglist, type, ignore);
|
||||
+
|
||||
case BUILT_IN_MEMCPY:
|
||||
- return fold_builtin_memcpy (fndecl, arglist);
|
||||
+ return fold_builtin_memory_op (arglist, type, ignore, /*endp=*/0);
|
||||
|
||||
case BUILT_IN_MEMPCPY:
|
||||
- return fold_builtin_mempcpy (arglist, type, /*endp=*/1);
|
||||
+ return fold_builtin_memory_op (arglist, type, ignore, /*endp=*/1);
|
||||
|
||||
case BUILT_IN_MEMMOVE:
|
||||
- return fold_builtin_memmove (arglist, type);
|
||||
+ return fold_builtin_memory_op (arglist, type, ignore, /*endp=*/3);
|
||||
+
|
||||
+ case BUILT_IN_BZERO:
|
||||
+ return fold_builtin_bzero (arglist, ignore);
|
||||
+
|
||||
+ case BUILT_IN_BCOPY:
|
||||
+ return fold_builtin_bcopy (arglist, ignore);
|
||||
|
||||
case BUILT_IN_SIGNBIT:
|
||||
case BUILT_IN_SIGNBITF:
|
155
gcc41-pr28690.patch
Normal file
155
gcc41-pr28690.patch
Normal file
@ -0,0 +1,155 @@
|
||||
2007-06-26 Jakub Jelinek <jakub@redhat.com>
|
||||
|
||||
* defaults.h (TARGET_INDEX_OPERAND_FIRST): Define.
|
||||
* config/rs6000/rs6000.h (TARGET_INDEX_OPERAND_FIRST): Define.
|
||||
* optabs.c (emit_cmp_and_jump_insns): Don't call swap_operand
|
||||
twice.
|
||||
* rtlanal.c (commutative_operand_precedence): Only prefer
|
||||
REG_POINTER and MEM_POINTER operands over REG and MEM operands
|
||||
if TARGET_INDEX_OPERAND_FIRST.
|
||||
(swap_commutative_operands_p): Only sort on REGNO if
|
||||
TARGET_INDEX_OPERAND_FIRST.
|
||||
* tree-ssa-address.c (gen_addr_rtx): Only use simplify_gen_binary
|
||||
instead of gen_rtx_PLUS if TARGET_INDEX_OPERAND_FIRST.
|
||||
|
||||
2007-06-20 Peter Bergner <bergner@vnet.ibm.com>
|
||||
|
||||
PR middle-end/28690
|
||||
* optabs.c (emit_cmp_and_jump_insns): Allow EQ compares.
|
||||
* rtlanal.c (commutative_operand_precedence): Prefer both REG_POINTER
|
||||
and MEM_POINTER operands over REG and MEM operands.
|
||||
(swap_commutative_operands_p): In case of a tie, sort on REGNO.
|
||||
* tree-ssa-address.c (gen_addr_rtx): Use simplify_gen_binary
|
||||
instead of gen_rtx_PLUS.
|
||||
|
||||
--- gcc/defaults.h.jj 2007-02-20 22:39:12.000000000 +0100
|
||||
+++ gcc/defaults.h 2007-06-26 00:32:16.000000000 +0200
|
||||
@@ -785,6 +785,10 @@ Software Foundation, 51 Franklin Street,
|
||||
#define TARGET_C99_FUNCTIONS 0
|
||||
#endif
|
||||
|
||||
+#ifndef TARGET_INDEX_OPERAND_FIRST
|
||||
+#define TARGET_INDEX_OPERAND_FIRST 0
|
||||
+#endif
|
||||
+
|
||||
/* Indicate that CLZ and CTZ are undefined at zero. */
|
||||
#ifndef CLZ_DEFINED_VALUE_AT_ZERO
|
||||
#define CLZ_DEFINED_VALUE_AT_ZERO(MODE, VALUE) 0
|
||||
--- gcc/config/rs6000/rs6000.h.jj 2007-02-20 22:39:00.000000000 +0100
|
||||
+++ gcc/config/rs6000/rs6000.h 2007-06-26 00:33:32.000000000 +0200
|
||||
@@ -57,6 +57,8 @@
|
||||
#define PPC405_ERRATUM77 0
|
||||
#endif
|
||||
|
||||
+#define TARGET_INDEX_OPERAND_FIRST (rs6000_cpu == PROCESSOR_POWER6)
|
||||
+
|
||||
/* Common ASM definitions used by ASM_SPEC among the various targets
|
||||
for handling -mcpu=xxx switches. */
|
||||
#define ASM_CPU_SPEC \
|
||||
--- gcc/optabs.c.jj 2007-02-20 22:39:12.000000000 +0100
|
||||
+++ gcc/optabs.c 2007-06-26 00:30:27.000000000 +0200
|
||||
@@ -3673,12 +3673,16 @@ emit_cmp_and_jump_insns (rtx x, rtx y, e
|
||||
/* Swap operands and condition to ensure canonical RTL. */
|
||||
if (swap_commutative_operands_p (x, y))
|
||||
{
|
||||
- /* If we're not emitting a branch, this means some caller
|
||||
- is out of sync. */
|
||||
- gcc_assert (label);
|
||||
+ enum rtx_code swapped_comparison = swap_condition (comparison);
|
||||
+
|
||||
+ /* If we're not emitting a branch, callers are required to pass
|
||||
+ operands in an order conforming to canonical RTL. We relax this
|
||||
+ for commutative comparsions so callers using EQ don't need to do
|
||||
+ swapping by hand. */
|
||||
+ gcc_assert (label || swapped_comparison == comparison);
|
||||
|
||||
op0 = y, op1 = x;
|
||||
- comparison = swap_condition (comparison);
|
||||
+ comparison = swapped_comparison;
|
||||
}
|
||||
|
||||
#ifdef HAVE_cc0
|
||||
--- gcc/rtlanal.c.jj 2007-02-20 22:39:12.000000000 +0100
|
||||
+++ gcc/rtlanal.c 2007-06-26 00:28:56.000000000 +0200
|
||||
@@ -2890,9 +2890,9 @@ commutative_operand_precedence (rtx op)
|
||||
|
||||
/* Constants always come the second operand. Prefer "nice" constants. */
|
||||
if (code == CONST_INT)
|
||||
- return -7;
|
||||
+ return -10;
|
||||
if (code == CONST_DOUBLE)
|
||||
- return -6;
|
||||
+ return -9;
|
||||
op = avoid_constant_pool_reference (op);
|
||||
code = GET_CODE (op);
|
||||
|
||||
@@ -2900,26 +2900,31 @@ commutative_operand_precedence (rtx op)
|
||||
{
|
||||
case RTX_CONST_OBJ:
|
||||
if (code == CONST_INT)
|
||||
- return -5;
|
||||
+ return -8;
|
||||
if (code == CONST_DOUBLE)
|
||||
- return -4;
|
||||
- return -3;
|
||||
+ return -7;
|
||||
+ return -6;
|
||||
|
||||
case RTX_EXTRA:
|
||||
/* SUBREGs of objects should come second. */
|
||||
if (code == SUBREG && OBJECT_P (SUBREG_REG (op)))
|
||||
- return -2;
|
||||
+ return -5;
|
||||
|
||||
if (!CONSTANT_P (op))
|
||||
return 0;
|
||||
else
|
||||
/* As for RTX_CONST_OBJ. */
|
||||
- return -3;
|
||||
+ return -6;
|
||||
|
||||
case RTX_OBJ:
|
||||
/* Complex expressions should be the first, so decrease priority
|
||||
of objects. */
|
||||
- return -1;
|
||||
+ if (!TARGET_INDEX_OPERAND_FIRST)
|
||||
+ return -1;
|
||||
+ if (REG_P (op))
|
||||
+ return (REG_POINTER (op)) ? -1 : -3;
|
||||
+ else
|
||||
+ return (MEM_P (op) && MEM_POINTER (op)) ? -2 : -4;
|
||||
|
||||
case RTX_COMM_ARITH:
|
||||
/* Prefer operands that are themselves commutative to be first.
|
||||
@@ -2949,8 +2954,16 @@ commutative_operand_precedence (rtx op)
|
||||
int
|
||||
swap_commutative_operands_p (rtx x, rtx y)
|
||||
{
|
||||
- return (commutative_operand_precedence (x)
|
||||
- < commutative_operand_precedence (y));
|
||||
+ int result = (commutative_operand_precedence (x)
|
||||
+ - commutative_operand_precedence (y));
|
||||
+ if (!TARGET_INDEX_OPERAND_FIRST || result)
|
||||
+ return result < 0;
|
||||
+
|
||||
+ /* Group together equal REGs to do more simplification. */
|
||||
+ if (REG_P (x) && REG_P (y))
|
||||
+ return REGNO (x) > REGNO (y);
|
||||
+
|
||||
+ return 0;
|
||||
}
|
||||
|
||||
/* Return 1 if X is an autoincrement side effect and the register is
|
||||
--- gcc/tree-ssa-address.c.jj 2007-02-20 22:39:12.000000000 +0100
|
||||
+++ gcc/tree-ssa-address.c 2007-06-26 00:29:49.000000000 +0200
|
||||
@@ -124,7 +124,9 @@ gen_addr_rtx (rtx symbol, rtx base, rtx
|
||||
if (base)
|
||||
{
|
||||
if (*addr)
|
||||
- *addr = gen_rtx_PLUS (Pmode, *addr, base);
|
||||
+ *addr = (TARGET_INDEX_OPERAND_FIRST
|
||||
+ ? simplify_gen_binary (PLUS, Pmode, base, *addr)
|
||||
+ : gen_rtx_PLUS (Pmode, *addr, base));
|
||||
else
|
||||
*addr = base;
|
||||
}
|
@ -1,84 +0,0 @@
|
||||
2006-08-16 Jakub Jelinek <jakub@redhat.com>
|
||||
|
||||
PR preprocessor/28709
|
||||
* macro.c (paste_tokens): Do error reporting here, use BUF with the
|
||||
spelled LHS token as opposed to spelling it again.
|
||||
(paste_all_tokens): Don't report errors here, just break on failure.
|
||||
|
||||
* gcc.dg/cpp/paste14.c: New test.
|
||||
|
||||
--- libcpp/macro.c.jj 2006-06-09 23:07:54.000000000 +0200
|
||||
+++ libcpp/macro.c 2006-08-16 17:30:17.000000000 +0200
|
||||
@@ -430,15 +430,14 @@ stringify_arg (cpp_reader *pfile, macro_
|
||||
static bool
|
||||
paste_tokens (cpp_reader *pfile, const cpp_token **plhs, const cpp_token *rhs)
|
||||
{
|
||||
- unsigned char *buf, *end;
|
||||
+ unsigned char *buf, *end, *lhsend;
|
||||
const cpp_token *lhs;
|
||||
unsigned int len;
|
||||
- bool valid;
|
||||
|
||||
lhs = *plhs;
|
||||
len = cpp_token_len (lhs) + cpp_token_len (rhs) + 1;
|
||||
buf = (unsigned char *) alloca (len);
|
||||
- end = cpp_spell_token (pfile, lhs, buf, false);
|
||||
+ end = lhsend = cpp_spell_token (pfile, lhs, buf, false);
|
||||
|
||||
/* Avoid comment headers, since they are still processed in stage 3.
|
||||
It is simpler to insert a space here, rather than modifying the
|
||||
@@ -455,10 +454,22 @@ paste_tokens (cpp_reader *pfile, const c
|
||||
/* Set pfile->cur_token as required by _cpp_lex_direct. */
|
||||
pfile->cur_token = _cpp_temp_token (pfile);
|
||||
*plhs = _cpp_lex_direct (pfile);
|
||||
- valid = pfile->buffer->cur == pfile->buffer->rlimit;
|
||||
- _cpp_pop_buffer (pfile);
|
||||
+ if (pfile->buffer->cur != pfile->buffer->rlimit)
|
||||
+ {
|
||||
+ _cpp_pop_buffer (pfile);
|
||||
+ _cpp_backup_tokens (pfile, 1);
|
||||
+ *lhsend = '\0';
|
||||
|
||||
- return valid;
|
||||
+ /* Mandatory error for all apart from assembler. */
|
||||
+ if (CPP_OPTION (pfile, lang) != CLK_ASM)
|
||||
+ cpp_error (pfile, CPP_DL_ERROR,
|
||||
+ "pasting \"%s\" and \"%s\" does not give a valid preprocessing token",
|
||||
+ buf, cpp_token_as_text (pfile, rhs));
|
||||
+ return false;
|
||||
+ }
|
||||
+
|
||||
+ _cpp_pop_buffer (pfile);
|
||||
+ return true;
|
||||
}
|
||||
|
||||
/* Handles an arbitrarily long sequence of ## operators, with initial
|
||||
@@ -490,17 +501,7 @@ paste_all_tokens (cpp_reader *pfile, con
|
||||
abort ();
|
||||
|
||||
if (!paste_tokens (pfile, &lhs, rhs))
|
||||
- {
|
||||
- _cpp_backup_tokens (pfile, 1);
|
||||
-
|
||||
- /* Mandatory error for all apart from assembler. */
|
||||
- if (CPP_OPTION (pfile, lang) != CLK_ASM)
|
||||
- cpp_error (pfile, CPP_DL_ERROR,
|
||||
- "pasting \"%s\" and \"%s\" does not give a valid preprocessing token",
|
||||
- cpp_token_as_text (pfile, lhs),
|
||||
- cpp_token_as_text (pfile, rhs));
|
||||
- break;
|
||||
- }
|
||||
+ break;
|
||||
}
|
||||
while (rhs->flags & PASTE_LEFT);
|
||||
|
||||
--- gcc/testsuite/gcc.dg/cpp/paste14.c.jj 2006-08-16 16:51:45.000000000 +0200
|
||||
+++ gcc/testsuite/gcc.dg/cpp/paste14.c 2006-08-16 16:53:30.000000000 +0200
|
||||
@@ -0,0 +1,7 @@
|
||||
+/* PR preprocessor/28709 */
|
||||
+/* { dg-do preprocess } */
|
||||
+
|
||||
+#define foo - ## >>
|
||||
+foo /* { dg-error "pasting \"-\" and \">>\"" } */
|
||||
+#define bar = ## ==
|
||||
+bar /* { dg-error "pasting \"=\" and \"==\"" } */
|
@ -1,76 +0,0 @@
|
||||
2006-09-16 Andrew Pinski <pinskia@physics.uc.edu>
|
||||
|
||||
PR tree-opt/29059
|
||||
* tree-ssa-propagate.c (set_rhs): Reject MODIFY_EXPR right
|
||||
away for the expr argument.
|
||||
|
||||
* gcc.c-torture/compile/strcpy-1.c: New test.
|
||||
* gcc.c-torture/compile/strcpy-2.c: New test.
|
||||
* gcc.c-torture/compile/memcpy-1.c: New test.
|
||||
* gcc.c-torture/compile/memcpy-2.c: New test.
|
||||
|
||||
--- gcc/tree-ssa-propagate.c (revision 116996)
|
||||
+++ gcc/tree-ssa-propagate.c (revision 116997)
|
||||
@@ -588,7 +588,8 @@ set_rhs (tree *stmt_p, tree expr)
|
||||
&& !is_gimple_val (TREE_OPERAND (TREE_OPERAND (expr, 0), 1)))
|
||||
return false;
|
||||
}
|
||||
- else if (code == COMPOUND_EXPR)
|
||||
+ else if (code == COMPOUND_EXPR
|
||||
+ || code == MODIFY_EXPR)
|
||||
return false;
|
||||
|
||||
switch (TREE_CODE (stmt))
|
||||
--- gcc/testsuite/gcc.c-torture/compile/strcpy-1.c (revision 0)
|
||||
+++ gcc/testsuite/gcc.c-torture/compile/strcpy-1.c (revision 116997)
|
||||
@@ -0,0 +1,15 @@
|
||||
+
|
||||
+
|
||||
+typedef struct
|
||||
+{
|
||||
+ char str[20];
|
||||
+}STACK;
|
||||
+STACK stack[15];
|
||||
+int level;
|
||||
+rezero ()
|
||||
+{
|
||||
+ level = 0;
|
||||
+ __builtin_strcpy (stack[level].str, "");
|
||||
+}
|
||||
+
|
||||
+
|
||||
--- gcc/testsuite/gcc.c-torture/compile/strcpy-2.c (revision 0)
|
||||
+++ gcc/testsuite/gcc.c-torture/compile/strcpy-2.c (revision 116997)
|
||||
@@ -0,0 +1,7 @@
|
||||
+char wrkstr_un[270];
|
||||
+extern void
|
||||
+LoadUserAlph (char *s)
|
||||
+{
|
||||
+ s = &wrkstr_un[0];
|
||||
+ __builtin_strcpy (s, "");
|
||||
+};
|
||||
--- gcc/testsuite/gcc.c-torture/compile/memcpy-1.c (revision 0)
|
||||
+++ gcc/testsuite/gcc.c-torture/compile/memcpy-1.c (revision 116997)
|
||||
@@ -0,0 +1,9 @@
|
||||
+static const char OggFLAC__MAPPING_VERSION_MAJOR = 1;
|
||||
+void f(void)
|
||||
+{
|
||||
+ char synthetic_first_packet_body[10];
|
||||
+ char *b = &synthetic_first_packet_body[4];
|
||||
+ __builtin_memcpy (b, &OggFLAC__MAPPING_VERSION_MAJOR, (1u));
|
||||
+}
|
||||
+
|
||||
+
|
||||
--- gcc/testsuite/gcc.c-torture/compile/memcpy-2.c (revision 0)
|
||||
+++ gcc/testsuite/gcc.c-torture/compile/memcpy-2.c (revision 116997)
|
||||
@@ -0,0 +1,10 @@
|
||||
+static const char OggFLAC__MAPPING_VERSION_MAJOR = 1;
|
||||
+void f(void)
|
||||
+{
|
||||
+ char synthetic_first_packet_body[10];
|
||||
+ char *b = synthetic_first_packet_body;
|
||||
+ b+=4u;
|
||||
+ __builtin_memcpy (b, &OggFLAC__MAPPING_VERSION_MAJOR, (1u));
|
||||
+}
|
||||
+
|
||||
+
|
@ -1,110 +0,0 @@
|
||||
2006-09-28 Jakub Jelinek <jakub@redhat.com>
|
||||
|
||||
PR middle-end/29272
|
||||
* builtins.c (fold_builtin_memset, fold_builtin_memory_op): Restrict
|
||||
single entry optimization to variables and components thereof.
|
||||
|
||||
* gcc.c-torture/execute/20060930-1.c: New test.
|
||||
|
||||
--- gcc/builtins.c.jj 2006-09-22 10:29:55.000000000 +0200
|
||||
+++ gcc/builtins.c 2006-09-28 20:31:30.000000000 +0200
|
||||
@@ -7905,7 +7905,7 @@ fold_builtin_exponent (tree fndecl, tree
|
||||
static tree
|
||||
fold_builtin_memset (tree arglist, tree type, bool ignore)
|
||||
{
|
||||
- tree dest, c, len, var, ret;
|
||||
+ tree dest, c, len, var, ret, inner;
|
||||
unsigned HOST_WIDE_INT length, cval;
|
||||
|
||||
if (!validate_arglist (arglist,
|
||||
@@ -7939,6 +7939,15 @@ fold_builtin_memset (tree arglist, tree
|
||||
&& !POINTER_TYPE_P (TREE_TYPE (var)))
|
||||
return 0;
|
||||
|
||||
+ /* If var is a VAR_DECL or a component thereof,
|
||||
+ we can use its alias set, otherwise we'd need to make
|
||||
+ sure we go through alias set 0. */
|
||||
+ inner = var;
|
||||
+ while (handled_component_p (inner))
|
||||
+ inner = TREE_OPERAND (inner, 0);
|
||||
+ if (! SSA_VAR_P (inner))
|
||||
+ return 0;
|
||||
+
|
||||
length = tree_low_cst (len, 1);
|
||||
if (GET_MODE_SIZE (TYPE_MODE (TREE_TYPE (var))) != length
|
||||
|| get_pointer_alignment (dest, BIGGEST_ALIGNMENT) / BITS_PER_UNIT
|
||||
@@ -8009,7 +8018,7 @@ fold_builtin_bzero (tree arglist, bool i
|
||||
static tree
|
||||
fold_builtin_memory_op (tree arglist, tree type, bool ignore, int endp)
|
||||
{
|
||||
- tree dest, src, len, destvar, srcvar, expr;
|
||||
+ tree dest, src, len, destvar, srcvar, expr, inner;
|
||||
unsigned HOST_WIDE_INT length;
|
||||
|
||||
if (! validate_arglist (arglist,
|
||||
@@ -8050,6 +8059,15 @@ fold_builtin_memory_op (tree arglist, tr
|
||||
&& !SCALAR_FLOAT_TYPE_P (TREE_TYPE (destvar)))
|
||||
return 0;
|
||||
|
||||
+ /* If destvar is a VAR_DECL or a component thereof,
|
||||
+ we can use its alias set, otherwise we'd need to make
|
||||
+ sure we go through alias set 0. */
|
||||
+ inner = destvar;
|
||||
+ while (handled_component_p (inner))
|
||||
+ inner = TREE_OPERAND (inner, 0);
|
||||
+ if (! SSA_VAR_P (inner))
|
||||
+ return 0;
|
||||
+
|
||||
srcvar = src;
|
||||
STRIP_NOPS (srcvar);
|
||||
if (TREE_CODE (srcvar) != ADDR_EXPR)
|
||||
@@ -8064,6 +8082,15 @@ fold_builtin_memory_op (tree arglist, tr
|
||||
&& !SCALAR_FLOAT_TYPE_P (TREE_TYPE (srcvar)))
|
||||
return 0;
|
||||
|
||||
+ /* If srcvar is a VAR_DECL or a component thereof,
|
||||
+ we can use its alias set, otherwise we'd need to make
|
||||
+ sure we go through alias set 0. */
|
||||
+ inner = srcvar;
|
||||
+ while (handled_component_p (inner))
|
||||
+ inner = TREE_OPERAND (inner, 0);
|
||||
+ if (! SSA_VAR_P (inner))
|
||||
+ return 0;
|
||||
+
|
||||
length = tree_low_cst (len, 1);
|
||||
if (GET_MODE_SIZE (TYPE_MODE (TREE_TYPE (destvar))) != length
|
||||
|| get_pointer_alignment (dest, BIGGEST_ALIGNMENT) / BITS_PER_UNIT
|
||||
--- gcc/testsuite/gcc.c-torture/execute/20060930-1.c.jj 2006-09-30 21:10:17.000000000 +0200
|
||||
+++ gcc/testsuite/gcc.c-torture/execute/20060930-1.c 2006-09-30 21:09:33.000000000 +0200
|
||||
@@ -0,0 +1,31 @@
|
||||
+/* PR middle-end/29272 */
|
||||
+
|
||||
+extern void abort (void);
|
||||
+
|
||||
+struct S { struct S *s; } s;
|
||||
+struct T { struct T *t; } t;
|
||||
+
|
||||
+static inline void
|
||||
+foo (void *s)
|
||||
+{
|
||||
+ struct T *p = s;
|
||||
+ __builtin_memcpy (&p->t, &t.t, sizeof (t.t));
|
||||
+}
|
||||
+
|
||||
+void *
|
||||
+__attribute__((noinline))
|
||||
+bar (void *p, struct S *q)
|
||||
+{
|
||||
+ q->s = &s;
|
||||
+ foo (p);
|
||||
+ return q->s;
|
||||
+}
|
||||
+
|
||||
+int
|
||||
+main (void)
|
||||
+{
|
||||
+ t.t = &t;
|
||||
+ if (bar (&s, &s) != (void *) &t)
|
||||
+ abort ();
|
||||
+ return 0;
|
||||
+}
|
@ -1,93 +0,0 @@
|
||||
2006-10-18 Jan Hubicka <jh@suse.cz>
|
||||
|
||||
PR middle-end/29299
|
||||
* cfgexpand.c (expand_used_vars_for_block): Vars marked used by user
|
||||
are used.
|
||||
|
||||
2006-10-15 Jan Hubicka <jh@suse.cz>
|
||||
Richard Guenther <rguenther@suse.de>
|
||||
|
||||
PR middle-end/29299
|
||||
* cgraphunit.c (cgraph_finalize_compilation_unit): Call
|
||||
process_function_and_variable_attributes on all variables, including
|
||||
those discovered during cgraph construction phase.
|
||||
|
||||
* gcc.dg/pr29299.c: New testcase.
|
||||
|
||||
--- gcc/cgraphunit.c (revision 117745)
|
||||
+++ gcc/cgraphunit.c (revision 117863)
|
||||
@@ -1055,6 +1055,7 @@ cgraph_finalize_compilation_unit (void)
|
||||
/* Keep track of already processed nodes when called multiple times for
|
||||
intermodule optimization. */
|
||||
static struct cgraph_node *first_analyzed;
|
||||
+ struct cgraph_node *first_processed = first_analyzed;
|
||||
static struct cgraph_varpool_node *first_analyzed_var;
|
||||
|
||||
if (errorcount || sorrycount)
|
||||
@@ -1077,7 +1078,10 @@ cgraph_finalize_compilation_unit (void)
|
||||
}
|
||||
|
||||
timevar_push (TV_CGRAPH);
|
||||
- process_function_and_variable_attributes (first_analyzed, first_analyzed_var);
|
||||
+ process_function_and_variable_attributes (first_processed,
|
||||
+ first_analyzed_var);
|
||||
+ first_processed = cgraph_nodes;
|
||||
+ first_analyzed_var = cgraph_varpool_nodes;
|
||||
cgraph_varpool_analyze_pending_decls ();
|
||||
if (cgraph_dump_file)
|
||||
{
|
||||
@@ -1119,11 +1123,16 @@ cgraph_finalize_compilation_unit (void)
|
||||
if (!edge->callee->reachable)
|
||||
cgraph_mark_reachable_node (edge->callee);
|
||||
|
||||
+ /* We finalize local static variables during constructing callgraph
|
||||
+ edges. Process their attributes too. */
|
||||
+ process_function_and_variable_attributes (first_processed,
|
||||
+ first_analyzed_var);
|
||||
+ first_processed = cgraph_nodes;
|
||||
+ first_analyzed_var = cgraph_varpool_nodes;
|
||||
cgraph_varpool_analyze_pending_decls ();
|
||||
}
|
||||
|
||||
/* Collect entry points to the unit. */
|
||||
-
|
||||
if (cgraph_dump_file)
|
||||
{
|
||||
fprintf (cgraph_dump_file, "Unit entry points:");
|
||||
@@ -1163,7 +1172,6 @@ cgraph_finalize_compilation_unit (void)
|
||||
dump_cgraph (cgraph_dump_file);
|
||||
}
|
||||
first_analyzed = cgraph_nodes;
|
||||
- first_analyzed_var = cgraph_varpool_nodes;
|
||||
ggc_collect ();
|
||||
timevar_pop (TV_CGRAPH);
|
||||
}
|
||||
--- gcc/cfgexpand.c (revision 117745)
|
||||
+++ gcc/cfgexpand.c (revision 117863)
|
||||
@@ -764,7 +764,12 @@ expand_used_vars_for_block (tree block,
|
||||
|
||||
/* Expand all variables at this level. */
|
||||
for (t = BLOCK_VARS (block); t ; t = TREE_CHAIN (t))
|
||||
- if (TREE_USED (t))
|
||||
+ if (TREE_USED (t)
|
||||
+ /* Force local static variables to be output when marked by
|
||||
+ used attribute. For unit-at-a-time, cgraph code already takes
|
||||
+ care of this. */
|
||||
+ || (!flag_unit_at_a_time && TREE_STATIC (t)
|
||||
+ && DECL_PRESERVE_P (t)))
|
||||
expand_one_var (t, toplevel);
|
||||
|
||||
this_sv_num = stack_vars_num;
|
||||
--- gcc/testsuite/gcc.dg/pr29299.c (revision 0)
|
||||
+++ gcc/testsuite/gcc.dg/pr29299.c (revision 117863)
|
||||
@@ -0,0 +1,10 @@
|
||||
+/* { dg-do compile } */
|
||||
+/* { dg-options "-O" } */
|
||||
+
|
||||
+static int bof __attribute__((used));
|
||||
+int foo()
|
||||
+{
|
||||
+ static int barbarbarbar __attribute__((used));
|
||||
+};
|
||||
+
|
||||
+/* { dg-final { scan-assembler "barbarbarbar" } } */
|
@ -1,113 +0,0 @@
|
||||
2007-03-30 Jason Merrill <jason@redhat.com>
|
||||
|
||||
PR c++/31187
|
||||
* typeck.c (cp_type_readonly): New fn.
|
||||
* cp-tree.h: Declare it.
|
||||
* decl.c (start_decl): Set implicit DECL_THIS_STATIC here.
|
||||
(cp_finish_decl): Not here.
|
||||
|
||||
2007-04-02 Jason Merrill <jason@redhat.com>
|
||||
|
||||
PR c++/31187
|
||||
* g++.dg/ext/visibility/anon3.C: New test.
|
||||
|
||||
--- gcc/cp/typeck.c (revision 123431)
|
||||
+++ gcc/cp/typeck.c (revision 123432)
|
||||
@@ -6897,6 +6897,16 @@ cp_type_quals (tree type)
|
||||
return TYPE_QUALS (type);
|
||||
}
|
||||
|
||||
+/* Returns nonzero if the TYPE is const from a C++ perspective: look inside
|
||||
+ arrays. */
|
||||
+
|
||||
+bool
|
||||
+cp_type_readonly (tree type)
|
||||
+{
|
||||
+ type = strip_array_types (type);
|
||||
+ return TYPE_READONLY (type);
|
||||
+}
|
||||
+
|
||||
/* Returns nonzero if the TYPE contains a mutable member. */
|
||||
|
||||
bool
|
||||
--- gcc/cp/decl.c (revision 123431)
|
||||
+++ gcc/cp/decl.c (revision 123432)
|
||||
@@ -3817,6 +3817,7 @@ start_decl (const cp_declarator *declara
|
||||
tree decl;
|
||||
tree type, tem;
|
||||
tree context;
|
||||
+ bool was_public;
|
||||
|
||||
*pushed_scope_p = NULL_TREE;
|
||||
|
||||
@@ -3969,6 +3970,8 @@ start_decl (const cp_declarator *declara
|
||||
decl);
|
||||
}
|
||||
|
||||
+ was_public = TREE_PUBLIC (decl);
|
||||
+
|
||||
/* Enter this declaration into the symbol table. */
|
||||
tem = maybe_push_decl (decl);
|
||||
|
||||
@@ -3988,6 +3991,17 @@ start_decl (const cp_declarator *declara
|
||||
&& (flag_conserve_space || ! TREE_PUBLIC (tem)));
|
||||
#endif
|
||||
|
||||
+ if (TREE_CODE (tem) == VAR_DECL
|
||||
+ && DECL_NAMESPACE_SCOPE_P (tem) && !TREE_PUBLIC (tem) && !was_public
|
||||
+ && !DECL_THIS_STATIC (tem) && !DECL_ARTIFICIAL (tem))
|
||||
+ {
|
||||
+ /* This is a const variable with implicit 'static'. Set
|
||||
+ DECL_THIS_STATIC so we can tell it from variables that are
|
||||
+ !TREE_PUBLIC because of the anonymous namespace. */
|
||||
+ gcc_assert (cp_type_readonly (TREE_TYPE (tem)));
|
||||
+ DECL_THIS_STATIC (tem) = 1;
|
||||
+ }
|
||||
+
|
||||
if (! processing_template_decl)
|
||||
start_decl_1 (tem);
|
||||
|
||||
@@ -5320,14 +5334,6 @@ cp_finish_decl (tree decl, tree init, bo
|
||||
{
|
||||
layout_var_decl (decl);
|
||||
maybe_commonize_var (decl);
|
||||
- if (DECL_NAMESPACE_SCOPE_P (decl) && !TREE_PUBLIC (decl)
|
||||
- && !DECL_THIS_STATIC (decl) && !DECL_ARTIFICIAL (decl))
|
||||
- {
|
||||
- /* This is a const variable with implicit 'static'. Set
|
||||
- DECL_THIS_STATIC so we can tell it from variables that are
|
||||
- !TREE_PUBLIC because of the anonymous namespace. */
|
||||
- DECL_THIS_STATIC (decl) = 1;
|
||||
- }
|
||||
}
|
||||
|
||||
make_rtl_for_nonlocal_decl (decl, init, asmspec);
|
||||
--- gcc/cp/cp-tree.h (revision 123431)
|
||||
+++ gcc/cp/cp-tree.h (revision 123432)
|
||||
@@ -4742,6 +4742,7 @@ extern bool comp_ptr_ttypes_const (tree
|
||||
extern int ptr_reasonably_similar (tree, tree);
|
||||
extern tree build_ptrmemfunc (tree, tree, int, bool);
|
||||
extern int cp_type_quals (tree);
|
||||
+extern bool cp_type_readonly (tree);
|
||||
extern bool cp_has_mutable_p (tree);
|
||||
extern bool at_least_as_qualified_p (tree, tree);
|
||||
extern void cp_apply_type_quals_to_decl (int, tree);
|
||||
--- gcc/testsuite/g++.dg/ext/visibility/anon3.C (revision 0)
|
||||
+++ gcc/testsuite/g++.dg/ext/visibility/anon3.C (revision 123432)
|
||||
@@ -0,0 +1,16 @@
|
||||
+// PR c++/31187
|
||||
+// Bug: the repeated declaration was confusing the compiler into
|
||||
+// thinking that foo1 had language internal linkage.
|
||||
+
|
||||
+class foo { };
|
||||
+
|
||||
+namespace
|
||||
+{
|
||||
+ extern foo foo1;
|
||||
+ foo foo1;
|
||||
+}
|
||||
+
|
||||
+template< foo * >
|
||||
+class bar { };
|
||||
+
|
||||
+bar< &foo1 > bar1;
|
@ -1,68 +0,0 @@
|
||||
2007-05-31 Jakub Jelinek <jakub@redhat.com>
|
||||
|
||||
PR c++/31806
|
||||
* decl.c (cp_finish_decl): Also clear was_readonly if a static var
|
||||
needs runtime initialization.
|
||||
|
||||
2007-05-30 Jakub Jelinek <jakub@redhat.com>
|
||||
|
||||
PR c++/31809
|
||||
* decl.c (cp_finish_decl): Clear TREE_READONLY flag on TREE_STATIC
|
||||
variables that need runtime initialization.
|
||||
|
||||
* g++.dg/opt/static5.C: New test.
|
||||
|
||||
--- gcc/cp/decl.c (revision 125200)
|
||||
+++ gcc/cp/decl.c (revision 125229)
|
||||
@@ -5357,7 +5357,18 @@ cp_finish_decl (tree decl, tree init, bo
|
||||
initializer. It is not legal to redeclare a static data
|
||||
member, so this issue does not arise in that case. */
|
||||
if (var_definition_p && TREE_STATIC (decl))
|
||||
- expand_static_init (decl, init);
|
||||
+ {
|
||||
+ /* If a TREE_READONLY variable needs initialization
|
||||
+ at runtime, it is no longer readonly and we need to
|
||||
+ avoid MEM_READONLY_P being set on RTL created for it. */
|
||||
+ if (init)
|
||||
+ {
|
||||
+ if (TREE_READONLY (decl))
|
||||
+ TREE_READONLY (decl) = 0;
|
||||
+ was_readonly = 0;
|
||||
+ }
|
||||
+ expand_static_init (decl, init);
|
||||
+ }
|
||||
}
|
||||
}
|
||||
|
||||
--- gcc/testsuite/g++.dg/opt/static5.C (revision 0)
|
||||
+++ gcc/testsuite/g++.dg/opt/static5.C (revision 125229)
|
||||
@@ -0,0 +1,29 @@
|
||||
+// PR c++/31809
|
||||
+// { dg-do run }
|
||||
+// { dg-options "-O2" }
|
||||
+
|
||||
+struct S
|
||||
+{
|
||||
+ unsigned v;
|
||||
+ static inline S f (unsigned a);
|
||||
+};
|
||||
+
|
||||
+inline S
|
||||
+S::f (unsigned a)
|
||||
+{
|
||||
+ static S t = { a };
|
||||
+ return t;
|
||||
+}
|
||||
+
|
||||
+const static S s = S::f (26);
|
||||
+
|
||||
+extern "C" void abort (void);
|
||||
+
|
||||
+int
|
||||
+main ()
|
||||
+{
|
||||
+ S t = s;
|
||||
+ if (t.v != 26)
|
||||
+ abort ();
|
||||
+ return 0;
|
||||
+}
|
@ -1,73 +0,0 @@
|
||||
2007-06-14 Jakub Jelinek <jakub@redhat.com>
|
||||
|
||||
PR middle-end/32285
|
||||
* calls.c (precompute_arguments): Also precompute CALL_EXPR arguments
|
||||
if ACCUMULATE_OUTGOING_ARGS.
|
||||
|
||||
* gcc.c-torture/execute/20070614-1.c: New test.
|
||||
|
||||
--- gcc/calls.c.jj 2007-06-13 17:38:55.000000000 +0200
|
||||
+++ gcc/calls.c 2007-06-14 14:50:56.000000000 +0200
|
||||
@@ -1269,13 +1269,25 @@ precompute_arguments (int flags, int num
|
||||
|
||||
/* If this is a libcall, then precompute all arguments so that we do not
|
||||
get extraneous instructions emitted as part of the libcall sequence. */
|
||||
- if ((flags & ECF_LIBCALL_BLOCK) == 0)
|
||||
+
|
||||
+ /* If we preallocated the stack space, and some arguments must be passed
|
||||
+ on the stack, then we must precompute any parameter which contains a
|
||||
+ function call which will store arguments on the stack.
|
||||
+ Otherwise, evaluating the parameter may clobber previous parameters
|
||||
+ which have already been stored into the stack. (we have code to avoid
|
||||
+ such case by saving the outgoing stack arguments, but it results in
|
||||
+ worse code) */
|
||||
+ if ((flags & ECF_LIBCALL_BLOCK) == 0 && !ACCUMULATE_OUTGOING_ARGS)
|
||||
return;
|
||||
|
||||
for (i = 0; i < num_actuals; i++)
|
||||
{
|
||||
enum machine_mode mode;
|
||||
|
||||
+ if ((flags & ECF_LIBCALL_BLOCK) == 0
|
||||
+ && TREE_CODE (args[i].tree_value) != CALL_EXPR)
|
||||
+ continue;
|
||||
+
|
||||
/* If this is an addressable type, we cannot pre-evaluate it. */
|
||||
gcc_assert (!TREE_ADDRESSABLE (TREE_TYPE (args[i].tree_value)));
|
||||
|
||||
--- gcc/testsuite/gcc.c-torture/execute/20070614-1.c.jj 2007-06-14 15:32:28.000000000 +0200
|
||||
+++ gcc/testsuite/gcc.c-torture/execute/20070614-1.c 2007-06-11 13:23:19.000000000 +0200
|
||||
@@ -0,0 +1,33 @@
|
||||
+extern void abort (void);
|
||||
+
|
||||
+_Complex v = 3.0 + 1.0iF;
|
||||
+
|
||||
+void
|
||||
+foo (_Complex z, int *x)
|
||||
+{
|
||||
+ if (z != v)
|
||||
+ abort ();
|
||||
+}
|
||||
+
|
||||
+_Complex bar (_Complex z) __attribute__ ((pure));
|
||||
+_Complex
|
||||
+bar (_Complex z)
|
||||
+{
|
||||
+ return v;
|
||||
+}
|
||||
+
|
||||
+int
|
||||
+baz (void)
|
||||
+{
|
||||
+ int a, i;
|
||||
+ for (i = 0; i < 6; i++)
|
||||
+ foo (bar (1.0iF * i), &a);
|
||||
+ return 0;
|
||||
+}
|
||||
+
|
||||
+int
|
||||
+main ()
|
||||
+{
|
||||
+ baz ();
|
||||
+ return 0;
|
||||
+}
|
@ -1,64 +0,0 @@
|
||||
2007-06-15 Jakub Jelinek <jakub@redhat.com>
|
||||
|
||||
PR tree-optimization/32353
|
||||
* tree-ssa-structalias.c (set_uids_in_ptset): Also handle RESULT_DECL.
|
||||
|
||||
* g++.dg/opt/nrv13.C: New test.
|
||||
|
||||
--- gcc/tree-ssa-structalias.c.jj 2007-06-11 11:12:27.000000000 +0200
|
||||
+++ gcc/tree-ssa-structalias.c 2007-06-15 16:40:29.000000000 +0200
|
||||
@@ -4343,7 +4343,8 @@ set_uids_in_ptset (tree ptr, bitmap into
|
||||
bitmap_set_bit (into, DECL_UID (sv->var));
|
||||
}
|
||||
else if (TREE_CODE (vi->decl) == VAR_DECL
|
||||
- || TREE_CODE (vi->decl) == PARM_DECL)
|
||||
+ || TREE_CODE (vi->decl) == PARM_DECL
|
||||
+ || TREE_CODE (vi->decl) == RESULT_DECL)
|
||||
{
|
||||
if (var_can_have_subvars (vi->decl)
|
||||
&& get_subvars_for_var (vi->decl))
|
||||
--- gcc/testsuite/g++.dg/opt/nrv13.C.jj 2007-06-15 16:59:02.000000000 +0200
|
||||
+++ gcc/testsuite/g++.dg/opt/nrv13.C 2007-06-15 17:03:39.000000000 +0200
|
||||
@@ -0,0 +1,42 @@
|
||||
+// PR tree-optimization/32353
|
||||
+// { dg-do run }
|
||||
+// { dg-options "-O2" }
|
||||
+
|
||||
+extern "C" void abort ();
|
||||
+
|
||||
+struct A
|
||||
+{
|
||||
+ int f;
|
||||
+ A (int x) : f (x) {}
|
||||
+};
|
||||
+
|
||||
+A
|
||||
+foo (const A &x, const A &y)
|
||||
+{
|
||||
+ A r (0);
|
||||
+ r = x.f == -111 ? y : (y.f == -111 || x.f > y.f) ? x : y;
|
||||
+ A s (0);
|
||||
+ r = r.f == -111 ? s : (r.f > s.f) ? r : s;
|
||||
+ return r;
|
||||
+}
|
||||
+
|
||||
+int
|
||||
+main ()
|
||||
+{
|
||||
+ if (foo (A (0), A (1)).f != 1)
|
||||
+ abort ();
|
||||
+ if (foo (A (1), A (9)).f != 9)
|
||||
+ abort ();
|
||||
+ if (foo (A (9), A (1)).f != 9)
|
||||
+ abort ();
|
||||
+ if (foo (A (-4), A (-5)).f != 0)
|
||||
+ abort ();
|
||||
+ if (foo (A (-111), A (-111)).f != 0)
|
||||
+ abort ();
|
||||
+ if (foo (A (2), A (-111)).f != 2)
|
||||
+ abort ();
|
||||
+ if (foo (A (-111), A (6)).f != 6)
|
||||
+ abort ();
|
||||
+ if (foo (A (-111), A (-4)).f != 0)
|
||||
+ abort ();
|
||||
+}
|
183
gcc41-pr32468-2.patch
Normal file
183
gcc41-pr32468-2.patch
Normal file
@ -0,0 +1,183 @@
|
||||
2007-06-25 Jakub Jelinek <jakub@redhat.com>
|
||||
|
||||
PR libgomp/32468
|
||||
* omp-low.c (check_combined_parallel): New function.
|
||||
(lower_omp_parallel): Call it via walk_stmts, set
|
||||
OMP_PARALLEL_COMBINED if appropriate.
|
||||
(determine_parallel_type): If OMP_FOR resp. OMP_SECTIONS
|
||||
isn't the only statement in WS_ENTRY_BB or OMP_RETURN
|
||||
the only one in PAR_EXIT_BB and not OMP_PARALLEL_COMBINED,
|
||||
don't consider it as combined parallel.
|
||||
|
||||
--- gcc/omp-low.c.jj 2007-06-21 13:38:10.000000000 +0200
|
||||
+++ gcc/omp-low.c 2007-06-25 19:21:35.000000000 +0200
|
||||
@@ -385,10 +385,13 @@ determine_parallel_type (struct omp_regi
|
||||
|
||||
if (single_succ (par_entry_bb) == ws_entry_bb
|
||||
&& single_succ (ws_exit_bb) == par_exit_bb
|
||||
- && workshare_safe_to_combine_p (par_entry_bb, ws_entry_bb))
|
||||
+ && workshare_safe_to_combine_p (par_entry_bb, ws_entry_bb)
|
||||
+ && (OMP_PARALLEL_COMBINED (last_stmt (par_entry_bb))
|
||||
+ || (last_and_only_stmt (ws_entry_bb)
|
||||
+ && last_and_only_stmt (par_exit_bb))))
|
||||
{
|
||||
- tree ws_stmt = last_stmt (region->inner->entry);
|
||||
+ tree ws_stmt = last_stmt (ws_entry_bb);
|
||||
|
||||
if (region->inner->type == OMP_FOR)
|
||||
{
|
||||
/* If this is a combined parallel loop, we need to determine
|
||||
@@ -4060,6 +4065,28 @@ lower_omp_for (tree *stmt_p, omp_context
|
||||
*stmt_p = new_stmt;
|
||||
}
|
||||
|
||||
+/* Callback for walk_stmts. Check if *TP only contains OMP_FOR
|
||||
+ or OMP_PARALLEL. */
|
||||
+
|
||||
+static tree
|
||||
+check_combined_parallel (tree *tp, int *walk_subtrees, void *data)
|
||||
+{
|
||||
+ struct walk_stmt_info *wi = data;
|
||||
+ int *info = wi->info;
|
||||
+
|
||||
+ *walk_subtrees = 0;
|
||||
+ switch (TREE_CODE (*tp))
|
||||
+ {
|
||||
+ case OMP_FOR:
|
||||
+ case OMP_SECTIONS:
|
||||
+ *info = *info == 0 ? 1 : -1;
|
||||
+ break;
|
||||
+ default:
|
||||
+ *info = -1;
|
||||
+ break;
|
||||
+ }
|
||||
+ return NULL;
|
||||
+}
|
||||
|
||||
/* Lower the OpenMP parallel directive in *STMT_P. CTX holds context
|
||||
information for the directive. */
|
||||
@@ -4077,6 +4104,19 @@ lower_omp_parallel (tree *stmt_p, omp_co
|
||||
par_bind = OMP_PARALLEL_BODY (stmt);
|
||||
par_body = BIND_EXPR_BODY (par_bind);
|
||||
child_fn = ctx->cb.dst_fn;
|
||||
+ if (!OMP_PARALLEL_COMBINED (stmt))
|
||||
+ {
|
||||
+ struct walk_stmt_info wi;
|
||||
+ int ws_num = 0;
|
||||
+
|
||||
+ memset (&wi, 0, sizeof (wi));
|
||||
+ wi.callback = check_combined_parallel;
|
||||
+ wi.info = &ws_num;
|
||||
+ wi.val_only = true;
|
||||
+ walk_stmts (&wi, &par_bind);
|
||||
+ if (ws_num == 1)
|
||||
+ OMP_PARALLEL_COMBINED (stmt) = 1;
|
||||
+ }
|
||||
|
||||
push_gimplify_context ();
|
||||
|
||||
--- gcc/testsuite/gcc.dg/gomp/pr32468-1.c.jj 2007-06-25 21:04:31.000000000 +0200
|
||||
+++ gcc/testsuite/gcc.dg/gomp/pr32468-1.c 2007-06-25 21:07:35.000000000 +0200
|
||||
@@ -0,0 +1,100 @@
|
||||
+/* PR libgomp/32468 */
|
||||
+/* { dg-do compile } */
|
||||
+/* { dg-options "-O2 -fopenmp -fdump-tree-ompexp" } */
|
||||
+
|
||||
+extern int printf (const char *, ...);
|
||||
+extern int omp_get_thread_num (void), omp_get_num_threads (void);
|
||||
+extern int bar (void);
|
||||
+extern int baz (const char *, ...);
|
||||
+
|
||||
+void
|
||||
+f1 (void)
|
||||
+{
|
||||
+#pragma omp parallel
|
||||
+ {
|
||||
+ baz ("%d/%d\n", omp_get_thread_num (), omp_get_num_threads ());
|
||||
+ #pragma omp sections
|
||||
+ {
|
||||
+ #pragma omp section
|
||||
+ printf ("section1 %d/%d\n", omp_get_thread_num (), omp_get_num_threads ());
|
||||
+ #pragma omp section
|
||||
+ printf ("section2 %d/%d\n", omp_get_thread_num (), omp_get_num_threads ());
|
||||
+ }
|
||||
+ }
|
||||
+}
|
||||
+
|
||||
+void
|
||||
+f2 (void)
|
||||
+{
|
||||
+#pragma omp parallel
|
||||
+ {
|
||||
+ #pragma omp sections
|
||||
+ {
|
||||
+ #pragma omp section
|
||||
+ printf ("section1 %d/%d\n", omp_get_thread_num (), omp_get_num_threads ());
|
||||
+ #pragma omp section
|
||||
+ printf ("section2 %d/%d\n", omp_get_thread_num (), omp_get_num_threads ());
|
||||
+ }
|
||||
+ baz ("%d/%d\n", omp_get_thread_num (), omp_get_num_threads ());
|
||||
+ }
|
||||
+}
|
||||
+
|
||||
+void
|
||||
+f3 (void)
|
||||
+{
|
||||
+#pragma omp parallel
|
||||
+ {
|
||||
+ int bb = bar ();
|
||||
+ #pragma omp sections
|
||||
+ {
|
||||
+ #pragma omp section
|
||||
+ printf ("section1 %d/%d\n", omp_get_thread_num (), omp_get_num_threads ());
|
||||
+ #pragma omp section
|
||||
+ printf ("section2 %d/%d\n", omp_get_thread_num (), omp_get_num_threads ());
|
||||
+ }
|
||||
+ }
|
||||
+}
|
||||
+
|
||||
+void
|
||||
+f4 (void)
|
||||
+{
|
||||
+ int i;
|
||||
+#pragma omp parallel
|
||||
+ {
|
||||
+ baz ("%d/%d\n", omp_get_thread_num (), omp_get_num_threads ());
|
||||
+ #pragma omp for schedule (dynamic, 15)
|
||||
+ for (i = 0; i < 10000; i++)
|
||||
+ printf ("section1 %d/%d\n", omp_get_thread_num (), omp_get_num_threads ());
|
||||
+ }
|
||||
+}
|
||||
+
|
||||
+void
|
||||
+f5 (void)
|
||||
+{
|
||||
+ int i;
|
||||
+#pragma omp parallel
|
||||
+ {
|
||||
+ #pragma omp for schedule (dynamic, 15)
|
||||
+ for (i = 0; i < 10000; i++)
|
||||
+ printf ("section1 %d/%d\n", omp_get_thread_num (), omp_get_num_threads ());
|
||||
+ baz ("%d/%d\n", omp_get_thread_num (), omp_get_num_threads ());
|
||||
+ }
|
||||
+}
|
||||
+
|
||||
+void
|
||||
+f6 (void)
|
||||
+{
|
||||
+ int i;
|
||||
+#pragma omp parallel
|
||||
+ {
|
||||
+ int bb = bar ();
|
||||
+ #pragma omp for schedule (runtime)
|
||||
+ for (i = 0; i < 10000; i++)
|
||||
+ printf ("section1 %d/%d\n", omp_get_thread_num (), omp_get_num_threads ());
|
||||
+ }
|
||||
+}
|
||||
+
|
||||
+/* There should not be a GOMP_parallel_{loop,sections}* call. */
|
||||
+/* { dg-final { scan-tree-dump-times "GOMP_parallel_loop" 0 "ompexp"} } */
|
||||
+/* { dg-final { scan-tree-dump-times "GOMP_parallel_sections" 0 "ompexp"} } */
|
||||
+/* { dg-final { cleanup-tree-dump "ompexp" } } */
|
||||
|
||||
Jakub
|
54
gcc41-pr32468.patch
Normal file
54
gcc41-pr32468.patch
Normal file
@ -0,0 +1,54 @@
|
||||
2007-06-25 Jakub Jelinek <jakub@redhat.com>
|
||||
|
||||
PR libgomp/32468
|
||||
* sections.c (GOMP_parallel_sections_start): Only decrease
|
||||
number of threads to COUNT if dyn_var is true.
|
||||
|
||||
* libgomp.c/pr32468.c: New test.
|
||||
|
||||
--- libgomp/sections.c.jj 2006-10-05 00:24:40.000000000 +0200
|
||||
+++ libgomp/sections.c 2007-06-25 22:03:17.000000000 +0200
|
||||
@@ -1,4 +1,4 @@
|
||||
-/* Copyright (C) 2005 Free Software Foundation, Inc.
|
||||
+/* Copyright (C) 2005, 2007 Free Software Foundation, Inc.
|
||||
Contributed by Richard Henderson <rth@redhat.com>.
|
||||
|
||||
This file is part of the GNU OpenMP Library (libgomp).
|
||||
@@ -106,7 +106,7 @@ GOMP_parallel_sections_start (void (*fn)
|
||||
struct gomp_work_share *ws;
|
||||
|
||||
num_threads = gomp_resolve_num_threads (num_threads);
|
||||
- if (num_threads > count)
|
||||
+ if (gomp_dyn_var && num_threads > count)
|
||||
num_threads = count;
|
||||
|
||||
ws = gomp_new_work_share (false, num_threads);
|
||||
--- libgomp/testsuite/libgomp.c/pr32468.c.jj 2007-06-25 21:51:07.000000000 +0200
|
||||
+++ libgomp/testsuite/libgomp.c/pr32468.c 2007-06-25 21:55:44.000000000 +0200
|
||||
@@ -0,0 +1,26 @@
|
||||
+/* PR libgomp/32468 */
|
||||
+/* { dg-do run } */
|
||||
+
|
||||
+#include <omp.h>
|
||||
+#include <stdlib.h>
|
||||
+
|
||||
+int
|
||||
+main (void)
|
||||
+{
|
||||
+ int res[2] = { -1, -1 };
|
||||
+ omp_set_dynamic (0);
|
||||
+ omp_set_num_threads (4);
|
||||
+#pragma omp parallel
|
||||
+ {
|
||||
+ #pragma omp sections
|
||||
+ {
|
||||
+ #pragma omp section
|
||||
+ res[0] = omp_get_num_threads () != 4;
|
||||
+ #pragma omp section
|
||||
+ res[1] = omp_get_num_threads () != 4;
|
||||
+ }
|
||||
+ }
|
||||
+ if (res[0] != 0 || res[1] != 0)
|
||||
+ abort ();
|
||||
+ return 0;
|
||||
+}
|
@ -1,73 +0,0 @@
|
||||
2007-01-24 Steve LoBasso <slobasso@yahoo.com>
|
||||
Paolo Carlini <pcarlini@suse.de>
|
||||
|
||||
* include/bits/deque.tcc (deque<>::erase(iterator, iterator)):
|
||||
Fix condition.
|
||||
* testsuite/23_containers/deque/modifiers/erase/3.cc: New.
|
||||
|
||||
--- libstdc++-v3/include/bits/deque.tcc (revision 121146)
|
||||
+++ libstdc++-v3/include/bits/deque.tcc (revision 121147)
|
||||
@@ -142,7 +142,7 @@ namespace _GLIBCXX_STD
|
||||
const difference_type __n = __last - __first;
|
||||
const difference_type __elems_before = (__first
|
||||
- this->_M_impl._M_start);
|
||||
- if (static_cast<size_type>(__elems_before) < (size() - __n) / 2)
|
||||
+ if (static_cast<size_type>(__elems_before) <= (size() - __n) / 2)
|
||||
{
|
||||
std::copy_backward(this->_M_impl._M_start, __first, __last);
|
||||
iterator __new_start = this->_M_impl._M_start + __n;
|
||||
--- libstdc++-v3/testsuite/23_containers/deque/modifiers/erase/3.cc (revision 0)
|
||||
+++ libstdc++-v3/testsuite/23_containers/deque/modifiers/erase/3.cc (revision 121147)
|
||||
@@ -0,0 +1,52 @@
|
||||
+// Copyright (C) 2007 Free Software Foundation, Inc.
|
||||
+//
|
||||
+// This file is part of the GNU ISO C++ Library. This library is free
|
||||
+// software; you can redistribute it and/or modify it under the
|
||||
+// terms of the GNU General Public License as published by the
|
||||
+// Free Software Foundation; either version 2, or (at your option)
|
||||
+// any later version.
|
||||
+
|
||||
+// This library is distributed in the hope that it will be useful,
|
||||
+// but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||
+// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||
+// GNU General Public License for more details.
|
||||
+
|
||||
+// You should have received a copy of the GNU General Public License along
|
||||
+// with this library; see the file COPYING. If not, write to the Free
|
||||
+// Software Foundation, 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301,
|
||||
+// USA.
|
||||
+
|
||||
+// 23.2.1.3 deque modifiers
|
||||
+
|
||||
+#include <deque>
|
||||
+#include <testsuite_hooks.h>
|
||||
+
|
||||
+void erase(size_t num_elm, size_t elm_strt, size_t elm_end)
|
||||
+{
|
||||
+ bool test __attribute__((unused)) = true;
|
||||
+ using __gnu_test::copy_tracker;
|
||||
+ using __gnu_test::assignment_operator;
|
||||
+
|
||||
+ std::deque<copy_tracker> x(num_elm);
|
||||
+ copy_tracker::reset();
|
||||
+
|
||||
+ x.erase(x.begin() + elm_strt, x.begin() + elm_end);
|
||||
+
|
||||
+ const size_t min_num_cpy = std::min(elm_strt, num_elm - elm_end);
|
||||
+ VERIFY( assignment_operator::count() == min_num_cpy );
|
||||
+}
|
||||
+
|
||||
+// http://gcc.gnu.org/ml/libstdc++/2007-01/msg00098.html
|
||||
+void test01()
|
||||
+{
|
||||
+ for (size_t num_elm = 0; num_elm <= 10; ++num_elm)
|
||||
+ for (size_t elm_strt = 0; elm_strt <= num_elm; ++elm_strt)
|
||||
+ for (size_t elm_end = elm_strt; elm_end <= num_elm; ++elm_end)
|
||||
+ erase(num_elm, elm_strt, elm_end);
|
||||
+}
|
||||
+
|
||||
+int main()
|
||||
+{
|
||||
+ test01();
|
||||
+ return 0;
|
||||
+}
|
35
gcc41-rh245424.patch
Normal file
35
gcc41-rh245424.patch
Normal file
@ -0,0 +1,35 @@
|
||||
2007-06-25 Jakub Jelinek <jakub@redhat.com>
|
||||
|
||||
* config/rs6000/rs6000.c (rs6000_function_ok_for_sibcall): Ensure
|
||||
decl is non-external for AIX ABI.
|
||||
|
||||
2007-06-25 David Edelsohn <edelsohn@gnu.org>
|
||||
|
||||
* config/rs6000/predicates.md (current_file_function_operand):
|
||||
Ensure the symbol is non-external for AIX ABI.
|
||||
|
||||
--- gcc/config/rs6000/rs6000.c.jj 2007-06-25 22:22:41.000000000 +0200
|
||||
+++ gcc/config/rs6000/rs6000.c 2007-06-25 23:11:20.000000000 +0200
|
||||
@@ -13938,7 +13938,8 @@ rs6000_function_ok_for_sibcall (tree dec
|
||||
}
|
||||
}
|
||||
if (DEFAULT_ABI == ABI_DARWIN
|
||||
- || (*targetm.binds_local_p) (decl))
|
||||
+ || ((*targetm.binds_local_p) (decl)
|
||||
+ && (DEFAULT_ABI != ABI_AIX || !DECL_EXTERNAL (decl))))
|
||||
{
|
||||
tree attr_list = TYPE_ATTRIBUTES (TREE_TYPE (decl));
|
||||
|
||||
--- gcc/config/rs6000/predicates.md.jj 2007-06-25 22:22:41.000000000 +0200
|
||||
+++ gcc/config/rs6000/predicates.md 2007-06-25 22:57:19.000000000 +0200
|
||||
@@ -696,7 +696,9 @@
|
||||
(define_predicate "current_file_function_operand"
|
||||
(and (match_code "symbol_ref")
|
||||
(match_test "(DEFAULT_ABI != ABI_AIX || SYMBOL_REF_FUNCTION_P (op))
|
||||
- && (SYMBOL_REF_LOCAL_P (op)
|
||||
+ && ((SYMBOL_REF_LOCAL_P (op)
|
||||
+ && (DEFAULT_ABI != ABI_AIX
|
||||
+ || !SYMBOL_REF_EXTERNAL_P (op)))
|
||||
|| (op == XEXP (DECL_RTL (current_function_decl),
|
||||
0)))")))
|
||||
|
@ -1,93 +0,0 @@
|
||||
2006-09-18 Jakub Jelinek <jakub@redhat.com>
|
||||
|
||||
* builtins.c (expand_builtin, maybe_emit_chk_warning): Handle
|
||||
BUILT_IN_STRNCAT_CHK.
|
||||
|
||||
* gcc.dg/builtin-strncat-chk-1.c: New test.
|
||||
|
||||
--- gcc/builtins.c.jj 2006-09-02 08:54:22.000000000 +0200
|
||||
+++ gcc/builtins.c 2006-09-18 16:54:57.000000000 +0200
|
||||
@@ -6437,6 +6437,7 @@ expand_builtin (tree exp, rtx target, rt
|
||||
case BUILT_IN_STPCPY_CHK:
|
||||
case BUILT_IN_STRNCPY_CHK:
|
||||
case BUILT_IN_STRCAT_CHK:
|
||||
+ case BUILT_IN_STRNCAT_CHK:
|
||||
case BUILT_IN_SNPRINTF_CHK:
|
||||
case BUILT_IN_VSNPRINTF_CHK:
|
||||
maybe_emit_chk_warning (exp, fcode);
|
||||
@@ -10128,6 +10129,11 @@ maybe_emit_chk_warning (tree exp, enum b
|
||||
arg_mask = 6;
|
||||
is_strlen = 1;
|
||||
break;
|
||||
+ case BUILT_IN_STRNCAT_CHK:
|
||||
+ /* For __strncat_chk the warning will be emitted only if overflowing
|
||||
+ by at least strlen (dest) + 1 bytes. */
|
||||
+ arg_mask = 12;
|
||||
+ break;
|
||||
case BUILT_IN_STRNCPY_CHK:
|
||||
arg_mask = 12;
|
||||
break;
|
||||
@@ -10165,6 +10171,22 @@ maybe_emit_chk_warning (tree exp, enum b
|
||||
if (! len || ! host_integerp (len, 1) || tree_int_cst_lt (len, size))
|
||||
return;
|
||||
}
|
||||
+ else if (fcode == BUILT_IN_STRNCAT_CHK)
|
||||
+ {
|
||||
+ tree src = TREE_VALUE (TREE_CHAIN (arglist));
|
||||
+ if (! src || ! host_integerp (len, 1) || tree_int_cst_lt (len, size))
|
||||
+ return;
|
||||
+ src = c_strlen (src, 1);
|
||||
+ if (! src || ! host_integerp (src, 1))
|
||||
+ {
|
||||
+ locus = EXPR_LOCATION (exp);
|
||||
+ warning (0, "%Hcall to %D might overflow destination buffer",
|
||||
+ &locus, get_callee_fndecl (exp));
|
||||
+ return;
|
||||
+ }
|
||||
+ else if (tree_int_cst_lt (src, size))
|
||||
+ return;
|
||||
+ }
|
||||
else if (! host_integerp (len, 1) || ! tree_int_cst_lt (size, len))
|
||||
return;
|
||||
|
||||
--- gcc/testsuite/gcc.dg/builtin-strncat-chk-1.c.jj 2006-09-18 13:07:54.000000000 +0200
|
||||
+++ gcc/testsuite/gcc.dg/builtin-strncat-chk-1.c 2006-09-18 16:55:09.000000000 +0200
|
||||
@@ -0,0 +1,38 @@
|
||||
+/* Test whether buffer overflow warnings for __strncat_chk builtin
|
||||
+ are emitted properly. */
|
||||
+/* { dg-do compile } */
|
||||
+/* { dg-options "-O2 -std=gnu99" } */
|
||||
+
|
||||
+extern void abort (void);
|
||||
+
|
||||
+#include "../gcc.c-torture/execute/builtins/chk.h"
|
||||
+
|
||||
+char buf1[20];
|
||||
+char *q;
|
||||
+
|
||||
+void
|
||||
+test (int arg, ...)
|
||||
+{
|
||||
+ char *p = &buf1[10];
|
||||
+
|
||||
+ *p = 0;
|
||||
+ strncat (p, "abcdefg", 9);
|
||||
+ *p = 0;
|
||||
+ strncat (p, "abcdefghi", 9);
|
||||
+ *p = 0;
|
||||
+ strncat (p, "abcdefghij", 9);
|
||||
+ *p = 0;
|
||||
+ strncat (p, "abcdefghi", 10);
|
||||
+ *p = 0;
|
||||
+ strncat (p, "abcdefghij", 10); /* { dg-warning "will always overflow" } */
|
||||
+ *p = 0;
|
||||
+ strncat (p, "abcdefgh", 11);
|
||||
+ *p = 0;
|
||||
+ strncat (p, "abcdefghijkl", 11); /* { dg-warning "will always overflow" } */
|
||||
+ *p = 0;
|
||||
+ strncat (p, q, 9);
|
||||
+ *p = 0;
|
||||
+ strncat (p, q, 10); /* { dg-warning "might overflow" } */
|
||||
+ *p = 0;
|
||||
+ strncat (p, q, 11); /* { dg-warning "might overflow" } */
|
||||
+}
|
@ -1,392 +0,0 @@
|
||||
2006-12-08 Jakub Jelinek <jakub@redhat.com>
|
||||
|
||||
* g++.dg/debug/vartrack1.C: New test.
|
||||
|
||||
* g++.dg/opt/ifcvt1.C: New test.
|
||||
|
||||
2006-12-08 Alexandre Oliva <aoliva@redhat.com>
|
||||
|
||||
* g++.dg/template/array17.C: New test.
|
||||
|
||||
2006-05-05 Jakub Jelinek <jakub@redhat.com>
|
||||
|
||||
* gcc.dg/tls/opt-13.c: New test.
|
||||
|
||||
2006-04-25 Jakub Jelinek <jakub@redhat.com>
|
||||
|
||||
* gcc.dg/20060425-2.c: New test.
|
||||
|
||||
* g++.dg/opt/pr15054-2.C: New test.
|
||||
|
||||
2006-04-20 Jakub Jelinek <jakub@redhat.com>
|
||||
|
||||
* gcc.c-torture/execute/20060420-1.c: New test.
|
||||
|
||||
2006-04-12 Jakub Jelinek <jakub@redhat.com>
|
||||
|
||||
* gcc.c-torture/execute/20060412-1.c: New test.
|
||||
|
||||
2006-02-25 Alexandre Oliva <aoliva@redhat.com>
|
||||
|
||||
* gcc.target/powerpc/altivec-23.c: New test.
|
||||
|
||||
--- gcc/testsuite/gcc.target/powerpc/altivec-23.c 1970-01-01 00:00:00.000000000 +0000
|
||||
+++ gcc/testsuite/gcc.target/powerpc/altivec-23.c 2006-02-25 04:10:36.000000000 -0300
|
||||
@@ -0,0 +1,25 @@
|
||||
+/* Verify that it is possible to define variables of composite types
|
||||
+ containing vector types. We used to crash handling the
|
||||
+ initializer of automatic ones. */
|
||||
+
|
||||
+/* { dg-do compile } */
|
||||
+/* { dg-xfail-if "" { "powerpc-ibm-aix*" } { "-maltivec" } { "" } } */
|
||||
+/* { dg-options "-maltivec -mabi=altivec" } */
|
||||
+
|
||||
+#include <altivec.h>
|
||||
+
|
||||
+typedef int bt;
|
||||
+typedef vector bt vt;
|
||||
+typedef struct { vt x; bt y[sizeof(vt) / sizeof (bt)]; } st;
|
||||
+#define INIT { 1, 2, 3, 4 }
|
||||
+
|
||||
+void f ()
|
||||
+{
|
||||
+ vt x = INIT;
|
||||
+ vt y[1] = { INIT };
|
||||
+ st s = { INIT, INIT };
|
||||
+}
|
||||
+
|
||||
+vt x = INIT;
|
||||
+vt y[1] = { INIT };
|
||||
+st s = { INIT, INIT };
|
||||
--- gcc/testsuite/gcc.c-torture/execute/20060420-1.c.jj 2006-04-20 18:47:19.000000000 +0200
|
||||
+++ gcc/testsuite/gcc.c-torture/execute/20060420-1.c 2006-04-20 19:07:20.000000000 +0200
|
||||
@@ -0,0 +1,71 @@
|
||||
+extern void abort (void);
|
||||
+
|
||||
+typedef float v4flt __attribute__ ((vector_size (16)));
|
||||
+
|
||||
+void __attribute__ ((noinline)) foo (float *dst, float **src, int a, int n)
|
||||
+{
|
||||
+ int i, j;
|
||||
+ int z = sizeof (v4flt) / sizeof (float);
|
||||
+ unsigned m = sizeof (v4flt) - 1;
|
||||
+
|
||||
+ for (j = 0; j < n && (((unsigned long) dst + j) & m); ++j)
|
||||
+ {
|
||||
+ float t = src[0][j];
|
||||
+ for (i = 1; i < a; ++i)
|
||||
+ t += src[i][j];
|
||||
+ dst[j] = t;
|
||||
+ }
|
||||
+
|
||||
+ for (; j < (n - (4 * z - 1)); j += 4 * z)
|
||||
+ {
|
||||
+ v4flt t0 = *(v4flt *) (src[0] + j + 0 * z);
|
||||
+ v4flt t1 = *(v4flt *) (src[0] + j + 1 * z);
|
||||
+ v4flt t2 = *(v4flt *) (src[0] + j + 2 * z);
|
||||
+ v4flt t3 = *(v4flt *) (src[0] + j + 3 * z);
|
||||
+ for (i = 1; i < a; ++i)
|
||||
+ {
|
||||
+ t0 += *(v4flt *) (src[i] + j + 0 * z);
|
||||
+ t1 += *(v4flt *) (src[i] + j + 1 * z);
|
||||
+ t2 += *(v4flt *) (src[i] + j + 2 * z);
|
||||
+ t3 += *(v4flt *) (src[i] + j + 3 * z);
|
||||
+ }
|
||||
+ *(v4flt *) (dst + j + 0 * z) = t0;
|
||||
+ *(v4flt *) (dst + j + 1 * z) = t1;
|
||||
+ *(v4flt *) (dst + j + 2 * z) = t2;
|
||||
+ *(v4flt *) (dst + j + 3 * z) = t3;
|
||||
+ }
|
||||
+ for (; j < n; ++j)
|
||||
+ {
|
||||
+ float t = src[0][j];
|
||||
+ for (i = 1; i < a; ++i)
|
||||
+ t += src[i][j];
|
||||
+ dst[j] = t;
|
||||
+ }
|
||||
+}
|
||||
+
|
||||
+float buffer[64];
|
||||
+
|
||||
+int
|
||||
+main (void)
|
||||
+{
|
||||
+ int i;
|
||||
+ float *dst, *src[2];
|
||||
+
|
||||
+ dst = buffer;
|
||||
+ dst += (-(long int) buffer & (16 * sizeof (float) - 1)) / sizeof (float);
|
||||
+ src[0] = dst + 16;
|
||||
+ src[1] = dst + 32;
|
||||
+ for (i = 0; i < 16; ++i)
|
||||
+ {
|
||||
+ src[0][i] = (float) i + 11 * (float) i;
|
||||
+ src[1][i] = (float) i + 12 * (float) i;
|
||||
+ }
|
||||
+ foo (dst, src, 2, 16);
|
||||
+ for (i = 0; i < 16; ++i)
|
||||
+ {
|
||||
+ float e = (float) i + 11 * (float) i + (float) i + 12 * (float) i;
|
||||
+ if (dst[i] != e)
|
||||
+ abort ();
|
||||
+ }
|
||||
+ return 0;
|
||||
+}
|
||||
--- gcc/testsuite/gcc.c-torture/execute/20060412-1.c.jj 2006-04-03 11:04:53.758553500 +0200
|
||||
+++ gcc/testsuite/gcc.c-torture/execute/20060412-1.c 2006-04-12 10:54:20.000000000 +0200
|
||||
@@ -0,0 +1,33 @@
|
||||
+extern void abort (void);
|
||||
+
|
||||
+struct S
|
||||
+{
|
||||
+ long o;
|
||||
+};
|
||||
+
|
||||
+struct T
|
||||
+{
|
||||
+ long o;
|
||||
+ struct S m[82];
|
||||
+};
|
||||
+
|
||||
+struct T t;
|
||||
+
|
||||
+int
|
||||
+main ()
|
||||
+{
|
||||
+ struct S *p, *q;
|
||||
+
|
||||
+ p = (struct S *) &t;
|
||||
+ p = &((struct T *) p)->m[0];
|
||||
+ q = p + 82;
|
||||
+ while (--q > p)
|
||||
+ q->o = -1;
|
||||
+ q->o = 0;
|
||||
+
|
||||
+ if (q > p)
|
||||
+ abort ();
|
||||
+ if (q - p > 0)
|
||||
+ abort ();
|
||||
+ return 0;
|
||||
+}
|
||||
--- gcc/testsuite/g++.dg/opt/pr15054-2.C 2006-04-19 19:21:31.748476000 +0200
|
||||
+++ gcc/testsuite/g++.dg/opt/pr15054-2.C 2006-04-25 15:55:07.000000000 +0200
|
||||
@@ -0,0 +1,39 @@
|
||||
+// PR middle-end/15054
|
||||
+
|
||||
+// { dg-do run }
|
||||
+// { dg-options "-O2" }
|
||||
+
|
||||
+extern "C" void abort (void);
|
||||
+
|
||||
+void
|
||||
+__attribute__((noinline))
|
||||
+check (long x, long y)
|
||||
+{
|
||||
+ if (x != y)
|
||||
+ abort ();
|
||||
+}
|
||||
+
|
||||
+struct A
|
||||
+{
|
||||
+ A() : a(2) { check (a, 2); }
|
||||
+ ~A() { check (a, 2); }
|
||||
+private:
|
||||
+ long a;
|
||||
+};
|
||||
+
|
||||
+class B {
|
||||
+ long b;
|
||||
+ B& operator =(const B& );
|
||||
+public:
|
||||
+ B (long p) : b(p) { check (b, 6); }
|
||||
+ B (const B& p) : b(p.b) { check (b, 6); }
|
||||
+ ~B () { check (b, 6); A obj; check (b, 6); }
|
||||
+ B foo() { return B(*this); }
|
||||
+};
|
||||
+
|
||||
+int main ()
|
||||
+{
|
||||
+ B o(6);
|
||||
+ o.foo().foo();
|
||||
+ return 0;
|
||||
+}
|
||||
--- gcc/testsuite/gcc.dg/20060425-2.c 2004-06-24 14:04:38.000000000 -0400
|
||||
+++ gcc/testsuite/gcc.dg/20060425-2.c 2006-04-25 09:15:04.000000000 -0400
|
||||
@@ -0,0 +1,10 @@
|
||||
+/* { dg-do compile } */
|
||||
+/* { dg-options "-O2" } */
|
||||
+
|
||||
+double
|
||||
+crashme (double v, double *p)
|
||||
+{
|
||||
+ if (v < 0. && *p == 1.)
|
||||
+ v = 0.;
|
||||
+ return v;
|
||||
+}
|
||||
--- gcc/testsuite/gcc.dg/tls/opt-13.c 2006-04-19 19:21:31.748476000 +0200
|
||||
+++ gcc/testsuite/gcc.dg/tls/opt-13.c 2006-05-05 11:01:33.000000000 +0200
|
||||
@@ -0,0 +1,16 @@
|
||||
+/* { dg-do compile } */
|
||||
+/* { dg-options "-O2" } */
|
||||
+/* { dg-require-effective-target tls } */
|
||||
+
|
||||
+__thread struct
|
||||
+{
|
||||
+ int a;
|
||||
+ char b[32];
|
||||
+} thr;
|
||||
+
|
||||
+int
|
||||
+main ()
|
||||
+{
|
||||
+ __builtin_strcpy (thr.b, "abcd");
|
||||
+ return 0;
|
||||
+}
|
||||
--- gcc/testsuite/g++.dg/debug/vartrack1.C 2004-06-24 14:04:38.000000000 -0400
|
||||
+++ gcc/testsuite/g++.dg/debug/vartrack1.C 2006-12-08 05:29:41.000000000 -0500
|
||||
@@ -0,0 +1,99 @@
|
||||
+// This testcase used to hang the compiler in vt_find_locations.
|
||||
+// { dg-do compile }
|
||||
+// { dg-options "-O2 -g" }
|
||||
+
|
||||
+struct S
|
||||
+{
|
||||
+ int a;
|
||||
+ S *b, *c, *d;
|
||||
+};
|
||||
+
|
||||
+struct T
|
||||
+{
|
||||
+ void f1 (S *x);
|
||||
+ void f2 (S *x);
|
||||
+ void f3 (S *x, S *y);
|
||||
+ S *e;
|
||||
+};
|
||||
+
|
||||
+void
|
||||
+T::f3 (S *x, S *y)
|
||||
+{
|
||||
+ while (x != this->e && (!x || x->a == 1))
|
||||
+ {
|
||||
+ if (x == y->c)
|
||||
+ {
|
||||
+ S *w = y->d;
|
||||
+ if (w && w->a == 0)
|
||||
+ {
|
||||
+ w->a = 1;
|
||||
+ y->a = 0;
|
||||
+ f2 (y);
|
||||
+ w = y->d;
|
||||
+ }
|
||||
+ if (w && (!w->c || w->c->a == 1) && (!w->d || w->d->a == 1))
|
||||
+ {
|
||||
+ w->a = 0;
|
||||
+ x = y;
|
||||
+ y = x->b;
|
||||
+ }
|
||||
+ else
|
||||
+ {
|
||||
+ if (w && (!w->d || w->d->a == 1))
|
||||
+ {
|
||||
+ if (w->c)
|
||||
+ w->c->a = 1;
|
||||
+ w->a = 0;
|
||||
+ f1 (w);
|
||||
+ w = y->d;
|
||||
+ }
|
||||
+ if (w)
|
||||
+ {
|
||||
+ w->a = y->a;
|
||||
+ if (w->d)
|
||||
+ w->d->a = 1;
|
||||
+ }
|
||||
+ y->a = 1;
|
||||
+ f2 (y);
|
||||
+ x = e;
|
||||
+ }
|
||||
+ }
|
||||
+ else
|
||||
+ {
|
||||
+ S *w = y->c;
|
||||
+ if (w && w->a == 0)
|
||||
+ {
|
||||
+ w->a = 1;
|
||||
+ y->a = 0;
|
||||
+ f1 (y);
|
||||
+ w = y->c;
|
||||
+ }
|
||||
+ if (w && (!w->c || w->c->a == 1) && (!w->d || w->d->a == 1))
|
||||
+ {
|
||||
+ w->a = 0;
|
||||
+ x = y;
|
||||
+ y = x->b;
|
||||
+ }
|
||||
+ else
|
||||
+ {
|
||||
+ if (w && (!w->c || w->c->a == 1))
|
||||
+ {
|
||||
+ w->a = 0;
|
||||
+ if (w->d)
|
||||
+ w->d->a = 1;
|
||||
+ f2 (w);
|
||||
+ w = y->c;
|
||||
+ }
|
||||
+ if (w)
|
||||
+ {
|
||||
+ w->a = y->a;
|
||||
+ if (w->c)
|
||||
+ w->c->a = 1;
|
||||
+ }
|
||||
+ y->a = 1;
|
||||
+ f1 (y);
|
||||
+ x = e;
|
||||
+ }
|
||||
+ }
|
||||
+ }
|
||||
+}
|
||||
--- gcc/testsuite/g++.dg/opt/ifcvt1.C 2006-10-04 16:28:56.502613000 +0200
|
||||
+++ gcc/testsuite/g++.dg/opt/ifcvt1.C 2006-12-08 12:23:23.000000000 +0100
|
||||
@@ -0,0 +1,17 @@
|
||||
+// { dg-do compile }
|
||||
+// { dg-options "-O2 -fnon-call-exceptions" }
|
||||
+
|
||||
+struct S { ~S () throw () {} };
|
||||
+double bar ();
|
||||
+
|
||||
+int
|
||||
+foo ()
|
||||
+{
|
||||
+ S a;
|
||||
+ int i = 0;
|
||||
+ double c = bar ();
|
||||
+ c = c < 0 ? -c : c;
|
||||
+ if (c <= 1.e-8)
|
||||
+ i += 24;
|
||||
+ return i;
|
||||
+}
|
||||
--- gcc/testsuite/g++.dg/template/array17.C 2006-10-04 16:28:56.502613000 +0200
|
||||
+++ gcc/testsuite/g++.dg/template/array17.C 2006-12-08 12:38:27.000000000 +0100
|
||||
@@ -0,0 +1,23 @@
|
||||
+// { dg-do compile }
|
||||
+
|
||||
+template <typename T>
|
||||
+struct V {
|
||||
+ T& operator[](int);
|
||||
+};
|
||||
+
|
||||
+struct S {
|
||||
+ S operator +(int);
|
||||
+ template <typename T> T value();
|
||||
+};
|
||||
+
|
||||
+template <typename T>
|
||||
+void R (T v)
|
||||
+{
|
||||
+ v[(S() + 0).template value<int>()][0] = 0;
|
||||
+}
|
||||
+
|
||||
+int
|
||||
+main ()
|
||||
+{
|
||||
+ R(V<V<int> >());
|
||||
+}
|
106
gcc41.spec
106
gcc41.spec
@ -1,6 +1,6 @@
|
||||
%define DATE 20070615
|
||||
%define DATE 20070626
|
||||
%define gcc_version 4.1.2
|
||||
%define gcc_release 13
|
||||
%define gcc_release 14
|
||||
%define _unpackaged_files_terminate_build 0
|
||||
%define multilib_64_archs sparc64 ppc64 s390x x86_64
|
||||
%define include_gappletviewer 1
|
||||
@ -118,33 +118,23 @@ Patch6: gcc41-ada-pr18302.patch
|
||||
Patch7: gcc41-ada-tweaks.patch
|
||||
Patch8: gcc41-java-slow_pthread_self.patch
|
||||
Patch9: gcc41-ppc32-retaddr.patch
|
||||
Patch10: gcc41-amdfam10.patch
|
||||
Patch11: gcc41-dsohandle.patch
|
||||
Patch12: gcc41-rh184446.patch
|
||||
Patch13: gcc41-pr20297-test.patch
|
||||
Patch14: gcc41-objc-rh185398.patch
|
||||
Patch15: gcc41-tests.patch
|
||||
Patch16: gcc41-hash-style-gnu.patch
|
||||
Patch17: gcc41-java-libdotdotlib.patch
|
||||
Patch18: gcc41-pr28709.patch
|
||||
Patch19: gcc41-pr28755.patch
|
||||
Patch20: gcc41-pr27898.patch
|
||||
Patch21: gcc41-pr27567.patch
|
||||
Patch22: gcc41-pr29272.patch
|
||||
Patch23: gcc41-pr29059.patch
|
||||
Patch24: gcc41-strncat-chk.patch
|
||||
Patch25: gcc41-pr29299.patch
|
||||
Patch26: gcc41-java-bogus-debugline.patch
|
||||
Patch27: gcc41-libjava-visibility.patch
|
||||
Patch28: gcc41-pr31187.patch
|
||||
Patch29: gcc41-pr31809.patch
|
||||
Patch30: gcc41-rh234515.patch
|
||||
Patch31: gcc41-pr32139.patch
|
||||
Patch32: gcc41-rh236895.patch
|
||||
Patch33: gcc41-pr32285.patch
|
||||
Patch34: gcc41-rh235008.patch
|
||||
Patch35: gcc41-pr31748.patch
|
||||
Patch36: gcc41-pr32353.patch
|
||||
Patch10: gcc41-dsohandle.patch
|
||||
Patch11: gcc41-rh184446.patch
|
||||
Patch12: gcc41-pr20297-test.patch
|
||||
Patch13: gcc41-hash-style-gnu.patch
|
||||
Patch14: gcc41-java-libdotdotlib.patch
|
||||
Patch15: gcc41-pr28755.patch
|
||||
Patch16: gcc41-pr27898.patch
|
||||
Patch17: gcc41-java-bogus-debugline.patch
|
||||
Patch18: gcc41-libjava-visibility.patch
|
||||
Patch19: gcc41-pr32139.patch
|
||||
Patch20: gcc41-rh236895.patch
|
||||
Patch21: gcc41-rh235008.patch
|
||||
Patch22: gcc41-pr31748.patch
|
||||
Patch23: gcc41-pr28690.patch
|
||||
Patch24: gcc41-pr32468.patch
|
||||
Patch25: gcc41-pr32468-2.patch
|
||||
Patch26: gcc41-rh245424.patch
|
||||
|
||||
%define _gnu %{nil}
|
||||
%ifarch sparc
|
||||
@ -433,33 +423,23 @@ which are required to run programs compiled with the GNAT.
|
||||
%patch7 -p0 -b .ada-tweaks~
|
||||
%patch8 -p0 -b .java-slow_pthread_self~
|
||||
%patch9 -p0 -b .ppc32-retaddr~
|
||||
%patch10 -p0 -b .amdfam10~
|
||||
%patch11 -p0 -b .dsohandle~
|
||||
%patch12 -p0 -b .rh184446~
|
||||
%patch13 -p0 -E -b .pr20297-test~
|
||||
%patch14 -p0 -b .objc-rh185398~
|
||||
%patch15 -p0 -b .tests~
|
||||
%patch16 -p0 -b .hash-style-gnu~
|
||||
%patch17 -p0 -b .java-libdotdotlib~
|
||||
%patch18 -p0 -b .pr28709~
|
||||
%patch19 -p0 -b .pr28755~
|
||||
%patch20 -p0 -b .pr27898~
|
||||
%patch21 -p0 -b .pr27567~
|
||||
%patch22 -p0 -b .pr29272~
|
||||
%patch23 -p0 -b .pr29059~
|
||||
%patch24 -p0 -b .strncat-chk~
|
||||
%patch25 -p0 -b .pr29299~
|
||||
%patch26 -p0 -b .java-bogus-debugline~
|
||||
%patch27 -p0 -b .libjava-visibility~
|
||||
%patch28 -p0 -b .pr31187~
|
||||
%patch29 -p0 -b .pr31809~
|
||||
%patch30 -p0 -b .rh234515~
|
||||
%patch31 -p0 -b .pr32139~
|
||||
%patch32 -p0 -b .rh236895~
|
||||
%patch33 -p0 -b .pr32285~
|
||||
%patch34 -p0 -b .rh235008~
|
||||
%patch35 -p0 -b .pr31748~
|
||||
%patch36 -p0 -b .pr32353~
|
||||
%patch10 -p0 -b .dsohandle~
|
||||
%patch11 -p0 -b .rh184446~
|
||||
%patch12 -p0 -E -b .pr20297-test~
|
||||
%patch13 -p0 -b .hash-style-gnu~
|
||||
%patch14 -p0 -b .java-libdotdotlib~
|
||||
%patch15 -p0 -b .pr28755~
|
||||
%patch16 -p0 -b .pr27898~
|
||||
%patch17 -p0 -b .java-bogus-debugline~
|
||||
%patch18 -p0 -b .libjava-visibility~
|
||||
%patch19 -p0 -b .pr32139~
|
||||
%patch20 -p0 -b .rh236895~
|
||||
%patch21 -p0 -b .rh235008~
|
||||
%patch22 -p0 -b .pr31748~
|
||||
%patch23 -p0 -b .pr28690~
|
||||
%patch24 -p0 -b .pr32468~
|
||||
%patch25 -p0 -b .pr32468-2~
|
||||
%patch26 -p0 -b .rh245424~
|
||||
|
||||
sed -i -e 's/4\.1\.3/4.1.2/' gcc/BASE-VER gcc/version.c
|
||||
sed -i -e 's/" (Red Hat[^)]*)"/" (Red Hat %{version}-%{gcc_release})"/' gcc/version.c
|
||||
@ -1583,6 +1563,20 @@ fi
|
||||
%doc rpm.doc/changelogs/libmudflap/ChangeLog*
|
||||
|
||||
%changelog
|
||||
* Tue Jun 26 2007 Jakub Jelinek <jakub@redhat.com> 4.1.2-14
|
||||
- update from gcc-4_1-branch (-r125727:126008)
|
||||
- PRs inline-asm/32109, rtl-optimization/28011, target/32389
|
||||
- gomp update from gcc-4_2-branch (-r125917:125918)
|
||||
- PR middle-end/32362
|
||||
- on ppc{,64} when tuning for power6{,x}, try to put the base
|
||||
register as first operand in instructions to improve
|
||||
performance (Peter Bergner, #225425, PR middle-end/28690)
|
||||
- on ppc64 emit nop after a call and disallow sibling calls
|
||||
if the target function is not defined in the same object file
|
||||
(David Edelsohn, #245424)
|
||||
- gomp parallel sections fix and fix for checking whether combined
|
||||
parallel can be used (PR libgomp/32468)
|
||||
|
||||
* Fri Jun 15 2007 Jakub Jelinek <jakub@redhat.com> 4.1.2-13
|
||||
- update from gcc-4_1-branch (-r124365:125727)
|
||||
- PRs libfortran/31409, libfortran/31880, libfortran/31964,
|
||||
|
Loading…
Reference in New Issue
Block a user