1. 01 Jun, 2018 14 commits
    • * Fix email address in ChangeLog. · 64acc19a
      From-SVN: r261080
      Bin Cheng committed
    • * MAINTAINERS: Update my email address. · 232d2edb
      From-SVN: r261079
      Bin Cheng committed
    • rs6000: Fix mangling for 128-bit float · 560a1dc6
      This patch changes the (C++) mangling of the 128-bit float types.
      IBM long double ("double-double") is mangled as "g", as before, and
      IEEE 128-bit long double is mangled as "u9__ieee128".
      
      
      	* config/rs6000/rs6000.c (rs6000_mangle_type): Change the mangling of
      	the 128-bit floating point types.  Fix function comment.
      
      From-SVN: r261078
      Segher Boessenkool committed
    • re PR fortran/63570 ([F2018] Implement 13.7.137 RANDOM INIT (REPEATABLE, IMAGE DISTINCT)) · ddd3e26e
      2018-06-01  Steven G. Kargl  <kargl@gcc.gnu.org>
      
      	PR fortran/63570
      	* check.c (gfc_check_random_init): New function. Check arguments of
      	RANDOM_INIT.
      	* gfortran.h (GFC_ISYM_RANDOM_INIT): New enum token.
      	* intrinsic.c (add_subroutines): Add RANDOM_INIT to list of 
      	subroutines.
      	(gfc_check_intrinsic_standard): Introduce Fortran 2018 check.
      	* intrinsic.h: Add prototypes for gfc_check_random_init and
      	gfc_resolve_random_init
      	* intrinsic.texi: Document new intrinsic subprogram.
      	* iresolve.c (gfc_resolve_random_init): Resolve routine name.
      	* trans-decl.c: Declare gfor_fndecl_random_init
      	* trans-intrinsic.c (conv_intrinsic_random_init): New function.
      	Translate call to RANDOM_INIT.
      	(gfc_conv_intrinsic_subroutine): Call it.
       	* trans.h: Declare gfor_fndecl_random_init
       
      2018-06-01  Steven G. Kargl  <kargl@gcc.gnu.org>
       
      	PR fortran/63570
      	* gfortran.dg/random_init_1.f90: New test.
      	* gfortran.dg/random_init_2.f90: New test.
      	* gfortran.dg/random_init_3.f90: New test.
      	* gfortran.dg/random_init_4.f90: New test.
      	* gfortran.dg/random_init_5.f90: New test.
      	* gfortran.dg/random_init_6.f90: New test.
      
      2018-06-01  Steven G. Kargl  <kargl@gcc.gnu.org>
      
      	PR fortran/63570
      	* libgfortran/Makefile.am: Add random_init.f90 to build.
      	* libgfortran/Makefile.in: Regenerated.
      	* libgfortran/gfortran.map: Expose symbol for _gfortran_random_init.
      	* libgfortran/intrinsics/random_init.f90: Implementation.
      
      From-SVN: r261075
      Steven G. Kargl committed
    • [AArch64] Used prefer aliases SXTL(2) and UXTL(2) · 77b8fb05
      The SSHL and USHL instructions are used with a shift operand of zero to
      sign and zero-extend integer vectors into wider modes.
      GCC makes extensive use of them to "unpack" vectors.
      
      AArch64 defines a shorthand alias for that case. Instead of writing:
      SSHLL <Vd>.<Ta>, <Vn>.<Tb>, 0
      
      we can write
      
      SXTL <Vd>.<Ta>, <Vn>.<Tb>
      
      Similar for the unsigned versions and the high-part versions (SSHL2 -> SXTL2).
      This makes the assembly of vectorised functions a bit more readable.
      
      	* config/aarch64/aarch64-simd.md
      	(aarch64_simd_vec_unpack<su>_lo_<mode>): Use UXTL and SXTL assembler
      	mnemonics.
      	(aarch64_simd_vec_unpack<su>_hi_<mode>): Use UXTL2 and SXTL2 assembler
      	mnemonics.
      
      From-SVN: r261073
      Kyrylo Tkachov committed
    • [MAINTAINERS] Update email address · 7aad7f4b
      2018-06-01  Tom de Vries  <tdevries@suse.de>
      
      	* MAINTAINERS: Update my email address.
      
      From-SVN: r261068
      Tom de Vries committed
    • Fix phi backedge detection in backprop (PR85989) · 33031ee6
      This PR is a nasty wrong code bug due to my fluffing a test for a
      backedge in gimple-ssa-backprop.c.  Backedges are supposed to be
      from definitions in the statement we're visiting to uses in statements
      that we haven't visited yet.  However, the check failed to account for
      PHIs in the current block that had already been processed, so if two
      PHIs in the same block referenced each other, we'd treat both
      references as backedges.
      
      In more detail:
      
      The first phase of the pass goes through all statements in an arbitrary
      order, making optimistic assumptions about any statements that haven't
      been visited yet.  The second phase then calculates a correct
      (supposedly maximal) fixed point.
      
      Although the first phase order is arbitrary in principle, we still use
      the CFG rpo to cut down on the backedges.  This means that the only
      thing that's truly arbitrary is the order that we process the PHIs
      in a block.  Any order should be OK and should eventually give the
      same results.  But we have to follow whatever order we pick,
      and the pass wasn't doing that.
      
      2018-06-01  Richard Sandiford  <richard.sandiford@linaro.org>
      
      gcc/
      	PR tree-optimization/85989
      	* gimple-ssa-backprop.c (backprop::m_visited_phis): New member
      	variable.
      	(backprop::intersect_uses): Check it when deciding whether this
      	is a backedge reference.
      	(backprop::process_block): Add each phi to m_visited_phis
      	after visiting it, then clear it at the end.
      
      gcc/testsuite/
      	PR tree-optimization/85989
      	* gcc.dg/torture/pr85989.c: New test.
      
      From-SVN: r261064
      Richard Sandiford committed
    • tree-vectorizer.h (vect_dr_stmt): New function. · 57c454d2
      2018-06-01  Richard Biener  <rguenther@suse.de>
      
      	* tree-vectorizer.h (vect_dr_stmt): New function.
      	(vect_get_load_cost): Adjust.
      	(vect_get_store_cost): Likewise.
      	* tree-vect-data-refs.c (vect_analyze_data_ref_dependence):
      	Use vect_dr_stmt instead of DR_SMTT.
      	(vect_record_base_alignments): Likewise.
      	(vect_calculate_target_alignment): Likewise.
      	(vect_compute_data_ref_alignment): Likewise and make static.
      	(vect_update_misalignment_for_peel): Likewise.
      	(vect_verify_datarefs_alignment): Likewise.
      	(vector_alignment_reachable_p): Likewise.
      	(vect_get_data_access_cost): Likewise.  Pass down
      	vinfo to vect_get_load_cost/vect_get_store_cost instead of DR.
      	(vect_get_peeling_costs_all_drs): Likewise.
      	(vect_peeling_hash_get_lowest_cost): Likewise.
      	(vect_enhance_data_refs_alignment): Likewise.
      	(vect_find_same_alignment_drs): Likewise.
      	(vect_analyze_data_refs_alignment): Likewise.
      	(vect_analyze_group_access_1): Likewise.
      	(vect_analyze_group_access): Likewise.
      	(vect_analyze_data_ref_access): Likewise.
      	(vect_analyze_data_ref_accesses): Likewise.
      	(vect_vfa_segment_size): Likewise.
      	(vect_small_gap_p): Likewise.
      	(vectorizable_with_step_bound_p): Likewise.
      	(vect_prune_runtime_alias_test_list): Likewise.
      	(vect_analyze_data_refs): Likewise.
      	(vect_supportable_dr_alignment): Likewise.
      	* tree-vect-loop-manip.c (get_misalign_in_elems): Likewise.
      	(vect_gen_prolog_loop_niters): Likewise.
      	* tree-vect-loop.c (vect_analyze_loop_2): Likewise.
      	* tree-vect-patterns.c (vect_recog_bool_pattern): Do not
      	modify DR_STMT.
      	(vect_recog_mask_conversion_pattern): Likewise.
      	(vect_try_gather_scatter_pattern): Likewise.
      	* tree-vect-stmts.c (vect_model_store_cost): Pass stmt_info
      	to vect_get_store_cost.
      	(vect_get_store_cost): Get stmt_info instead of DR.
      	(vect_model_load_cost): Pass stmt_info to vect_get_load_cost.
      	(vect_get_load_cost): Get stmt_info instead of DR.
      
      From-SVN: r261062
      Richard Biener committed
    • re PR tree-optimization/86017 (multiple consecutive calls to bzero/memset not merged) · 47cac108
      2018-06-01  Richard Biener  <rguenther@suse.de>
      
      	PR middle-end/86017
      	* gimple-fold.c (var_decl_component_p): Also allow offsetted
      	vars wrapped in MEM_REFs.
      
      	* gcc.dg/tree-ssa/pr86017.c: New testcase.
      
      From-SVN: r261061
      Richard Biener committed
    • c-ada-spec.c (dump_ada_declaration): Generate a forward declaration for a… · abc24d93
      c-ada-spec.c (dump_ada_declaration): Generate a forward declaration for a typedef independently of whether the...
      
      	* c-ada-spec.c (dump_ada_declaration) <TYPE_DECL>: Generate a forward
      	declaration for a typedef independently of whether the declaration of
      	the subtype is generated.
      
      From-SVN: r261058
      Eric Botcazou committed
    • Fix SVE fallout from r260951 · 67e5c59a
      2018-06-01  Richard Sandiford  <richard.sandiford@linaro.org>
      
      gcc/
      	* config/aarch64/aarch64.c (aarch64_ira_change_pseudo_allocno_class):
      	Fix subreg tests so that we only return a choice between
      	GENERAL_REGS and FP_REGS if the original classes included both.
      
      From-SVN: r261057
      Richard Sandiford committed
    • re PR ipa/85960 (-fipa-pta and ifunc are incompatible) · 07205c41
      2018-06-01  Richard Biener  <rguenther@suse.de>
      
      	PR ipa/85960
      	* tree-ssa-structalias.c (get_function_part_constraint):
      	Handle NULL fi->decl.
      	(find_func_aliases_for_call): Properly handle indirect
      	fi from direct call.
      	(find_func_clobbers): Likewise.
      	(ipa_pta_execute): Likewise.
      	(create_variable_info_for): For functions that are ifunc_resolver
      	resolve to a varinfo that contains the result of the resolver
      	call.
      	(associate_varinfo_to_alias): Do not treat ifunc resolvers as
      	aliases.
      
      	* gcc.dg/ipa/ipa-pta-19.c: New testcase.
      
      From-SVN: r261056
      Richard Biener committed
    • 2018-05-15 Michael Collison <michael.collison@arm.com> · eeb59c16
      	* config/aarch64/aarch64.md:
      	(*fix_to_zero_extenddfdi2): New pattern.
      	* gcc.target/aarch64/fix_extend1.c: New testcase.
      
      From-SVN: r261051
      Michael Collison committed
    • Daily bump. · b670ffe9
      From-SVN: r261050
      GCC Administrator committed
  2. 31 May, 2018 26 commits
    • libgo: update to Go 1.10.2 release · 11309337
          
          Reviewed-on: https://go-review.googlesource.com/115196
      
      From-SVN: r261041
      Ian Lance Taylor committed
    • 2nd Patch for PR78009 · 8b0b334a
      Patch for PR83026
      
      https://gcc.gnu.org/bugzilla/show_bug.cgi?id=78809
      Inline strcmp with small constant strings
      
      https://gcc.gnu.org/bugzilla/show_bug.cgi?id=83026
      missing strlen optimization for strcmp of unequal strings
      
      The design doc for PR78809 is at:
      https://www.mail-archive.com/gcc@gcc.gnu.org/msg83822.html
      
      this patch is for the second part of change of PR78809 and PR83026:
      
      B. for strncmp (s1, s2, n) (!)= 0 or strcmp (s1, s2) (!)= 0
      
         B.1. (PR83026) When the lengths of both arguments are constant and
              it's a strcmp:
            * if the lengths are NOT equal, we can safely fold the call
              to a non-zero value.
            * otherwise, do nothing now.
      
         B.2. (PR78809) When the length of one argument is constant, try to replace
         the call with a __builtin_str(n)cmp_eq call where possible, i.e:
      
         strncmp (s, STR, C) (!)= 0 in which, s is a pointer to a string, STR is a
         string with constant length, C is a constant.
           if (C <= strlen(STR) && sizeof_array(s) > C)
             {
               replace this call with
               __builtin_strncmp_eq (s, STR, C) (!)= 0
             }
           if (C > strlen(STR)
             {
               it can be safely treated as a call to strcmp (s, STR) (!)= 0
               can handled by the following strcmp.
             }
      
         strcmp (s, STR) (!)= 0 in which, s is a pointer to a string, STR is a
         string with constant length.
           if  (sizeof_array(s) > strlen(STR))
             {
               replace this call with
               __builtin_strcmp_eq (s, STR, strlen(STR)+1) (!)= 0
             }
      
         later when expanding the new __builtin_str(n)cmp_eq calls, first expand them
         as __builtin_memcmp_eq, if the expansion does not succeed, change them back
         to call to __builtin_str(n)cmp.
      
      adding test case strcmpopt_2.c and strcmpopt_4.c into gcc.dg for part B of
      PR78809 adding test case strcmpopt_3.c into gcc.dg for PR83026
      
      From-SVN: r261039
      Qing Zhao committed
    • re PR target/85984 (ICE in create_pseudo_cfg, at dwarf2cfi.c:2874) · 28c84b62
      	PR target/85984
      	* bb-reorder.c (pass_partition_blocks::gate): Return false for
      	functions with naked attribute.
      
      	* gcc.target/i386/pr85984.c: New test.
      
      From-SVN: r261037
      Jakub Jelinek committed
    • re PR target/85591 (__builtin_cpu_is() is not detecting bdver2 with Model = 0x02) · 8b8003ed
      	PR target/85591
      	* config/i386/cpuinfo.c (get_amd_cpu): Return
      	AMDFAM15H_BDVER2 for AMDFAM15H model 0x2.
      
      From-SVN: r261036
      Uros Bizjak committed
    • PR libstdc++/78870 support std::filesystem on Windows · 9534a5e6
      	PR libstdc++/78870 support std::filesystem on Windows
      	* config.h.in: Regenerate.
      	* configure: Regenerate.
      	* configure.ac: Check for link, readlink and symlink.
      	* include/bits/fs_path.h (path::operator/=(const path&)): Move
      	definition out of class body.
      	(path::is_absolute(), path::_M_append(path)): Likewise.
      	(operator<<(basic_ostream, const path&)): Use std::quoted directly.
      	(operator>>(basic_istream, path&)): Likewise.
      	(u8path): Reorder definitions and fix Windows implementation.
      	(path::is_absolute()): Define inline and fix for Windows.
      	[!_GLIBCXX_FILESYSTEM_IS_WINDOWS] (path::operator/=(const path&)):
      	Define POSIX version inline.
      	(path::_M_append(path)): Define inline.
      	* include/experimental/bits/fs_path.h (path::is_absolute()): Move
      	definition out of class body.
      	(operator<<(basic_ostream, const path&)): Fix type of delimiter and
      	escape characters.
      	(operator>>(basic_istream, path&)): Likewise.
      	(path::is_absolute()): Define inline and fix for Windows.
      	* src/filesystem/dir-common.h (__gnu_posix): New namespace.
      	(__gnu_posix::char_type, __gnu_posix::DIR, __gnu_posix::dirent)
      	(__gnu_posix::opendir, __gnu_posix::readdir, __gnu_posix::closedir):
      	Define as adaptors for Windows functions/types or as
      	using-declarations for POSIX functions/types.
      	(_Dir_base, get_file_type): Qualify names to use declarations from
      	__gnu_posix namespace.
      	(_Dir_base::is_dor_or_dotdot): New helper functions.
      	* src/filesystem/dir.cc (_Dir, recursive_directory_iterator): Qualify
      	names to use declarations from __gnu_posix namespace.
      	* src/filesystem/ops-common.h (__gnu_posix): New nested namespace.
      	(__gnu_posix::open, __gnu_posix::close, __gnu_posix::stat_type)
      	(__gnu_posix::stat, __gnu_posix::lstat, __gnu_posix::mode_t)
      	(__gnu_posix::chmod, __gnu_posix::mkdir, __gnu_posix::getcwd)
      	(__gnu_posix::chdir, __gnu_posix::utimbuf, __gnu_posix::utime)
      	(__gnu_posix::rename, __gnu_posix::truncate, __gnu_posix::char_type):
      	Define as adaptors for Windows functions/types or as
      	using-declarations for POSIX functions/types.
      	(stat_type, do_copy_file): Qualify names to use declarations from
      	__gnu_posix namespace.
      	(do_space): Declare new function.
      	(make_file_type): Only use S_ISLNK if defined.
      	* src/filesystem/ops.cc (char_ptr, filesystem::canonical): Use
      	path::value_type not char.
      	(filesystem::copy, create_dir, filesystem::create_directory): Qualify
      	names to use declarations from __gnu_posix namespace.
      	(filesystem::create_hard_link): Check HAVE_LINK autoconf macro and
      	add implementation for Windows.
      	(filesystem::create_symlink): Check HAVE_SYMLINK autoconf macro.
      	(filesystem::current_path(error_code&)): Use __gnu_posix::getcwd.
      	[!_PC_PATH_MAX]: Don't use pathconf.
      	[PATH_MAX]: Use if defined.
      	(filesystem::current_path(const path&, error_code&))
      	(filesystem::equivalent, do_stat, filesystem::hard_link_count)
      	(filesystem::last_write_time, filesystem::permissions): Use names
      	from __gnu_posix.
      	(filesystem::read_symlink): Check HAVE_READLINK autoconf macro.
      	(filesystem::remove) [_GLIBCXX_FILESYSTEM_IS_WINDOWS]: Add
      	implementation for Windows.
      	(filesystem::rename, filesystem::resize_file): Use names from
      	__gnu_posix.
      	(filesystem::space): Use do_space.
      	[_GLIBCXX_FILESYSTEM_IS_WINDOWS]: Get absolute path to directory.
      	(filesystem::status, filesystem::symlink_status): Use names from
      	__gnu_posix.
      	(filesystem::temp_directory_path): Add implementation for Windows.
      	* src/filesystem/path.cc (dot): Define constant.
      	(path::replace_extension): Use dot.
      	(path::_M_find_extension): Likewise. Use path::string_type not
      	std::string.
      	(path::_M_split_cmpts): Use dot.
      	(filesystem_error::_M_get_what): Use u8string() not native().
      	* src/filesystem/std-dir.cc (_Dir, recursive_directory_iterator):
      	Qualify names to use declarations from __gnu_posix namespace.
      	* src/filesystem/std-ops.cc (filesystem::absolute(const path&)): Use
      	correct error_code.
      	(filesystem::absolute(const path&, error_code&)): Add implementation
      	for Windows.
      	(char_ptr, filesystem::canonical): Use path::value_type not char.
      	(do_copy_file): Use names from __gnu_posix.
      	[_GLIBCXX_FILESYSTEM_IS_WINDOWS]: Do not use fchmod, fchmodat or
      	sendfile.
      	(filesystem::copy, create_dir, filesystem::create_directory): Qualify
      	names to use declarations from __gnu_posix namespace.
      	(filesystem::create_hard_link): Check HAVE_LINK autoconf macro and
      	add implementation for Windows.
      	(filesystem::create_symlink): Check HAVE_SYMLINK autoconf macro.
      	(filesystem::current_path(error_code&)): Use __gnu_posix::getcwd.
      	[!_PC_PATH_MAX]: Don't use pathconf.
      	[PATH_MAX]: Use if defined.
      	(filesystem::current_path(const path&, error_code&))
      	(filesystem::equivalent, do_stat, filesystem::hard_link_count)
      	(filesystem::last_write_time, filesystem::permissions): Use names
      	from __gnu_posix.
      	(filesystem::read_symlink): Check HAVE_READLINK autoconf macro.
      	(filesystem::remove) [_GLIBCXX_FILESYSTEM_IS_WINDOWS]: Add
      	implementation for Windows.
      	(filesystem::rename, filesystem::resize_file): Use names from
      	__gnu_posix.
      	(do_space): Define.
      	(filesystem::space): Use do_space.
      	(filesystem::status, filesystem::symlink_status): Use names from
      	__gnu_posix.
      	(filesystem::temp_directory_path): Add implementation for Windows.
      	* src/filesystem/std-path.cc
      	[_GLIBCXX_FILESYSTEM_IS_WINDOWS] (path::operator/=(const path&)):
      	Define for Windows.
      	(dot): Define constant.
      	(path::replace_extension, is_dot): Use dot.
      	(path::lexically_normal): Check _M_type instead of calling
      	non-existent function.
      	(path::_M_find_extension): Use dot. Use path::string_type not
      	std::string.
      	(path::_M_split_cmpts): Use dot.
      	(filesystem_error::_M_get_what): Use u8string() not native().
      	* testsuite/27_io/filesystem/iterators/directory_iterator.cc: Do not
      	use symlinks.
      	* testsuite/27_io/filesystem/iterators/recursive_directory_iterator.cc:
      	Likewise.
      	* testsuite/27_io/filesystem/operations/absolute.cc: Use
      	__gnu_test::root_path() instead of "/" and add Windows-specific tests.
      	* testsuite/27_io/filesystem/operations/canonical.cc: Use
      	path::string() to get narrow string, not path::native().
      	* testsuite/27_io/filesystem/operations/copy.cc: Construct fstreams
      	with std::filesystem::path not std::basic_string.
      	* testsuite/27_io/filesystem/operations/copy_file.cc: Likewise.
      	* testsuite/27_io/filesystem/operations/exists.cc: Use
      	__gnu_test::root_path() instead of "/".
      	* testsuite/27_io/filesystem/operations/is_empty.cc: Construct
      	fstreams with std::filesystem::path not std::basic_string.
      	* testsuite/27_io/filesystem/operations/last_write_time.cc: Use
      	path::string() to get narrow string.
      	* testsuite/27_io/filesystem/operations/space.cc: Check results for
      	errors, expect sensible values otherwise.
      	* testsuite/27_io/filesystem/operations/temp_directory_path.cc: Add
      	helpers for adjusting the environment on Windows.
      	* testsuite/27_io/filesystem/path/append/path.cc: Test
      	Windows-specific behaviour.
      	* testsuite/27_io/filesystem/path/construct/format.cc: Fix creation
      	of path::string_type objects.
      	* testsuite/27_io/filesystem/path/construct/locale.cc: Compare native
      	string to wide string on Windows.
      	* testsuite/27_io/filesystem/path/decompose/root_directory.cc: Allow
      	for backslash as root-directory.
      	* testsuite/27_io/filesystem/path/decompose/stem.cc: Use
      	path::string() to get narrow string.
      	* testsuite/27_io/filesystem/path/itr/traversal.cc: Test Windows-style
      	paths.
      	* testsuite/27_io/filesystem/path/native/string.cc: Use string_type
      	not std::string.
      	* testsuite/27_io/filesystem/path/query/is_absolute.cc: Adjust for
      	different definintion of absolute paths on Windows.
      	* testsuite/experimental/filesystem/iterators/directory_iterator.cc:
      	Do not use symlinks.
      	* testsuite/experimental/filesystem/operations/absolute.cc: Test
      	Windows behaviour.
      	* testsuite/experimental/filesystem/operations/copy.cc: Construct
      	fstreams with NTCTS not std::basic_string.
      	* testsuite/experimental/filesystem/operations/copy_file.cc: Likewise.
      	* testsuite/experimental/filesystem/operations/exists.cc: Use
      	__gnu_test::root_path() instead of "/".
      	* testsuite/experimental/filesystem/operations/is_empty.cc: Construct
      	fstreams with NTCTS not std::basic_string.
      	* testsuite/experimental/filesystem/operations/last_write_time.cc:
      	Use path::string() to get narrow string.
      	* testsuite/experimental/filesystem/operations/space.cc: Use
      	__gnu_test::root_path() instead of "/".
      	* testsuite/experimental/filesystem/operations/temp_directory_path.cc:
      	Add helpers for adjusting the environment on Windows.
      	* testsuite/experimental/filesystem/path/append/path.cc: Use
      	path::string() to get narrow strings for comparisons.
      	* testsuite/experimental/filesystem/path/concat/path.cc: Likewise.
      	* testsuite/experimental/filesystem/path/decompose/root_directory.cc:
      	Likewise.
      	* testsuite/experimental/filesystem/path/decompose/stem.cc: Likewise.
      	* testsuite/experimental/filesystem/path/native/string.cc: Use
      	string_type not std::string.
      	* testsuite/experimental/filesystem/path/query/is_absolute.cc:
      	Adjust for different definintion of absolute paths on Windows.
      	* testsuite/util/testsuite_fs.h (__gnu_test::root_path()): New
      	function.
      	(__gnu_test::scoped_file): Construct fstreams with NTCTS not
      	std::basic_string.
      
      From-SVN: r261034
      Jonathan Wakely committed
    • sse.md (avx_vec_concat<mode>): Substitute concat_tg_mode mode attribute with xtg_mode. · c9315097
      	* config/i386/sse.md (avx_vec_concat<mode>):
      	Substitute concat_tg_mode mode attribute with xtg_mode.
      	(<mask_codefor>avx512dq_broadcast<mode><mask_name>_1): Ditto.
      	(concat_tg_mode): Remove mode attribute.
      
      From-SVN: r261031
      Uros Bizjak committed
    • PR c/82063 - issues with arguments enabled by -Wall · d258f4aa
      gcc/c-family/ChangeLog:
      
      	PR c/82063
      	* c.opt (-Wno-alloc-size-larger-than): New option.
      	* doc/invoke.texi (-Walloc-size-larger-than): Update.
      
      gcc/ChangeLog:
      
      	PR c/82063
      	* calls.c (alloc_max_size): Correct a logic error/typo.
      	Treat excessive arguments as infinite.  Warn for invalid arguments.
      
      gcc/testsuite/ChangeLog:
      
      	PR c/82063
      	* gcc.dg/Walloc-size-larger-than-1.c: New test.
      	* gcc.dg/Walloc-size-larger-than-10.c: New test.
      	* gcc.dg/Walloc-size-larger-than-11.c: New test.
      	* gcc.dg/Walloc-size-larger-than-12.c: New test.
      	* gcc.dg/Walloc-size-larger-than-13.c: New test.
      	* gcc.dg/Walloc-size-larger-than-14.c: New test.
      	* gcc.dg/Walloc-size-larger-than-15.c: New test.
      	* gcc.dg/Walloc-size-larger-than-16.c: New test.
      	* gcc.dg/Walloc-size-larger-than-17.c: New test.
      	* gcc.dg/Walloc-size-larger-than-2.c: New test.
      	* gcc.dg/Walloc-size-larger-than-3.c: New test.
      	* gcc.dg/Walloc-size-larger-than-4.c: New test.
      	* gcc.dg/Walloc-size-larger-than-5.c: New test.
      	* gcc.dg/Walloc-size-larger-than-6.c: New test.
      	* gcc.dg/Walloc-size-larger-than-7.c: New test.
      	* gcc.dg/Walloc-size-larger-than-8.c: New test.
      	* gcc.dg/Walloc-size-larger-than-9.c: New test.
      	* gcc.dg/Walloc-size-larger-than.c: New test.
      
      From-SVN: r261030
      Martin Sebor committed
    • x86: Re-enable partial_reg_dependency and movx for Haswell · 3217e694
      r254152 disabled partial_reg_dependency and movx for Haswell and newer
      Intel processors.  r258972 restored them for skylake-avx512.  For Haswell,
      movx improves performance.  But partial_reg_stall may be better than
      partial_reg_dependency in theory.  We will investigate performance impact
      of partial_reg_stall vs partial_reg_dependency on Haswell for GCC 9.  In
      the meantime, this patch restores both partial_reg_dependency and mox for
      Haswell in GCC 8.
      
      On Haswell, improvements for EEMBC benchmarks with
      
      -mtune-ctrl=movx,partial_reg_dependency -Ofast -march=haswell
      
      vs
      
      -Ofast -mtune=haswell
      
      are
      
      automotive
      =========
        aifftr01 (default) - goodperf: Runtime improvement of   2.6% (time).
        aiifft01 (default) - goodperf: Runtime improvement of   2.2% (time).
      
      networking
      =========
        ip_pktcheckb1m (default) - goodperf: Runtime improvement of   3.8% (time).
        ip_pktcheckb2m (default) - goodperf: Runtime improvement of   5.2% (time).
        ip_pktcheckb4m (default) - goodperf: Runtime improvement of   4.4% (time).
        ip_pktcheckb512k (default) - goodperf: Runtime improvement of   4.2% (time).
      
      telecom
      =========
        fft00data_1 (default) - goodperf: Runtime improvement of   8.4% (time).
        fft00data_2 (default) - goodperf: Runtime improvement of   8.6% (time).
        fft00data_3 (default) - goodperf: Runtime improvement of   9.0% (time).
      
      	PR target/85829
      	* config/i386/x86-tune.def: Re-enable partial_reg_dependency
      	and movx for Haswell.
      
      From-SVN: r261028
      H.J. Lu committed
    • re PR middle-end/85879 (ICE in expand_debug_locations, at cfgexpand.c:5405) · bd1cab35
      Fix PR middle-end/85879
      
      	gcc/
      	* gimplify.c (gimplify_adjust_omp_clauses): Add 'remove = true'
      	when emitting error on private/firstprivate reductions.
      	* omp-low.c (lower_omp_target): Avoid reference-type processing
      	on pointers for firstprivate clause.
      
      	gcc/testsuite/
      	* gfortran.dg/goacc/pr77371-1.f90: New test.
      	* gfortran.dg/goacc/pr77371-2.f90: New test.
      	* gfortran.dg/goacc/pr85879.f90: New test.
      
      Co-Authored-By: Cesar Philippidis <cesar@codesourcery.com>
      
      From-SVN: r261025
      Chung-Lin Tang committed
    • PR libstdc++/85951 for make_signed/make_unsigned for character types · 22f1f4c7
      Because the wide character types are neither signed integer types nor
      unsigned integer types they need to be transformed to an integral type
      of the correct size and the lowest rank (which is not necessarily the
      underlying type). Reuse the helpers for enumeration types to select the
      correct integer.
      
      The refactoring of __make_unsigned_selector and __make_signed_selector
      slightly reduces the number of template instantiations and so reduces
      memory usage.
      
      	PR libstdc++/85951
      	* include/std/type_traits [_GLIBCXX_USE_C99_STDINT_TR1]: Do not define
      	uint_least16_t and uint_least32_t.
      	(__make_unsigned<wchar_t>): Define unconditionally.
      	(__make_unsigned_selector<_Tp, true, false>): Remove intermediate
      	typedefs.
      	(__make_unsigned_selector_base): New type to provide helper templates.
      	(__make_unsigned_selector<_Tp, false, true>): Reimplement using
      	__make_unsigned_selector_base helpers.
      	(__make_unsigned<char16_t>, __make_unsigned<char32_t>): Define.
      	(__make_signed_selector<_Tp, true, false>): Remove intermediate
      	typedefs.
      	(__make_signed<wchar_t>, __make_signed<char16_t>)
      	(__make_signed<char32_t>)): Define unconditionally.
      	* testsuite/20_util/make_signed/requirements/typedefs-3.cc: Check
      	wchar_t, char16_t and char32_t are transformed correctly.
      	* testsuite/20_util/make_signed/requirements/typedefs_neg.cc: Adjust
      	dg-error lineno.
      	* testsuite/20_util/make_unsigned/requirements/typedefs-3.cc: Check
      	wchar_t, char16_t and char32_t are transformed correctly.
      	* testsuite/20_util/make_unsigned/requirements/typedefs_neg.cc: Adjust
      	dg-error lineno.
      
      From-SVN: r261023
      Jonathan Wakely committed
    • stack_usage1.adb: Replace -fstack-usage with -Wstack-usage. · 2ae39fb2
      	* gnat.dg/stack_usage1.adb: Replace -fstack-usage with -Wstack-usage.
      	* gnat.dg/stack_usage1b.adb: Likewise.
      	* gnat.dg/stack_usage1c.adb: Likewise.
      	* gnat.dg/stack_usage3.adb: Likewise.
      	* gnat.dg/stack_usage1_pkg.adb: Delete.
      
      From-SVN: r261021
      Eric Botcazou committed
    • store_merging_10.c: Turn dg-do compile into dg-do run. · 78668dd0
      	* gcc.dg/store_merging_10.c: Turn dg-do compile into dg-do run.
      	* gcc.dg/store_merging_11.c: Likewise.
      	* gcc.dg/store_merging_13.c: Likewise.
      	* gcc.dg/store_merging_14.c: Likewise.
      	* gcc.dg/store_merging_15.c: Likewise.
      	* gcc.dg/store_merging_16.c: Likewise.  Remove local variable.
      
      From-SVN: r261019
      Eric Botcazou committed
    • [Ada] Remove obsolete figure in documentation · 7b1e3952
      2018-05-31  Pierre-Marie de Rodat  <derodat@adacore.com>
      
      gcc/ada/
      
      	* doc/gnat_ugn/project-manager-figure.png: Delete.
      
      From-SVN: r261018
      Pierre-Marie de Rodat committed
    • [Ada] Add missing spec files for VxWorks runtimes · 76bce685
      2018-05-31  Pierre-Marie de Rodat  <derodat@adacore.com>
      
      gcc/ada/
      
      	* vxworks-arm-link.spec, vxworks-e500-link.spec,
      	vxworks-gnat-crtbe-link.spec, vxworks-smp-arm-link.spec,
      	vxworks-smp-e500-link.spec, vxworks-smp-ppc-link.spec,
      	vxworks-smp-x86-link.spec: New files.
      
      From-SVN: r261017
      Pierre-Marie de Rodat committed
    • [Ada] Minor copyright header adjustments · 986bd14e
      2018-05-31  Pierre-Marie de Rodat  <derodat@adacore.com>
      
      gcc/ada/
      
      	* gnatvsn.adb: Re-center the copyright header.
      	* indepsw-darwin.adb: Adjust the starting copyright year to 2011.
      
      From-SVN: r261016
      Pierre-Marie de Rodat committed
    • [Ada] Document Stubs_Subdir in gnattest section on user guide · 9200846e
      2018-05-31  Fedor Rybin  <frybin@adacore.com>
      
      gcc/ada/
      
      	* doc/gnat_ugn/gnat_utility_programs.rst: Document Stubs_Subdir in
      	gnattest section on user guide.
      
      From-SVN: r261015
      Fedor Rybin committed
    • [Ada] Static predicate check on characters of a string literal · 2a35a4ca
      This patch implements the rule given in R< 4.2 (11): if the component type of
      a string literal is a character type with a static predicate, that predicate
      must be applied to each character in the string.
      
      Compiling the example below must yield:
      
         gcc -c -gnata main.adb
      
        main.adb:4:23: warning: static expression fails static predicate check on "C"
        main.adb:4:23: warning: expression is no longer considered static
        main.adb:4:24: warning: static expression fails static predicate check on "C"
        main.adb:4:24: warning: expression is no longer considered static
        main.adb:4:25: warning: static expression fails static predicate check on "C"
        main.adb:4:25: warning: expression is no longer considered static
      
      Execution must yield:
      
        raised SYSTEM.ASSERTIONS.ASSERT_FAILURE :
                                              Static_Predicate failed at main.adb:4
      ----
      
      procedure Main is
         subtype C is Character with Static_Predicate => C in 'A' | 'B' | 'C';
         type S is array (Positive range <>) of C;
         X : constant S := "abc";
      begin
         null;
      end;
      
      2018-05-31  Ed Schonberg  <schonberg@adacore.com>
      
      gcc/ada/
      
      	* sem_res.adb (Resolve_String_Literal): If the type is a string type
      	whose component subtype has a static predicate, ensure that the
      	predicate is applied to each character by expanding the string into the
      	equivalent aggregate. This is also done if the component subtype is
      	constrained.
      
      From-SVN: r261014
      Ed Schonberg committed
    • [Ada] Remove obsolete code in trans.c · d9898483
      2018-05-31  Eric Botcazou  <ebotcazou@adacore.com>
      
      gcc/ada/
      
      	* gcc-interface/trans.c (Call_to_gnu): Remove obsolete code.
      
      From-SVN: r261013
      Eric Botcazou committed
    • [Ada] Detect returning procedures annotated with No_Return · 0562ed31
      GNAT was emitting a warning about procedures with No_Return aspect on the
      spec and a returning body, but failed to handle similar procedures with
      no explicit spec. Now fixed.
      
      This was also affecting GNATprove, where an undetected mismatch between
      No_Return aspect and the body was a soundness bug, i.e. GNATprove was
      silently accept code that raise a runtime exception.
      
      ------------
      -- Source --
      ------------
      
      procedure P (X : Boolean) with No_Return is
      begin
         if X then
            raise Program_Error;
         end if;
      end;
      
      -----------------
      -- Compilation --
      -----------------
      
      $ gcc -c p.adb
      p.adb:3:04: warning: implied return after this statement will raise
                           Program_Error
      p.adb:3:04: warning: procedure "P" is marked as No_Return
      
      2018-05-31  Piotr Trojanek  <trojanek@adacore.com>
      
      gcc/ada/
      
      	* sem_ch6.adb (Check_Missing_Return): Handle procedures with no
      	explicit spec.
      
      From-SVN: r261012
      Piotr Trojanek committed
    • [Ada] Fix wrong value returned for unconstrained packed array · 6e03839f
      2018-05-31  Eric Botcazou  <ebotcazou@adacore.com>
      
      gcc/ada/
      
      	* gcc-interface/trans.c (Call_to_gnu): In the by-reference case, if
      	the type of the parameter is an unconstrained array type, convert
      	to the type of the actual before the type of the formal only if the
      	conversion was suppressed earlier.  Use in_param and gnu_actual_type
      	local variables throughout, and uniform spelling for In Out or Out.
      	Also remove dead code in the component-by-reference case.
      
      From-SVN: r261011
      Eric Botcazou committed
    • [Ada] Fix __gnat_backtrace for VxWorks7 on x86 · fe1db400
      A STORAGE ERROR is raised in __gnat_backtrace:
      
      adainit: 0x00400DBC
      
      Execution of ce.vxe terminated by unhandled exception
      raised STORAGE_ERROR : SIGSEGV: possible stack overflow
      Call stack traceback locations:
      0x4082f1 0x408323 0x4080c9
      
      It was passing with vxsim because the WRS_RTP_BASE is set to a different
      place hence the (CURRENT) < (TOP_STACK) was stopping the backtrace at the
      right time. So let's stop at the main symbol when RTS=rtp.
      
      2018-05-31  Frederic Konrad  <konrad@adacore.com>
      
      gcc/ada/
      
      	* tracebak.c (STOP_FRAME): Harden condition.
      	(is_return_from, EXTRA_STOP_CONDITION): New helpers for VxWorks in RTP
      	mode.
      
      From-SVN: r261010
      Frederic Konrad committed
    • [Ada] Illegal copy of limited object · 6ae40af3
      This patch fixes a spurious copy of a limited object, when that object
      is a discriminated record component of a limited type LT, and the enclosing
      record is initialized by means of an aggregate, one of whose components is a
      call to a build-in-place function that returns an unconstrained object of
      type T.
      
      2018-05-31  Ed Schonberg  <schonberg@adacore.com>
      
      gcc/ada/
      
      	* checks.adb (Apply_Discriminant_Check): Do not apply discriminant
      	check to a call to a build-in-place function, given that the return
      	object is limited and cannot be copied.
      
      gcc/testsuite/
      
      	* gnat.dg/limited1.adb, gnat.dg/limited1_inner.adb,
      	gnat.dg/limited1_inner.ads, gnat.dg/limited1_outer.adb,
      	gnat.dg/limited1_outer.ads: New testcase.
      
      From-SVN: r261009
      Ed Schonberg committed
    • [Ada] Update comment on __atomic_compare_exchange in s-atomic_primitives · c9f35768
      Remove mention of unavailability, long obsolete, and reword suggestion of use
      to indicate that we might want to switch to an internal interface using them.
      The current wording suggests just that we should bind the current
      Sync_Compare_And_Swap Ada subprograms to __atomic_compare builtins instead of
      __sync_compare, which would be highly confusing.
      
      2018-05-31  Olivier Hainque  <hainque@adacore.com>
      
      gcc/ada/
      
      	* libgnat/s-atopri.ads: Update comment on __atomic_compare_exchange
      	builtins.
      
      From-SVN: r261008
      Olivier Hainque committed
    • [Ada] Fix internal error on allocator with function call · 1b6f8e97
      2018-05-31  Eric Botcazou  <ebotcazou@adacore.com>
      
      gcc/ada/
      
      	* gcc-interface/trans.c (Call_to_gnu): If this is a function call and
      	there is no target, also create a temporary for the return value for
      	an allocator if the type is an unconstrained record type with default
      	discriminant.
      
      From-SVN: r261007
      Eric Botcazou committed
    • [Ada] Spurious tampering check failure · 3c5d07ab
      This patch modifies the transient scope mechanism to create a scope when the
      condition of an iteration scheme returns a controlled result or involves the
      secondary stack. As a result, a while loop which iterates over a container
      properly manages the tampering bit at each iteration of the loop.
      
      2018-05-31  Hristian Kirtchev  <kirtchev@adacore.com>
      
      gcc/ada/
      
      	* exp_ch7.adb (Find_Transient_Context): An iteration scheme is a valid
      	boudary for a transient scope.
      
      gcc/testsuite/
      
      	* gnat.dg/tampering_check1.adb, gnat.dg/tampering_check1_ivectors.ads,
      	gnat.dg/tampering_check1_trim.adb, gnat.dg/tampering_check1_trim.ads:
      	New testcase.
      
      From-SVN: r261006
      Hristian Kirtchev committed
    • [Ada] Rename "GPL" version to "Community" · 9977c785
      2018-05-31  Valentine Reboul  <reboul@adacore.com>
      
      gcc/ada/
      
      	* gnatvsn.ads: Rename "GPL" version to "Community".
      
      From-SVN: r261005
      Valentine Reboul committed