+2009-04-10 H.J. Lu <hongjiu.lu@intel.com>
+
+ PR middle-end/39701
+ * common.opt (-fdelete-null-pointer-checks): Initialize to 1.
+
+ * opts.c (decode_options): Don't set flag_delete_null_pointer_checks
+ here.
+
+ * doc/invoke.texi: Update -fdelete-null-pointer-checks.
+
+2009-04-10 Chao-ying Fu <fu@mips.com>
+
+ * doc/tm.texi (Instruction Output): Document
+ TARGET_ASM_FINAL_POSTSCAN_INSN.
+ * target.h (final_postscan_insn): New field in asm_out.
+ * target-def.h (TARGET_ASM_FINAL_POSTSCAN_INSN): New define.
+ (TARGET_ASM_OUT): Add TARGET_ASM_FINAL_POSTSCAN_INSN.
+ * final.c (final_scan_insn): Call
+ targetm.asm_out.final_postscan_insn after outputting
+ an asm macro and a normal instruction.
+
+ * config/mips/mips.h (FINAL_PRESCAN_INSN): New define.
+ * config/mips/mips-protos.h (mips_final_prescan_insn): Declare.
+ * config/mips/mips.c (mips_at_reg_p): New for_each_rtx callback.
+ (mips_final_prescan_insn, mips_final_postscan_insn): New functions.
+ (TARGET_ASM_FINAL_POSTSCAN_INSN): New define.
+
+2009-04-10 Paolo Bonzini <bonzini@gnu.org>
+
+ PR middle-end/39701
+ * fold-const.c (tree_single_nonzero_warnv_p): Pass non-static
+ variables as non-NULL even with -fdelete-null-pointer-checks.
+
+2009-04-10 H.J. Lu <hongjiu.lu@intel.com>
+
+ * config/rs6000/darwin-vecsave.asm: Remove extra "*/".
+
+2009-04-09 H.J. Lu <hongjiu.lu@intel.com>
+
+ PR target/39678
+ * config/i386/i386.c (classify_argument): Handle SCmode with
+ (bit_offset % 64) != 0.
+
+2009-04-09 Sandra Loosemore <sandra@codesourcery.com>
+
+ * doc/invoke.texi (Optimize Options): Add cross-reference to
+ -Q --help=optimizers examples.
+
+2009-04-10 Ben Elliston <bje@au.ibm.com>
+
+ PR target/36800
+ * config/rs6000/rs6000.c (rs6000_gimplify_va_arg): Do not set
+ regalign for the reg == fpr and TDmode case.
+
+2009-04-09 David Ayers <ayers@fsfe.org>
+
+ PR objc/29200
+ * objc/objc-act.c (warn_with_method): Remove helper function.
+ (check_duplicates): Call warning and inform directly.
+ (really_start_method): Likewise.
+
+2009-04-09 Paolo Bonzini <bonzini@gnu.org>
+
+ * expmed.c (expand_divmod): Always use a comparison for a division
+ by a large unsigned integer.
+
+ * fold-const.c (tree_single_nonzero_warnv_p): Always treat decls
+ for things others than variables or functions as nonzero.
+
+2009-04-09 Nick Clifton <nickc@redhat.com>
+
+ * unwind-compat.c: Change copyright header to refer to version
+ 3 of the GNU General Public License with version 3.1 of the
+ GCC Runtime Library Exception and to point readers at the
+ COPYING3 and COPYING3.RUNTIME files and the FSF's license web page.
+ * config/alpha/crtfastmath.c: Likewise.
+ * config/alpha/linux-unwind.h: Likewise.
+ * config/alpha/qrnnd.asm: Likewise.
+ * config/alpha/vms-crt0-64.c: Likewise.
+ * config/alpha/vms-crt0.c: Likewise.
+ * config/alpha/vms-dwarf2.asm: Likewise.
+ * config/alpha/vms-dwarf2eh.asm: Likewise.
+ * config/alpha/vms-psxcrt0-64.c: Likewise.
+ * config/alpha/vms-psxcrt0.c: Likewise.
+ * config/alpha/vms_tramp.asm: Likewise.
+ * config/arc/initfini.c: Likewise.
+ * config/arc/lib1funcs.asm: Likewise.
+ * config/arm/bpabi-v6m.S: Likewise.
+ * config/arm/bpabi.S: Likewise.
+ * config/arm/bpabi.c: Likewise.
+ * config/arm/crti.asm: Likewise.
+ * config/arm/crtn.asm: Likewise.
+ * config/arm/ieee754-df.S: Likewise.
+ * config/arm/ieee754-sf.S: Likewise.
+ * config/arm/lib1funcs.asm: Likewise.
+ * config/arm/libunwind.S: Likewise.
+ * config/arm/linux-atomic.c: Likewise.
+ * config/arm/mmintrin.h: Likewise.
+ * config/arm/pr-support.c: Likewise.
+ * config/arm/unaligned-funcs.c: Likewise.
+ * config/arm/unwind-arm.c: Likewise.
+ * config/arm/unwind-arm.h: Likewise.
+ * config/avr/libgcc.S: Likewise.
+ * config/bfin/crti.s: Likewise.
+ * config/bfin/crtlibid.s: Likewise.
+ * config/bfin/crtn.s: Likewise.
+ * config/bfin/lib1funcs.asm: Likewise.
+ * config/bfin/linux-unwind.h: Likewise.
+ * config/cris/arit.c: Likewise.
+ * config/cris/cris_abi_symbol.c: Likewise.
+ * config/darwin-64.c: Likewise.
+ * config/darwin-crt2.c: Likewise.
+ * config/darwin-crt3.c: Likewise.
+ * config/darwin.h: Likewise.
+ * config/dbxelf.h: Likewise.
+ * config/dfp-bit.c: Likewise.
+ * config/dfp-bit.h: Likewise.
+ * config/elfos.h: Likewise.
+ * config/fixed-bit.c: Likewise.
+ * config/fixed-bit.h: Likewise.
+ * config/fp-bit.c: Likewise.
+ * config/fp-bit.h: Likewise.
+ * config/fr30/crti.asm: Likewise.
+ * config/fr30/crtn.asm: Likewise.
+ * config/fr30/lib1funcs.asm: Likewise.
+ * config/freebsd-spec.h: Likewise.
+ * config/frv/cmovd.c: Likewise.
+ * config/frv/cmovh.c: Likewise.
+ * config/frv/cmovw.c: Likewise.
+ * config/frv/frvbegin.c: Likewise.
+ * config/frv/frvend.c: Likewise.
+ * config/frv/lib1funcs.asm: Likewise.
+ * config/glibc-stdint.h: Likewise.
+ * config/h8300/clzhi2.c: Likewise.
+ * config/h8300/crti.asm: Likewise.
+ * config/h8300/crtn.asm: Likewise.
+ * config/h8300/ctzhi2.c: Likewise.
+ * config/h8300/fixunssfsi.c: Likewise.
+ * config/h8300/lib1funcs.asm: Likewise.
+ * config/h8300/parityhi2.c: Likewise.
+ * config/h8300/popcounthi2.c: Likewise.
+ * config/i386/ammintrin.h: Likewise.
+ * config/i386/att.h: Likewise.
+ * config/i386/avxintrin.h: Likewise.
+ * config/i386/biarch64.h: Likewise.
+ * config/i386/bmmintrin.h: Likewise.
+ * config/i386/cpuid.h: Likewise.
+ * config/i386/cross-stdarg.h: Likewise.
+ * config/i386/crtfastmath.c: Likewise.
+ * config/i386/crtprec.c: Likewise.
+ * config/i386/cygming-crtbegin.c: Likewise.
+ * config/i386/cygming-crtend.c: Likewise.
+ * config/i386/cygwin.asm: Likewise.
+ * config/i386/emmintrin.h: Likewise.
+ * config/i386/gmm_malloc.h: Likewise.
+ * config/i386/gthr-win32.c: Likewise.
+ * config/i386/i386.h: Likewise.
+ * config/i386/immintrin.h: Likewise.
+ * config/i386/linux-unwind.h: Likewise.
+ * config/i386/linux64.h: Likewise.
+ * config/i386/mm3dnow.h: Likewise.
+ * config/i386/mmintrin-common.h: Likewise.
+ * config/i386/mmintrin.h: Likewise.
+ * config/i386/nmmintrin.h: Likewise.
+ * config/i386/pmm_malloc.h: Likewise.
+ * config/i386/pmmintrin.h: Likewise.
+ * config/i386/smmintrin.h: Likewise.
+ * config/i386/sol2-c1.asm: Likewise.
+ * config/i386/sol2-ci.asm: Likewise.
+ * config/i386/sol2-cn.asm: Likewise.
+ * config/i386/sol2-gc1.asm: Likewise.
+ * config/i386/tmmintrin.h: Likewise.
+ * config/i386/unix.h: Likewise.
+ * config/i386/w32-unwind.h: Likewise.
+ * config/i386/wmmintrin.h: Likewise.
+ * config/i386/x86-64.h: Likewise.
+ * config/i386/x86intrin.h: Likewise.
+ * config/i386/xmmintrin.h: Likewise.
+ * config/ia64/crtbegin.asm: Likewise.
+ * config/ia64/crtend.asm: Likewise.
+ * config/ia64/crtfastmath.c: Likewise.
+ * config/ia64/crti.asm: Likewise.
+ * config/ia64/crtn.asm: Likewise.
+ * config/ia64/fde-glibc.c: Likewise.
+ * config/ia64/lib1funcs.asm: Likewise.
+ * config/ia64/linux-unwind.h: Likewise.
+ * config/ia64/quadlib.c: Likewise.
+ * config/ia64/unwind-ia64.c: Likewise.
+ * config/linux.h: Likewise.
+ * config/m32c/m32c-lib1.S: Likewise.
+ * config/m32c/m32c-lib2-trapv.c: Likewise.
+ * config/m32c/m32c-lib2.c: Likewise.
+ * config/m32r/initfini.c: Likewise.
+ * config/m68hc11/larith.asm: Likewise.
+ * config/m68hc11/m68hc11-crt0.S: Likewise.
+ * config/m68k/cf.md: Likewise.
+ * config/m68k/crti.s: Likewise.
+ * config/m68k/crtn.s: Likewise.
+ * config/m68k/lb1sf68.asm: Likewise.
+ * config/m68k/linux-unwind.h: Likewise.
+ * config/mcore/crti.asm: Likewise.
+ * config/mcore/crtn.asm: Likewise.
+ * config/mcore/lib1.asm: Likewise.
+ * config/mips/linux-unwind.h: Likewise.
+ * config/mips/loongson.h: Likewise.
+ * config/mips/mips16.S: Likewise.
+ * config/mmix/crti.asm: Likewise.
+ * config/mmix/crtn.asm: Likewise.
+ * config/pa/fptr.c: Likewise.
+ * config/pa/hpux-unwind.h: Likewise.
+ * config/pa/lib2funcs.asm: Likewise.
+ * config/pa/linux-atomic.c: Likewise.
+ * config/pa/linux-unwind.h: Likewise.
+ * config/pa/milli64.S: Likewise.
+ * config/pa/quadlib.c: Likewise.
+ * config/pa/stublib.c: Likewise.
+ * config/picochip/libgccExtras/adddi3.asm: Likewise.
+ * config/picochip/libgccExtras/ashlsi3.asm: Likewise.
+ * config/picochip/libgccExtras/ashlsi3.c: Likewise.
+ * config/picochip/libgccExtras/ashrsi3.asm: Likewise.
+ * config/picochip/libgccExtras/ashrsi3.c: Likewise.
+ * config/picochip/libgccExtras/cmpsi2.asm: Likewise.
+ * config/picochip/libgccExtras/divmod15.asm: Likewise.
+ * config/picochip/libgccExtras/divmodhi4.asm: Likewise.
+ * config/picochip/libgccExtras/divmodsi4.asm: Likewise.
+ * config/picochip/libgccExtras/longjmp.asm: Likewise.
+ * config/picochip/libgccExtras/lshrsi3.asm: Likewise.
+ * config/picochip/libgccExtras/lshrsi3.c: Likewise.
+ * config/picochip/libgccExtras/parityhi2.asm: Likewise.
+ * config/picochip/libgccExtras/popcounthi2.asm: Likewise.
+ * config/picochip/libgccExtras/setjmp.asm: Likewise.
+ * config/picochip/libgccExtras/subdi3.asm: Likewise.
+ * config/picochip/libgccExtras/ucmpsi2.asm: Likewise.
+ * config/picochip/libgccExtras/udivmodhi4.asm: Likewise.
+ * config/picochip/libgccExtras/udivmodsi4.asm: Likewise.
+ * config/rs6000/750cl.h: Likewise.
+ * config/rs6000/altivec.h: Likewise.
+ * config/rs6000/biarch64.h: Likewise.
+ * config/rs6000/crtresfpr.asm: Likewise.
+ * config/rs6000/crtresgpr.asm: Likewise.
+ * config/rs6000/crtresxfpr.asm: Likewise.
+ * config/rs6000/crtresxgpr.asm: Likewise.
+ * config/rs6000/crtsavfpr.asm: Likewise.
+ * config/rs6000/crtsavgpr.asm: Likewise.
+ * config/rs6000/darwin-asm.h: Likewise.
+ * config/rs6000/darwin-fallback.c: Likewise.
+ * config/rs6000/darwin-fpsave.asm: Likewise.
+ * config/rs6000/darwin-ldouble.c: Likewise.
+ * config/rs6000/darwin-tramp.asm: Likewise.
+ * config/rs6000/darwin-unwind.h: Likewise.
+ * config/rs6000/darwin-vecsave.asm: Likewise.
+ * config/rs6000/darwin-world.asm: Likewise.
+ * config/rs6000/e500crtres32gpr.asm: Likewise.
+ * config/rs6000/e500crtres64gpr.asm: Likewise.
+ * config/rs6000/e500crtres64gprctr.asm: Likewise.
+ * config/rs6000/e500crtrest32gpr.asm: Likewise.
+ * config/rs6000/e500crtrest64gpr.asm: Likewise.
+ * config/rs6000/e500crtresx32gpr.asm: Likewise.
+ * config/rs6000/e500crtresx64gpr.asm: Likewise.
+ * config/rs6000/e500crtsav32gpr.asm: Likewise.
+ * config/rs6000/e500crtsav64gpr.asm: Likewise.
+ * config/rs6000/e500crtsav64gprctr.asm: Likewise.
+ * config/rs6000/e500crtsavg32gpr.asm: Likewise.
+ * config/rs6000/e500crtsavg64gpr.asm: Likewise.
+ * config/rs6000/e500crtsavg64gprctr.asm: Likewise.
+ * config/rs6000/eabi-ci.asm: Likewise.
+ * config/rs6000/eabi-cn.asm: Likewise.
+ * config/rs6000/eabi.asm: Likewise.
+ * config/rs6000/linux-unwind.h: Likewise.
+ * config/rs6000/linux64.h: Likewise.
+ * config/rs6000/paired.h: Likewise.
+ * config/rs6000/paired.md: Likewise.
+ * config/rs6000/ppc64-fp.c: Likewise.
+ * config/rs6000/ppu_intrinsics.h: Likewise.
+ * config/rs6000/rs6000.h: Likewise.
+ * config/rs6000/si2vmx.h: Likewise.
+ * config/rs6000/sol-ci.asm: Likewise.
+ * config/rs6000/sol-cn.asm: Likewise.
+ * config/rs6000/spe.h: Likewise.
+ * config/rs6000/spu2vmx.h: Likewise.
+ * config/rs6000/sysv4.h: Likewise.
+ * config/rs6000/tramp.asm: Likewise.
+ * config/rs6000/vec_types.h: Likewise.
+ * config/s390/linux-unwind.h: Likewise.
+ * config/s390/tpf-unwind.h: Likewise.
+ * config/score/crti.asm: Likewise.
+ * config/score/crtn.asm: Likewise.
+ * config/sh/crt1.asm: Likewise.
+ * config/sh/crti.asm: Likewise.
+ * config/sh/crtn.asm: Likewise.
+ * config/sh/divtab-sh4-300.c: Likewise.
+ * config/sh/divtab-sh4.c: Likewise.
+ * config/sh/divtab.c: Likewise.
+ * config/sh/lib1funcs-4-300.asm: Likewise.
+ * config/sh/lib1funcs-Os-4-200.asm: Likewise.
+ * config/sh/lib1funcs.asm: Likewise.
+ * config/sh/lib1funcs.h: Likewise.
+ * config/sh/linux-atomic.asm: Likewise.
+ * config/sh/linux-unwind.h: Likewise.
+ * config/sh/shmedia.h: Likewise.
+ * config/sh/sshmedia.h: Likewise.
+ * config/sh/ushmedia.h: Likewise.
+ * config/sparc/crtfastmath.c: Likewise.
+ * config/sparc/linux-unwind.h: Likewise.
+ * config/sparc/sol2-c1.asm: Likewise.
+ * config/sparc/sol2-ci.asm: Likewise.
+ * config/sparc/sol2-cn.asm: Likewise.
+ * config/spu/divmodti4.c: Likewise.
+ * config/spu/divv2df3.c: Likewise.
+ * config/spu/float_disf.c: Likewise.
+ * config/spu/float_unsdidf.c: Likewise.
+ * config/spu/float_unsdisf.c: Likewise.
+ * config/spu/float_unssidf.c: Likewise.
+ * config/spu/mfc_multi_tag_release.c: Likewise.
+ * config/spu/mfc_multi_tag_reserve.c: Likewise.
+ * config/spu/mfc_tag_release.c: Likewise.
+ * config/spu/mfc_tag_reserve.c: Likewise.
+ * config/spu/mfc_tag_table.c: Likewise.
+ * config/spu/multi3.c: Likewise.
+ * config/spu/spu_internals.h: Likewise.
+ * config/spu/spu_intrinsics.h: Likewise.
+ * config/spu/spu_mfcio.h: Likewise.
+ * config/spu/vec_types.h: Likewise.
+ * config/spu/vmx2spu.h: Likewise.
+ * config/stormy16/stormy16-lib2.c: Likewise.
+ * config/svr4.h: Likewise.
+ * config/sync.c: Likewise.
+ * config/v850/lib1funcs.asm: Likewise.
+ * config/vxlib-tls.c: Likewise.
+ * config/vxlib.c: Likewise.
+ * config/vxworks-dummy.h: Likewise.
+ * config/xtensa/crti.asm: Likewise.
+ * config/xtensa/crtn.asm: Likewise.
+ * config/xtensa/ieee754-df.S: Likewise.
+ * config/xtensa/ieee754-sf.S: Likewise.
+ * config/xtensa/lib1funcs.asm: Likewise.
+ * config/xtensa/lib2funcs.S: Likewise.
+ * config/xtensa/linux-unwind.h: Likewise.
+ * config/xtensa/unwind-dw2-xtensa.c: Likewise.
+ * config/xtensa/unwind-dw2-xtensa.h: Likewise.
+ * coretypes.h: Likewise.
+ * crtstuff.c: Likewise.
+ * defaults.h: Likewise.
+ * dwarf2.h: Likewise.
+ * emutls.c: Likewise.
+ * gbl-ctors.h: Likewise.
+ * gcov-io.h: Likewise.
+ * ginclude/float.h: Likewise.
+ * ginclude/iso646.h: Likewise.
+ * ginclude/stdarg.h: Likewise.
+ * ginclude/stdbool.h: Likewise.
+ * ginclude/stddef.h: Likewise.
+ * ginclude/stdfix.h: Likewise.
+ * ginclude/stdint-gcc.h: Likewise.
+ * ginclude/tgmath.h: Likewise.
+ * gthr-aix.h: Likewise.
+ * gthr-dce.h: Likewise.
+ * gthr-gnat.c: Likewise.
+ * gthr-gnat.h: Likewise.
+ * gthr-lynx.h: Likewise.
+ * gthr-mipssde.h: Likewise.
+ * gthr-nks.h: Likewise.
+ * gthr-posix.c: Likewise.
+ * gthr-posix.h: Likewise.
+ * gthr-posix95.h: Likewise.
+ * gthr-rtems.h: Likewise.
+ * gthr-single.h: Likewise.
+ * gthr-solaris.h: Likewise.
+ * gthr-tpf.h: Likewise.
+ * gthr-vxworks.h: Likewise.
+ * gthr-win32.h: Likewise.
+ * gthr.h: Likewise.
+ * libgcc2.c: Likewise.
+ * libgcc2.h: Likewise.
+ * libgcov.c: Likewise.
+ * tsystem.h: Likewise.
+ * typeclass.h: Likewise.
+ * unwind-c.c: Likewise.
+ * unwind-compat.h: Likewise.
+ * unwind-dw2-fde-compat.c: Likewise.
+ * unwind-dw2-fde-darwin.c: Likewise.
+ * unwind-dw2-fde-glibc.c: Likewise.
+ * unwind-dw2-fde.c: Likewise.
+ * unwind-dw2-fde.h: Likewise.
+ * unwind-dw2.c: Likewise.
+ * unwind-dw2.h: Likewise.
+ * unwind-generic.h: Likewise.
+ * unwind-pe.h: Likewise.
+ * unwind-sjlj.c: Likewise.
+ * unwind.inc: Likewise.
+ * config/arm/neon-gen.ml: Change generated copyright header to
+ refer to version 3 of the GNU General Public License with
+ version 3.1 of the GCC Runtime Library Exception and to point
+ readers at the COPYING3 and COPYING3.RUNTIME files and the
+ FSF's license web page.
+ * config/arm/arm_neon.h: Regenerate.
+
+2009-04-09 Jakub Jelinek <jakub@redhat.com>
+
+ * config/cris/cris.md: Change copyright header to refer to version
+ 3 of the GNU General Public License.
+ * doc/install.texi2html: Change copyright header to refer to version
+ 3 of the GNU General Public License and to point readers at the
+ COPYING3 file and the FSF's license web page.
+ * config/vax/linux.h: Likewise.
+
+2009-04-09 Paolo Bonzini <bonzini@gnu.org>
+
+ * config/i386/i386.md (cmpcc): New.
+ * config/i386/sync.md (sync_compare_and_swap*): Set FLAGS_REG.
+ (sync_compare_and_swap_cc*): Delete.
+
+ * config/s390/s390.c (s390_compare_emitted): Remove.
+ (s390_emit_compare): Handle MODE_CC s390_compare_op0 like
+ s390_compare_emitted used to be handled. Assert that modes match.
+ (s390_emit_compare_and_swap): Use s390_emit_compare, do not
+ refer to sync_compare_and_swap_ccsi.
+ * config/s390/s390.h (s390_compare_emitted): Remove.
+ * config/s390/s390.md (seq): Look for MODE_CC s390_compare_op0
+ instead of s390_compare_emitted.
+ (stack_protect_test, sync_compare_and_swap_cc): Set s390_compare_op0
+ instead of s390_compare_emitted.
+ * config/s390/s390.md (cmpcc): New.
+ (sync_compare_and_swapqi, sync_compare_and_swaphi): Clobber
+ CC_REGNUM, do not pretend it's set.
+ (sync_compare_and_swap_cc*): Delete.
+ * config/s390/predicates.md (cc_reg_operand): New.
+
+ * expr.c (sync_compare_and_swap_cc): Delete.
+ * optabs.h (sync_compare_and_swap_cc): Delete.
+ * optabs.c (prepare_cmp_insn): Ignore which specific CCmode
+ is being used with can_compare_p.
+ (emit_cmp_and_jump_insn_1): Likewise when looking in the optab.
+ (find_cc_set): New.
+ (expand_bool_compare_and_swap): Do not use sync_compare_and_swap_cc,
+ look for a MODE_CC set instead. Use emit_store_flag.
+ (expand_compare_and_swap_loop): Likewise, with some additional
+ complication to avoid a force_reg when useless. Use
+ emit_cmp_and_jump_insns.
+ * genopinit.c (optabs): Delete sync_compare_and_swap_cc.
+ * doc/md.texi (sync_compare_and_swap_cc): Merge with
+ sync_compare_and_swap documentation.
+
+2009-04-09 Jan Hubicka <jh@suse.cz>
+
+ * except.c (find_prev_try): Break out from ....
+ (duplicate_eh_regions): ... here; properly update prev_try pointers
+ when duplication part of tree.
+ (dump_eh_tree): Improve dumping.
+ (verify_eh_region): New.
+ (verify_eh_tree): Use it.
+
+2009-04-06 Richard Guenther <rguenther@suse.de>
+
+ * c-gimplify.c (c_gimplify_expr): Fix the invalid GENERIC
+ &ARRAY addresses by adjusting their types and prepending
+ a conversion.
+ * tree-cfg.c (verify_gimple_assign_single): Verify that
+ addresses are correct.
+
+2009-04-09 Richard Guenther <rguenther@suse.de>
+
+ * tree-ssa-ccp.c (maybe_fold_stmt_addition): Move non-constant
+ indices into an array reference if possible.
+ * tree-ssa-forwprop.c (tree_ssa_forward_propagate_single_use_vars):
+ Fold POINTER_PLUS_EXPR statements with invariant address.
+
+2009-04-09 Alan Modra <amodra@bigpond.net.au>
+
+ PR target/39634
+ * config.gcc (powerpc64-*-linux*): Always build biarch.
+
+2009-04-09 Joseph Myers <joseph@codesourcery.com>
+
+ PR c/39613
+ * c-typeck.c (do_case): If case label is not an INTEGER_CST, fold
+ it and pedwarn if this results in an INTEGER_CST.
+
+2009-04-08 Kaveh R. Ghazi <ghazi@caip.rutgers.edu>
+
+ * doc/install.texi: Update minimum GMP version. Remove obsolete
+ text in MPFR section.
+
+2009-04-08 Jakub Jelinek <jakub@redhat.com>
+
+ * dwarf2out.c (class_scope_p): New static inline.
+ (class_or_namespace_scope_p): Use it.
+ (gen_variable_die): Use DW_TAG_member tag for static data member
+ declarations instead of DW_TAG_variable.
+
+ PR middle-end/39573
+ * omp-low.c (expand_omp_taskreg): Finalize taskreg static local_decls
+ variables.
+
+2009-04-08 Richard Guenther <rguenther@suse.de>
+
+ * tree-ssa-sccvn.c (valueize_refs): Do not continue to
+ valueize random data.
+
+2009-04-08 David Edelsohn <edelsohn@gnu.org>
+
+ * config.gcc (aix tm_file): Add aix-stdint.h.
+ (aix tm clause use_gcc_stdint): Set to wrap.
+ * config/rs6000/aix-stdint.h: New file.
+
+2009-04-08 Richard Guenther <rguenther@suse.de>
+
+ PR middle-end/36291
+ * tree-dfa.c (add_referenced_var): Do not recurse into
+ global initializers.
+ * tree-ssa-ccp.c (get_symbol_constant_value): Add newly
+ exposed variables.
+ (fold_const_aggregate_ref): Likewise.
+
+2009-04-08 Paolo Bonzini <bonzini@gnu.org>
+
+ * recog.c (ordered_comparison_operator): New.
+ * gensupport.c (std_preds): Add it.
+ * doc/md.texi (Machine-Independent Predicates): Document it.
+
+2009-04-08 Jan Hubicka <jh@suse.cz>
+
+ * tree-eh.c (cleanup_eh): When not optimizing, do not try EH merging.
+ * function.h (rtl_eh): Remove exception_handler_label_map.
+ * except.c (ehl_hash, ehl_eq, add_ehl_entry,
+ remove_exception_handler_label, for_each_eh_label_1): Remove.
+ (rtl_remove_unreachable_regions): Remove.
+ (convert_from_eh_region_ranges): Do not remove unreachable regions.
+ (find_exception_handler_labels): Don't build the hashtable.
+ (maybe_remove_eh_handler): Remove.
+ (for_each_eh_label): Rewrite to walk the tree.
+ (rest_of_handle_eh): Do not cleanup cfg prior EH construction.
+ * except.h (maybe_remove_eh_handler): Remove.
+ * passes.c (init_optimization_passes): Schedule second EH cleanup
+ before out-of-ssa.
+ * cfgrtl.c (rtl_delete_block, rtl_merge_blocks,
+ cfg_layout_merge_blocks): Do not call maybe_remove_eh_handler.
+
+2009-04-08 Paolo Bonzini <bonzini@gnu.org>
+
+ * genoutput.c (validate_optab_operands): New.
+ (gen_insn, gen_expand): Call it.
+
+ * genflags.c (gen_insn): Detect misused iterators.
+ (main): Pass line_no to gen_insn, exit with status 1 on error.
+
+ * genextract.c (line_no): Make global.
+ (VEC_safe_set_locstr): Change assertion to error message.
+ (main): Exit with status 1 on error.
+
+2009-04-08 Joseph Myers <joseph@codesourcery.com>
+
+ PR c/39614
+ PR c/39673
+ * c-common.h (C_MAYBE_CONST_EXPR_PRE, C_MAYBE_CONST_EXPR_EXPR,
+ C_MAYBE_CONST_EXPR_INT_OPERANDS, C_MAYBE_CONST_EXPR_NON_CONST,
+ EXPR_INT_CONST_OPERANDS): Remove duplicate definitions.
+ * c-convert.c (convert): Do not call fold on results of conversion
+ functions when the result is a C_MAYBE_CONST_EXPR.
+ * c-parser.c (c_parser_postfix_expression): Do not fold condition
+ of __builtin_choose_expr.
+ * c-typeck.c (remove_c_maybe_const_expr): New.
+ (build_unary_op, build_conditional_expr, build_compound_expr,
+ build_binary_op, c_objc_common_truthvalue_conversion): Call
+ remove_c_maybe_const_expr on any input C_MAYBE_CONST_EXPR with
+ integer operands.
+
+2009-04-08 Bingfeng Mei <bmei@broadcom.com>
+
+ * fold-const.c (const_binop): Combine two VECTOR_CST under operation
+ CODE to produce a new one. Add a prototype to use fold_convert_const
+
+2009-04-08 Danny Smith <dannysmith@users.sourceforge.net>
+
+ PR bootstrap/39660
+ * config/i386/host-mingw32.c (mingw32_gt_pch_use_address): Don't
+ mix declarations and code.
+
+2009-04-08 Ben Elliston <bje@au.ibm.com>
+
+ * gcc.c: Replace `CC' with `GCC' throughout.
+
+2009-04-07 H.J. Lu <hongjiu.lu@intel.com>
+
+ * doc/invoke.texi: Document Atom support.
+
+2009-04-07 Jason Merrill <jason@redhat.com>
+
+ PR c++/25185
+ * c-common.h, c-common.c: Add flag_pretty_templates.
+ * c-opts.c (c_common_handle_option): Set it.
+ * c.opt: Add -fno-pretty-templates.
+ * doc/invoke.texi (C++ Dialect Options): Likewise.
+
+2009-04-07 Uros Bizjak <ubizjak@gmail.com>
+
+ * config/ia64/ia64.c (ia64_builtins): Add IA64_BUILTIN_HUGE_VALQ.
+ (ia64_init_builtins): Handle IA64_BUILTIN_HUGE_VALQ.
+ (ia64_expand_builtin): Likewise.
+
+2009-04-07 Martin Jambor <mjambor@suse.cz>
+
+ * tree-ssa-alias.c (refs_may_alias_p_1): Check for
+ is_gimple_min_invariant rather than CONSTANT_CLASS_P so that invariant
+ ADDR_EXPRS are include too.
+
+2009-04-07 Richard Guenther <rguenther@suse.de>
+
+ * tree-ssa-alias.c (ref_maybe_used_by_call_p_1): Non-aliased
+ decls are only used if passes as parameters or if they are
+ local statics and the call is not to a builtin.
+ (call_may_clobber_ref_p_1): Likewise.
+
+2009-04-07 Paolo Bonzini <bonzini@gnu.org>
+
+ * expr.c (do_store_flag): Remove last argument. Simplify code
+ to avoid duplication of tests already done by can_compare_p.
+ (expand_expr_real_1): Adjust caller.
+
+2009-04-07 Paolo Bonzini <bonzini@gnu.org>
+
+ * optabs.c (can_compare_p): Test the predicate of a
+ cbranch and cstore pattern.
+
+2009-04-07 Paolo Bonzini <bonzini@gnu.org>
+
+ * expr.c (convert_move): Use emit_store_flag instead of
+ "emulating" it.
+
+2009-04-07 Paolo Bonzini <bonzini@gnu.org>
+
+ * config/i386/i386.c (ix86_compare_emitted): Remove.
+ (ix86_expand_compare, ix86_expand_branch): Handle MODE_CC
+ ix86_compare_op0 like ix86_compare_emitted used to be handled.
+ * config/i386/i386.h (ix86_compare_emitted): Remove.
+ * config/i386/i386.md (stack_protect_test): Set ix86_compare_op0
+ instead of ix86_compare_emitted.
+ * config/i386/sync.md (sync_compare_and_swap_cc): Likewise.
+
+2009-04-07 Andrew Stubbs <ams@codesourcery.com>
+
+ * config.gcc (sh-*-*): Add sysroot-suffix.h to tm_file.
+ Add t-sysroot-suffix to tmake_file.
+ * config/print-sysroot-suffix.sh: New file.
+ * config/t-sysroot-suffix: New file.
+
+2009-04-07 Ben Elliston <bje@au.ibm.com>
+
+ * libgcc2.c (INFINITY): Use __builtin_huge_val, not __builtin_inf,
+ as the latter produces a warning when the target does not support
+ infinity.
+
+2009-04-07 Ben Elliston <bje@au.ibm.com>
+
+ * dfp.c: Replace type punning assignments with memcpy throughout.
+ * Makefile.in (dfp.o-warn): Remove.
+
+2009-04-07 Alan Modra <amodra@bigpond.net.au>
+
+ PR target/39634
+ * config.gcc: Merge powerpc-*-linux* and powerpc64-*-linux*.
+ Include soft-fp/t-softfp after rs6000/t-linux64.
+
+2009-04-06 Eric Botcazou <ebotcazou@adacore.com>
+
+ * stor-layout.c (set_sizetype): Use the full precision of their
+ machine mode for bitsize types.
+
+2009-04-06 H.J. Lu <hongjiu.lu@intel.com>
+
+ * config/i386/i386.md: Revert 2 accidental checkins.
+
+2009-04-06 Joey Ye <joey.ye@intel.com>
+ Xuepeng Guo <xuepeng.guo@intel.com>
+ H.J. Lu <hongjiu.lu@intel.com>
+
+ Atom pipeline model, tuning and insn selection.
+ * config.gcc (atom): Add atom config options and target.
+
+ * config/i386/atom.md: New.
+
+ * config/i386/i386.c (atom_cost): New cost.
+ (m_ATOM): New macro flag.
+ (initial_ix86_tune_features): Set m_ATOM.
+ (x86_accumulate_outgoing_args): Likewise.
+ (x86_arch_always_fancy_math_387): Likewise.
+ (processor_target): Add Atom cost.
+ (cpu_names): Add Atom cpu name.
+ (override_options): Set Atom ISA.
+ (ix86_issue_rate): New case PROCESSOR_ATOM.
+ (ix86_adjust_cost): Likewise.
+
+ * config/i386/i386.h (TARGET_ATOM): New target macro.
+ (ix86_tune_indices): Add X86_TUNE_OPT_AGU.
+ (TARGET_OPT_AGU): New target option.
+ (target_cpu_default): Add TARGET_CPU_DEFAULT_atom.
+ (processor_type): Add PROCESSOR_ATOM.
+
+ * config/i386/i386.md (cpu): Add new value "atom".
+ (use_carry, movu): New attr.
+ (atom.md): Include atom.md.
+ (adddi3_carry_rex64): Set attr "use_carry".
+ (addqi3_carry): Likewise.
+ (addhi3_carry): Likewise.
+ (addsi3_carry): Likewise.
+ (*addsi3_carry_zext): Likewise.
+ (subdi3_carry_rex64): Likewise.
+ (subqi3_carry): Likewise.
+ (subhi3_carry): Likewise.
+ (subsi3_carry): Likewise.
+ (x86_movdicc_0_m1_rex64): Likewise.
+ (*x86_movdicc_0_m1_se): Likewise.
+ (x86_movsicc_0_m1): Likewise.
+ (*x86_movsicc_0_m1_se): Likewise.
+ (*adddi_1_rex64): Emit add insn as much as possible.
+ (*addsi_1): Likewise.
+ (return_internal): Set atom_unit.
+ (return_internal_long): Likewise.
+ (return_pop_internal): Likewise.
+ (*rcpsf2_sse): Set atom_sse_attr attr.
+ (*qrt<mode>2_sse): Likewise.
+ (*prefetch_sse): Likewise.
+
+ * config/i386/i386-c.c (ix86_target_macros_internal): New case
+ PROCESSOR_ATOM.
+ (ix86_target_macros_internal): Likewise.
+
+ * config/i386/sse.md (cpu): Set attr "atom_sse_attr".
+ (*prefetch_sse_rex): Likewise.
+ (sse_rcpv4sf2): Likewise.
+ (sse_vmrcpv4sf2): Likewise.
+ (sse_sqrtv4sf2): Likewise.
+ (<sse>_vmsqrt<mode>2): Likewise.
+ (sse_ldmxcsr): Likewise.
+ (sse_stmxcsr): Likewise.
+ (*sse_sfence): Likewise.
+ (sse2_clflush): Likewise.
+ (*sse2_mfence): Likewise.
+ (*sse2_lfence): Likewise.
+ (avx_movup<avxmodesuffixf2c><avxmodesuffix>): Set attr "movu".
+ (<sse>_movup<ssemodesuffixf2c>): Likewise.
+ (avx_movdqu<avxmodesuffix>): Likewise.
+ (avx_lddqu<avxmodesuffix>): Likewise.
+ (sse2_movntv2di): Change attr "type" to "ssemov".
+ (sse2_movntsi): Likewise.
+ (rsqrtv8sf2): Change attr "type" to "sseadd".
+ (sse3_addsubv2df3): Set attr "atom_unit".
+ (sse3_h<plusminus_insn>v4sf3): Likewise.
+ (*sse2_pmaddwd): Likewise.
+ (*vec_extractv2di_1_rex64): Likewise.
+ (*vec_extractv2di_1_avx): Likewise.
+ (sse2_psadbw): Likewise.
+ (ssse3_phaddwv8hi3): Likewise.
+ (ssse3_phaddwv4hi3): Likewise.
+ (ssse3_phadddv4si3): Likewise.
+ (ssse3_phadddv2si3): Likewise.
+ (ssse3_phaddswv8hi3): Likewise.
+ (ssse3_phaddswv4hi3): Likewise.
+ (ssse3_phsubwv8hi3): Likewise.
+ (ssse3_phsubwv4hi3): Likewise.
+ (ssse3_phsubdv4si3): Likewise.
+ (ssse3_phsubdv2si3): Likewise.
+ (ssse3_phsubswv8hi3): Likewise.
+ (ssse3_phsubswv4hi3): Likewise.
+ (ssse3_pmaddubsw128): Likewise.
+ (sse3_pmaddubsw: Likewise.
+ (ssse3_palignrti): Likewise.
+ (ssse3_palignrdi): Likewise.
+
+2009-04-06 Gerald Pfeifer <gerald@pfeifer.com>
+
+ * doc/install.texi (Specific): Fix two cross-references to MinGW.
+
+2009-04-06 Richard Guenther <rguenther@suse.de>
+
+ PR tree-optimization/28868
+ * tree-ssa-pre.c (inserted_phi_names): New bitmap to keep track
+ of which PHI results we inserted.
+ (insert_into_preds_of_block): Record inserted PHIs.
+ (eliminate): Eliminate redundant PHI nodes.
+ (init_pre): Init inserted_phi_names.
+
+2009-04-06 Richard Guenther <rguenther@suse.de>
+
+ PR tree-optimization/39643
+ * tree-ssa-ccp.c (ccp_fold): Fold REALPART_EXPRs and
+ IMAGPART_EXPRs of complex constants.
+ (execute_fold_all_builtins): If we folded a call queue
+ TODO_update_address_taken.
+
+2009-04-06 Jan Hubicka <jh@suse.cz>
+
+ PR middle-end/39659
+ * except.c (remove_unreachable_regions): Propagate may_contain_throw
+ flag.
+
+2009-04-06 Andrew Stubbs <ams@codesourcery.com>
+
+ * config/sh/lib1funcs.asm (ic_invalidate): Move ICBI out of the
+ delay slot.
+ (ic_invalidate_array): Likewise.
+
+2009-04-06 Hariharan Sandanagobalane <hariharan@picochip.com>
+
+ * calls.c (emit_library_call_value_1): Fix a problem with parameter
+ alignment for library calls.
+
+2009-04-06 Danny Smith <dannysmith@users.sourceforge.net>
+
+ * config.gcc (mingw32 tm_file): Add mingw-stdint.h.
+ (mingw32 tm clause use_gcc_stdint): Set to wrap.
+ * config/i386/mingw-stdint.h: New file.
+
+2009-04-05 Richard Guenther <rguenther@suse.de>
+
+ PR tree-optimization/39648
+ * tree-ssa-sccvn.c (vn_reference_fold_indirect): Work around
+ our &A vs. &A[0] IL deficiencies.
+
+2009-04-04 Jan Hubicka <jh@suse.cz>
+
+ * except.c (sjlj_find_directly_reachable_regions): Be ready for
+ removed toplevel regions.
+ (sjlj_mark_call_sites): Likewise.
+
+2009-04-04 Dave Korn <dave.korn.cygwin@gmail.com>
+
+ * config.gcc (cygwin tm_file): Add cygwin-stdint.h.
+ (cygwin tm clause use_gcc_stdint): Set to wrap.
+ * config/i386/cygwin-stdint.h: New file.
+
+2009-04-04 Richard Guenther <rguenther@suse.de>
+
+ * Makefile.in (tree-ssa-copy.o): Add $(CFGLOOP_H) dependency.
+ * tree-ssa-copy.c (init_copy_prop): Do not propagate through
+ single-argument PHIs if we are in loop-closed SSA form.
+ * tree-vect-loop-manip.c (slpeel_add_loop_guard): Pass extra guards
+ for the pre-condition.
+ (slpeel_tree_peel_loop_to_edge): Likewise.
+ (vect_build_loop_niters): Take an optional sequence to append stmts.
+ (vect_generate_tmps_on_preheader): Likewise.
+ (vect_do_peeling_for_loop_bound): Take extra guards for the
+ pre-condition.
+ (vect_do_peeling_for_alignment): Adjust. Unconditionally apply
+ the cost model check.
+ (vect_loop_versioning): Take stmt and stmt list to put pre-condition
+ guards if we are going to peel. Do not apply versioning in that case.
+ * tree-vectorizer.h (vect_loop_versioning): Adjust declaration.
+ (vect_do_peeling_for_loop_bound): Likewise.
+ * tree-vect-loop.c (vect_transform_loop): If we are peeling for
+ loop bound only record extra pre-conditions, do not apply loop
+ versioning.
+
+2009-04-04 Richard Guenther <rguenther@suse.de>
+
+ * tree-ssa-operands.c (pop_stmt_changes): Remove automatic
+ renaming code.
+
+2009-04-04 Jan Hubicka <jh@suse.cz>
+
+ * tree-ssa-uncprop.c (associate_equivalences_with_edges): Use
+ last_basic_block for size of bb->index indexed array.
+ * bt-load.c (compute_defs_uses_and_gen, compute_kill,
+ compute_out, link_btr_uses, build_btr_def_use_webs,
+ build_btr_def_use_webs, migrate_btr_defs): Likewise.
+
+2009-04-04 Jan Hubicka <jh@suse.cz>
+
+ * except.c (remove_eh_handler_and_replace): Break out from ...
+ (remove_eh_handler): ... here.
+ (bring_to_root): New function.
+ (remove_unreachable_regions): Collect MUST_NOT_THROW, unify runtime
+ handled ones, bring others to root of tree.
+
+2009-04-04 Jan Hubicka <jh@suse.cz>
+
+ * tree-eh.c (tree_empty_eh_handler_p): Pattern match more curefully.
+ (all_phis_safe_to_merge): New function.
+ (update_info): New structure.
+ (make_eh_edge_and_update_phi, update_eh_edges): New functions.
+ (cleanup_empty_eh): Update SSA if possible.
+
+2009-04-04 Richard Guenther <rguenther@suse.de>
+
+ * tree-ssa.c (verify_ssa): With -O0 we do not need VOPs.
+ * tree-ssa-operands.c (append_vdef): Do not append VOPs at -O0.
+ (append_vuse): Likewise.
+
+2009-04-04 Jakub Jelinek <jakub@redhat.com>
+
+ * unwind-dw2.h (_Unwind_FrameState): Add REG_UNDEFINED enum value.
+ * unwind-dw2.c (execute_cfa_program): Set how to REG_UNDEFINED
+ instead of REG_UNSAVED for DW_CFA_undefined.
+ (uw_update_context_1): Handle REG_UNDEFINED the same as REG_UNSAVED.
+ (uw_update_context): If RA column is REG_UNDEFINED, mark it as
+ outermost frame.
+
+2009-04-04 Richard Earnshaw <rearnsha@arm.com>
+
+ PR target/39501
+ * arm.md (movsfcc): Disable if not TARGET_HARD_FLOAT.
+ * testsuite/gcc.c-torture/execute/pr39501.c: New file.
+ * testsuite/gcc.c-torture/execute/pr39501.x: New file.
+
+2009-04-04 Richard Guenther <rguenther@suse.de>
+
+ PR tree-optimization/8781
+ PR tree-optimization/37892
+ * tree-ssa-sccvn.h (vn_reference_fold_indirect): Declare.
+ * tree-ssa-sccvn.c (vn_reference_fold_indirect): New function.
+ (valueize_refs): Call it for *& valueizations.
+ (shared_reference_ops_from_ref): Rename to ...
+ (valueize_shared_reference_ops_from_ref): ... this and valueize.
+ (shared_reference_ops_from_call): Rename to ...
+ (valueize_shared_reference_ops_from_call): ... this and valueize.
+ (vn_reference_lookup): Update.
+ (visit_reference_op_call): Likewise.
+ * tree-ssa-pre.c (phi_translate_1): Fold *&.
+ (eliminate): Value-replace the call address in call statements.
+
+2009-04-04 Richard Guenther <rguenther@suse.de>
+
+ PR tree-optimization/39636
+ * tree-ssa-forwprop.c
+ (forward_propagate_addr_into_variable_array_index): Check for
+ GIMPLE_ASSIGN before accessing the rhs code.
+
+2009-04-03 Jason Merrill <jason@redhat.com>
+
+ * stor-layout.c (set_sizetype): Set TYPE_CANONICAL.
+
+2009-04-03 Steve Ellcey <sje@cup.hp.com>
+
+ * config/ia64/ia64.md (extendsfdf2, extendsfxf2, extenddfxf2,
+ truncdfsf2, truncxfsf2, truncxfdf2, floatdixf2, fix_truncsfdi2,
+ fix_truncdfdi2, fix_truncxfdi2, fix_truncxfdi2_alts, floatunsdisf2,
+ floatunsdidf2, floatunsdixf2, fixuns_truncsfdi2, fixuns_truncdfdi2,
+ fixuns_truncxfdi2, fixuns_truncxfdi2_alts, divsi3_internal,
+ smuldi3_highpart, umuldi3_highpart, ctzdi2, *getf_exp_xf,
+ divdi3_internal_lat, divdi3_internal_thr, mulditi3, *mulditi3_internal,
+ umulditi3, *umulditi3_internal, addsf3, mulsf3, abssf2, negsf2,
+ *nabssf2, sminsf3, smaxsf3, *maddsf4, *msubsf4, *nmulsf3, *nmaddsf4,
+ *nmaddsf4_alts, divsf3, *sqrt_approx, sqrtsf2, sqrtsf2_internal_thr,
+ adddf3, *adddf3_trunc, muldf3, *muldf3_trunc, absdf2, negdf2, *nabsdf2,
+ smindf3, smaxdf3, *madddf4, *madddf4_trunc, *msubdf4, *msubdf4_trunc,
+ *nmuldf3, *nmuldf3_trunc, *nmadddf4, *nmadddf4_alts, *nmadddf4_truncsf,
+ *nmadddf4_truncsf_alts, divdf3, sqrtdf2, sqrtdf2_internal_thr, divxf3,
+ sqrtxf2, sqrtxf2_internal_thr, *recip_approx):
+ Use fr_reg_or_fp01_operand instead of fr_register_operand
+
+ * config/ia64/div.md (extend<mode>rf2, truncrf<mode>2,
+ recip_approx_rf, divsf3_internal_thr, divsf3_internal_lat,
+ divdf3_internal_thr, divdf3_internal_lat divxf3_internal): Ditto.
+
+2009-04-03 Vladimir Makarov <vmakarov@redhat.com>
+
+ PR rtl-optimization/39607
+ PR rtl-optimization/39631
+
+ Revert:
+
+ 2009-03-30 Vladimir Makarov <vmakarov@redhat.com>
+ * reload.c (push_reload, find_dummy_reload): Use df_get_live_out
+ instead of DF_LR_OUT.
+ * ira-lives.c (process_bb_node_lives): Ditto.
+ * ira-color.c (ira_loop_edge_freq): Use df_get_live_{out,in}
+ instead of DF_LR_{OUT,IN}.
+ * ira-emit.c (generate_edge_moves, add_ranges_and_copies): Ditto.
+ * ira-build.c (create_bb_allocnos, create_loop_allocnos): Ditto.
+
+2009-04-03 Steven Bosscher <steven@gcc.gnu.org>
+
+ * omp-low.c (pass_expand_omp): Don't claim to provide PROP_gimple_lomp.
+ (execute_lower_omp): Always run but take the short way out if -fopenmp
+ is not given.
+ (gate_lower_omp): Remove, forcing the pass manager to always run the
+ pass and always set PROP_gimple_lomp.
+ (pass_lower_omp): Remove gate function.
+ * matrix-reorg.c (pass_ipa_matrix_reorg): Don't claim to provide
+ PROP_trees. Instead, require it.
+ * ipa-cp.c (pass_ipa_cp): Likewise.
+ * ipa-inline.c (pass_early_inline): Don't claim to provide PROP_cfg.
+ (pass_ipa_early_inline, pass_inline_parameters, pass_ipa_inline): Idem.
+ * tree-profile.c (pass_tree_profile): Don't claim to provide PROP_cfg
+ and PROP_gimple_leh.
+
+2009-04-03 Richard Guenther <rguenther@suse.de>
+
+ PR middle-end/13146
+ PR tree-optimization/23940
+ PR tree-optimization/33237
+ PR middle-end/33974
+ PR middle-end/34093
+ PR tree-optimization/36201
+ PR tree-optimization/36230
+ PR tree-optimization/38049
+ PR tree-optimization/38207
+ PR tree-optimization/38230
+ PR tree-optimization/38301
+ PR tree-optimization/38585
+ PR middle-end/38895
+ PR tree-optimization/38985
+ PR tree-optimization/39299
+ * tree-ssa-structalias.h: Remove.
+ * tree-ssa-operands.h (NULL_USE_OPERAND_P): Make of type use_operand_p.
+ (NULL_DEF_OPERAND_P): Make of type def_operand_p.
+ (struct vuse_element_d): Remove.
+ (struct vuse_vec_d): Likewise.
+ (VUSE_VECT_NUM_ELEM, VUSE_VECT_ELEMENT_NC, VUSE_ELEMENT_PTR_NC,
+ VUSE_ELEMENT_VAR_NC, VUSE_VECT_ELEMENT, VUSE_ELEMENT_PTR,
+ SET_VUSE_VECT_ELEMENT, SET_VUSE_ELEMENT_VAR, SET_VUSE_ELEMENT_PTR,
+ VUSE_ELEMENT_VAR): Likewise.
+ (struct voptype_d): Likewise.
+ (NUM_VOP_FREE_BUCKETS): Likewise.
+ (struct ssa_operands): Remove vop_free_buckets and mpt_table fields.
+ (struct stmt_operands_d): Remove.
+ (VUSE_OP_PTR, VUSE_OP, SET_VUSE_OP, VUSE_NUM, VUSE_VECT,
+ VDEF_RESULT_PTR, VDEF_RESULT, VDEF_OP_PTR, VDEF_OP, SET_VDEF_OP,
+ VDEF_NUM, VDEF_VECT): Likewise.
+ (copy_virtual_operands): Remove.
+ (operand_build_cmp): Likewise.
+ (create_ssa_artificial_load_stmt): Likewise.
+ (enum ssa_op_iter_type): Remove ssa_op_iter_vdef.
+ (struct ssa_operand_iterator_d): Remove vuses, vdefs, mayusesm
+ vuse_index and mayuse_index members. Pack and move done and iter_type
+ members to the front.
+ (SSA_OP_VMAYUSE): Remove.
+ (SSA_OP_VIRTUAL_USES): Adjust.
+ (FOR_EACH_SSA_VDEF_OPERAND): Remove.
+ (unlink_stmt_vdef): Declare.
+ (add_to_addressable_set): Remove.
+ * tree-vrp.c (stmt_interesting_for_vrp): Adjust.
+ (vrp_visit_stmt): Likewise.
+ * doc/tree-ssa.texi (Alias analysis): Update.
+ * doc/invoke.texi (max-aliased-vops): Remove docs.
+ (avg-aliased-vops): Likewise.
+ * tree-into-ssa.c (syms_to_rename): Remove.
+ (need_to_update_vops_p): Likewise.
+ (need_to_initialize_update_ssa_p): Rename to ...
+ (update_ssa_initialized_fn): ... this. Track function we are
+ initialized for.
+ (symbol_marked_for_renaming): Simplify.
+ (add_new_name_mapping): Do not set need_to_update_vops_p.
+ (dump_currdefs): Use SYMS_TO_RENAME.
+ (rewrite_update_stmt): Always walk all uses/defs.
+ (dump_update_ssa): Adjust.
+ (init_update_ssa): Take function argument. Track what we are
+ initialized for.
+ (delete_update_ssa): Reset SYMS_TO_RENAME and update_ssa_initialized_fn.
+ (create_new_def_for): Initialize for cfun, assert we are initialized
+ for cfun.
+ (mark_sym_for_renaming): Simplify.
+ (mark_set_for_renaming): Do not initialize update-ssa.
+ (need_ssa_update_p): Simplify. Take function argument.
+ (name_mappings_registered_p): Assert we ask for the correct function.
+ (name_registered_for_update_p): Likewise.
+ (ssa_names_to_replace): Likewise.
+ (release_ssa_name_after_update_ssa): Likewise.
+ (update_ssa): Likewise. Use SYMS_TO_RENAME.
+ (dump_decl_set): Do not print a newline.
+ (debug_decl_set): Do it here.
+ (dump_update_ssa): And here.
+ * tree-ssa-loop-im.c (move_computations): Adjust.
+ (movement_possibility): Likewise.
+ (determine_max_movement): Likewise.
+ (gather_mem_refs_stmt): Likewise.
+ * tree-dump.c (dequeue_and_dump): Do not handle SYMBOL_MEMORY_TAG
+ or NAME_MEMORY_TAG.
+ * tree-complex.c (update_all_vops): Remove.
+ (expand_complex_move): Adjust.
+ * tree-ssa-loop-niter.c (chain_of_csts_start): Use NULL_TREE.
+ Simplify test for memory referencing statement. Exclude
+ non-invariant ADDR_EXPRs.
+ * tree-pretty-print.c (dump_generic_node): Do not handle memory tags.
+ * tree-loop-distribution.c (generate_memset_zero): Adjust.
+ (rdg_flag_uses): Likewise.
+ * tree-tailcall.c (suitable_for_tail_opt_p): Remove memory-tag
+ related code.
+ (tree_optimize_tail_calls_1): Also split the
+ edge from the entry block if we have degenerate PHI nodes in
+ the first basic block.
+ * tree.c (init_ttree): Remove memory-tag related code.
+ (tree_code_size): Likewise.
+ (tree_node_structure): Likewise.
+ (build7_stat): Re-write to be build6_stat.
+ * tree.h (MTAG_P, TREE_MEMORY_TAG_CHECK, TMR_TAG): Remove.
+ (SSA_VAR_P): Adjust.
+ (struct tree_memory_tag): Remove.
+ (struct tree_memory_partition_tag): Likewise.
+ (union tree_node): Adjust.
+ (build7): Re-write to be build6.
+ * tree-pass.h (pass_reset_cc_flags): Remove.
+ (TODO_update_address_taken): New flag.
+ (pass_simple_dse): Remove.
+ * ipa-cp.c (ipcp_update_callgraph): Update SSA form.
+ * params.h (MAX_ALIASED_VOPS): Remove.
+ (AVG_ALIASED_VOPS): Likewise.
+ * omp-low.c (expand_omp_taskreg): Update SSA form.
+ * tree-ssa-dse.c (dse_optimize_stmt): Properly query if the rhs
+ aliases the lhs in a copy stmt.
+ * tree-ssa-dse.c (struct address_walk_data): Remove.
+ (memory_ssa_name_same): Likewise.
+ (memory_address_same): Likewise.
+ (get_kill_of_stmt_lhs): Likewise.
+ (dse_possible_dead_store_p): Simplify, use the oracle. Handle
+ unused stores. Look through PHI nodes into post-dominated regions.
+ (dse_optimize_stmt): Simplify. Properly remove stores.
+ (tree_ssa_dse): Compute dominators.
+ (execute_simple_dse): Remove.
+ (pass_simple_dse): Likewise.
+ * ipa-reference.c (scan_stmt_for_static_refs): Open-code
+ gimple_loaded_syms and gimple_stored_syms computation.
+ * toplev.c (dump_memory_report): Dump alias and pta stats.
+ * tree-ssa-sccvn.c (vn_reference_compute_hash): Simplify.
+ (vn_reference_eq): Likewise.
+ (vuses_to_vec, copy_vuses_from_stmt, vdefs_to_vec,
+ copy_vdefs_from_stmt, shared_lookup_vops, shared_vuses_from_stmt,
+ valueize_vuses): Remove.
+ (get_def_ref_stmt_vuses): Simplify. Rename to ...
+ (get_def_ref_stmt_vuse): ... this.
+ (vn_reference_lookup_2): New function.
+ (vn_reference_lookup_pieces): Use walk_non_aliased_vuses for
+ walking equivalent vuses. Simplify.
+ (vn_reference_lookup): Likewise.
+ (vn_reference_insert): Likewise.
+ (vn_reference_insert_pieces): Likewise.
+ (visit_reference_op_call): Simplify.
+ (visit_reference_op_load): Likewise.
+ (visit_reference_op_store): Likewise.
+ (init_scc_vn): Remove shared_lookup_vuses initialization.
+ (free_scc_vn): Remove shared_lookup_vuses freeing.
+ (sort_vuses, sort_vuses_heap): Remove.
+ (get_ref_from_reference_ops): Export.
+ * tree-ssa-sccvn.h (struct vn_reference_s): Replace vuses
+ vector with single vuse pointer.
+ (vn_reference_lookup_pieces, vn_reference_lookup,
+ vn_reference_insert, vn_reference_insert_pieces): Adjust prototypes.
+ (shared_vuses_from_stmt): Remove.
+ (get_ref_from_reference_ops): Declare.
+ * tree-ssa-loop-manip.c (slpeel_can_duplicate_loop_p): Adjust.
+ * tree-ssa-copyrename.c (copy_rename_partition_coalesce): Remove
+ memory-tag related code.
+ * tree-ssa-ccp.c (get_symbol_constant_value): Remove memory-tag code.
+ (likely_value): Add comment, skip static-chain of call statements.
+ (surely_varying_stmt_p): Adjust.
+ (gimplify_and_update_call_from_tree): Likewise.
+ (execute_fold_all_builtins): Do not rebuild alias info.
+ (gimplify_and_update_call_from_tree): Properly update VOPs.
+ * tree-ssa-loop-ivopts.c (get_ref_tag): Remove.
+ (copy_ref_info): Remove memory-tag related code.
+ * tree-call-cdce.c (tree_call_cdce): Rename the VOP.
+ * ipa-pure-const.c (check_decl): Remove memory-tag related code.
+ (check_stmt): Open-code gimple_loaded_syms and gimple_stored_syms
+ computation.
+ * tree-ssa-dom.c (gimple_p): Remove typedef.
+ (eliminate_redundant_computations): Adjust.
+ (record_equivalences_from_stmt): Likewise.
+ (avail_expr_hash): Likewise.
+ (avail_expr_eq): Likewise.
+ * tree-ssa-propagate.c (update_call_from_tree): Properly update VOPs.
+ (stmt_makes_single_load): Likewise.
+ (stmt_makes_single_store): Likewise.
+ * tree-ssa-alias.c: Rewrite completely.
+ (debug_memory_partitions, dump_mem_ref_stats, debug_mem_ref_stats,
+ debug_mem_sym_stats, dump_mem_sym_stats_for_var,
+ debug_all_mem_sym_stats, debug_mp_info, update_mem_sym_stats_from_stmt,
+ delete_mem_ref_stats, create_tag_raw, dump_points_to_info,
+ dump_may_aliases_for, debug_may_aliases_for, new_type_alias):
+ Remove public functions.
+ (pass_reset_cc_flags): Remove.
+ (pass_build_alias): Move ...
+ * tree-ssa-structalias.c (pass_build_alias): ... here.
+ * tree-ssa-alias.c (may_be_aliased): Move ...
+ * tree-flow-inline.h (may_be_aliased): ... here.
+ tree-ssa-alias.c (struct count_ptr_d, count_ptr_derefs,
+ count_uses_and_derefs): Move ...
+ * gimple.c: ... here.
+ * gimple.h (count_uses_and_derefs): Declare.
+ * tree-ssa-alias.c (dump_alias_stats, ptr_deref_may_alias_global_p,
+ ptr_deref_may_alias_decl_p, ptr_derefs_may_alias_p,
+ same_type_for_tbaa, nonaliasing_component_refs_p, decl_refs_may_alias_p,
+ indirect_ref_may_alias_decl_p, indirect_refs_may_alias_p,
+ ref_maybe_used_by_call_p, ref_maybe_used_by_stmt_p,
+ call_may_clobber_ref_p, stmt_may_clobber_ref_p, maybe_skip_until,
+ get_continuation_for_phi, walk_non_aliased_vuses, walk_aliased_vdefs):
+ New functions.
+ * tree-dfa.c (refs_may_alias_p): Move ...
+ * tree-ssa-alias.c (refs_may_alias_p): ... here. Extend.
+ * tree-ssa-alias.h: New file.
+ * tree-ssa-sink.c (is_hidden_global_store): Adjust.
+ (statement_sink_location): Likewise.
+ * opts.c (decode_options): Do not adjust max-aliased-vops or
+ avg-aliased-vops values.
+ * timevar.def (TV_TREE_MAY_ALIAS): Remove.
+ (TV_CALL_CLOBBER): Likewise.
+ (TV_FLOW_SENSITIVE): Likewise.
+ (TV_FLOW_INSENSITIVE): Likewise.
+ (TV_MEMORY_PARTITIONING): Likewise.
+ (TV_ALIAS_STMT_WALK): New timevar.
+ * tree-ssa-loop-ivcanon.c (empty_loop_p): Adjust.
+ * tree-ssa-address.c (create_mem_ref_raw): Use build6.
+ (get_address_description): Remove memory-tag related code.
+ * tree-ssa-ifcombine.c (bb_no_side_effects_p): Adjust.
+ * treestruct.def (TS_MEMORY_TAG, TS_MEMORY_PARTITION_TAG): Remove.
+ * tree-eh.c (cleanup_empty_eh): Do not leave stale SSA_NAMEs
+ and immediate uses in statements. Document.
+ * gimple-pretty-print.c (dump_gimple_mem_ops): Adjust.
+ (dump_symbols): Remove.
+ (dump_gimple_mem_ops): Do not dump loaded or stored syms.
+ * alias.c (get_deref_alias_set): New function split out from ...
+ (get_alias_set): ... here.
+ * alias.h (get_deref_alias_set): Declare.
+ * tree-vect-data-refs.c (vect_create_data_ref_ptr): Remove unused
+ type parameter. Remove restrict pointer handling. Create a
+ ref-all pointer in case type-based alias sets do not conflict.
+ (vect_analyze_data_refs): Remove SMT related code.
+ * tree-vect-stmts.c (vectorizable_store): Re-instantiate TBAA assert.
+ (vectorizable_load): Likewise.
+ * tree-data-ref.h (struct dr_alias): Remove symbol_tag field.
+ (DR_SYMBOL_TAG, DR_VOPS): Remove.
+ * tree-data-ref.c (dr_may_alias_p): Use the alias-oracle.
+ Ignore vops and SMTs.
+ (dr_analyze_alias): Likewise..
+ (free_data_ref): Likewise.
+ (create_data_ref): Likewise.
+ (analyze_all_data_dependences): Likewise.
+ (get_references_in_stmt): Adjust.
+ * tree-flow-inline.h (gimple_aliases_computed_p,
+ gimple_addressable_vars, gimple_call_clobbered_vars,
+ gimple_call_used_vars, gimple_global_var, may_aliases, memory_partition,
+ factoring_name_p, mark_call_clobbered, clear_call_clobbered,
+ compare_ssa_operands_equal, symbol_mem_tag, set_symbol_mem_tag,
+ gimple_mem_ref_stats): Remove.
+ (gimple_vop): New function.
+ (op_iter_next_use): Remove vuses and mayuses cases.
+ (op_iter_next_def): Remove vdefs case.
+ (op_iter_next_tree): Remove vuses, mayuses and vdefs cases.
+ (clear_and_done_ssa_iter): Do not set removed fields.
+ (op_iter_init): Likewise. Skip vuse and/or vdef if requested.
+ Assert we are not iterating over vuses or vdefs if not also
+ iterating over uses or defs.
+ (op_iter_init_use): Likewise.
+ (op_iter_init_def): Likewise.
+ (op_iter_next_vdef): Remove.
+ (op_iter_next_mustdef): Likewise.
+ (op_iter_init_vdef): Likewise.
+ (compare_ssa_operands_equal): Likewise.
+ (link_use_stmts_after): Handle vuse operand.
+ (is_call_used): Use is_call_clobbered.
+ (is_call_clobbered): Global variables are always call clobbered,
+ query the call-clobbers bitmap.
+ (mark_call_clobbered): Ignore global variables.
+ (clear_call_clobbered): Likewise.
+ * tree-ssa-coalesce.c (create_outofssa_var_map): Adjust
+ virtual operands sanity check.
+ * tree.def (NAME_MEMORY_TAG, SYMBOL_MEMORY_TAG, MEMORY_PARTITION_TAG):
+ Remove.
+ (TARGET_MEM_REF): Remove TMR_TAG operand.
+ * tree-dfa.c (add_referenced_var): Initialize call-clobber state.
+ Remove call-clobber related code.
+ (remove_referenced_var): Likewise. Do not clear mpt or symbol_mem_tag.
+ (dump_variable): Do not dump SMTs, memory stats, may-aliases or
+ partitions or escape reason.
+ (get_single_def_stmt, get_single_def_stmt_from_phi,
+ get_single_def_stmt_with_phi): Remove.
+ (dump_referenced_vars): Tidy.
+ (get_ref_base_and_extent): Allow bare decls.
+ (collect_dfa_stats): Adjust.
+ * graphite.c (rename_variables_in_stmt): Adjust.
+ (graphite_copy_stmts_from_block): Likewise.
+ (translate_clast): Likewise.
+ * tree-ssa-pre.c (struct bb_bitmap_sets): Add expr_dies bitmap.
+ (EXPR_DIES): New.
+ (translate_vuse_through_block): Use the oracle.
+ (phi_translate_1): Adjust.
+ (value_dies_in_block_x): Use the oracle. Cache the outcome
+ in EXPR_DIES.
+ (valid_in_sets): Check if the VUSE for
+ a REFERENCE is available.
+ (eliminate): Do not remove stmts during elimination,
+ instead queue and remove them afterwards.
+ (do_pre): Do not rebuild alias info.
+ (pass_pre): Run TODO_rebuild_alias before PRE.
+ * tree-ssa-live.c (remove_unused_locals): Remove memory-tag code.
+ * tree-sra.c (sra_walk_function): Use gimple_references_memory_p.
+ (mark_all_v_defs_stmt): Remove.
+ (mark_all_v_defs_seq): Adjust.
+ (sra_replace): Likewise.
+ (scalarize_use): Likewise.
+ (scalarize_copy): Likewise.
+ (scalarize_init): Likewise.
+ (scalarize_ldst): Likewise.
+ (todoflags): Remove.
+ (tree_sra): Do not rebuild alias info.
+ (tree_sra_early): Adjust.
+ (pass_sra): Run TODO_update_address_taken before SRA.
+ * tree-predcom.c (set_alias_info): Remove.
+ (prepare_initializers_chain): Do not call it.
+ (mark_virtual_ops_for_renaming): Adjust.
+ (mark_virtual_ops_for_renaming_list): Remove.
+ (initialize_root_vars): Adjust.
+ (initialize_root_vars_lm): Likewise.
+ (prepare_initializers_chain): Likewise.
+ * tree-ssa-copy.c (may_propagate_copy): Remove memory-tag related code.
+ (may_propagate_copy_into_stmt): Likewise.
+ (merge_alias_info): Do nothing for now.
+ (propagate_tree_value_into_stmt): Adjust.
+ (stmt_may_generate_copy): Likewise.
+ * tree-ssa-forwprop.c (tidy_after_forward_propagate_addr): Do
+ not mark symbols for renaming.
+ (forward_propagate_addr_expr): Match up push/pop_stmt_changes
+ with the same statement, make sure to update the new pointed-to one.
+ * tree-ssa-dce.c (eliminate_unnecessary_stmts): Do not copy
+ call statements, do not mark symbols for renaming.
+ (mark_operand_necessary): Dump something.
+ (ref_may_be_aliased): New function.
+ (mark_aliased_reaching_defs_necessary_1): New helper function.
+ (mark_aliased_reaching_defs_necessary): Likewise.
+ (mark_all_reaching_defs_necessary_1): Likewise.
+ (mark_all_reaching_defs_necessary): Likewise.
+ (propagate_necessity): Do not process virtual PHIs. For
+ non-aliased loads mark all reaching definitions as necessary.
+ For aliased loads and stores mark the immediate dominating
+ aliased clobbers as necessary.
+ (visited): New global static.
+ (perform_tree_ssa_dce): Free visited bitmap after propagating
+ necessity.
+ (remove_dead_phis): Perform simple dead virtual PHI removal.
+ (remove_dead_stmt): Properly unlink virtual operands when
+ removing stores.
+ (eliminate_unnecessary_stmts): Schedule PHI removal after
+ stmt removal.
+ * tree-ssa-ter.c (is_replaceable_p): Adjust.
+ (process_replaceable): Likewise.
+ (find_replaceable_in_bb): Likewise.
+ * tree-ssa.c (verify_ssa_name): Verify all VOPs are
+ based on the single gimple vop.
+ (verify_flow_insensitive_alias_info): Remove.
+ (verify_flow_sensitive_alias_info): Likewise.
+ (verify_call_clobbering): Likewise.
+ (verify_memory_partitions): Likewise.
+ (verify_alias_info): Likewise.
+ (verify_ssa): Adjust..
+ (execute_update_addresses_taken): Export. Update SSA
+ manually. Optimize only when optimizing. Use a local bitmap.
+ (pass_update_address_taken): Remove TODO_update_ssa, add
+ TODO_dump_func.
+ (pass_update_address_taken): Just use TODO_update_address_taken.
+ (init_tree_ssa): Do not initialize addressable_vars.
+ (verify_ssa): Verify new VUSE / VDEF properties.
+ Verify that all stmts definitions have the stmt as SSA_NAME_DEF_STMT.
+ Do not call verify_alias_info.
+ (delete_tree_ssa): Clear the VUSE, VDEF operands.
+ Do not free the loaded and stored syms bitmaps. Reset the escaped
+ and callused solutions. Do not free addressable_vars.
+ Remove memory-tag related code.
+ (warn_uninitialized_var): Aliases are always available.
+ * tree-ssa-loop-prefetch.c (gather_memory_references): Adjust.
+ * lambda-code.c (can_put_in_inner_loop): Adjust.
+ (can_put_after_inner_loop): Likewise.
+ (perfect_nestify): Likewise.
+ * tree-vect-stmts.c (vect_stmt_relevant_p): Adjust.
+ (vect_gen_widened_results_half): Remove CALL_EXPR handling.
+ (vectorizable_conversion): Do not mark symbols for renaming.
+ * tree-inline.c (remap_gimple_stmt): Clear VUSE/VDEF.
+ (expand_call_inline): Unlink the calls virtual operands before
+ replacing it.
+ (tree_function_versioning): Do not call update_ssa if we are not
+ updating clones. Simplify.
+ * tree-ssa-phiprop.c (phivn_valid_p): Adjust.
+ (propagate_with_phi): Likewise..
+ * tree-outof-ssa.c (create_temp): Remove memory tag and call
+ clobber code. Assert we are not aliased or global.
+ * tree-flow.h: Include tree-ssa-alias.h
+ (enum escape_type): Remove.
+ (struct mem_sym_stats_d): Likewise.
+ (struct mem_ref_stats_d): Likewise.
+ (struct gimple_df): Add vop member. Remove global_var,
+ call_clobbered_vars, call_used_vars, addressable_vars,
+ aliases_compted_p and mem_ref_stats members. Add syms_to_rename,
+ escaped and callused members.
+ (struct ptr_info_def): Remove all members, add points-to solution
+ member pt.
+ (struct var_ann_d): Remove in_vuse_list, in_vdef_list,
+ call_clobbered, escape_mask, mpt and symbol_mem_tag members.
+ * Makefile.in (TREE_FLOW_H): Add tree-ssa-alias.h.
+ (tree-ssa-structalias.o): Remove tree-ssa-structalias.h.
+ (tree-ssa-alias.o): Likewise.
+ (toplev.o): Add tree-ssa-alias.h
+ (GTFILES): Remove tree-ssa-structalias.h, add tree-ssa-alias.h.
+ * gimple.c (gimple_set_bb): Fix off-by-one error.
+ (is_gimple_reg): Do not handle memory tags.
+ (gimple_copy): Also copy virtual operands.
+ Delay updating the statement. Do not reset loaded and stored syms.
+ (gimple_set_stored_syms): Remove.
+ (gimple_set_loaded_syms): Likewise.
+ (gimple_call_copy_skip_args): Copy the virtual operands
+ and mark the new statement modified.
+ * tree-ssa-structalias.c (may_alias_p): Remove.
+ (set_uids_in_ptset): Take the alias set to prune with as
+ parameter. Fold in the alias test of may_alias_p.
+ (compute_points_to_sets): Compute whether a ptr is dereferenced
+ in a local sbitmap.
+ (process_constraint): Deal with &ANYTHING on the lhs, reject all
+ other ADDRESSOF constraints on the lhs.
+ (get_constraint_for_component_ref): Assert that we don't get
+ ADDRESSOF constraints from the base of the reference.
+ Properly generate UNKNOWN_OFFSET for DEREF if needed.
+ (struct variable_info): Remove collapsed_to member.
+ (get_varinfo_fc): Remove.
+ (new_var_info): Do not set collapsed_to.
+ (dump_constraint): Do not follow cycles.
+ (dump_constraint_graph): Likewise.
+ (build_pred_graph): Likewise.
+ (build_succ_graph): Likewise.
+ (rewrite_constraints): Likewise.
+ (do_simple_structure_copy): Remove.
+ (do_rhs_deref_structure_copy): Remove.
+ (do_lhs_deref_structure_copy): Remove.
+ (collapse_rest_of_var): Remove.
+ (do_structure_copy): Re-implement.
+ (pta_stats): New global variable.
+ (dump_pta_stats): New function.
+ (struct constraint_expr): Make offset signed.
+ (UNKNOWN_OFFSET): Define special value.
+ (dump_constraint): Dump UNKNOWN_OFFSET as UNKNOWN.
+ (solution_set_expand): New helper function split out from ...
+ (do_sd_constraint): ... here.
+ (solution_set_add): Handle UNKNOWN_OFFSET. Handle negative offsets.
+ (do_ds_constraint): Likewise.
+ (do_sd_constraint): Likewise. Do not special-case ESCAPED = *ESCAPED
+ and CALLUSED = *CALLUSED.
+ (set_union_with_increment): Make inc argument signed.
+ (type_safe): Remove.
+ (get_constraint_for_ptr_offset): Handle unknown and negative
+ constant offsets.
+ (first_vi_for_offset): Handle offsets before start. Bail
+ out early for offsets beyond the variable extent.
+ (first_or_preceding_vi_for_offset): New function.
+ (init_base_vars): Add ESCAPED = ESCAPED + UNKNOWN_OFFSET constraint.
+ Together with ESCAPED = *ESCAPED this properly computes reachability.
+ (find_what_var_points_to): New function.
+ (find_what_p_points_to): Implement in terms of find_what_var_points_to.
+ (pt_solution_reset, pt_solution_empty_p, pt_solution_includes_global,
+ pt_solution_includes_1, pt_solution_includes, pt_solutions_intersect_1,
+ pt_solutions_intersect): New functions.
+ (compute_call_used_vars): Remove.
+ (compute_may_aliases): New main entry into PTA computation.
+ * gimple.h (gimple_p): New typedef.
+ (struct gimple_statement_base): Remove references_memory_p.
+ (struct gimple_statement_with_memory_ops_base): Remove
+ vdef_ops, vuse_ops, stores and loads members. Add vdef and vuse
+ members.
+ (gimple_vuse_ops, gimple_set_vuse_ops, gimple_vdef_ops,
+ gimple_set_vdef_ops, gimple_loaded_syms, gimple_stored_syms,
+ gimple_set_references_memory): Remove.
+ (gimple_vuse_op, gimple_vdef_op, gimple_vuse, gimple_vdef,
+ gimple_vuse_ptr, gimple_vdef_ptri, gimple_set_vuse, gimple_set_vdef):
+ New functions.
+ * tree-cfg.c (move_block_to_fn): Fix off-by-one error.
+ (verify_expr): Allow RESULT_DECL.
+ (gimple_duplicate_bb): Do not copy virtual operands.
+ (gimple_duplicate_sese_region): Adjust.
+ (gimple_duplicate_sese_tail): Likewise.
+ (mark_virtual_ops_in_region): Remove.
+ (move_sese_region_to_fn): Do not call it.
+ * passes.c (init_optimization_passes): Remove pass_reset_cc_flags
+ and pass_simple_dse.
+ (execute_function_todo): Handle TODO_update_address_taken,
+ call execute_update_addresses_taken for TODO_rebuild_alias.
+ (execute_todo): Adjust.
+ (execute_one_pass): Init dump files early.
+ * ipa-struct-reorg.c (finalize_var_creation): Do not mark vars
+ call-clobbered.
+ (create_general_new_stmt): Clear vops.
+ * tree-ssa-reassoc.c (get_rank): Adjust.
+ * tree-vect-slp.c (vect_create_mask_and_perm): Do not mark
+ symbols for renaming.
+ * params.def (PARAM_MAX_ALIASED_VOPS): Remove.
+ (PARAM_AVG_ALIASED_VOPS): Likewise.
+ * tree-ssanames.c (init_ssanames): Allocate SYMS_TO_RENAME.
+ (duplicate_ssa_name_ptr_info): No need to copy the shared bitmaps.
+ * tree-ssa-operands.c: Simplify for new virtual operand representation.
+ (operand_build_cmp, copy_virtual_operands,
+ create_ssa_artificial_load_stmt, add_to_addressable_set,
+ gimple_add_to_addresses_taken): Remove public functions.
+ (unlink_stmt_vdef): New function.
+
+2009-04-03 Alan Modra <amodra@bigpond.net.au>
+
+ * config.gcc (powerpc-*-linux*): Merge variants.
+
+2009-04-02 Chao-ying Fu <fu@mips.com>
+ James Grosbach <james.grosbach@microchip.com>
+
+ * config/mips/mips.c (mips_frame_info): Add acc_mask, num_acc,
+ num_cop0_regs, acc_save_offset, cop0_save_offset, acc_sp_offset,
+ cop0_sp_offset.
+ (machine_function): Add interrupt_handler_p, use_shadow_register_set_p,
+ keep_interrupts_masked_p, use_debug_exception_return_p.
+ (mips_attribute_table): Add interrupt, use_shadow_register_set,
+ keep_interrupts_masked, use_debug_exception_return.
+ (mips_interrupt_type_p, mips_use_shadow_register_set_p,
+ mips_keep_interrupts_masked_p, mips_use_debug_exception_return_p):
+ New functions.
+ (mips_function_ok_for_sibcall): Return false for interrupt handlers.
+ (mips_print_operand): Process COP0 registers to print $0 .. $31
+ correctly for GAS to process.
+ (mips_interrupt_extra_call_saved_reg_p): New function.
+ (mips_cfun_call_saved_reg_p): For interrupt handlers, we need to check
+ extra registers.
+ (mips_cfun_might_clobber_call_saved_reg_p): Likewise.
+ (mips_compute_frame_info): Add supports for interrupt context that
+ includes doubleword accumulators and COP0 registers.
+ (mips_for_each_saved_acc): New function.
+ (mips_for_each_saved_gpr_and_fpr): Change the function name from
+ mips_for_each_saved_reg.
+ (mips_save_reg): Save accumulators.
+ (mips_kernel_reg_p): A new for_each_rtx callback.
+ (mips_expand_prologue): Support interrupt handlers.
+ (mips_restore_reg): Restore accumulators.
+ (mips_expand_epilogue): Support interrupt handlers.
+ (mips_can_use_return_insn): Return false for interrupt handlers.
+ (mips_epilogue_uses): New function.
+ * config/mips/mips.md (UNSPEC_ERET, UNSPEC_DERET, UNSPEC_DI,
+ UNSPEC_EHB, UNSPEC_RDPGPR, UNSPEC_COP0): New UNSPEC.
+ (mips_eret, mips_deret, mips_di, mips_ehb, mips_rdpgpr,
+ cop0_move): New instructions.
+ * config/mips/mips-protos.h (mips_epilogue_uses): Declare.
+ * config/mips/mips.h (K0_REG_NUM, K1_REG_NUM, KERNEL_REG_P): New
+ defines.
+ (COP0_STATUS_REG_NUM, COP0_CAUSE_REG_NUM, COP0_EPC_REG_NUM):
+ New defines.
+ (CAUSE_IPL, SR_IPL, SR_EXL, SR_IE): New defines.
+ (MIPS_PROLOGUE_TEMP_REGNUM, MIPS_EPILOGUE_TEMP_REGNUM): For
+ interrupt handlers, we use K0 as the temporary register.
+ (EPILOGUE_USES): Change to a function call.
+ * config/mips/sde.h (MIPS_EPILOGUE_TEMP_REGNUM): For interrupt
+ handlers, we use K0 as the temporary register.
+
+ * doc/extend.texi (Function Attributes): Document interrupt,
+ use_shadow_register_set, keep_interrupts_masked,
+ use_debug_exception_return for MIPS attributes.
+
+2009-04-03 Alan Modra <amodra@bigpond.net.au>
+
+ * config.gcc (powerpc64-*-gnu*): Add rs6000/default64.h to tm_file.
+ Remove a number of t-files from tmake_file.
+ * config/rs6000/sysv4.opt (mprototype): Name variable target_prototype.
+ * config/rs6000/sysv4.h (TARGET_PROTOTYPE): Define.
+ * config/rs6000/linux64.h (SUBSUBTARGET_OVERRIDE_OPTIONS): Set
+ target_prototype, not TARGET_PROTOTYPE.
+ (LINK_OS_GNU_SPEC): Define.
+ * config/rs6000/t-linux64 (LIB2FUNCS_EXTRA): Delete tramp.S
+ and darwin-ldoubdle.c.
+
+2009-04-02 Michael Meissner <meissner@linux.vnet.ibm.com>
+
+ PR driver/39293
+ * gcc.c (save_temps_flag): Add support for -save-temps=obj.
+ (cpp_options): Ditto.
+ (default_compilers): Ditto.
+ (display_help): Ditto.
+ (process_command): Ditto.
+ (do_spec_1): Ditto.
+ (set_input): Use lbasename instead of duplicate code.
+ (save_temps_prefix): New static for -save-temps=obj.
+ (save_temps_length): Ditto.
+
+ * doc/invoke.texi (-save-temps=obj): Document new variant to
+ -save-temps switch.
+
+2009-04-02 Jeff Law <law@redhat.com>
+
+ * reload1.c (fixup_eh_region_notes): Remove write-only "trap_count"
+ variable.
+
+2009-04-02 H.J. Lu <hongjiu.lu@intel.com>
+
+ * configure.ac: Support -Bstatic/-Bdynamic for linker version > 2.
+ * configure: Regenerated.
+
+2009-04-02 Rafael Avila de Espindola <espindola@google.com>
+
+ * c-decl.c (merge_decls): Make sure newdecl and olddecl don't
+ share the argument list.
+
+2009-04-02 Rafael Avila de Espindola <espindola@google.com>
+
+ Merge
+
+ 2009-02-12 Diego Novillo <dnovillo@google.com>
+
+ * varpool.c (debug_varpool): New.
+ * cgraph.h (debug_varpool): Declare.
+
+2009-04-02 Jan Hubicka <jh@suse.cz>
+
+ * passes.c (init_optimization_passes): Remove two copies of ehcleanup
+ pass.
+
+2009-04-02 H.J. Lu <hongjiu.lu@intel.com>
+
+ * config/i386/i386.c (ix86_abi): Move initialization to ...
+ (override_options): Here.
+
+2009-04-02 Christian Bruel <christian.bruel@st.com>
+
+ * config/sh/sh.c (sh_dwarf_register_span): New function.
+ (TARGET_DWARF_REGISTER_SPAN): Define.
+ * config/sh/sh-protos.h (sh_dwarf_register_span): Declare.
+
+2009-04-02 Ira Rosen <irar@il.ibm.com>
+
+ PR tree-optimization/39595
+ * tree-vect-slp.c (vect_build_slp_tree): Check that the size of
+ interleaved loads group is not greater than the SLP group size.
+
2009-04-02 Rafael Avila de Espindola <espindola@google.com>
* builtins.c (is_builtin_name): New.
Also, make sure the function properly sets TYPE_STUB_DECL() on
the newly created typedef variant type.
* c-common.h (is_typedef_decl, set_underlying_type): Declare ...
- * c-common.c (is_typedef_decl, set_underlying_type): ... new entry points.
+ * c-common.c (is_typedef_decl, set_underlying_type): ... new entry
+ points.
2009-04-02 Richard Guenther <rguenther@suse.de>
* config/i386/i386.c (legitimate_constant_p): Recognize
all one vector constant.
-2009-04-01 Jan-Benedict Glaw <jbglaw@jbglaw-dev.homezone.telefonica.de>
+2009-04-01 Jan-Benedict Glaw <jbglaw@jbglaw-dev.homezone.telefonica.de>
* gcc/config/vax/vax.c: Add #includes to silence warnings.
Change #include order to silence two warnings.
-2009-04-01 Jan-Benedict Glaw <jbglaw@jbglaw-dev.homezone.telefonica.de>
+2009-04-01 Jan-Benedict Glaw <jbglaw@jbglaw-dev.homezone.telefonica.de>
* gcc/config/vax/linux.h (TARGET_DEFAULT): Add the MASK_QMATH flag bit.
(ASM_SPEC): Pass -k to the assembler for PIC code.
-2009-04-01 Jan-Benedict Glaw <jbglaw@jbglaw-dev.homezone.telefonica.de>
+2009-04-01 Jan-Benedict Glaw <jbglaw@jbglaw-dev.homezone.telefonica.de>
* gcc/config.gcc: Add vax-*-linux* to the switch.
* gcc/config/vax/linux.h: New file. (TARGET_VERSION,
TARGET_OS_CPP_BUILTINS, TARGET_DEFAULT, CPP_SPEC, LINK_SPEC): Define.
-2009-04-01 Jan-Benedict Glaw <jbglaw@jbglaw-dev.homezone.telefonica.de>
+2009-04-01 Jan-Benedict Glaw <jbglaw@jbglaw-dev.homezone.telefonica.de>
* gcc/config/vax/vax.c (vax_output_int_move, adjacent_operands_p):
Use predicate macros instead of GET_CODE() == foo.
* gcc/config/vax/vax.md (movsi_2, movstrictqi, and<mode>3, ashrsi3,
ashlsi3, rotrsi3, <unnamed>): Likewise.
-2009-04-01 Jan-Benedict Glaw <jbglaw@jbglaw-dev.homezone.telefonica.de>
+2009-04-01 Jan-Benedict Glaw <jbglaw@jbglaw-dev.homezone.telefonica.de>
* gcc/config/vax/builtins.md (jbbssiqi, jbbssihi, jbbssisi, jbbcciqi,
jbbccihi, jbbccisi): Remova trailing whitespace.
* gcc/config/vax/vax.h: Likewise.
* gcc/config/vax/vax.md (nonlocal_goto): Likewise.
-2009-04-01 Jan-Benedict Glaw <jbglaw@jbglaw-dev.homezone.telefonica.de>
+2009-04-01 Jan-Benedict Glaw <jbglaw@jbglaw-dev.homezone.telefonica.de>
* gcc/config/vax/vax.c (vax_float_literal, vax_output_int_move)
(indirectable_address_p, adjacent_operands_p): Add spaces around
braces.
* gcc/config/vax/vax-protos.h (adjacent_operands_p): Likewise.
-2009-04-01 Jan-Benedict Glaw <jbglaw@jbglaw-dev.homezone.telefonica.de>
+2009-04-01 Jan-Benedict Glaw <jbglaw@jbglaw-dev.homezone.telefonica.de>
* gcc/config/vax/vax.c (legitimate_constant_address_p,
legitimate_constant_p, indirectable_address_p, nonindexed_address_p,
vax_mode_dependent_address_p): Update comments to match functions
modified by the recent int->bool conversion.
-2009-04-01 Jan-Benedict Glaw <jbglaw@jbglaw-dev.homezone.telefonica.de>
+2009-04-01 Jan-Benedict Glaw <jbglaw@jbglaw-dev.homezone.telefonica.de>
* gcc/config/vax/builtins.md: Update copyright message.
* gcc/config/vax/constraints.md: Likewise.
* gcc/config/vax/vax.md: Likewise.
* gcc/config/vax/vax.opt: Likewise.
-2009-04-01 Jan-Benedict Glaw <jbglaw@jbglaw-dev.homezone.telefonica.de>
+2009-04-01 Jan-Benedict Glaw <jbglaw@jbglaw-dev.homezone.telefonica.de>
* gcc/config/vax/builtins.md (ffssi2, ffssi2_internal,
sync_lock_test_and_set<mode>, sync_lock_release<mode>): Fix indention.
* gcc/config/vax/vax.md (movsi, movsi_2, mov<mode>, call_value,
untyped_call): Likewise.
-2009-04-01 Matt Thomas <matt@3am-software.com>
+2009-04-01 Matt Thomas <matt@3am-software.com>
- * config/vax/predicates.md: New file. (symbolic_operand,
- local_symbolic_operand, external_symbolic_operand,
+ * config/vax/predicates.md: New file.
+ (symbolic_operand, local_symbolic_operand, external_symbolic_operand,
external_const_operand, nonsymbolic_operand, external_memory_operand,
indirect_memory_operand, indexed_memory_operand,
illegal_blk_memory_operand, illegal_addsub_di_memory_operand,
nonimmediate_addsub_di_operand, general_addsub_di_operand): New
predicate.
- * config/vax/constraints.md: New file. (Z0, U06, U08, U16, CN6, S08,
- S16, I, J, K, L, M, N, O, G, Q, B, R, T): New constraint.
- * config/vax/builtins.md: New file. (ffssi2, ffssi2_internal,
- sync_lock_test_and_set<mode>, jbbssiqi, jbbssihi, jbbssisi,
- sync_lock_release<mode>, jbbcciqi, jbbccihi, jbbccisi): Define.
+ * config/vax/constraints.md: New file.
+ (Z0, U06, U08, U16, CN6, S08, S16, I, J, K, L, M, N, O, G, Q, B, R, T):
+ New constraint.
+ * config/vax/builtins.md: New file.
+ (ffssi2, ffssi2_internal, sync_lock_test_and_set<mode>, jbbssiqi,
+ jbbssihi, jbbssisi, sync_lock_release<mode>, jbbcciqi, jbbccihi,
+ jbbccisi): Define.
* config/vax/vax.opt (mqmath): Add option.
* config/vax/vax.md (isfx): Extend with DI.
(VAXintQH, VAXintQHSD): Define.
ASM_OUTPUT_DWARF_PCREL): Define.
(ASM_SPEC): Change definition to allow PIC generation.
+2009-04-01 Steve Ellcey <sje@cup.hp.com>
+
+ * doc/sourcebuild.texi: Update front-end requirements.
+
2009-04-01 Jakub Jelinek <jakub@redhat.com>
PR target/39226
2009-04-01 Rafael Avila de Espindola <espindola@google.com>
- * varasm.c (default_function_rodata_section): Declare DOT as const char*.
+ * varasm.c (default_function_rodata_section): Declare DOT as
+ const char*.
2009-04-01 Kai Tietz <kai.tietz@onevision.com>
Andrey Galkin <agalkin@hypercom.com>
2009-03-31 Joseph Myers <joseph@codesourcery.com>
* c-common.c (c_get_ident): New.
- (c_common_nodes_and_builtins): Call it for type names that may be
- NULL.
+ (c_common_nodes_and_builtins): Call it for type names that may be NULL.
2009-04-01 Ben Elliston <bje@au.ibm.com>
2009-03-31 Ramana Radhakrishnan <ramana.radhakrishnan@arm.com>
- PR target/27237
+ PR target/27237
* doc/invoke.texi (ARM Options): Update documentation for -mthumb.
2009-03-31 Richard Guenther <rguenther@suse.de>
2009-03-30 Paolo Bonzini <bonzini@gnu.org>
- * combine.c (simplify_comparison): Use have_insn_for.
- * dojump.c (do_jump): Likewise.
+ * combine.c (simplify_comparison): Use have_insn_for.
+ * dojump.c (do_jump): Likewise.
2009-03-30 Paolo Bonzini <bonzini@gnu.org>
2009-03-30 Paolo Bonzini <bonzini@gnu.org>
- * cfglayout.c (pass_into_cfg_layout_mode, pass_outof_cfg_layout_mode):
- Provide/destroy PROP_cfglayout respectively.
- * gcse.c (pass_jump_bypass, pass_gcse): Require it.
- * tree-pass.h (PROP_cfglayout): New.
+ * cfglayout.c (pass_into_cfg_layout_mode, pass_outof_cfg_layout_mode):
+ Provide/destroy PROP_cfglayout respectively.
+ * gcse.c (pass_jump_bypass, pass_gcse): Require it.
+ * tree-pass.h (PROP_cfglayout): New.
2009-03-30 Paolo Bonzini <bonzini@gnu.org>