1. 11 Oct, 2018 8 commits
    • libcpp: show macro definition when used with wrong argument count · 954ad112
      Consider:
      
      demo.c: In function 'test':
      demo.c:5:40: error: macro "LOG_2" requires 3 arguments, but only 2 given
      5 |   LOG_2 ("loading file: %s\n", filename);
        |                                        ^
      
      This patch adds a note showing the definition of the macro in
      question, giving:
      
      demo.c: In function 'test':
      demo.c:5:40: error: macro "LOG_2" requires 3 arguments, but only 2 given
      5 |   LOG_2 ("loading file: %s\n", filename);
        |                                        ^
      In file included from demo.c:1:
      logging.h:1: note: macro "LOG_2" defined here
      1 | #define LOG_2(FMT, ARG0, ARG1) do { fprintf (stderr, (FMT), (ARG0), (ARG1)); }
        | 
      
      gcc/testsuite/ChangeLog:
      	* g++.dg/diagnostic/macro-arg-count.C: Move to...
      	* c-c++-common/cpp/macro-arg-count-1.c: ...here, generalizing
      	output for C vs C++.  Expect notes showing the definitions of the
      	macros.
      	* c-c++-common/cpp/macro-arg-count-2.c: New test, adapted from the
      	above.
      
      libcpp/ChangeLog:
      	* macro.c (_cpp_arguments_ok): If the argument count is wrong, add
      	a note showing the definition of the macro.
      
      From-SVN: r265040
      David Malcolm committed
    • x86-tune-costs.h (bdver?_memcpy, [...]): Unify to ... · c727b835
      2018-10-11  Richard Biener  <rguenther@suse.de>
      
      	* config/i386/x86-tune-costs.h (bdver?_memcpy, bdver?_memset,
      	bdver?_cost): Unify to ...
      	(bdver_memcpy, bdver_memset, bdver_cost): ... this.
      	* config/i386/i386.c (processor_cost_table): Adjust.
      
      From-SVN: r265038
      Richard Biener committed
    • [PATCH] A couple of line map fixes · c1b48b29
      https://gcc.gnu.org/ml/gcc-patches/2018-10/msg00623.html
      	* include/line-map.h (LINEMAPS_MACRO_LOWEST_LOCATION): Fix
      	off-by-one error.
      	* line-map.c (linemap_enter_macro): Use RAII.  Clear all of the
      	macro_locations.
      
      From-SVN: r265037
      Nathan Sidwell committed
    • Make ext allocators support heterogeneous equality comparison · c7790bdb
      The Allocator requirements include the ability to compare different
      specializations of the same allocator class template. This did not work
      for __gnu_cxx::new_allocator and other extension allocators.  This patch
      replaces the equality operators for those allocators with inline friends
      that support heterogeneous comparisons.  (I'm not changing all ext
      allocators because some are bit-rotted already).
      
      Additionally, the equality operators for comparing two std::allocator
      objects of the same type are now defined as inline friends. Those
      overloads don't need to be declared at namespace scope, because they
      aren't specified in the standard (but they're needed in this
      implementation to avoid ambiguities caused by the extra overloads
      defined for the base allocator type).
      
      	* include/bits/allocator.h
      	(operator==(const allocator<_Tp>&, const allocator<_Tp>))
      	(operator!=(const allocator<_Tp>&, const allocator<_Tp>)): Replace
      	with inline friends.
      	* include/ext/debug_allocator.h (operator==, operator!=): Replace
      	with inline friend functions that compare to rebound allocators.
      	* include/ext/malloc_allocator.h (operator==, operator!=): Likewise.
      	* include/ext/new_allocator.h (operator==, operator!=): Likewise.
      	* testsuite/ext/debug_allocator/eq.cc: New test.
      	* testsuite/ext/ext_pointer/alloc_eq.cc: New test.
      	* testsuite/ext/malloc_allocator/eq.cc: New test.
      	* testsuite/ext/new_allocator/eq.cc: New test.
      
      From-SVN: r265036
      Jonathan Wakely committed
    • [testsuite] Further fixes to warn-abs-1.c · e7336b8e
      2018-10-11  Martin Jambor  <mjambor@suse.cz>
      
      	testsuite/
      	* gcc.dg/warn-abs-1.c: Guard tests assuming size of long double is
      	greater that the size of double by target large_long double.
      
      From-SVN: r265035
      Martin Jambor committed
    • c-lex.c (c_common_has_attribute): Return 201803 instead of 20180312 for no_unique_address. · 46c62690
      	* c-lex.c (c_common_has_attribute): Return 201803 instead of 20180312
      	for no_unique_address.
      
      	* g++.dg/cpp2a/feat-cxx2a.C: New test.
      
      From-SVN: r265034
      Jakub Jelinek committed
    • re PR c++/87547 (G++ reports bad type names for bit-field members) · f7904392
      	PR c++/87547
      	* rtti.c (get_tinfo_decl_dynamic): Use unlowered_expr_type instead
      	of TREE_TYPE.
      
      	* g++.dg/rtti/typeid12.C: New test.
      
      From-SVN: r265033
      Jakub Jelinek committed
    • Daily bump. · 6b0649cb
      From-SVN: r265032
      GCC Administrator committed
  2. 10 Oct, 2018 12 commits
  3. 09 Oct, 2018 20 commits
    • Cleanup of libcpp diagnostic callbacks · c24300ba
      This patch renames the "error" callback within libcpp
      to "diagnostic", and uses the pair of enums in cpplib.h, rather
      than passing two different kinds of "int" around.
      
      gcc/c-family/ChangeLog:
      	* c-common.c (c_option_controlling_cpp_error): Rename to...
      	(c_option_controlling_cpp_diagnostic): ...this, and convert
      	"reason" from int to enum.
      	(c_cpp_error): Rename to...
      	(c_cpp_diagnostic): ...this, converting level and reason to enums.
      	* c-common.h (c_cpp_error): Rename to...
      	(c_cpp_diagnostic): ...this, converting level and reason to enums.
      	* c-opts.c (c_common_init_options): Update for renaming.
      
      gcc/fortran/ChangeLog:
      	* cpp.c (gfc_cpp_init_0): Update for renamings.
      	(cb_cpp_error): Rename to...
      	(cb_cpp_diagnostic): ...this, converting level and reason to
      	enums.
      
      gcc/ChangeLog:
      	* genmatch.c (error_cb): Rename to...
      	(diagnostic_cb): ...this, converting int params to enums.
      	(fatal_at): Update for renaming.
      	(warning_at): Likewise.
      	(main): Likewise.
      	* input.c (selftest::ebcdic_execution_charset::apply):
      	Update for renaming of...
      	(selftest::ebcdic_execution_charset::on_error): ...this, renaming
      	to...
      	(selftest::ebcdic_execution_charset::on_diagnostic): ...this,
      	converting level and reason to enums.
      	(class selftest::lexer_error_sink): Rename to...
      	(class selftest::lexer_test_options): ...this, renaming field
      	"m_errors" to "m_diagnostics".
      	(selftest::lexer_test_options::apply): Update for renaming of...
      	(selftest::lexer_test_options::on_error): ...this, renaming to...
      	(selftest::lexer_test_options::on_diagnostic): ...this
      	converting level and reason to enums.
      	(selftest::test_lexer_string_locations_raw_string_unterminated):
      	Update for renamings.
      	* opth-gen.awk (struct cpp_reason_option_codes_t): Use enum for
      	"reason".
      
      libcpp/ChangeLog:
      	* charset.c (noop_error_cb): Rename to...
      	(noop_diagnostic_cb): ...this, converting params to enums.
      	(cpp_interpret_string_ranges): Update for renaming and enums.
      	* directives.c (check_eol_1): Convert reason to enum.
      	(do_diagnostic): Convert code and reason to enum.
      	(do_error): Use CPP_W_NONE rather than 0.
      	(do_pragma_dependency): Likewise.
      	* errors.c (cpp_diagnostic_at): Convert level and reason to enums.
      	Update for renaming.
      	(cpp_diagnostic): Convert level and reason to enums.
      	(cpp_error): Convert level to enum.
      	(cpp_warning): Convert reason to enums.
      	(cpp_pedwarning): Likewise.
      	(cpp_warning_syshdr): Likewise.
      	(cpp_diagnostic_with_line): Convert level and reason to enums.
      	Update for renaming.
      	(cpp_error_with_line): Convert level to enum.
      	(cpp_warning_with_line): Convert reason to enums.
      	(cpp_pedwarning_with_line): Likewise.
      	(cpp_warning_with_line_syshdr): Likewise.
      	(cpp_error_at): Convert level to enum.
      	(cpp_errno): Likewise.
      	(cpp_errno_filename): Likewise.
      	* include/cpplib.h (enum cpp_diagnostic_level): Name this enum,
      	and move to before struct cpp_callbacks.
      	(enum cpp_warning_reason): Likewise.
      	(cpp_callbacks::diagnostic): Convert params from int to enums.
      	(cpp_error): Convert int param to enum cpp_diagnostic_level.
      	(cpp_warning): Convert int param to enum cpp_warning_reason.
      	(cpp_pedwarning): Likewise.
      	(cpp_warning_syshdr): Likewise.
      	(cpp_errno): Convert int param to enum cpp_diagnostic_level.
      	(cpp_errno_filename): Likewise.
      	(cpp_error_with_line): Likewise.
      	(cpp_warning_with_line): Convert int param to enum
      	cpp_warning_reason.
      	(cpp_pedwarning_with_line): Likewise.
      	(cpp_warning_with_line_syshdr): Likewise.
      	(cpp_error_at): Convert int param to enum cpp_diagnostic_level.
      	* macro.c (create_iso_definition): Convert int to enum.
      	(_cpp_create_definition): Likewise.
      
      From-SVN: r264999
      David Malcolm committed
    • re PR c++/84423 ([concepts] ICE with invalid using declaration) · 5abdb369
      /cp
      2018-10-09  Paolo Carlini  <paolo.carlini@oracle.com>
      
      	PR c++/84423
      	* pt.c (convert_template_argument): Immediately return error_mark_node
      	if the second argument is erroneous.
      	* parser.c (cp_parser_type_id): Add location_t * parameter.
      	(cp_parser_type_id_1): Likewise.
      	(cp_parser_alias_declaration): Adjust cp_parser_type_id call,
      	obtain the location of the type and save it.
      	(cp_parser_template_type_arg): Adjust.
      	(cp_parser_trailing_type_id): Likewise.
      	* decl.c (grokdeclarator): Improve error message for 'auto' in
      	alias declaration.
      
      /testsuite
      2018-10-09  Paolo Carlini  <paolo.carlini@oracle.com>
      
      	PR c++/84423
      	* g++.dg/concepts/pr84423-1.C: New.
      	* g++.dg/concepts/pr84423-2.C: Likewise.
      	* g++.dg/cpp0x/auto39.C: Test location too.
      	* g++.dg/cpp0x/auto9.C: Likewise.
      	* g++.dg/cpp1y/pr60384.C: Likewise.
      
      From-SVN: r264996
      Paolo Carlini committed
    • 2018-10-09 François Dumont <fdumont@gcc.gnu.org> · 2f039722
      	* include/bits/stl_list.h
      	(_List_operator<>::operator==): Replace member function with inline
      	friend.
      	(_List_operator<>::operator!=): Likewise.
      	(_List_const_operator<>::operator==): Likewise.
      	(_List_const_operator<>::operator!=): Likewise.
      	(operator==(const _List_iterator<>&, const _List_const_iterator<>&)):
      	Remove.
      	(operator!=(const _List_iterator<>&, const _List_const_iterator<>&)):
      	Remove.
      
      From-SVN: r264993
      François Dumont committed
    • This is part 2/2 for contributing PPC64LE support for X86 SSE3 instrisics. · 6cb877be
      This is part 2/2 for contributing PPC64LE support for X86 SSE3
      instrisics. This patch includes testsuite/gcc.target tests for the
      intrinsics defined in pmmintrin.h. 
      
      Tested on POWER8 ppc64le and ppc64 (-m64 and -m32, the latter only reporting
      10 new unsupported tests.)
      
      [gcc/testsuite]
      
      2018-10-09  Paul A. Clarke  <pc@us.ibm.com>
      
      	* gcc.target/powerpc/sse3-check.h: New file.
      	* gcc.target/powerpc/sse3-addsubps.c: New file.
      	* gcc.target/powerpc/sse3-addsubpd.c: New file.
      	* gcc.target/powerpc/sse3-haddps.c: New file.
      	* gcc.target/powerpc/sse3-hsubps.c: New file.
      	* gcc.target/powerpc/sse3-haddpd.c: New file.
      	* gcc.target/powerpc/sse3-hsubpd.c: New file.
      	* gcc.target/powerpc/sse3-lddqu.c: New file.
      	* gcc.target/powerpc/sse3-movsldup.c: New file.
      	* gcc.target/powerpc/sse3-movshdup.c: New file.
      	* gcc.target/powerpc/sse3-movddup.c: New file.
      	* gcc.target/powerpc/pr37191.c: New file.
      
      From-SVN: r264992
      Paul A. Clarke committed
    • This is a follow-on to earlier commits for adding compatibility implementations… · 1fb0f892
      This is a follow-on to earlier commits for adding compatibility implementations of x86 intrinsics for PPC64LE.
      
      This is a follow-on to earlier commits for adding compatibility
      implementations of x86 intrinsics for PPC64LE.  This is the first of
      two patches.  This patch adds 11 of the 13 x86 intrinsics from
      <pmmintrin.h> ("SSE3").  (Patch 2/2 adds tests for these intrinsics,
      and briefly describes the tests performed.)
      
      Implementations are relatively straightforward, with occasional
      extra effort for vector element ordering.
      
      Not implemented are _mm_wait and _mm_monitor, as there are no
      direct or trivial analogs in the POWER ISA.
      
      ./gcc/ChangeLog:
      2018-10-05  Paul A. Clarke  <pc@us.ibm.com>
      
      	* config.gcc (powerpc*-*-*): Add pmmintrin.h to extra_headers.
      	* config/rs6000/pmmintrin.h: New file.
      
      From-SVN: r264991
      Paul A. Clarke committed
    • re PR fortran/83522 (ICE on allocatable string reference, string(:)(:)) · af2d2d13
      2018-10-09  Tobias Burnus <burnus@net-b.de>
      
      	PR fortran/83522
      	* resolve.c (resolve_ref): Reject nonscalar
      	substring references.
      
              PR fortran/83522
      	* gfortran.dg/actual_array_substr_1.f90: Add dg-error,
      	change to dg-do compile.
      	* gfortran.dg/actual_array_substr_2.f90: Ditto.
      	* gfortran.dg/array_initializer_1.f90: Use array
      	element not size-one section.
      	* gfortran.dg/array_substring.f90: New.
      
      From-SVN: r264990
      Tobias Burnus committed
    • re PR tree-optimization/86659 (gnat.dg/sso/q[23].adb FAIL) · 6fd8679f
      	PR tree-optimization/86659
      	* gimple-match.h (gimple_match_op constructors): Initialize reverse.
      
      From-SVN: r264986
      Eric Botcazou committed
    • runtime: skip testSetPanicOnFault for gollvm · 91b01194
          
          LLVM doesn't support non-call exception. This test was passing
          more or less by luck: if the faulting instruction is between two
          calls with the same landing pad (in instruction layout order,
          not the program's logic order), it generates a merged PC range
          that covers the faulting instruction. If the instruction layout
          order changes, or it uses two different (but may be degenerate)
          landing pads, this doesn't work.
          
          Reviewed-on: https://go-review.googlesource.com/c/140517
      
      From-SVN: r264985
      Ian Lance Taylor committed
    • [Ada] Fix spurious -Wuninitialized warnings for small records · c743425f
      This change is aimed at getting rid of spurious -Wuninitialized warnings
      issued for small records passed by copy and containing default values
      for some of their components.
      
      The source of the problem is that the _Init parameter of the
      initialization routine is declared as an in/out parameter, so the
      uninitialized object is passed by copy to it and this can be flagged by
      -Wuninitialized.
      
      That's why the mode of the parameter is changed to out, except for the
      cases where information really needs to be passed in: unconstrained
      array types, protected and task types.
      
      For the following record type Rec!
      
       type Rec is record
          B : Boolean := True;
        end record;
      
      the initialization routine must now be:
      
            procedure r__recIP (_init : out r__rec1) is
            begin
               _init.b := true;
               return;
            end r__recIP;
      
      2018-10-09  Eric Botcazou  <ebotcazou@adacore.com>
      
      gcc/ada/
      
      	* exp_ch3.adb (Is_Null_Statement_List): New predicate.
      	(Build_Array_Init_Proc): Use it to find out whether the
      	initialization procedure Is_Null_Init_Proc; if so, set
      	Warnings_Off on the parameter.
      	(Build_Init_Procedure): Likewise.
      	(Init_Formals): Use an in/out first parameter only for
      	unconstrained arrays and for records either containing or built
      	for proteced types or task types; use an out parameter in all
      	the other cases.
      	* fe.h (Is_Init_Proc): Declare.
      	* gcc-interface/decl.c (type_requires_init_of_formal): Do not
      	return true for a discriminant in an unchecked union.
      	(gnat_to_gnu_param): Do not create a PARM_DECL for the Out
      	parameter of an initialization procedure.
      
      From-SVN: r264984
      Eric Botcazou committed
    • [Ada] Fix incorrect computation of Component_Size in ASIS mode · 4b9e1bc7
      2018-10-09  Eric Botcazou  <ebotcazou@adacore.com>
      
      gcc/ada/
      
      	* gcc-interface/decl.c (gnat_to_gnu_entity) <E_Constant>: If
      	this is not a definition, retrieve the expression in all cases
      	even if we are just annotating types.
      	* gcc-interface/trans.c (gnat_to_gnu): Also translate Size
      	attribute for constrained types in this mode.
      
      From-SVN: r264983
      Eric Botcazou committed
    • [Ada] Minor tweaks to suppress warnings · 005f870e
      2018-10-09  Eric Botcazou  <ebotcazou@adacore.com>
      
      gcc/ada/
      
      	* adaint.c (__gnat_get_executable_suffix_ptr): Add new line.
      	(__gnat_locate_exec): Check that HOST_EXECUTABLE_SUFFIX is not
      	empty before doing a string search for it.
      	* socket.c (ATTRIBUTE_UNUSED): Define.
      	(__gnat_disable_sigpipe): Add ATTRIBUTE_UNUSED on parameter.
      	* terminals.c (ATTRIBUTE_UNUSED): Move around.
      	(__gnat_setup_child_communication): Add ATTRIBUTE_UNUSED on
      	parameter.
      	(__gnat_send_header): Add ATTRIBUTE_UNUSED on parameters.
      
      From-SVN: r264982
      Eric Botcazou committed
    • [Ada] Ignore pragmas Compile_Time_Error/Warning in GNATprove mode · ea891b43
      GNATprove does not have sometimes the precise information of the
      compiler about size of types and objects, so that it cannot evaluate the
      expressions in pragma Compile_Time_Error/Warning the same way the
      compiler does.  Thus, these pragmas should be ignored in GNATprove mode,
      as it can neither verify them nor assume them (if the expression cannot
      be evaluated at compile time, then the semantics for GNAT is to ignore
      them).
      
      2018-10-09  Yannick Moy  <moy@adacore.com>
      
      gcc/ada/
      
      	* sem_prag.adb (Process_Compile_Time_Warning_Or_Error): Rewrite
      	pragmas as null statements in GNATprove mode.
      
      From-SVN: r264981
      Yannick Moy committed
    • [Ada] Fix spurious error on derived record passed as Out parameter · e693ddbe
      This fixlet gets rid of a spurious error issued in the specific case of
      a call to a subprogram taking an Out parameter of a discriminated record
      type without default discriminants, if the actual parameter is the
      result of the conversion to the record type of a variable whose type is
      derived from the record and has a representation clause.
      
      The compiler was failing to initialize the temporary made around the
      call because of the representation clause, but this is required for a
      type with discriminants because discriminants may be read by the called
      subprogram.
      
      2018-10-09  Eric Botcazou  <ebotcazou@adacore.com>
      
      gcc/ada/
      
      	* exp_ch6.adb (Add_Call_By_Copy_Code): Initialize the temporary
      	made for an Out parameter if the formal type has discriminants.
      
      gcc/testsuite/
      
      	* gnat.dg/derived_type5.adb, gnat.dg/derived_type5_pkg.ads: New
      	testcase.
      
      From-SVN: r264980
      Eric Botcazou committed
    • [Ada] SPARK: fix bug related to non access object permissions · 38c2f655
      2018-10-09  Maroua Maalej  <maalej@adacore.com>
      
      gcc/ada/
      
      	* sem_spark.adb (Check_Declaration): fix bug related to non
      	access object permissions.
      
      From-SVN: r264979
      Maroua Maalej committed
    • [Ada] Minor copyright header fix · 827845b8
      2018-10-09  Doug Rupp  <rupp@adacore.com>
      
      gcc/ada/
      
      	* libgnat/a-ncelfu.ads: Fix name in header to match package.
      
      From-SVN: r264978
      Doug Rupp committed
    • [Ada] Fix strange warning when using Ada.Iterator_Interface · 865234bf
      The back-end was recently changed to issue more -Wuninitialized warnings
      on Out parameters and this has caught a case related to
      Ada.Iterator_Interface.: This patchlet simply kills this uninteresting
      warning.
      
      2018-10-09  Eric Botcazou  <ebotcazou@adacore.com>
      
      gcc/ada/
      
      	* exp_disp.adb (Make_Disp_Asynchronous_Select_Spec): Set
      	Warnings_Off on the B out parameter.
      
      gcc/testsuite/
      
      	* gnat.dg/warn17.adb: New testcase.
      
      From-SVN: r264977
      Eric Botcazou committed
    • [Ada] Einfo: minor comment fix · fd40a157
      2018-10-09  Eric Botcazou  <ebotcazou@adacore.com>
      
      gcc/ada/
      
      	* einfo.ads: Small comment fix.
      
      From-SVN: r264976
      Eric Botcazou committed
    • [Ada] Internal error on inlined renaming of subprogram instance · 0444d067
      This fixes a recent regression introduced in the compiler for the
      inlined renaming of a subprogram instantiated in a package body.  It was
      wrongly clearing the Is_Public flag on the entity associated with the
      body.
      
      2018-10-09  Eric Botcazou  <ebotcazou@adacore.com>
      
      gcc/ada/
      
      	* sem_ch7.adb (Has_Referencer): Add comment for the
      	N_Freeze_Entity case.  Do not rely on
      	Has_Referencer_Of_Non_Subprograms to clear the Is_Public flag on
      	subprogram entities.
      
      gcc/testsuite/
      
      	* gnat.dg/inline14.adb, gnat.dg/inline14_pkg.adb,
      	gnat.dg/inline14_pkg.ads: New testcase.
      
      From-SVN: r264975
      Eric Botcazou committed
    • [Ada] Unnesting: fix handling of private types that are synchronized · c14bd502
      2018-10-09  Ed Schonberg  <schonberg@adacore.com>
      
      gcc/ada/
      
      	* exp_unst.adb (In_Synchronized_Call): Handle properly private
      	types whose full views are synchronized types, in order to
      	recognize generated subprograms whose bodies must be considered
      	reachable even if no direct calls to them are visible in the
      	source.
      
      From-SVN: r264974
      Ed Schonberg committed
    • [Ada] Fix expansion of operations on nonbinary modular types · 184d0451
      2018-10-09  Ed Schonberg  <schonberg@adacore.com>
      
      gcc/ada/
      
      	* exp_ch4.adb (Expand_Modular_Op): When expanding an operation
      	on nonbinary modular types, convert the opersnds to an integer
      	type that is large enough to hold the modulus of the type, which
      	may be larger than Integer'Last.
      
      From-SVN: r264973
      Ed Schonberg committed