1. 09 Nov, 2015 7 commits
    • Copy gnulib obstack files · c9f265c9
      This copies obstack.[ch] from gnulib, and updates the docs.  The next
      patch should be applied if someone repeats the import at a later date.
      
      include/
      	* obstack.h: Import current gnulib file.
      libiberty/
      	* obstack.c: Import current gnulib file.
      	* obstacks.texi: Updated doc, from glibc's manual/memory.texi.
      
      From-SVN: r229987
      Alan Modra committed
    • Update libsanitizer obstack interceptors · 62c0f0a6
      New obstack uses sensible types, size_t instead of int for length
      params.  Since libsanitizer does not use prototypes from obstack.h to
      call the real functions, it's necessary to update the libsanitizer
      function declarations emitted by the INTERCEPTOR macro.
      
      	* sanitizer_common/sanitizer_common_interceptors.inc: Update size
      	params for _obstack_begin_1, _obstack_begin, _obstack_newchunk
      	interceptors.
      	* configure.ac: Substitute OBSTACK_DEFS.
      	* asan/Makefile.am: Add OBSTACK_DEFS to DEFS.
      	* tsan/Makefile.am: Likewise.
      	* configure: Regenerate.
      	* Makefile.in: Regenerate.
      	* asan/Makefile.in: Regenerate.
      	* interception/Makefile.in: Regenerate.
      	* libbacktrace/Makefile.in: Regenerate.
      	* lsan/Makefile.in: Regenerate.
      	* sanitizer_common/Makefile.in: Regenerate.
      	* tsan/Makefile.in: Regenerate.
      	* ubsan/Makefile.in: Regenerate.
      
      From-SVN: r229986
      Alan Modra committed
    • Correct libvtv obstack use · 37697711
      Fixes a compile error with both old and new obstacks due to
      obstack_chunk_free having the wrong signature.  Also, setting chunk
      size and alignment before obstack_init is pointless since they are
      overwritten.
      
      	* vtv_malloc.cc (obstack_chunk_free): Correct param type.
      	(__vtv_malloc_init): Use obstack_specify_allocation.
      
      From-SVN: r229985
      Alan Modra committed
    • New obstack_next_free is not an lvalue · c240b3e0
      New obstack.h casts obstack_next_free to (void *), resulting in it
      being a non-lvalue, and warnings on pointer arithmetic.
      
      gcc/
      	* gensupport.c (add_mnemonic_string): Make len param a size_t.
      	(gen_mnemonic_setattr): Make "size" var a size_t.  Use
      	obstack_blank_fast to shrink obstack.  Cast obstack_next_free
      	return value.
      gcc/objc/
      	* objc-encoding.c (encode_aggregate_within): Cast obstack_next_free
      	return value.
      
      From-SVN: r229984
      Alan Modra committed
    • Fix bb-reorder problem with degenerate cond_jump (PR68182) · d4c8d5ed
      The code mistakenly thinks any cond_jump has two successors.  This is
      not true if both destinations are the same, as can happen with weird
      patterns as in the PR.
      
      
      	PR rtl-optimization/68182
      	* gcc/bb-reorder.c (reorder_basic_blocks_simple): Treat a conditional
      	branch with only one successor just like unconditional branches.
      
      From-SVN: r229983
      Segher Boessenkool committed
    • [PATCH] Remove backedge handling support in tree-ssa-threadupdate.c · 4f70cb39
      	* tree-ssa-threadupdate.c (register_jump_thraed): Assert that a
      	non-FSM path has no edges marked with EDGE_DFS_BACK.
      	(ssa_redirect_edges): No longer call mark_loop_for_removal.
      	(thread_single_edge, def_split_header_continue_p): Remove.
      	(bb_ends_with_multiway_branch): Likewise.
      	(thread_through_loop_header): Remove cases of threading from
      	latch through the header.  Simplify knowing we won't thread
      	the latch.
      	(thread_through_all_blocks): Simplify knowing that only the FSM
      	threader needs to handle backedges.
      
      From-SVN: r229982
      Jeff Law committed
    • Daily bump. · a2478e36
      From-SVN: r229980
      GCC Administrator committed
  2. 08 Nov, 2015 9 commits
  3. 07 Nov, 2015 22 commits
    • * config/sparc/sparc.opt (mfix-at697f): Add final period. · cad669df
      From-SVN: r229941
      Eric Botcazou committed
    • Wno-frame-address.c: Skip on hppa*-*-*. · 171258f7
      	* gcc.dg/Wno-frame-address.c: Skip on hppa*-*-*.
      
      From-SVN: r229940
      John David Anglin committed
    • re PR fortran/68153 (ICE for intrinsic reshape with negative dim in effective shape) · 57e59620
      2015-11-07  Steven G. Kargl  <kargl@gcc.gnu.org>
      
      	PR fortran/68153
      	* check.c (gfc_check_reshape): Improve check for valid SHAPE argument.
      
      2015-11-07  Steven G. Kargl  <kargl@gcc.gnu.org>
      
      	PR fortran/68153
      	* gfortran.dg/pr68153.f90: New test.
      
      From-SVN: r229939
      Steven G. Kargl committed
    • re PR fortran/68151 (ICE on using select case with function of wrong type) · 727cde64
      2015-11-07  Steven G. Kargl  <kargl@gcc.gnu.org>
      
      	PR fortran/68151
      	* match.c (match_case_selector):  Check for invalid type.
      
      2015-11-07  Steven G. Kargl  <kargl@gcc.gnu.org>
      
      	PR fortran/68151
      	* gfortran.dg/pr68151.f90: New test.
      
      From-SVN: r229938
      Steven G. Kargl committed
    • i386: Use the STC bb-reorder algorithm at -Os (PR67864) · bc05d49d
      For x86, STC still gives better results for optimise-for-size than
      "simple" does.  So use STC at -Os as well.
      
      
      	PR rtl-optimization/67864
      	* common/config/i386/i386-common.c (ix86_option_optimization_table)
      	<OPT_freorder_blocks_algorithm_>: Use REORDER_BLOCKS_ALGORITHM_STC
      	at -Os and up.
      
      From-SVN: r229937
      Segher Boessenkool committed
    • replace BITS_PER_UNIT with __CHAR_BIT__ in target libs · a153644f
      libgcc/ChangeLog:
      
      2015-11-07  Trevor Saunders  <tbsaunde+gcc@tbsaunde.org>
      
      	* config/visium/lib2funcs.c (__set_trampoline_parity): Use
      	__CHAR_BIT__ instead of BITS_PER_UNIT.
      	* fixed-bit.h: Likewise.
      	* fp-bit.h: Likewise.
      	* libgcc2.c (__popcountSI2): Likewise.
      	(__popcountDI2): Likewise.
      	* libgcc2.h: Likewise.
      	* libgcov.h: Likewise.
      
      libobjc/ChangeLog:
      
      2015-11-07  Trevor Saunders  <tbsaunde+gcc@tbsaunde.org>
      
      	PR libobjc/24775
      	* encoding.c (_darwin_rs6000_special_round_type_align): Use
      	__CHAR_BIT__ instead of BITS_PER_UNIT.
      	(objc_sizeof_type): Likewise.
      	(objc_layout_structure): Likewise.
      	(objc_layout_structure_next_member): Likewise.
      	(objc_layout_finish_structure): Likewise.
      	(objc_layout_structure_get_info): Likewise.
      
      From-SVN: r229936
      Trevor Saunders committed
    • atexit.c: New file. · 3dee689d
      * config/rs6000/atexit.c: New file.
      * config/rs6000/t-aix-cxa (LIB2ADDEH): Build atexit.c.
      * config/rs6000/libgcc-aix-cxa.ver (atexit): Add symbol to exports.
      * config/rs6000/cxa_finalize.c
      (catomic_compare_and_exchange_bool_acq): Negate return value.
      
      From-SVN: r229932
      David Edelsohn committed
    • Handle internal functions in is_tm_pure_call · 6ca5a442
      The upcoming changes to use internal functions for things like sqrt
      caused a failure in gcc.dg/tm/20100610.c, because we were trying to get
      call flags from the null gimple_call_fn of an IFN_SQRT call.  We've been
      making fairly heavy use of internal functions for a while now so I think
      this might be latent.
      
      Tested on x86_64-linux-gnu, aarch64-linux-gnu and arm-linux-gnueabi.
      
      gcc/
      	* trans-mem.c (is_tm_pure_call): Use gimple_call_flags for
      	internal functions.
      
      From-SVN: r229925
      Richard Sandiford committed
    • Move #undef DEF_BUILTIN* to builtins.def · 0aad0198
      I was confused at first why tree-core.h was undefining DEF_BUILTIN_CHKP
      before defining it, then undefining it again after including builtins.def.
      This is because builtins.def provides a default definition of
      DEF_BUILTIN_CHKP, but leaves it up to the caller to undefine it where
      necessary.  Similarly to the previous internal-fn.def patch, it seems
      more obvious for builtins.def to #undef things unconditionally.
      
      One argument might have been that keeping preprocessor stuff
      out of the .def files makes it easier for non-cpp parsers.  In practice
      though we already have #ifs and multiline #defines, so single-line #undefs
      should be easy in comparison.
      
      Tested on x86_64-linux-gnu, aarch64-linux-gnu and arm-linux-gnueabi.
      
      gcc/ada/
      	* gcc-interface/utils.c: Don't undef DEF_BUILTIN.
      
      gcc/c-family/
      	* c-common.c: Don't undef DEF_BUILTIN.
      
      gcc/jit/
      	* jit-builtins.c: Don't undef DEF_BUILTIN.
      
      gcc/lto/
      	* lto-lang.c: Don't undef DEF_BUILTIN.
      
      gcc/
      	* builtins.def: #undef DEF_BUILTIN and DEF_BUILTIN_CHKP
      	* builtins.c, genmatch.c, tree-core.h: Don't undef them here.
      
      From-SVN: r229924
      Richard Sandiford committed
    • Move #undef DEF_INTERNAL_FN to internal-fn.def · 46e343b8
      In practice the definition of DEF_INTERNAL_FN is never reused after
      including internal-fn.def, so we might as well #undef it there.
      
      This becomes more obvious with a later patch that adds other
      DEF_INTERNAL_* directives, such as DEF_INTERNAL_OPTAB_FN.
      If the includer doesn't care about the information carried in
      these new directives, it can simply leave the macro undefined
      and internals.def will provide a definition that forwards to
      DEF_INTERNAL_FN.  It doesn't make much sense for includers to have
      to #undef macros that are defined by internals.def and it seems overly
      complicated to get internals.def to undef macros only in the cases
      where it provided a definition.  Instead I went with the approach of
      #undeffing all the DEF_INTERNAL_* macros unconditionally.
      
      Tested on x86_64-linux-gnu, aarch64-linux-gnu and arm-linux-gnueabi.
      
      gcc/
      	* internal-fn.def: #undef DEF_INTERNAL_FN at the end.
      	* internal-fn.c: Don't undef it here.
      	* tree-core.h: Likewise.
      
      From-SVN: r229923
      Richard Sandiford committed
    • Move const char * -> int/fp folds to fold-const-call.c · df838ef0
      This patch moves folds that deal with constant string arguments and
      return a constant integer or floating-point value.  For example, it
      handles strcmp ("foo", "bar") but not strstr ("foobar", "bar"),
      which wouldn't currently be accepted by the gimple folders.
      
      The builtins.c folding for strlen (via c_strlen) is a bit more general
      than what the fold-const-call.c code does (and more general than we need
      for the gimple folders).  I've therefore left it as-is, even though it
      partially duplicates the new code.
      
      Tested on x86_64-linux-gnu, aarch64-linux-gnu and arm-linux-gnueabi.
      
      gcc/
      	* builtins.c (fold_builtin_nan): Delete.
      	(fold_builtin_memcmp): Remove case where both arguments are constant.
      	(fold_builtin_strcmp, fold_builtin_strncmp): Likewise.
      	(fold_builtin_strspn, fold_builtin_strcspn): Likewise.
      	(fold_builtin_1): Remove BUILT_IN_NAN* handling.
      	* fold-const-call.c: Include fold-const.h.
      	(host_size_t_cst_p): New function.
      	(build_cmp_result, fold_const_builtin_nan): Likewise.
      	(fold_const_call_1): New function, split out from...
      	(fold_const_call): ...here (for all three interfaces).  Handle
      	constant nan, nans, strlen, strcmp, strncmp, strspn and strcspn.
      
      From-SVN: r229922
      Richard Sandiford committed
    • Move constant bitop and bswap folds to fold-const-call.c · db9bd5d5
      The only folds left in builtins.c were for constants, so we can remove
      the builtins.c handling entirely.
      
      Tested on x86_64-linux-gnu, aarch64-linux-gnu and arm-linux-gnueabi.
      
      gcc/
      	* builtins.c (fold_builtin_bitop, fold_builtin_bswap): Delete.
      	(fold_builtin_1): Don't call them.
      	* fold-const-call.c: Include tm.h.
      	(fold_const_call_ss): New variant for integer-to-integer folds.
      	(fold_const_call): Call it.
      
      From-SVN: r229921
      Richard Sandiford committed
    • Handle constant fp classifications in fold-const-call.c · 2556a032
      Move the constant "is finite", "is infinite" and "is nan" queries
      to fold-const-call.c.
      
      Tested on x86_64-linux-gnu, aarch64-linux-gnu and arm-linux-gnueabi.
      
      gcc/
      	* builtins.c (fold_builtin_classify): Move constant cases to...
      	* fold-const-call.c (fold_const_call_ss): ...here.
      
      From-SVN: r229920
      Richard Sandiford committed
    • Move c_getstr to fold-const.c · 5486d913
      Upcoming patches to fold-const-call.c want to use c_getstr, which is
      currently defined in builtins.c.  The function doesn't really do anything
      related to built-ins, and I'd rather not make fold-const-call.c depend
      on builtins.c and builtins.c depend on fold-const-call.c, so this patch
      moves the function to fold-const.c instead.
      
      Tested on x86_64-linux-gnu, aarch64-linux-gnu and arm-linux-gnueabi.
      
      gcc/
      	* builtins.h (c_getstr): Move to...
      	* fold-const.h (c_getstr): ...here.
      	* builtins.c (c_getstr): Move to...
      	* fold-const.c (c_getstr): ...here.
      
      From-SVN: r229919
      Richard Sandiford committed
    • Don't treat rint as setting errno · eb0b164e
      builtins.def says that rint sets errno, but it looks like this might
      be a mistake.  C99 says that rint doesn't set errno and the builtins.c
      expansion code doesn't try to keep errno up to date.
      
      Perhaps this was because earlier versions of POSIX said that
      rint sets errno on overflow:
      
              http://pubs.opengroup.org/onlinepubs/009695399/functions/rintf.html
      
      However, this is another instance of the observation that "rounding
      functions could never overflow" (because anything using exponents
      that large is already integral).  The page above also says that
      differences with C99 are unintentional and the ERANGE clause has
      been removed from later versions of POSIX:
      
              http://pubs.opengroup.org/onlinepubs/9699919799/functions/rint.html
      
      Also, the version of POSIX that lists ERANGE for rint does the same
      for nearbyint:
      
              http://pubs.opengroup.org/onlinepubs/009695399/functions/nearbyintf.html
      
      and we already treat nearbyint as not setting errno.  This too has been
      clarified in later versions of POSIX:
      
              http://pubs.opengroup.org/onlinepubs/9699919799/functions/nearbyint.html
      
      Tested on x86_64-linux-gnu, aarch64-linux-gnu and arm-linux-gnueabi.
      
      gcc/
      	* builtins.def (BUILTIN_RINT, BUILTIN_RINTF, BUILTIN_RINTL): Use
      	ATTR_MATHFN_FPROUNDING rather than ATTR_MATHFN_FPROUNDING_ERRNO.
      
      From-SVN: r229918
      Richard Sandiford committed
    • Add -fno-math-errno to gcc.dg/lto/20110201-1_0.c · 02b7230d
      At the moment the ECF_* flags for a gimple call to a built-in
      function are derived from the function decl, which in turn is
      derived from the global command-line options.  So if the compiler
      is run with -fno-math-errno, we always assume functions don't set
      errno, regardless of local optimization options.  Similarly if the
      compiler is run with -fmath-errno, we always assume functions set errno.
      
      This shows up in gcc.dg/lto/20110201-1_0.c, where we compile
      the file with -O0 and use -O2 -ffast-math for a specific function.
      -O2 -ffast-math is enough for us to convert cabs to sqrt as hoped,
      but because of the global -fmath-errno setting, we assume that the
      call to sqrt is not pure or const and create vops for it.  This makes
      it appear to the gimple code that a simple sqrt optab isn't enough.
      
      Later patches move more decisions about maths functions to gimple
      and think that in this case we should use:
      
              y = sqrt (x);
              if (!(x >= 0))
                  sqrt (x); // to set errno.
      
      This is being tracked as PR68235.  For now the patch adds
      -fno-math-errno to the dg-options for this test.
      
      Tested on x86_64-linux-gnu, aarch64-linux-gnu and arm-linux-gnueabi.
      
      gcc/testsuite/
      	PR tree-optimization/68235
      	* gcc.dg/lto/20110201-1_0.c: Add -fno-math-errno.
      
      From-SVN: r229917
      Richard Sandiford committed
    • Try to update dominance info in tree-call-cdce.c · f127ea51
      The pass would free the dominance info after making a change, but it
      should be pretty easy to keep the information up-to-date when the call
      has no EH edges.
      
      Tested on x86_64-linux-gnu, arm-linux-gnueabi and aarch64-linux-gnu.
      
      gcc/
      	* tree-call-cdce.c (shrink_wrap_one_built_in_call): Try to update
      	the dominance info; free it if we can't.
      	(pass_call_cdce::execute): Don't free the dominance info here.
      
      From-SVN: r229916
      Richard Sandiford committed
    • [PATCH] Remove more backedge threading support · 88419b52
      	* tree-ssa-threadedge.c (dummy_simplify): Remove.
      	(thread_around_empty_blocks): Remove backedge_seen_p argument.
      	If we thread to a backedge, then return false.  Update recursive
      	call to eliminate backedge_seen_p argument.
      	(thread_through_normal_block): Remove backedge_seen_p argument.
      	Remove backedge_seen_p argument from calls to
      	thread_around_empty_blocks.  Remove checks on backedge_seen_p.
      	If we thread to a backedge, then return 0.
      	(thread_across_edge): Remove bookkeeping for backedge_seen.  Don't
      	pass it to thread_through_normal_block or thread_through_empty_blocks.
      	For joiner handling, if we see a backedge, do not try normal
      	threading.
      
      From-SVN: r229911
      Jeff Law committed
    • add original schedule to scop · 0473915e
          * graphite-optimize-isl.c (optimize_isl): Call isl_union_map_is_equal.
          * graphite-poly.c (new_scop): Initialize original_schedule.
          (free_scop): Free original_schedule.
          * graphite-poly.h (struct scop): Add field original_schedule.
          * graphite-sese-to-poly.c (build_scop_original_schedule): New.
          (build_poly_scop): Call build_scop_original_schedule.
      
      From-SVN: r229910
      Abderrazek Zaafrani committed
    • do not create unnecessary dimensions in scop scattering · 504fbc11
                 * graphite-sese-to-poly.c (build_pbb_scattering_polyhedrons): Remove.
                 (build_pbb_minimal_scattering_polyhedrons): New.
                 (build_scop_scattering): Remove.
                 (build_scop_minimal_scattering): New.
                 (build_scop_scattering): Call build_pbb_minimal_scattering_polyhedrons.
                 (build_poly_scop): Call build_scop_minimal_scattering.
      
      From-SVN: r229909
      Abderrazek Zaafrani committed
    • re PR go/66138 (json decoder Decode function fails for some structure return values) · f5eb9a8e
      	PR go/66138
          reflect, encoding/json, encoding/xml: fix unexported embedded structs
          
          Bring in three changes from the master Go repository.  These changes
          will be in Go 1.6, but they are appropriate for gccgo now because they
          resolve a long-standing discrepancy between how gc and gccgo handle the
          PkgPath field for embedded unexported struct fields.  The core issue is
          described at https://golang.org/cl/7247.  This has been reported against
          gccgo as https://gcc.gnu.org/PR66138.
          
          The three changes being brought over are:
          
          https://golang.org/cl/14010
          
          reflect: adjust access to unexported embedded structs
          
          This CL changes reflect to allow access to exported fields and
          methods in unexported embedded structs for gccgo and after gc
          has been adjusted to disallow access to embedded unexported structs.
          
          Adresses #12367, #7363, #11007, and #7247.
          
          https://golang.org/cl/14011
          
          encoding/json: check for exported fields in embedded structs
          
          Addresses issue #12367.
          
          https://golang.org/cl/14012
          
          encoding/xml: check for exported fields in embedded structs
          
          Addresses issue #12367.
          
          Reviewed-on: https://go-review.googlesource.com/16723
      
      From-SVN: r229907
      Ian Lance Taylor committed
    • Daily bump. · 39f02a1f
      From-SVN: r229906
      GCC Administrator committed
  4. 06 Nov, 2015 2 commits
    • [PATCH] Allow vrp to thread across backedges using FSM threader · b9e59e4f
      	* cfg-flags.def (IGNORE): New edge flag.
      	* tree-vrp.c (identify_jump_threads): Mark and clear edges
      	scheduled for removal with EDGE_IGNORE around call into
      	jump threader.  Do no thread across edges with EDGE_IGNORE,
      	but do allow threading across those with EDGE_DFS_BACK.
      
      	* gcc.dg/tree-ssa/ssa-dom-thread-7.c: Adjust to look for
      	realized jump threads.
      	* gcc.dg/tree-ssa-pr66752-3.c: Look in vrp1 dump for jump
      	threads rather than dom1 dump.
      
      From-SVN: r229902
      Jeff Law committed
    • inline asm and multi-alternative constraints · a6fa947e
      	* doc/md.texi (multi-alternative constraints): Don't document
      	alternatives inherently tied to reload for the user documentation.
      
      From-SVN: r229897
      David Wohlferd committed