1. 14 Apr, 2020 21 commits
    • xtensa: fix PR target/94584 · a288e202
      Patterns zero_extendhisi2, zero_extendqisi2 and extendhisi2_internal can
      load value from memory, but they don't treat volatile memory correctly.
      Add %v1 before load instructions to emit 'memw' instruction when
      -mserialize-volatile is in effect.
      
      2020-04-14  Max Filippov  <jcmvbkbc@gmail.com>
      gcc/
      	* config/xtensa/xtensa.md (zero_extendhisi2, zero_extendqisi2)
      	(extendhisi2_internal): Add %v1 before the load instructions.
      
      gcc/testsuite/
      	* gcc.target/xtensa/pr94584.c: New test.
      Max Filippov committed
    • Update gcc sv.po. · ae046fa2
      	* sv.po: Update.
      Joseph Myers committed
    • libstdc++: Fix constraints on std::compare_three_way · e1e9e8d7
      My "simplification" of std::compare_three_way's constraints in commit
      f214ffb3 was incorrect, because
      std::three_way_comparable_with imposes additional restrictions beyond
      the <=> expression being valid.
      
      	* libsupc++/compare (compare_three_way): Fix constraint so that
      	BUILTIN-PTR-THREE-WAY does not require three_way_comparable_with.
      	* testsuite/18_support/comparisons/object/builtin-ptr-three-way.cc:
      	New test.
      Jonathan Wakely committed
    • libstdc++: Add comparison operators to std::shared_ptr (PR 94562) · f5fa62ed
      This also implements the proposed resolution to LWG issue 3247, so that
      the ill-formed <=> expression with nullptr is not used.
      
      	PR libstdc++/94562
      	* include/bits/shared_ptr.h (operator<=>): Define for C++20.
      	* include/bits/shared_ptr_base.h (operator<=>): Likewise.
      	* include/bits/unique_ptr.h (operator<=>): Add inline specifier.
      	* testsuite/20_util/shared_ptr/comparison/cmp_c++20.cc: New test.
      	* testsuite/20_util/shared_ptr/comparison/less.cc: Do not expect
      	std::less<A*> to be used when comparing std::shared_ptr<A> objects in
      	C++20.
      Jonathan Wakely committed
    • coroutines: Fix compile error with symmetric transfers [PR94359] · a126a157
      For symmetric transfers to work with C++20 coroutines, it is
      currently necessary to tail call the callee coroutine from resume
      method of the caller coroutine. The current codegen marks these
      resume calls as "MUST_TAIL_CALL" to indicate that the tail call is
      required for correctness.
      
      Unfortunately, several targets have ABI constraints that prevent
      an indirect tail-call, which results in the PRs compile error.
      
      The change here tests the target sibcall hook for the resume
      expression and only marks it as requiring a tail call if that's
      supported.
      
      This doesn't fix the underlying problem; that really a solution is
      needed to allow the tail-calls (or equivalent) to take place - but
      that will be deferred until next stage 1.
      
      gcc/cp/ChangeLog:
      
      2020-04-14  Iain Sandoe  <iain@sandoe.co.uk>
      
      	PR c++/94359
      	* coroutines.cc (build_actor_fn): Check that the target can
      	support the resume tailcall before mandating it.
      
      gcc/testsuite/ChangeLog:
      
      2020-04-14  Iain Sandoe  <iain@sandoe.co.uk>
      
      	PR c++/94359
      	* g++.dg/coroutines/torture/symmetric-transfer-00-basic.C:
      	Expect a run fail for targets without arbitrary indirect
      	tail-calls.
      Iain Sandoe committed
    • Fix for PR/94542, do not make TLS refs PC-relative · aba64538
      For rs6000 target, it is not valid to make PC-relative
      references to TLS symbols. So addr_to_insn_form() needs
      to check if things are TLS before returning PC-rel forms.
      
      2020-04-14  Aaron Sawdey  <acsawdey@linux.ibm.com>
      
      	PR target/94542
      	* config/rs6000/rs6000.c (address_to_insn_form): Do not attempt to
      	use PC-relative addressing for TLS references.
      Aaron Sawdey committed
    • c++: Add testcase for PR c++/93207 · 52d4ed1d
      gcc/testsuite/ChangeLog:
      
      	PR c++/93207
      	* g++.dg/concepts/variadic5.C: New test.
      Patrick Palka committed
    • c++: "'decltype_type' not supported" in diagnostic [PR85278] · 58a29af8
      This fixes a garbled concepts diagnostic by moving the handling of DECLTYPE_TYPE
      from pp_cxx_type_specifier_seq to cxx_pretty_printer::simple_type_specifier, a
      move which also seems to be more consistent with the language grammar.
      
      This patch also fixes pretty printing of rvalue reference types via
      cxx_pretty_printer::type_id, which eventually calls pp_c_pointer which currently
      doesn't distinguish between lvalue and rvalue references.
      
      gcc/c-family/ChangeLog:
      
      	PR c++/85278
      	* c-pretty-print.c (pp_c_pointer) <case REFERENCE_TYPE>: Print a double
      	ampersand if it's an rvalue reference type.
      
      gcc/cp/ChangeLog:
      
      	PR c++/85278
      	* cxx-pretty-print.c (cxx_pretty_printer:simple_type_specifier)
      	<case DECLTYPE_TYPE>: Handle DECLTYPE_TYPE here instead of ...
      	(pp_cxx_type_specifier_seq) <case DECLTYPE_TYPE>: ... here.
      	(cxx_pretty_printer::direct_abstract_declarator) <case DECLTYPE_TYPE>:
      	New no-op case.
      
      gcc/testsuite/ChangeLog:
      
      	PR c++/85278
      	* g++.dg/concepts/diagnostic9.C: New test.
      Patrick Palka committed
    • ipa-sra: Fix treatment of internal functions (PR 94434) · 9707b593
      IPA-SRA can segfault when processing a call to an internal function
      because such calls do not have corresponding call graphs and should be
      treated like memory accesses anyway, which what the patch below does.
      
      The patch makes an attempt to differentiate between reads and writes,
      although for things passed by value it does not make any difference.
      It treats all arguments of functions denoted with internal_store_fn_p
      as written to, even though in practice only some are, but for IPA-SRA
      purposes, actions needed to be taken when processing a read are also
      always performed when analyzing a write, so the code is just slightly
      pessimistic.  But not as pessimistic as bailing out on any internal
      call immediately.
      
      I have LTO bootstrapped and tested the patch on x86_64-linux and
      normally bootstrapped and tested it on aarch64-linux, although one
      which is not SVE capable.  I would appreciate testing on such machine
      too - as well as a small testcase that would follow all relevant
      conventions in gcc.target/aarch64/sve.
      
      2020-04-14  Martin Jambor  <mjambor@suse.cz>
      
      	PR ipa/94434
      	* ipa-sra.c: Include internal-fn.h.
      	(enum isra_scan_context): Update comment.
      	(scan_function): Treat calls to internal_functions like loads or stores.
      Martin Jambor committed
    • c++: Stray RESULT_DECLs in result of constexpr call [PR94034] · b2562229
      When evaluating the initializer of 'a' in the following example
      
        struct A {
          A() = default; A(const A&);
          A *p = this;
        };
        constexpr A foo() { return {}; }
        constexpr A a = foo();
      
      the PLACEHOLDER_EXPR for 'this' in the aggregate initializer returned by foo
      gets resolved to the RESULT_DECL of foo.  But due to guaranteed RVO, the 'this'
      should really be resolved to '&a'.
      
      Fixing this properly by immediately resolving 'this' and PLACEHOLDER_EXPRs to
      the ultimate object under construction would in general mean that we would no
      longer be able to cache constexpr calls for which RVO possibly applies, because
      the result of the call may now depend on the ultimate object under construction.
      
      So as a mostly correct stopgap solution that retains cachability of RVO'd
      constexpr calls, this patch fixes this issue by rewriting all occurrences of the
      RESULT_DECL in the result of a constexpr function call with the current object
      under construction, after the call returns.  This means the 'this' pointer
      during construction of the temporary will still point to the temporary object
      instead of the ultimate object, but besides that this approach seems
      functionally equivalent to the proper approach.
      
      gcc/cp/ChangeLog:
      
      	PR c++/94034
      	* constexpr.c (replace_result_decl_data): New struct.
      	(replace_result_decl_data_r): New function.
      	(replace_result_decl): New function.
      	(cxx_eval_call_expression): Use it.
      	* tree.c (build_aggr_init_expr): Set the location of the AGGR_INIT_EXPR
      	to that of its initializer.
      
      gcc/testsuite/ChangeLog:
      
      	PR c++/94034
      	* g++.dg/cpp0x/constexpr-empty15.C: New test.
      	* g++.dg/cpp1y/constexpr-nsdmi6a.C: New test.
      	* g++.dg/cpp1y/constexpr-nsdmi6b.C: New test.
      	* g++.dg/cpp1y/constexpr-nsdmi7a.C: New test.
      	* g++.dg/cpp1y/constexpr-nsdmi7b.C: New test.
      Patrick Palka committed
    • testsuite: Add testcase for already fixed PR [PR94573] · 66b88011
      2020-04-14  Jakub Jelinek  <jakub@redhat.com>
      
      	PR tree-optimization/94573
      	* gcc.dg/store_merging_30.c: New test.
      Jakub Jelinek committed
    • PR tree-optimization/94574 - aarch64: ICE during GIMPLE pass:ccp · f65cecab
      In this PR the testcase ICEs because a BIT_INSERT_EXPR whose replaced bits are
      not fully inside the container is generated. A size check is added to avoid
      this kind of ICE.
      
      gcc/ChangeLog:
      
      	PR tree-optimization/94574
      	* tree-ssa.c (non_rewritable_lvalue_p): Add size check when analyzing
      	whether a vector-insert is rewritable using a BIT_INSERT_EXPR.
      
      gcc/testsuite/ChangeLog:
      
      	PR tree-optimization/94574
      	* gcc.dg/pr94574.c: New test.
      Yang Yang committed
    • i386: Remove mode size check in ix86_get_ssemov · 438ffa2a
      Even though ix86_hard_regno_mode_ok doesn't allow xmm16-xmm31 nor
      ymm16-ymm31 in 128/256 bit modes when AVX512VL is disabled, LRA can
      still generate reg to reg moves with xmm16-xmm31 and ymm16-ymm31 in
      128/256 bit modes.  Remove mode size check in ix86_get_ssemov.
      
      gcc/
      
      	PR target/94561
      	* config/i386/i386.c (ix86_get_ssemov): Remove mode size check.
      
      gcc/testsuite/
      
      	PR target/94561
      	* gcc.target/i386/pr94561.c: New test.
      H.J. Lu committed
    • Add myself as callgraph (IPA) reviewer · efd5bd4d
      2020-04-14  Martin Jambor  <mjambor@suse.cz>
      
      	* MAINTAINERS (Reviewers): Add myself as callgraph (IPA) reviewer.
      Martin Jambor committed
    • [Fortran] Fix name conflict check for use-assoc (PR 92736) · 36c3edb1
      	* module.c (gfc_match_use): Fix name-conflict check for use-associating
      	the same symbol again in a submodule.
      
      	* gfortran.dg/use_rename_10.f90: New.
      	* gfortran.dg/use_rename_11.f90: New.
      Tobias Burnus committed
    • Fix PR 94270 by not warning about artifical dummy arguments. · 3b0e49a5
      2020-04-14  Thomas Koenig  <tkoenig@gcc.gnu.org>
      
      	PR fortran/94270
      	* interface.c (gfc_get_formal_from_actual_arglist): Always
      	set artificial attribute for symbols.
      	* trans-decl.c (generate_local_decl): Do not warn if the
      	symbol is artifical.
      
      2020-04-14  Thomas Koenig  <tkoenig@gcc.gnu.org>
      
      	PR fortran/94270
      	* gfortran.dg/warn_unused_dummy_argument_6.f90: New test.
      Thomas König committed
    • Add me as callgraph (IPA) reviewer. · a1ff717f
      ChangeLog:
      
      2020-04-14  Martin Liska  <mliska@suse.cz>
      
      	* MAINTAINERS: Add me as callgraph (IPA) reviewer.
      Martin Liska committed
    • libstdc++: Make comparison category comparisons noexcept (PR 94565) · 597601aa
      	PR libstdc++/94565
      	* libsupc++/compare (__unspec): Add noexcept-specifier to constructor.
      	* testsuite/18_support/comparisons/categories/94565.cc: New test.
      Jonathan Wakely committed
    • c++: Improve redeclared parameter name diagnostic [PR94588] · 7eee265e
      While reviewing [basic.scope.param] I noticed we don't show the location
      of the previous declaration when giving an error about "A parameter name
      shall not be redeclared in the outermost block of the function definition".
      
      	PR c++/94588
      	* name-lookup.c (check_local_shadow): Add an inform call.
      
      	* g++.dg/diagnostic/redeclaration-1.C: Add dg-message.
      Marek Polacek committed
    • Daily bump. · e020d2bb
      GCC Administrator committed
  2. 13 Apr, 2020 16 commits
    • Update and correct documentation of -Wall and -Wrestrict. · d28e5b14
      gcc/ChangeLog:
      	* doc/extend.texi (-Wall): Mention -Wformat-overflow and
      	-Wformat-truncation.  Move -Wzero-length-bounds last.
      	(-Wrestrict): Document positive form of option enabled by -Wall.
      Martin Sebor committed
    • PR c/92326 - wrong bound in zero-length array diagnostics · 09f04139
      gcc/c-family/ChangeLog:
      
      	PR c/92326
      	* c-pretty-print.c (c_pretty_printer::direct_abstract_declarator): Avoid
      	printing array bound for flexible array members.
      
      gcc/testsuite/ChangeLog:
      
      	PR c/92326
      	* c-c++-common/Warray-bounds-8.c: New test.
      	* gcc.dg/Warray-bounds-46.c: Adjust expected format of flexible array
      	memebrs in diagnostics.
      	* gcc.dg/Warray-bounds-49.c: Same.
      Martin Sebor committed
    • c++: Infinite diagnostic loop with decltype([]{}) [PR94521] · 1dcb7799
      We are hitting a recursive loop when printing the signature of a function
      containing a decltype([]{}) type.  The loop is
      
        dump_function_decl -> dump_substitution
      		     -> dump_template_bindings
      		     -> dump_type
      		     -> dump_aggr_type
      		     -> dump_scope -> dump_function_decl
      
      and we loop because dump_template_bindings wants to print the resolved type of
      decltype([]{}) (i.e. just a lambda type), so it calls dump_aggr_type, which
      wants to print the function scope of the lambda type.  But the function scope of
      the lambda type is the function which we're in the middle of printing.
      
      This patch breaks the loop by passing TFF_NO_FUNCTION_ARGUMENTS to
      dump_function_decl from dump_scope, so that we avoid recursing into
      dump_substitution and ultimately looping.
      
      This also means we no longer emit the "[with ...]" clause when printing a
      function template scope, and we instead just emit its template argument list in
      a more natural way, e.g. instead of
          foo(int, char) [with T=bool]::x
      we would now print
          foo<bool>::x
      which seems like an improvement on its own.
      
      The full signature of the function 'spam' in the below testcase is now
        void spam(decltype (<lambda>)*) [with T = int; decltype (<lambda>) = spam<int>::<lambda()>]
      
      gcc/cp/ChangeLog:
      
      	PR c++/94521
      	* error.c (dump_scope): Pass TFF_NO_FUNCTION_ARGUMENTS to
      	dump_function_decl when printing a function template instantiation as a
      	scope.
      
      gcc/testsuite/ChangeLog:
      
      	PR c++/94521
      	* g++.dg/cpp2a/lambda-uneval12.C: New test.
      Patrick Palka committed
    • c++: More self-modifying constexpr init [PR94470] · 077dd9b3
      In this PR we're incorrectly rejecting a self-modifying constexpr initializer as
      a consequence of the fix for PR78572.
      
      It looks like however that the fix for PR78572 is obsoleted by the fix for
      PR89336: the testcase from the former PR successfully compiles even with its fix
      reverted.
      
      But then further testing showed that the analogous testcase of PR78572 where the
      array has an aggregate element type is still problematic (i.e. we ICE) even with
      the fix for PR78572 applied.  The reason is that in cxx_eval_bare_aggregate we
      attach a constructor_elt of aggregate type always to the end of the new
      CONSTRUCTOR, but that's not necessarily correct if the CONSTRUCTOR is
      self-modifying.  We should instead be using get_or_insert_ctor_field to insert
      the constructor_elt in the right place.
      
      So this patch reverts the PR78572 fix and makes the appropriate changes to
      cxx_eval_bare_aggregate.  This fixes PR94470, and we now are also able to fully
      reduce the initializers of 'arr' and 'arr2' in the new test array57.C to
      constant initializers.
      
      gcc/cp/ChangeLog:
      
      	PR c++/94470
      	* constexpr.c (get_or_insert_ctor_field): Set default value of parameter
      	'pos_hint' to -1.
      	(cxx_eval_bare_aggregate): Use get_or_insert_ctor_field instead of
      	assuming the the next index belongs at the end of the new CONSTRUCTOR.
      	(cxx_eval_store_expression): Revert PR c++/78572 fix.
      
      gcc/testsuite/ChangeLog:
      
      	PR c++/94470
      	* g++.dg/cpp1y/constexpr-nsdmi8.C: New test.
      	* g++.dg/cpp1y/constexpr-nsdmi9.C: New test.
      	* g++.dg/init/array57.C: New test.
      Patrick Palka committed
    • coroutines: Rename the coroutines cpp builtin. · ee26baf4
      The current standard draft (n4861) amends the cpp builtin for
      coroutines to '__cpp_impl_coroutine', no other change.
      
      gcc/c-family/ChangeLog:
      
      2020-04-13  Iain Sandoe  <iain@sandoe.co.uk>
      
      	* c-cppbuiltin.c (c_cpp_builtins): Update coroutines builtin
      	define, per n4861.
      
      gcc/testsuite/ChangeLog:
      
      2020-04-13  Iain Sandoe  <iain@sandoe.co.uk>
      
      	* g++.dg/coroutines/coro-pre-proc.C: Update coroutines builtin
      	define, per n4861.
      	* g++.dg/coroutines/coro.h: Likewise.
      
      libstdc++-v3/ChangeLog:
      
      2020-04-13  Iain Sandoe  <iain@sandoe.co.uk>
      
      	* include/std/coroutine: Update coroutines builtin define,
      	per n4861.
      Iain Sandoe committed
    • Minor documentation fix · 2dd4ceac
      	* doc/extend.texi: Add realloc to list of built-in functions
      	are recognized by the compiler.
      Zackery Spytz committed
    • Darwin, testsuite: Fix darwin-version-1.c fails with XCode 11.4. · f8e72b8d
      From XCode 11.4 on 10.14/15 use of 10.6 and 10.7 is deprecated.
      The tools issue diagnostics if -mmacosx-version-min= < 10.8
      
      Adjust the testcase to avoid that usage on 10.14, 10.15 for now.
      
      gcc/testsuite/ChangeLog:
      
      2020-04-13  Iain Sandoe  <iain@sandoe.co.uk>
      
      	* gcc.dg/darwin-version-1.c: Use -mmacosx-version-min= 10.8
      	for system versions 10.14 and 10.15.
      Iain Sandoe committed
    • Commit test case for PR 87644, which has fixed itself somehow. · ec72bb0c
      2020-04-13  Thomas Koenig  <tkoenig@gcc.gnu.org>
      
      	PR fortran/87644
      	* gfortran.dg/variable_parameter.f90: New test.
      Thomas König committed
    • ICE on wrong code [PR94192]. · efbf7392
      The idea is not have another resolution of a pointer if an error has
      occurred previously.
      
      2020-04-13  Linus Koenig <link@sig-st.de>
      
      	PR fortran/94192
      	* resolve.c (resolve_fl_var_and_proc): Set flag "error" to 1 if
      	pointer is found to not have an assumed rank or a deferred shape.
      	* simplify.c (simplify_bound): If an error has been issued for a
      	given pointer, one should not attempt to find its bounds.
      
      2020-04-13  Linus Koenig <link@sig-st.de>
      
      	PR fortran/94192
      	* gfortran.dg/bound_resolve_after_error_1.f90: New test.
      Linus Koenig committed
    • c++: lambdas with internal linkage are different to no-linkage [PR94426] · 8d213cbb
      My fix for 94147 was confusing no-linkage with internal linkage, at
      the language level.  That's wrong. (the std is confusing here, because
      it describes linkage of names (which is wrong), and lambdas have no
      names)
      
      Lambdas with extra-scope, have linkage.  However, at the
      implementation-level that linkage is at least as restricted as the
      linkage of the extra-scope decl.
      
      Further, when instantiating a variable initialized by a lambda, we
      must determine the visibility of the variable itself, before
      instantiating its initializer.  If the template arguments are internal
      (or no-linkage), the variable will have internal linkage, regardless
      of the linkage of the template it is instantiated from.  We need to
      know that before instantiating the lambda, so we can restrict its
      linkage correctly.
      
      	* decl2.c (determine_visibility): A lambda's visibility is
      	affected by its extra scope.
      	* pt.c (instantiate_decl): Determine var's visibility before
      	instantiating its initializer.
      	* tree.c (no_linkage_check): Revert code looking at visibility of
      	lambda's extra scope.
      `	gcc/cp/
      	* g++.dg/cpp0x/lambda/pr94426-[12].C: New.
      	* g++.dg/abi/lambda-vis.C: Drop a warning.
      	* g++.dg/cpp0x/lambda/lambda-mangle.C: Lambda visibility on
      	variable changes.
      	* g++.dg/opt/dump1.C: Drop warnings of no import.
      Nathan Sidwell committed
    • x86: Restore the frame pointer in word_mode · efc1f357
      We must restore the frame pointer in word_mode for eh_return epilogues
      since the upper 32 bits of RBP register can have any values.
      
      Tested on Linux/x32 and Linux/x86-64.
      
      	PR target/94556
      	* config/i386/i386.c (ix86_expand_epilogue): Restore the frame
      	pointer in word_mode for eh_return epilogues.
      H.J. Lu committed
    • MSP430: Dont add offsets to addresses when emitting asm for post_inc · 04637536
      Some insns, which operate on SImode operands, output assembler template
      that comprise of multiple instructions using HImode operands. To access
      the high word of an SImode operand, an operand selector '%H' is used to
      offset the operand value by a constant amount.
      
      When one of these HImode operands is a memory reference to a post_inc,
      the address does not need to be offset, since the preceding instruction
      has already offset the address to the correct value.
      
      This fixes an ICE in change_address_1, at emit-rtl.c:2318 for
      gcc.c-torture/execute/pr20527-1.c in the "-mlarge -O2 -flto
      -fuse-linker-plugin -fno-fat-lto-objects" configuration.
      
      This test generated the following insn, and the attempt to output the
      high part of the post_inc address caused the ICE.
      (set (reg:SI 6 R6)
           (minus:SI (reg:SI 6 R6)
                     (mem:SI (post_inc:PSI (reg:PSI 10 R10)) {subsi3}
      
      gcc/ChangeLog:
      
      2020-04-13  Jozef Lawrynowicz  <jozef.l@mittosystems.com>
      
      	* config/msp430/msp430.c (msp430_print_operand): Don't add offsets to
      	memory references in %B, %C and %D operand selectors when the inner
      	operand is a post increment address.
      Jozef Lawrynowicz committed
    • MSP430: Fix memory offsets used by %C and %D asm output operand modifiers · 14f27ee6
      The %C and %D operand modifiers are supposed to access the 3rd and 4th
      words of a 64-bit value, so for memory references they need to offset
      the given address by 4 and 6 bytes respectively.
      
      gcc/ChangeLog:
      
      2020-04-13  Jozef Lawrynowicz  <jozef.l@mittosystems.com>
      
      	* config/msp430/msp430.c (msp430_print_operand): Offset a %C memory
      	reference by 4 bytes, and %D memory reference by 6 bytes.
      
      gcc/testsuite/ChangeLog:
      
      2020-04-13  Jozef Lawrynowicz  <jozef.l@mittosystems.com>
      
      	* gcc.target/msp430/operand-modifiers.c: New test.
      Jozef Lawrynowicz committed
    • d: Merge update dmd 799066f49 · a1ccbae6
      Removes the implementation of __traits(argTypes), which only supported
      x86_64 targets.  The only use of this trait is an unused va_arg()
      function, this has been removed as well.
      
      Reviewed-on: https://github.com/dlang/dmd/pull/11022
      
      gcc/d/ChangeLog:
      
      2020-04-13  Iain Buclaw  <ibuclaw@gdcproject.org>
      
      	* Make-lang.in (D_FRONTEND_OBJS): Remove d/argtypes.o.
      	* d-target.cc (Target::toArgTypes): New function.
      
      libphobos/ChangeLog:
      
      2020-04-13  Iain Buclaw  <ibuclaw@gdcproject.org>
      
      	* libdruntime/core/stdc/stdarg.d: Remove run-time va_list template.
      Iain Buclaw committed
    • Rename 'libgomp.oacc-c-c++-common/static-dynamic-lifetimes-*' to… · af4c9257
      Rename 'libgomp.oacc-c-c++-common/static-dynamic-lifetimes-*' to 'libgomp.oacc-c-c++-common/structured-dynamic-lifetimes-*' [PR92843]
      
      Fix-up for commit be9862dd "Test cases for
      mixed structured/dynamic data lifetimes with OpenACC [PR92843]": it's
      "structured", not "static" data lifetimes/reference counters.
      
      	libgomp/
      	PR libgomp/92843
      	* testsuite/libgomp.oacc-c-c++-common/static-dynamic-lifetimes-1-lib.c:
      	Rename to...
      	* testsuite/libgomp.oacc-c-c++-common/structured-dynamic-lifetimes-1-lib.c:
      	... this.
      	* testsuite/libgomp.oacc-c-c++-common/static-dynamic-lifetimes-1.c:
      	Rename to...
      	* testsuite/libgomp.oacc-c-c++-common/structured-dynamic-lifetimes-1.c:
      	... this.
      	* testsuite/libgomp.oacc-c-c++-common/static-dynamic-lifetimes-2-lib.c:
      	Rename to...
      	* testsuite/libgomp.oacc-c-c++-common/structured-dynamic-lifetimes-2-lib.c:
      	... this.
      	* testsuite/libgomp.oacc-c-c++-common/static-dynamic-lifetimes-2.c:
      	Rename to...
      	* testsuite/libgomp.oacc-c-c++-common/structured-dynamic-lifetimes-2.c:
      	... this.
      	* testsuite/libgomp.oacc-c-c++-common/static-dynamic-lifetimes-3-lib.c:
      	Rename to...
      	* testsuite/libgomp.oacc-c-c++-common/structured-dynamic-lifetimes-3-lib.c:
      	... this.
      	* testsuite/libgomp.oacc-c-c++-common/static-dynamic-lifetimes-3.c:
      	Rename to...
      	* testsuite/libgomp.oacc-c-c++-common/structured-dynamic-lifetimes-3.c:
      	... this.
      	* testsuite/libgomp.oacc-c-c++-common/static-dynamic-lifetimes-4-lib.c:
      	Rename to...
      	* testsuite/libgomp.oacc-c-c++-common/structured-dynamic-lifetimes-4-lib.c:
      	... this.
      	* testsuite/libgomp.oacc-c-c++-common/static-dynamic-lifetimes-4.c:
      	Rename to...
      	* testsuite/libgomp.oacc-c-c++-common/structured-dynamic-lifetimes-4.c:
      	... this.
      	* testsuite/libgomp.oacc-c-c++-common/static-dynamic-lifetimes-5-lib.c:
      	Rename to...
      	* testsuite/libgomp.oacc-c-c++-common/structured-dynamic-lifetimes-5-lib.c:
      	... this.
      	* testsuite/libgomp.oacc-c-c++-common/static-dynamic-lifetimes-5.c:
      	Rename to...
      	* testsuite/libgomp.oacc-c-c++-common/structured-dynamic-lifetimes-5.c:
      	... this.
      	* testsuite/libgomp.oacc-c-c++-common/static-dynamic-lifetimes-6-lib.c:
      	Rename to...
      	* testsuite/libgomp.oacc-c-c++-common/structured-dynamic-lifetimes-6-lib.c:
      	... this.
      	* testsuite/libgomp.oacc-c-c++-common/static-dynamic-lifetimes-6.c:
      	Rename to...
      	* testsuite/libgomp.oacc-c-c++-common/structured-dynamic-lifetimes-6.c:
      	... this.
      	* testsuite/libgomp.oacc-c-c++-common/static-dynamic-lifetimes-7-lib.c:
      	Rename to...
      	* testsuite/libgomp.oacc-c-c++-common/structured-dynamic-lifetimes-7-lib.c:
      	... this.
      	* testsuite/libgomp.oacc-c-c++-common/static-dynamic-lifetimes-7.c:
      	Rename to...
      	* testsuite/libgomp.oacc-c-c++-common/structured-dynamic-lifetimes-7.c:
      	... this.
      	* testsuite/libgomp.oacc-c-c++-common/static-dynamic-lifetimes-8-lib.c:
      	Rename to...
      	* testsuite/libgomp.oacc-c-c++-common/structured-dynamic-lifetimes-8-lib.c:
      	... this.
      	* testsuite/libgomp.oacc-c-c++-common/static-dynamic-lifetimes-8.c::
      	Rename to...
      	* testsuite/libgomp.oacc-c-c++-common/structured-dynamic-lifetimes-8.c:
      	... this.
      Thomas Schwinge committed
    • Daily bump. · bf4b1301
      GCC Administrator committed
  3. 12 Apr, 2020 3 commits
    • Added a test case from a PR that was fixed by something else. · 87be4cec
      2020-04-12  Thomas Koenig  <tkoenig@gcc.gnu.org>
      
      	PR fortran/94091
      	* gfortran.dg/char_length_22.f90: New test.
      
      Committed ChangeLog entry.
      Thomas König committed
    • Darwin, testsuite: Adjust indirect thunk tests for default flags. · ce6437aa
      Darwin mandates an indirection for variables in the commmon
      section.  Since the change to -fno-common, variables in some
      of the thunk tests are now in the .data section where they
      may be accessed directly.  Remove the indirections from the
      scan-assembler matches.
      
      gcc/testsuite/ChangeLog:
      
      2020-04-12  Iain Sandoe  <iain@sandoe.co.uk>
      
      	* gcc.target/i386/indirect-thunk-1.c: Adjust for fno-common
      	change, removing indirections for vars in .data.
      	* gcc.target/i386/indirect-thunk-2.c: Likewise.
      	* gcc.target/i386/indirect-thunk-3.c: Likewise.
      	* gcc.target/i386/indirect-thunk-4.c: Likewise.
      	* gcc.target/i386/indirect-thunk-attr-1.c: Likewise.
      	* gcc.target/i386/indirect-thunk-attr-2.c: Likewise.
      	* gcc.target/i386/indirect-thunk-attr-3.c: Likewise.
      	* gcc.target/i386/indirect-thunk-attr-4.c: Likewise.
      	* gcc.target/i386/indirect-thunk-attr-5.c: Likewise.
      	* gcc.target/i386/indirect-thunk-attr-6.c: Likewise.
      	* gcc.target/i386/indirect-thunk-extern-1.c: Likewise.
      	* gcc.target/i386/indirect-thunk-extern-2.c: Likewise.
      	* gcc.target/i386/indirect-thunk-extern-3.c: Likewise.
      	* gcc.target/i386/indirect-thunk-extern-4.c: Likewise.
      	* gcc.target/i386/indirect-thunk-inline-1.c: Likewise.
      	* gcc.target/i386/indirect-thunk-inline-2.c: Likewise.
      	* gcc.target/i386/indirect-thunk-inline-3.c: Likewise.
      	* gcc.target/i386/indirect-thunk-inline-4.c: Likewise.
      Iain Sandoe committed
    • Daily bump. · ae6fc5ce
      GCC Administrator committed