1. 09 Nov, 2017 13 commits
    • [multiple changes] · 3ec54569
      2017-11-09  Pascal Obry  <obry@adacore.com>
      
      	* libgnarl/s-taprop__mingw.adb: On Windows, initialize the thead handle
      	only for foreign threads.  We initialize the thread handle only if not
      	yet initialized. This happens in Enter_Task for foreign threads only.
      	But for native threads (Ada tasking) we do want to keep the real
      	handle (from Create_Task) to be able to free the corresponding
      	resources in Finalize_TCB (CloseHandle).
      
      2017-11-09  Yannick Moy  <moy@adacore.com>
      
      	* sem_attr.adb (Analyze_Attribute): Default initialize P_Type,
      	P_Base_Type.
      	(Error_Attr_P): Fix name in pragma No_Return.
      	(Unexpected_Argument): Add pragma No_Return.
      	(Placement_Error): Add pragma No_Return.
      
      2017-11-09  Javier Miranda  <miranda@adacore.com>
      
      	* exp_disp.adb (Elab_Flag_Needed): Elaboration flag not needed when the
      	dispatch table is statically built.
      	(Make_DT): Declare constant the Interface_Table object associated with
      	an statically built dispatch table. For this purpose the Offset_To_Top
      	value of each interface is computed using the dummy object.
      	* exp_ch3.adb (Build_Init_Procedure): Do not generate code initializing
      	the Offset_To_Top field of secondary dispatch tables when the dispatch
      	table is statically built.
      	(Initialize_Tag): Do not generate calls to Register_Interface_Offset
      	when the dispatch table is statically built.
      	* doc/gnat_rm/standard_and_implementation_defined_restrictions.rst:
      	Document the new GNAT restriction Static_Dispatch_Tables.
      	* gnat_rm.texi: Regenerate.
      
      2017-11-09  Hristian Kirtchev  <kirtchev@adacore.com>
      
      	* sem_aggr.adb (Resolve_Delta_Record_Aggregate): Reorder declarations
      	to avoid a dormant bug.
      
      2017-11-09  Jerome Lambourg  <lambourg@adacore.com>
      
      	* init.c: Define missing __gnat_alternate_stack for QNX. Set it to 0,
      	as such capability is not available on the OS.
      	* link.c: Make sure linker options for QNX are correct.
      	* libgnarl/s-osinte__qnx.ads: Add some missing bindings to pthread.
      	* libgnarl/s-taprop__qnx.adb: New, derived from s-taprop__posix.adb. This brings
      	in particular a workaround with locks priority ceiling where a higher
      	priority task is allowed to lock a lower ceiling priority lock. This
      	also fixes the scheduling of FIFO tasks when the priority of a task is
      	lowered.
      	* libgnat/system-qnx-aarch64.ads: Fix priority ranges.
      
      2017-11-09  Yannick Moy  <moy@adacore.com>
      
      	* erroutc.adb (Output_Error_Msgs): Justify CodePeer false positive
      	message.
      	* gnatbind.adb (Scan_Bind_Arg): Simplify test to remove always true
      	condition.
      	* namet.adb (Copy_One_Character): Add assumption for static analysis,
      	as knowledge that Hex(2) is in the range 0..255 is too complex for
      	CodePeer.
      	(Finalize): Add assumption for static analysis, as the fact that there
      	are symbols in the table depends on a global invariant at this point in
      	the program.
      	* set_targ.adb (Check_Spaces): Justify CodePeer false positive message.
      	* stylesw.adb (Save_Style_Check_Options): Rewrite to avoid test always
      	true.
      
      From-SVN: r254573
      Pierre-Marie de Rodat committed
    • [multiple changes] · 6214b83b
      2017-11-09  Javier Miranda  <miranda@adacore.com>
      
      	* libgnat/s-rident.ads (Static_Dispatch_Tables): New restriction name.
      	* exp_disp.adb (Building_Static_DT): Check restriction.
      	(Building_Static_Secondary_DT): Check restriction.
      	(Make_DT): Initialize the HT_Link to No_Tag.
      	* opt.ads (Static_Dispatch_Tables): Rename flag...
      	(Building_Static_Dispatch_Tables): ... into this.  This will avoid
      	conflict with the restriction name.
      	* gnat1drv.adb: Update.
      	* exp_aggr.adb (Is_Static_Dispatch_Table_Aggregate): Update.
      	* exp_ch3.adb (Expand_N_Object_Declaration): Update.
      
      2017-11-09  Pascal Obry  <obry@adacore.com>
      
      	* libgnarl/s-taprop__mingw.adb: Minor code clean-up.  Better using a
      	named number.
      
      From-SVN: r254572
      Pierre-Marie de Rodat committed
    • exp_ch3.adb, [...]: Minor reformatting. · d63199d8
      gcc/ada/
      
      2017-11-09  Ed Schonberg  <schonberg@adacore.com>
      
      	* exp_ch3.adb, gnat1drv.adb, namet.adb, namet.ads, sem_aggr.adb,
      	sem_ch2.adb, sem_ch4.adb: Minor reformatting.
      	* sem_res.adb (Resolve_Entity_Name): Suppress spurious error on read of
      	out parameter when in Ada_83 mode, the oarameter is of a composite
      	type, and it appears as the prefix of an attribute.
      
      2017-11-09  Bob Duff  <duff@adacore.com>
      
      	* sinfo.ads: Minor comment fix.
      
      2017-11-09  Hristian Kirtchev  <kirtchev@adacore.com>
      
      	* sem_prag.ads: Add pragmas Unmodified and Unreferenced to table
      	Pragma_Significant_In_SPARK.
      
      gcc/testsuite/
      
      2017-11-09  Hristian Kirtchev  <kirtchev@adacore.com>
      
      	* gnat.dg/unreferenced.adb: New testcase.
      
      2017-11-09  Ed Schonberg  <schonberg@adacore.com>
      
      	* gnat.dg/out_param.adb: New testcase.
      
      From-SVN: r254571
      Pierre-Marie de Rodat committed
    • [multiple changes] · dcd5fd67
      2017-11-09  Yannick Moy  <moy@adacore.com>
      
      	* binde.adb (Diagnose_Elaboration_Problem): Mark procedure No_Return.
      	* checks.adb (Apply_Scalar_Range_Check): Rescope variable OK closer to
      	use.  Default initialize Hi, Lo.
      	(Selected_Range_Checks): Retype Num_Checks more precisely.
      	(Determine_Range, Determine_Range_R): Default initialize Hi_Right,
      	Lo_Right.
      	* contracts.adb (Process_Contract_Cases): Mark parameter Stmts as
      	Unmodified.
      	(Process_Postconditions): Mark parameter Stmts as Unmodified.
      	* exp_attr.adb (Expand_Loop_Entry_Attribute): Default initialize Blk.
      	* exp_ch4.adb (Expand_N_Allocator): Default initialize Typ.
      	(Expand_Concatenate): Default initialize High_Bound.
      	(Optimize_Length_Comparison): Default initialize Ent, Index.
      	* exp_ch5.adb (Expand_Predicated_Loop): Default initialize L_Hi and
      	L_Lo.
      	* exp_ch6.adb (Expand_N_Extended_Return_Statement): Default initialize
      	Return_Stmt.
      	* exp_ch9.adb (Expand_Entry_Barrier): Default initialize Func_Body and
      	remove pragma Warnings(Off).
      	* exp_imgv.adb (Expand_Image_Attribute): Default initialize Tent.
      	* exp_util.adb (Find_Interface_Tag): Default initialize AI_Tag.
      	* freeze.adb (Check_Component_Storage_Order): Default initialize
      	Comp_Byte_Aligned rather than silencing messages with pragma
      	Warnings(Off), which does not work for CodePeer initialization
      	messages, and given that here the possible read of an unitialized value
      	depends on a proper use of parameters by the caller.
      	* inline.adb (Expand_Inlined_Call): Default initialize Lab_Decl, Targ.
      	* sem_ch12.adb (Build_Operator_Wrapper): Default initialize Expr.
      	* sem_ch3.adb (Build_Derived_Array_Type): Default initialize
      	Implicit_Base.
      	* sem_ch4.adb (List_Operand_Interps): Default initialize Nam and remove
      	pragma Warnings(Off).
      	(Analyze_Case_Expression): Rescope checking block within branch where
      	Others_Present is set by the call to Check_Choices.
      	* sem_ch5.adb (Analyze_Assignment): Default initialize
      	Save_Full_Analysis.
      	* sem_ch6.adb (Analyze_Function_Return): Default initialize Obj_Decl,
      	and restructure code to defend against previous errors, so that, in
      	that case, control does not flow to the elsif condition which read an
      	uninitialized Obj_Decl.
      	* sem_ch9.adb (Analyze_Requeue): Default initialize Synch_Type.
      	(Check_Interfaces): Default initialize Full_T_Ifaces and Priv_T_Ifaces,
      	which seem to be left uninitialized and possibly read in some cases.
      	* sem_dim.adb (Analyze_Aspect_Dimension_System): Retype Position more
      	precisely.  This requires to exchange the test for exiting in case of
      	too many positions and the increment to Position, inside the loop.
      	* sem_eval.adb (Eval_Concatenation): Default initialize Folded_Val,
      	which cannot be read uninitialized, but the reasons for that are quite
      	subtle.
      	* sem_intr.adb (Check_Intrinsic_Call): Default initialize Rtyp.
      	* sem_prag.adb (Collect_Subprogram_Inputs_Outputs): Default initialize
      	Spec_Id.
      	* sem_res.adb (Make_Call_Into_Operator): Default initialize Opnd_Type,
      	and test for presence of non-null Opnd_Type before testing its scope,
      	in a test which would read its value uninitialized, and is very rarely
      	exercized (it depends on the presence of an extension of System).
      	* sem_spark.ads: Update comment to fix name of main analysis procedure.
      	* sem_warn.adb (Warn_On_Known_Condition): Default initialize
      	Test_Result.
      	* set_targ.adb (FailN): Mark procedure with No_Return.
      	* stylesw.adb (Save_Style_Check_Options): Delete useless code to
      	initialize all array Options to white space, as there is already code
      	doing the same for the remaining positions in Options at the end of the
      	procedure.
      
      2017-11-09  Eric Botcazou  <ebotcazou@adacore.com>
      
      	* exp_ch11.adb (Possible_Local_Raise): Do not issue the warning for
      	generic instantiations either.
      
      From-SVN: r254570
      Pierre-Marie de Rodat committed
    • [multiple changes] · c312b9f2
      2017-11-09  Piotr Trojanek  <trojanek@adacore.com>
      
      	* sem_prag.adb (Analyze_Part_Of): Reword error message.
      	(Get_SPARK_Mode_Type): Do not raise Program_Error in case pragma
      	SPARK_Mode appears with an illegal mode, treat this as a non-existent
      	mode.
      
      2017-11-09  Ed Schonberg  <schonberg@adacore.com>
      
      	* sem_ch4.adb (Analyze_Call): Reject a call to a function that returns
      	a limited view of a type T declared in unit U1, when the function is
      	declared in another unit U2 and the call appears in a procedure within
      	another unit.
      
      2017-11-09  Justin Squirek  <squirek@adacore.com>
      
      	* sem_ch8.adb (Analyze_Use_Package): Force installation of use_clauses
      	when processing generic instances.
      
      2017-11-09  Bob Duff  <duff@adacore.com>
      
      	* namet.ads, namet.adb (Valid_Name_Id): New subtype that excludes
      	Error_Name and No_Name.  Use this (versus Name_Id) to indicate which
      	objects can have those special values. Valid_Name_Id could usefully be
      	used all over the compiler front end, but that's too much trouble for
      	now. If we did that, we might want to rename:
      	Name_Id --> Optional_Name_Id, Valid_Name_Id --> Name_Id.
      	For parameters of type Valid_Name_Id, remove some redundant tests,
      	including the ones found by CodePeer.  Use Is_Valid_Name instead of
      	membership test when appropriate.
      	(Error_Name_Or_No_Name): Delete this; it's no longer needed.
      	* sem_ch2.adb (Analyze_Identifier): Use "not Is_Valid_Name" instead of
      	"in Error_Name_Or_No_Name".
      	(Check_Parameterless_Call): Use "not Is_Valid_Name" instead of "in
      	Error_Name_Or_No_Name".
      
      From-SVN: r254569
      Pierre-Marie de Rodat committed
    • gnat1drv.adb (Adjust_Global_Switches): Suppress warnings in codepeer mode here… · c23f55b4
      gnat1drv.adb (Adjust_Global_Switches): Suppress warnings in codepeer mode here unless -gnateC is specified.
      
      gcc/ada/
      
      2017-11-09  Arnaud Charlet  <charlet@adacore.com>
      
      	* gnat1drv.adb (Adjust_Global_Switches): Suppress warnings in codepeer
      	mode here unless -gnateC is specified.
      	* switch-c.adb (Scan_Front_End_Switches): Do not suppress warnings with
      	-gnatC here.
      
      2017-11-09  Piotr Trojanek  <trojanek@adacore.com>
      
      	* lib-writ.adb (Write_ALI): Remove processing of the frontend xrefs as
      	part of the ALI writing; they are now processed directly from memory
      	when requested by the backend.
      	* lib-xref.ads (Collect_SPARK_Xrefs): Remove.
      	(Iterate_SPARK_Xrefs): New routine for iterating over frontend xrefs.
      	* lib-xref-spark_specific.adb (Traverse_Compilation_Unit): Remove.
      	(Add_SPARK_File): Remove.
      	(Add_SPARK_Xref): Refactored from removed code; filters xref entries
      	that are trivially uninteresting to the SPARK backend.
      	* spark_xrefs.ads: Remove code that is no longer needed.
      	* spark_xrefs.adb (dspark): Adapt to use Iterate_SPARK_Xrefs.
      
      2017-11-09  Hristian Kirtchev  <kirtchev@adacore.com>
      
      	* sem_elab.adb: Update the documentation on adding a new elaboration
      	schenario. Add new hash table Recorded_Top_Level_Scenarios.
      	(Is_Check_Emitting_Scenario): Removed.
      	(Is_Recorded_Top_Level_Scenario): New routine.
      	(Kill_Elaboration_Scenario): Reimplemented.
      	(Record_Elaboration_Scenario): Mark the scenario as recorded.
      	(Set_Is_Recorded_Top_Level_Scenario): New routine.
      	(Update_Elaboration_Scenario): Reimplemented.
      	* sinfo.adb (Is_Recorded_Scenario): Removed.
      	(Set_Is_Recorded_Scenario): Removed.
      	* sinfo.ads: Remove attribute Is_Recorded_Scenario along with
      	occurrences in nodes.
      	(Is_Recorded_Scenario): Removed along with pragma Inline.
      	(Set_Is_Recorded_Scenario): Removed along with pragma Inline.
      
      2017-11-09  Piotr Trojanek  <trojanek@adacore.com>
      
      	* sem_prag.adb (Analyze_Part_Of): Change "designate" to "denote" in
      	error message.
      
      2017-11-09  Justin Squirek  <squirek@adacore.com>
      
      	* sem_res.adb (Resolve_Allocator): Add warning messages corresponding
      	to the allocation of an anonymous access-to-controlled object.
      
      gcc/testsuite/
      
      2017-11-09  Hristian Kirtchev  <kirtchev@adacore.com>
      
      	* gnat.dg/elab3.adb, gnat.dg/elab3.ads, gnat.dg/elab3_pkg.adb,
      	gnat.dg/elab3_pkg.ads: New testcase.
      
      2017-11-09  Pierre-Marie de Rodat  <derodat@adacore.com>
      
          * gnat.dg/controlled2.adb, gnat.dg/controlled4.adb, gnat.dg/finalized.adb:
          Disable the new warning from GNAT.
      
      From-SVN: r254568
      Pierre-Marie de Rodat committed
    • Remove non needed check in bmp_iter_set_init (PR tree-optimization/82669). · 6281f276
      2017-11-09  Martin Liska  <mliska@suse.cz>
      
      	PR tree-optimization/82669
      	* sbitmap.h (bmp_iter_set_init): Remove non needed check.
      
      From-SVN: r254567
      Martin Liska committed
    • [multiple changes] · d0567dc0
      2017-11-09  Jerome Lambourg  <lambourg@adacore.com>
      
      	* sigtramp-qnx.c: Fix obvious typo.
      
      2017-11-09  Doug Rupp  <rupp@adacore.com>
      
      	* libgnarl/s-taprop__linux.adb (Monotonic_Clock): Minor reformatting.
      
      2017-11-09  Ed Schonberg  <schonberg@adacore.com>
      
      	* sem_res.adb (Resolve): If expression is an entity whose type has
      	implicit dereference, generate reference to it, because no reference is
      	generated for an overloaded entity during analysis, given that its
      	identity may not be known.
      
      2017-11-09  Javier Miranda  <miranda@adacore.com>
      
      	* exp_disp.adb (Expand_Interface_Thunk): Replace substraction of
      	offset-to-top field by addition.
      	(Make_Secondary_DT): Initialize the offset-to-top field with a negative
      	offset.
      	* exp_ch3.adb (Build_Offset_To_Top_Function): Build functions that
      	return a negative offset-to-top value.
      	(Initialize_Tag): Invoke runtime services Set_Dynamic_Offset_To_Top and
      	Set_Static_Offset_To_Top passing a negative offet-to-top value;
      	initialize also the offset-to-top field with a negative offset.
      	* libgnat/a-tags.adb (Base_Address): Displace the pointer by means of
      	an addition since the offset-to-top field is now a negative value.
      	(Displace): Displace the pointer to the object means of a substraction
      	since it is now a negative value.
      	(Set_Dynamic_Offset_to_top): Displace the pointer to the object by
      	means of a substraction since it is now a negative value.
      
      2017-11-09  Eric Botcazou  <ebotcazou@adacore.com>
      
      	* gnat1drv.adb (Gnat1drv): Call Errout.Finalize (Last_Call => True)
      	before Errout.Output_Messages also in the case of compilation errors.
      
      2017-11-09  Javier Miranda  <miranda@adacore.com>
      
      	* doc/gnat_ugn/the_gnat_compilation_model.rst (Interfacing with C++ at
      	the Class Level): Fix error interfacing with C strings.
      	* gnat_ugn.texi: Regenerate.
      
      2017-11-09  Jerome Lambourg  <lambourg@adacore.com>
      
      	* system-qnx-aarch64.ads: Fix the priority constants.
      	* s-osinte__qnx.ads: Fix constants for handling the locking protocols
      	and scheduling.
      	* s-osinte__qnx.adb: New file , prevents the use of priority 0 that
      	corresponds to an idle priority on QNX.
      
      2017-11-09  Piotr Trojanek  <trojanek@adacore.com>
      
      	* sem_prag.adb, sem_util.adb, sem_elab.adb: Fix minor typos in
      	comments.
      
      From-SVN: r254566
      Pierre-Marie de Rodat committed
    • [multiple changes] · 6350cb2a
      2017-11-09  Piotr Trojanek  <trojanek@adacore.com>
      
      	* lib-xref-spark_specific.adb (Add_SPARK_Xrefs): Ignore loop parameters
      	in expression funtions that are expanded into variables.
      
      2017-11-09  Piotr Trojanek  <trojanek@adacore.com>
      
      	* sem_util.adb: Minor whitespace cleanup.
      
      2017-11-09  Jerome Lambourg  <lambourg@adacore.com>
      
      	* libgnarl/s-taprop__qnx.adb: Refine aarch64-qnx. Use the POSIX
      	s-taprop version rather than a custom one.
      	* sigtramp-qnx.c (aarch64-qnx): Implement the signal trampoline.
      
      From-SVN: r254563
      Pierre-Marie de Rodat committed
    • GCOV: support multiple functions per a line (PR gcov-profile/48463) · 136ca74e
      2017-11-09  Martin Liska  <mliska@suse.cz>
      
      	PR gcov-profile/48463
      	* coverage.c (coverage_begin_function): Output also end locus
      	of a function and information whether the function is
      	artificial.
      	* gcov-dump.c (tag_function): Parse and print the information.
      	* gcov.c (INCLUDE_MAP): Add include.
      	(INCLUDE_SET): Likewise.
      	(struct line_info): Move earlier in the source file because
      	of vector<line_info> in function_info structure.
      	(line_info::line_info): Likewise.
      	(line_info::has_block): Likewise.
      	(struct source_info): Add new member index.
      	(source_info::get_functions_at_location): New function.
      	(function_info::group_line_p): New function.
      	(output_intermediate_line): New function.
      	(output_intermediate_file): Use the mentioned function.
      	(struct function_start): New.
      	(struct function_start_pair_hash): Likewise.
      	(process_file): Add code that identifies group functions.
      	Assign lines either to global or function scope.
      	(generate_results): Skip artificial functions.
      	(find_source): Assign index for each source file.
      	(read_graph_file): Read new flag artificial and end_line.
      	(add_line_counts): Assign it either to global of function scope.
      	(accumulate_line_counts): Isolate core of the function to
      	accumulate_line_info and call it for both function and global
      	scope lines.
      	(accumulate_line_info): New function.
      	(output_line_beginning): Fix GNU coding style.
      	(print_source_line): New function.
      	(output_line_details): Likewise.
      	(output_function_details): Likewise.
      	(output_lines): Iterate both source (global) scope and function
      	scope.
      	(struct function_line_start_cmp): New class.
      	* doc/gcov.texi: Reflect changes in documentation.
      
      From-SVN: r254562
      Martin Liska committed
    • re PR debug/82837 (ICE in output_operand: invalid expression as operand) · 6bc322a1
      	PR debug/82837
      	* dwarf2out.c (const_ok_for_output_1): Reject NEG in addition to NOT.
      	(mem_loc_descriptor): Handle (const (neg (...))) as (neg (const (...)))
      	and similarly for not instead of neg.
      
      	* gcc.dg/debug/dwarf2/pr82837.c: New test.
      
      From-SVN: r254561
      Jakub Jelinek committed
    • Add option to force indirect calls for x86 · e7c77c4f
      This patch adds a -mforce-indirect-call option to force all calls
      or tail calls on x86_64 between functions to indirect. This is similar to the
      large code model, but doesn't affect jumps inside functions, so has much
      less run time overhead.
      
      This is useful with Intel Processor Trace (PT). PT has precise timing
      for indirect calls/jumps, but not for direct ones. So if we can force
      them to indirect it allows to time every function relatively accurately
      (minus the overhead of the indirect branch)
      
      Without this short functions often don't see a timing update and cannot
      be measured.
      
      The timing requires at least Skylake or Goldmont based CPUs.
      
      I made it an option. Originally I tried to make it a new code model,
      but since it can be combined with other code models (medium, pic, kernel
      etc.) this turned out to be too many combinations.
      
      For example with gcc. This first column is a ns time stamp for the
      functions.
      
      $ perf record -e intel_pt/noretcomp=1,cyc=1,cyc_thresh=1/u ./cc1 -O3 hello.c
      $ perf script --itrace=cr -F callindent,time,sym,addr --ns  | sed -n 180000,182000p | less
      ...
      1184596.432756920:                             build_int_cst                        =>           79c9de c_common_nodes_and_builtins
      1184596.432756921:                             tree_cons                            =>           ee2080 tree_cons
      1184596.432756938:                                 ggc_internal_alloc               =>           80f3e0 ggc_internal_alloc
      1184596.432756951:                                     memset@plt                   =>           598af0 memset@plt
      1184596.432756967:                                     __memset_avx2_unaligned_erms =>           80f605 ggc_internal_alloc
      1184596.432756969:                                 ggc_internal_alloc               =>           ee20a2 tree_cons
      1184596.432756973:                             tree_cons                            =>           79c9f4 c_common_nodes_and_builtins
      1184596.432756974:                             build_int_cst                        =>           ef9a40 build_int_cst
      1184596.432756996:                                 wide_int_to_tree                 =>           ef93a0 wide_int_to_tree
      1184596.432757000:                                     wi::force_to_size            =>           f48f70 wi::force_to_size
      1184596.432757005:                                     canonize                     =>           ef94de wide_int_to_tree
      1184596.432757021:                                     get_int_cst_ext_nunits       =>           ee1960 get_int_cst_ext_nunits
      1184596.432757026:                                     get_int_cst_ext_nunits       =>           ef94fe wide_int_to_tree
      1184596.432757042:                                     tree_int_cst_elt_check       =>           83e310 tree_int_cst_elt_check
      1184596.432757044:                                     tree_int_cst_elt_check       =>           ef9761 wide_int_to_tree
      1184596.432757046:                                 wide_int_to_tree                 =>           ef9a9b build_int_cst
      
      gcc/:
      2017-11-08  Andi Kleen  <ak@linux.intel.com>
      
      	* config/i386/i386.opt: Add -mforce-indirect-call.
      	* config/i386/predicates.md: Check for flag_force_indirect_call.
      	* doc/invoke.texi: Document -mforce-indirect-call
      
      gcc/testsuite/:
      2017-11-08  Andi Kleen  <ak@linux.intel.com>
      
      	* gcc.target/i386/force-indirect-call-1.c: New test.
      	* gcc.target/i386/force-indirect-call-2.c: New test.
      	* gcc.target/i386/force-indirect-call-3.c: New test.
      
      From-SVN: r254560
      Andi Kleen committed
    • Daily bump. · 8b74c9cd
      From-SVN: r254559
      GCC Administrator committed
  2. 08 Nov, 2017 27 commits
    • re PR fortran/82841 (Segfault in gfc_simplify_transfer) · b0369790
      2017-11-08  Steven G. Kargl  <kargl@kgcc.gnu.org>
      
      	PR Fortran/82841
      	* simplify.c(gfc_simplify_transfer): Do not dereference a NULL pointer.
      	Unwrap a short line.
       
      2017-11-08  Steven G. Kargl  <kargl@kgcc.gnu.org>
      
      	PR Fortran/82841
      	* gfortran.dg/transfer_simplify_11.f90: new test.
      
      From-SVN: r254555
      Steven G. Kargl committed
    • RISC-V: Fix build error · fb5621b1
        - This build error was indroduced by "RISC-V: Implement movmemsi"
          and "RISC-V: Support -mpreferred-stack-boundary flag"
      
      gcc/ChangeLog
      
      2017-11-08  Kito Cheng  <kito.cheng@gmail.com>
      
              * config/riscv/riscv-protos.h (riscv_slow_unaligned_access_p):
              New extern.
              (MOVE_RATIO): Use riscv_slow_unaligned_access_p.
              config/riscv/riscv.c (predict.h): New include.
              (riscv_slow_unaligned_access_p): No longer static.
              (riscv_block_move_straight): Add require.
              config/riscv/riscv-protos.h (riscv_hard_regno_nregs): Delete.
      
      From-SVN: r254554
      Kito Cheng committed
    • re PR fortran/82884 (ICE in gfc_resolve_character_array_constructor, at fortran/array.c:2069) · fd5dce5c
      2017-11-08  Steven G. Kargl  <kargl@gcc.gnu.org>
      
      	PR fortran/82884
      	* arith.c (gfc_hollerith2character): Clear pad.
      
      2017-11-08  Steven G. Kargl  <kargl@gcc.gnu.org>
      
      	PR fortran/82884
      	* gfortran.dg/hollerith_character_array_constructor.f90: New test.
      
      From-SVN: r254553
      Steven G. Kargl committed
    • re PR target/82855 (AVX512: replace OP+movemask with OP_mask+ktest) · deef5083
      	PR target/82855
      	* config/i386/sse.md (<avx512>_eq<mode>3<mask_scalar_merge_name>,
      	<avx512>_eq<mode>3<mask_scalar_merge_name>_1): Use
      	nonimmediate_operand predicate for operand 1 instead of
      	register_operand.
      
      From-SVN: r254552
      Jakub Jelinek committed
    • [AArch64] Add STP pattern to store a vec_concat of two 64-bit registers · 7692ce17
      On top of the previous vec_merge simplifications [1] we can add this pattern to perform
      a store of a vec_concat of two 64-bit values in distinct registers as an STP.
      This avoids constructing such a vector explicitly in a register and storing it as
      a Q register.
      This way for the code in the testcase we can generate:
      
      construct_lane_1:
              ldp     d1, d0, [x0]
              fmov    d3, 1.0e+0
              fmov    d2, 2.0e+0
              fadd    d4, d1, d3
              fadd    d5, d0, d2
              stp     d4, d5, [x1, 32]
              ret
      
      construct_lane_2:
              ldp     x2, x0, [x0]
              add     x3, x2, 1
              add     x4, x0, 2
              stp     x3, x4, [x1, 32]
              ret
      
      instead of the current:
      construct_lane_1:
              ldp     d0, d1, [x0]
              fmov    d3, 1.0e+0
              fmov    d2, 2.0e+0
              fadd    d0, d0, d3
              fadd    d1, d1, d2
              dup     v0.2d, v0.d[0]
              ins     v0.d[1], v1.d[0]
              str     q0, [x1, 32]
              ret
      
      construct_lane_2:
              ldp     x2, x3, [x0]
              add     x0, x2, 1
              add     x2, x3, 2
              dup     v0.2d, x0
              ins     v0.d[1], x2
              str     q0, [x1, 32]
              ret
      
      Bootstrapped and tested on aarch64-none-linux-gnu.
      
      [1] https://gcc.gnu.org/ml/gcc-patches/2017-06/msg00272.html
          https://gcc.gnu.org/ml/gcc-patches/2017-06/msg00273.html
          https://gcc.gnu.org/ml/gcc-patches/2017-06/msg00274.html
      
      	* config/aarch64/aarch64-simd.md (store_pair_lanes<mode>):
      	New pattern.
      	* config/aarch64/constraints.md (Uml): New constraint.
      	* config/aarch64/predicates.md (aarch64_mem_pair_lanes_operand): New
      	predicate.
      
      	* gcc.target/aarch64/store_v2vec_lanes.c: New test.
      
      From-SVN: r254551
      Kyrylo Tkachov committed
    • [simplify-rtx] Simplify vec_merge of vec_duplicates into vec_concat · 040939a2
      Another vec_merge simplification that's missing from simplify-rtx.c is transforming
      a vec_merge of two vec_duplicates. For example:
      (set (reg:V2DF 80)
          (vec_merge:V2DF (vec_duplicate:V2DF (reg:DF 84))
              (vec_duplicate:V2DF (reg:DF 81))
              (const_int 2)))
      
      Can be transformed into the simpler:
      (set (reg:V2DF 80)
          (vec_concat:V2DF (reg:DF 81)
                      (reg:DF 84)))
      
      I believe this should always be beneficial.
      I'm still looking into finding a small testcase demonstrating this, but on aarch64 SPEC
      I've seen this eliminate some really bizzare codegen where GCC was generating nonsense like:
        ldr q18, [sp, 448]
        ins v18.d[0], v23.d[0]
        ins v18.d[1], v22.d[0]
      
      With q18 being pushed and popped off the stack in the prologue and epilogue of the function!
      These are large files from SPEC that I haven't been able to analyse yet as to why GCC even attempts
      to do that, but with this patch it doesn't try to load a register and overwrite all its lanes.
      This patch shaves off about 5k of code size from zeusmp on aarch64 at -O3, so I believe it's a good
      thing to do. 
      
      	* simplify-rtx.c (simplify_ternary_operation): Simplify vec_merge
      	of two vec_duplicates into a vec_concat.
      
      From-SVN: r254550
      Kyrylo Tkachov committed
    • vec_merge + vec_duplicate + vec_concat simplification · 40757a25
      Another vec_merge simplification that's missing is transforming:
      (vec_merge (vec_duplicate x) (vec_concat (y) (z)) (const_int N))
      into
      (vec_concat x z) if N == 1 (0b01) or
      (vec_concat y x) if N == 2 (0b10)
      
      For the testcase in this patch on aarch64 this allows us to try matching during combine the pattern:
      (set (reg:V2DI 78 [ x ])
          (vec_concat:V2DI
              (mem:DI (reg/v/f:DI 76 [ y ]) [1 *y_4(D)+0 S8 A64])
              (mem:DI (plus:DI (reg/v/f:DI 76 [ y ])
                      (const_int 8 [0x8])) [1 MEM[(long long int *)y_4(D) + 8B]+0 S8 A64])))
      
      rather than the more complex:
      (set (reg:V2DI 78 [ x ])
          (vec_merge:V2DI (vec_duplicate:V2DI (mem:DI (plus:DI (reg/v/f:DI 76 [ y ])
                          (const_int 8 [0x8])) [1 MEM[(long long int *)y_4(D) + 8B]+0 S8 A64]))
              (vec_duplicate:V2DI (mem:DI (reg/v/f:DI 76 [ y ]) [1 *y_4(D)+0 S8 A64]))
              (const_int 2 [0x2])))
      
      We don't actually have an aarch64 pattern for the simplified version above, but it's a simple enough
      form to add, so this patch adds such a pattern that performs a concatenated load of two 64-bit vectors
      in adjacent memory locations as a single Q-register LDR. The new aarch64 pattern is needed to demonstrate
      the effectiveness of the simplify-rtx change, so I've kept them together as one patch.
      
      Now for the testcase in the patch we can generate:
      construct_lanedi:
              ldr     q0, [x0]
              ret
      
      construct_lanedf:
              ldr     q0, [x0]
              ret
      
      instead of:
      construct_lanedi:
              ld1r    {v0.2d}, [x0]
              ldr     x0, [x0, 8]
              ins     v0.d[1], x0
              ret
      
      construct_lanedf:
              ld1r    {v0.2d}, [x0]
              ldr     d1, [x0, 8]
              ins     v0.d[1], v1.d[0]
              ret
      
      The new memory constraint Utq is needed because we need to allow only the Q-register addressing modes but
      the MEM expressions in the RTL pattern have 64-bit vector modes, and if we don't constrain them they will
      allow the D-register addressing modes during register allocation/address mode selection, which will produce
      invalid assembly.
      
      Bootstrapped and tested on aarch64-none-linux-gnu. 
      
      	* simplify-rtx.c (simplify_ternary_operation, VEC_MERGE):
      	Simplify vec_merge of vec_duplicate and vec_concat.
      	* config/aarch64/constraints.md (Utq): New constraint.
      	* config/aarch64/aarch64-simd.md (load_pair_lanes<mode>): New
      	define_insn.
      
      	* gcc.target/aarch64/load_v2vec_lanes_1.c: New test.
      
      From-SVN: r254549
      Kyrylo Tkachov committed
    • Simplify vec_merge of vec_duplicate with const_vector · 6432f025
      I'm trying to improve some of the RTL-level handling of vector lane operations on aarch64 and that
      involves dealing with a lot of vec_merge operations. One simplification that I noticed missing
      from simplify-rtx are combinations of vec_merge with vec_duplicate.
      In this particular case:
      (vec_merge (vec_duplicate (X)) (const_vector [A, B]) (const_int N))
      
      which can be replaced with
      
      (vec_concat (X) (B)) if N == 1 (0b01) or
      (vec_concat (A) (X)) if N == 2 (0b10).
      
      For the aarch64 testcase in this patch this simplifications allows us to try to combine:
      (set (reg:V2DI 77 [ x ])
          (vec_concat:V2DI (mem:DI (reg:DI 0 x0 [ y ]) [1 *y_3(D)+0 S8 A64])
              (const_int 0 [0])))
      
      instead of the more complex:
      (set (reg:V2DI 77 [ x ])
          (vec_merge:V2DI (vec_duplicate:V2DI (mem:DI (reg:DI 0 x0 [ y ]) [1 *y_3(D)+0 S8 A64]))
              (const_vector:V2DI [
                      (const_int 0 [0])
                      (const_int 0 [0])
                  ])
              (const_int 1 [0x1])))
      
      
      For the simplified form above we already have an aarch64 pattern: *aarch64_combinez<mode> which
      is missing a DI/DFmode version due to an oversight, so this patch extends that pattern as well to
      use the VDC mode iterator that includes DI and DFmode (as well as V2HF which VD_BHSI was missing).
      The aarch64 hunk is needed to see the benefit of the simplify-rtx.c hunk, so I didn't split them
      into separate patches.
      
      Before this for the testcase we'd generate:
      construct_lanedi:
              movi    v0.4s, 0
              ldr     x0, [x0]
              ins     v0.d[0], x0
              ret
      
      construct_lanedf:
              movi    v0.2d, 0
              ldr     d1, [x0]
              ins     v0.d[0], v1.d[0]
              ret
      
      but now we can generate:
      construct_lanedi:
              ldr     d0, [x0]
              ret
      
      construct_lanedf:
              ldr     d0, [x0]
              ret
      
      Bootstrapped and tested on aarch64-none-linux-gnu.
      
      
      	* simplify-rtx.c (simplify_ternary_operation, VEC_MERGE):
      	Simplify vec_merge of vec_duplicate and const_vector.
      	* config/aarch64/predicates.md (aarch64_simd_or_scalar_imm_zero):
      	New predicate.
      	* config/aarch64/aarch64-simd.md (*aarch64_combinez<mode>): Use VDC
      	mode iterator.  Update predicate on operand 1 to
      	handle non-const_vec constants.  Delete constraints.
      	(*aarch64_combinez_be<mode>): Likewise for operand 2.
      
      	* gcc.target/aarch64/construct_lane_zero_1.c: New test.
      
      From-SVN: r254548
      Kyrylo Tkachov committed
    • [multiple changes] · 8d9a1ba7
      2017-11-08  Piotr Trojanek  <trojanek@adacore.com>
      
      	* lib-xref.ads, lib-xref-spark_specific.adb
      	(Traverse_Compilation_Unit): Move declaration to package body.
      
      2017-11-08  Hristian Kirtchev  <kirtchev@adacore.com>
      
      	* exp_spark.adb (Expand_SPARK_N_Object_Renaming_Declaration): Obtain
      	the type of the renaming from its defining entity, rather then the
      	subtype mark as there may not be a subtype mark.
      
      2017-11-08  Jerome Lambourg  <lambourg@adacore.com>
      
      	* adaint.c, s-oscons-tmplt.c, init.c, libgnat/system-qnx-aarch64.ads,
      	libgnarl/a-intnam__qnx.ads, libgnarl/s-intman__qnx.adb,
      	libgnarl/s-osinte__qnx.ads, libgnarl/s-qnx.ads,
      	libgnarl/s-taprop__qnx.adb, s-oscons-tmplt.c, sigtramp-qnx.c,
      	terminals.c: Initial port of GNAT for aarch64-qnx
      
      2017-11-08  Elisa Barboni  <barboni@adacore.com>
      
      	* exp_util.adb (Find_DIC_Type): Move...
      	* sem_util.ads, sem_util.adb (Find_DIC_Type): ... here.
      
      2017-11-08  Justin Squirek  <squirek@adacore.com>
      
      	* sem_res.adb (Resolve_Allocator): Add info messages corresponding to
      	the owner and corresponding coextension.
      
      2017-11-08  Ed Schonberg  <schonberg@adacore.com>
      
      	* sem_aggr.adb (Resolve_Delta_Aggregate): Divide into the
      	following separate procedures.
      	(Resolve_Delta_Array_Aggregate): Previous code form
      	Resolve_Delta_Aggregate.
      	(Resolve_Delta_Record_Aggregate): Extend previous code to cover latest
      	ARG decisions on the legality rules for delta aggregates for records:
      	in the case of a variant record, components from different variants
      	cannot be specified in the delta aggregate, and this must be checked
      	statically.
      
      From-SVN: r254547
      Pierre-Marie de Rodat committed
    • [multiple changes] · 76b37a56
      2017-11-08  Piotr Trojanek  <trojanek@adacore.com>
      
      	* spark_xrefs.ads (SPARK_Scope_Record): Remove File_Num component.
      	* lib-xref-spark_specific.adb (Add_SPARK_Scope): Skip initialization of
      	removed component.
      
      2017-11-08  Gary Dismukes  <dismukes@adacore.com>
      
      	* sem_ch4.adb: Minor typo fix.
      
      From-SVN: r254546
      Pierre-Marie de Rodat committed
    • [multiple changes] · ec98bb7d
      2017-11-08  Piotr Trojanek  <trojanek@adacore.com>
      
      	* spark_xrefs.ads (SPARK_Scope_Record): Remove Spec_File_Num and
      	Spec_Scope_Num components.
      	* spark_xrefs.adb (dspark): Skip pretty-printing to removed components.
      	* lib-xref-spark_specific.adb (Add_SPARK_Scope): Skip initialization of
      	removed components.
      	(Collect_SPARK_Xrefs): Skip setting proper values of removed
      	components.
      
      2017-11-08  Gary Dismukes  <dismukes@adacore.com>
      
      	* exp_ch4.adb (Expand_N_Type_Conversion): Add test that the selector
      	name is a discriminant in check for unconditional accessibility
      	violation within instances.
      
      From-SVN: r254545
      Pierre-Marie de Rodat committed
    • lib-xref-spark_specific.adb (Add_SPARK_Xrefs): Remove special-case for constants… · 9ac3cbb3
      lib-xref-spark_specific.adb (Add_SPARK_Xrefs): Remove special-case for constants (with variable input).
      
      gcc/ada/
      
      2017-11-08  Piotr Trojanek  <trojanek@adacore.com>
      
      	* lib-xref-spark_specific.adb (Add_SPARK_Xrefs): Remove special-case
      	for constants (with variable input).
      	(Is_Constant_Object_Without_Variable_Input): Remove.
      
      2017-11-08  Hristian Kirtchev  <kirtchev@adacore.com>
      
      	* exp_ch9.adb, sem_disp.adb, sem_util.adb: Minor reformatting.
      
      2017-11-08  Piotr Trojanek  <trojanek@adacore.com>
      
      	* spark_xrefs.ads (Rtype): Remove special-casing of constants for SPARK
      	cross-references.
      	(dspark): Remove hardcoded table bound.
      
      2017-11-08  Ed Schonberg  <schonberg@adacore.com>
      
      	* sem_ch4.adb (Analyze_Aggregate): For Ada2020 delta aggregates, use
      	the type of the base of the construct to determine the type (or
      	candidate interpretations) of the delta aggregate. This allows the
      	construct to appear in a context that expects a private extension.
      	* sem_res.adb (Resolve): Handle properly a delta aggregate with an
      	overloaded base.
      
      gcc/testsuite/
      
      2017-11-08  Ed Schonberg  <schonberg@adacore.com>
      
      	* gnat.dg/delta_aggr.adb: New testcase.
      
      From-SVN: r254544
      Pierre-Marie de Rodat committed
    • [multiple changes] · 2cf8eabd
      2017-11-08  Piotr Trojanek  <trojanek@adacore.com>
      
      	* spark_xrefs.ads (SPARK_Xref_Record): Replace file and scope indices
      	with Entity_Id of the reference.
      	* spark_xrefs.adb (dspark): Adapt pretty-printing routine.
      	* lib-xref-spark_specific.adb (Add_SPARK_Xrefs): Store Entity_Id of the
      	reference, not the file and scope indices.
      
      2017-11-08  Arnaud Charlet  <charlet@adacore.com>
      
      	* errout.ads (Current_Node): New.
      	* errout.adb (Error_Msg): Use Current_Node.
      	* par-ch6.adb, par-ch7.adb, par-ch9.adb, par-util.adb: Set Current_Node
      	when relevant.
      	* style.adb: Call Error_Msg_N when possible.
      
      From-SVN: r254543
      Pierre-Marie de Rodat committed
    • spark_xrefs.ads (SPARK_Scope_Record): Rename Scope_Id component to Entity. · 45a6947d
      2017-11-08  Piotr Trojanek  <trojanek@adacore.com>
      
      	* spark_xrefs.ads (SPARK_Scope_Record): Rename Scope_Id component to
      	Entity.
      	* lib-xref-spark_specific.adb, spark_xrefs.adb: Propagate renaming of
      	the Scope_Id record component.
      
      From-SVN: r254542
      Piotr Trojanek committed
    • spark_xrefs.ads (SPARK_File_Record): Remove string components. · 00b3de22
      2017-11-08  Piotr Trojanek  <trojanek@adacore.com>
      
      	* spark_xrefs.ads (SPARK_File_Record): Remove string components.
      	* spark_xrefs.adb (dspark): Remove pretty-printing of removed
      	SPARK_File_Record components.
      	* lib-xref-spark_specific.adb (Add_SPARK_File): Do not store string
      	representation of files/units.
      
      From-SVN: r254541
      Piotr Trojanek committed
    • lib-xref.ads, [...] (Traverse_Declarations): Remove Inside_Stubs parameter. · 784ef0fb
      2017-11-08  Piotr Trojanek  <trojanek@adacore.com>
      
      	* lib-xref.ads, lib-xref-spark_specific.adb (Traverse_Declarations):
      	Remove Inside_Stubs parameter.
      
      From-SVN: r254540
      Piotr Trojanek committed
    • [multiple changes] · 3e5400f4
      2017-11-08  Piotr Trojanek  <trojanek@adacore.com>
      
      	* spark_xrefs.ads (SPARK_Xref_Record): Referenced object is now
      	represented by Entity_Id.
      	(SPARK_Scope_Record): Referenced scope (e.g. subprogram) is now
      	represented by Entity_Id; this information is not repeated as
      	Scope_Entity.
      	(Heap): Moved from lib-xref-spark_specific.adb, to reside next to
      	Name_Of_Heap_Variable.
      	* spark_xrefs.adb (dspark): Adapt debug routine to above changes in
      	data types.
      	* lib-xref-spark_specific.adb: Adapt routines for populating SPARK
      	scope and xrefs tables to above changes in data types.
      
      2017-11-08  Justin Squirek  <squirek@adacore.com>
      
      	* sem_ch8.adb (Mark_Use_Clauses): Add condition to always mark the
      	primitives of generic actuals.
      	(Mark_Use_Type): Add recursive call to properly mark class-wide type's
      	base type clauses as per ARM 8.4 (8.2/3).
      
      2017-11-08  Ed Schonberg  <schonberg@adacore.com>
      
      	* sem_ch6.adb (Analyze_Generic_Subprobram_Body): Validate
      	categorization dependency of the body, as is done for non-generic
      	units.
      	(New_Overloaded_Entity, Visible_Part_Type): Remove linear search
      	through declarations (Simple optimization, no behavior change).
      
      From-SVN: r254539
      Pierre-Marie de Rodat committed
    • spark_xrefs.ads (SPARK_Xref_Record): Remove inessential components. · 013e9958
      2017-11-08  Piotr Trojanek  <trojanek@adacore.com>
      
      	* spark_xrefs.ads (SPARK_Xref_Record): Remove inessential components.
      	(SPARK_Scope_Record): Remove inessential components.
      	* spark_xrefs.adb (dspark): Remove pretty-printing of removed record
      	components.
      	* lib-xref-spark_specific.adb (Add_SPARK_Scope): Remove setting of
      	removed record components.
      	(Add_SPARK_Xrefs): Remove setting of removed record components.
      
      From-SVN: r254538
      Piotr Trojanek committed
    • pr57878.C (__sso_string_base::_M_get_allocator): Return a value. · 388f3a64
      	* g++.dg/pr57878.C (__sso_string_base::_M_get_allocator): Return
      	a value.
      
      From-SVN: r254537
      Jakub Jelinek committed
    • re PR tree-optimization/78821 (GCC7: Copying whole 32 bits structure field by… · 383ac8dc
      re PR tree-optimization/78821 (GCC7: Copying whole 32 bits structure field by field not optimised into copying whole 32 bits at once)
      
      	PR tree-optimization/78821
      	* gimple-ssa-store-merging.c (struct store_operand_info): Add bit_not_p
      	data member.
      	(store_operand_info::store_operand_info): Initialize it to false.
      	(pass_store_merging::terminate_all_aliasing_chains): Rewritten to use
      	ref_maybe_used_by_stmt_p and stmt_may_clobber_ref_p on lhs of each
      	store in the group, and if chain_info is non-NULL, to ignore altogether
      	that chain.
      	(compatible_load_p): Fail if bit_not_p does not match.
      	(imm_store_chain_info::output_merged_store): Handle bit_not_p loads.
      	(handled_load): Fill in bit_not_p.  Handle BIT_NOT_EXPR.
      	(pass_store_merging::process_store): Adjust
      	terminate_all_aliasing_chains calls to pass NULL in all current spots,
      	call terminate_all_aliasing_chains newly when adding a store into
      	a chain with non-NULL chain_info.
      
      	* gcc.dg/store_merging_2.c: Expect 3 store mergings instead of 2.
      	* gcc.dg/store_merging_13.c (f7, f8, f9, f10, f11, f12, f13): New
      	functions.
      	(main): Test also those.  Expect 13 store mergings instead of 6.
      	* gcc.dg/store_merging_14.c (f7, f8, f9): New functions.
      	(main): Test also those.  Expect 9 store mergings instead of 6.
      
      From-SVN: r254536
      Jakub Jelinek committed
    • lib-xref-spark_specific.adb (Add_SPARK_Xrefs): Remove dead check for empty entities. · a14ab2c3
      2017-11-08  Piotr Trojanek  <trojanek@adacore.com>
      
      	* lib-xref-spark_specific.adb (Add_SPARK_Xrefs): Remove dead check for
      	empty entities.
      
      From-SVN: r254535
      Piotr Trojanek committed
    • [AArch64] Simplify aarch64_can_eliminate · 6216fd90
      Simplify aarch64_can_eliminate - if we need a frame pointer, we must
      eliminate to HARD_FRAME_POINTER_REGNUM.  Rather than hardcoding all
      combinations from the ELIMINABLE_REGS list, just do the correct check.
      
          gcc/
      	* config/aarch64/aarch64.c (aarch64_can_eliminate): Simplify logic.
      
      From-SVN: r254534
      Wilco Dijkstra committed
    • [AArch64] Remove aarch64_frame_pointer_required · 7040939b
      To implement -fomit-leaf-frame-pointer, there are 2 places where we need
      to check whether we have to use a frame chain (since register allocation
      may allocate LR in a leaf function that omits the frame pointer, but if
      LR is spilled we must emit a frame chain).  To simplify this do not force
      frame_pointer_needed via aarch64_frame_pointer_required, but enable the
      frame chain in aarch64_layout_frame.  Now aarch64_frame_pointer_required
      can be removed and aarch64_can_eliminate is simplified.
      
          gcc/
      	* config/aarch64/aarch64.c (aarch64_frame_pointer_required)
      	Remove.
      	(aarch64_layout_frame): Initialise emit_frame_chain.
      	(aarch64_can_eliminate): Remove omit leaf frame pointer code.
      	(TARGET_FRAME_POINTER_REQUIRED): Remove define.
      
          testsuite/
      	* gcc.target/aarch64/dwarf-cfa-reg.c: Update.
      
      From-SVN: r254533
      Wilco Dijkstra committed
    • sem_disp.adb (Is_Inherited_Public_Operation): Extend the functionality of this… · 7cc7f3aa
      sem_disp.adb (Is_Inherited_Public_Operation): Extend the functionality of this routine to handle multiple levels of derivations.
      
      gcc/ada/
      
      2017-11-08  Javier Miranda  <miranda@adacore.com>
      
      	* sem_disp.adb (Is_Inherited_Public_Operation): Extend the
      	functionality of this routine to handle multiple levels of derivations.
      
      2017-11-08  Hristian Kirtchev  <kirtchev@adacore.com>
      
      	* einfo.adb: Elist36 is now used as Nested_Scenarios.
      	(Nested_Scenarios): New routine.
      	(Set_Nested_Scenarios): New routine.
      	(Write_Field36_Name): New routine.
      	* einfo.ads: Add new attribute Nested_Scenarios along with occurrences
      	in entities.
      	(Nested_Scenarios): New routine along with pragma Inline.
      	(Set_Nested_Scenarios): New routine along with pragma Inline.
      	* sem_elab.adb (Find_And_Process_Nested_Scenarios): New routine.
      	(Process_Nested_Scenarios): New routine.
      	(Traverse_Body): When a subprogram body is traversed for the first
      	time, find, save, and process all suitable scenarios found within.
      	Subsequent traversals of the same subprogram body utilize the saved
      	scenarios.
      
      2017-11-08  Piotr Trojanek  <trojanek@adacore.com>
      
      	* lib-xref-spark_specific.adb (Add_SPARK_Scope): Remove detection of
      	protected operations.
      	(Add_SPARK_Xrefs): Simplify detection of empty entities.
      	* get_spark_xrefs.ads, get_spark_xrefs.adb, put_spark_xrefs.ads,
      	put_spark_xrefs.adb, spark_xrefs_test.adb: Remove code for writing,
      	reading and testing SPARK cross-references stored in the ALI files.
      	* lib-xref.ads (Output_SPARK_Xrefs): Remove.
      	* lib-writ.adb (Write_ALI): Do not write SPARK cross-references to the
      	ALI file.
      	* spark_xrefs.ads, spark_xrefs.adb (pspark): Remove, together
      	with description of the SPARK xrefs ALI format.
      	* gcc-interface/Make-lang.in (GNAT_ADA_OBJS): Remove get_spark_refs.o
      	and put_spark_refs.o.
      
      2017-11-08  Hristian Kirtchev  <kirtchev@adacore.com>
      
      	* exp_ch4.adb (Apply_Accessibility_Check): Do not finalize the object
      	when the associated access type is subject to pragma
      	No_Heap_Finalization.
      	* exp_intr.adb (Expand_Unc_Deallocation): Use the available view of the
      	designated type in case it comes from a limited withed unit.
      
      gcc/testsuite/
      
      2017-11-08  Javier Miranda  <miranda@adacore.com>
      
      	* gnat.dg/overriding_ops2.adb, gnat.dg/overriding_ops2.ads,
      	gnat.dg/overriding_ops2_pkg.ads, gnat.dg/overriding_ops2_pkg-high.ads:
      	New testcase.
      
      From-SVN: r254532
      Pierre-Marie de Rodat committed
    • exp_ch3.adb (Expand_N_Object_Declaration): Save and restore relevant SPARK-related flags. · daf82dd8
      2017-11-08  Hristian Kirtchev  <kirtchev@adacore.com>
      
      	* exp_ch3.adb (Expand_N_Object_Declaration): Save and restore relevant
      	SPARK-related flags.  Add ??? comment.
      	* exp_util.adb (Insert_Actions): Add an entry for node
      	N_Variable_Reference_Marker.
      	* sem.adb (Analyze): Add an entry for node N_Variable_Reference_Marker.
      	* sem_ch8.adb (Find_Direct_Name): Add constant Is_Assignment_LHS. Build
      	and record a variable reference marker for the current name.
      	(Find_Expanded_Name): Add constant Is_Assignment_LHS. Build and record
      	a variable reference marker for the current name.
      	* sem_elab.adb (Build_Variable_Reference_Marker): New routine.
      	(Extract_Variable_Reference_Attributes): Reimplemented.
      	(Info_Scenario): Add output for variable references and remove output
      	for variable reads.
      	(Info_Variable_Read): Removed.
      	(Info_Variable_Reference): New routine.
      	(Is_Suitable_Scenario): Variable references are now suitable scenarios
      	while variable reads are not.
      	(Output_Active_Scenarios): Add output for variable references and
      	remove output for variable reads.
      	(Output_Variable_Read): Removed.
      	(Output_Variable_Reference): New routine.
      	(Process_Variable_Read): Removed.
      	(Process_Variable_Reference): New routine.
      	(Process_Variable_Reference_Read): New routine.
      	* sem_elab.ads (Build_Variable_Reference_Marker): New routine.
      	* sem_res.adb (Resolve_Actuals): Build and record a variable reference
      	marker for the current actual.
      	* sem_spark.adb (Check_Node): Add an entry for node
      	N_Variable_Reference_Marker.
      	* sem_util.adb (Within_Subprogram_Call): Moved to the library level.
      	* sem_util.ads (Within_Subprogram_Call): Moved to the library level.
      	* sinfo.adb (Is_Read): New routine.
      	(Is_Write): New routine.
      	(Target): Updated to handle variable reference markers.
      	(Set_Is_Read): New routine.
      	(Set_Is_Write): New routine.
      	(Set_Target): Updated to handle variable reference markers.
      	* sinfo.ads: Add new attributes Is_Read and Is_Write along with
      	occurrences in nodes. Update attribute Target. Add new node
      	kind N_Variable_Reference_Marker.
      	(Is_Read): New routine along with pragma Inline.
      	(Is_Write): New routine along with pragma Inline.
      	(Set_Is_Read): New routine along with pragma Inline.
      	(Set_Is_Write): New routine along with pragma Inline.
      	* sprint.adb (Sprint_Node_Actual): Add an entry for node
      	N_Variable_Reference_Marker.
      
      From-SVN: r254531
      Hristian Kirtchev committed
    • aarch64-vect-lane-2.c (search_line_fast): Change type to void. · 428dab52
      	* c-c++-common/torture/aarch64-vect-lane-2.c (search_line_fast):
      	Change type to void.
      
      From-SVN: r254530
      Andreas Schwab committed
    • sem_util.adb (Subprogram_Name): Append suffix for overloaded subprograms. · 879e92d0
      2017-11-08  Arnaud Charlet  <charlet@adacore.com>
      
      	* sem_util.adb (Subprogram_Name): Append suffix for overloaded
      	subprograms.
      
      From-SVN: r254529
      Arnaud Charlet committed