1. 20 Apr, 2016 20 commits
    • [multiple changes] · 7e22a38c
      2016-04-20  Ed Schonberg  <schonberg@adacore.com>
      
      	* sem_ch13.adb (Rep_Item_Too_Late): Better error message for
      	an illegal aspect that freezes the entity to which it applies.
      
      2016-04-20  Bob Duff  <duff@adacore.com>
      
      	* a-stwibo.ads, a-stzbou.ads
      	("="): Add overriding keyword before function to avoid crash when
      	compiler is called with -gnatyO (check overriding indicators).
      
      2016-04-20  Ed Schonberg  <schonberg@adacore.com>
      
      	* sem_prag.adb (Analyze_Pragma, case Check_Policy):  If this
      	is a configuration pragma and it uses the ARG syntax, insert
      	the rewritten pragma after the current one rather than using
      	Insert_Actions.
      
      2016-04-20  Arnaud Charlet  <charlet@adacore.com>
      
      	* exp_aggr.adb (Backend_Processing_Possible): Add handling of
      	C back-end.
      
      From-SVN: r235253
      Arnaud Charlet committed
    • s-imgllu.adb, [...]: Minor reformatting. · b83dd5ec
      2016-04-20  Hristian Kirtchev  <kirtchev@adacore.com>
      
      	* s-imgllu.adb, sem_util.adb, s-imgint.adb, s-imguns.adb,
      	s-imglli.adb: Minor reformatting.
      
      From-SVN: r235251
      Hristian Kirtchev committed
    • re PR tree-optimization/70725 (Internal compiler error (ICE) on valid code) · 2697b189
      	PR tree-optimization/70725
      	* tree-if-conv.c (is_false_predicate): New function.
      	(predicate_mem_writes): Use it.
      
      	* gcc.dg/pr70725.c: New test.
      
      From-SVN: r235250
      Marek Polacek committed
    • sem_res.adb (Rewrite_Renamed_Operator): Do not rewrite the renamed operator when… · d566e90a
      sem_res.adb (Rewrite_Renamed_Operator): Do not rewrite the renamed operator when the associated node appears within a...
      
      2016-04-20  Hristian Kirtchev  <kirtchev@adacore.com>
      
      	* sem_res.adb (Rewrite_Renamed_Operator): Do not rewrite the
      	renamed operator when the associated node appears within a
      	pre/postcondition.
      	* sem_util.ads, sem_util.adb (In_Pre_Post_Condition): New routine.
      
      From-SVN: r235249
      Hristian Kirtchev committed
    • [multiple changes] · 9a476d75
      2016-04-20  Yannick Moy  <moy@adacore.com>
      
      	* osint.adb (Relocate_Path): Fix test when Path is shorter than Prefix.
      	* einfo.adb (Set_Overridden_Operation): Add assertion.
      	* sem_util.adb (Unique_Entity): for renaming-as-body return the spec
      	entity.
      
      2016-04-20  Javier Miranda  <miranda@adacore.com>
      
      	* exp_unst.adb (Append_Unique_Call): New subprogram.
      	(Unnest_Subprogram): Replace the unique occurrence
      	of Call.Append() by Append_Unique_Call() which protects us from
      	adding to the Calls table duplicated entries.
      
      2016-04-20  Arnaud Charlet  <charlet@adacore.com>
      
      	* exp_attr.adb (Is_GCC_Target): Fix for C backend.
      	* xref_lib.ads (Dependencies_Tables): instantiate
      	Table package with types that guarantee its safe use.
      	* s-imgllu.adb, s-imgint.adb, s-imguns.adb, s-imglli.adb: Avoid nested
      	procedures.
      
      From-SVN: r235248
      Arnaud Charlet committed
    • exp_attr.adb (Expand_N_Attribute_Reference [Attribute_Valid]): Disable expansion… · 88438c0e
      exp_attr.adb (Expand_N_Attribute_Reference [Attribute_Valid]): Disable expansion when generating C code.
      
      2016-04-20  Arnaud Charlet  <charlet@adacore.com>
      
      	* exp_attr.adb (Expand_N_Attribute_Reference [Attribute_Valid]):
      	Disable expansion when generating C code.
      	* sinfo.ads, inline.ads: Minor editing.
      
      From-SVN: r235247
      Arnaud Charlet committed
    • sem_util.adb, [...]: Minor reformatting. · c37e6613
      2016-04-20  Hristian Kirtchev  <kirtchev@adacore.com>
      
      	* sem_util.adb, contracts.adb, ghost.adb, exp_ch6.adb: Minor
      	reformatting.
      
      From-SVN: r235246
      Hristian Kirtchev committed
    • contracts.adb (Build_Postconditions_Procedure): Code cleanup. · 7f5e1dee
      2016-04-20  Javier Miranda  <miranda@adacore.com>
      
      	* contracts.adb (Build_Postconditions_Procedure): Code cleanup.
      	* ghost.adb (Os_OK_Ghost_Context.Is_OK_Declaration): Handle the
      	declaration of the internally built _postcondition procedure.
      
      From-SVN: r235245
      Javier Miranda committed
    • [multiple changes] · 31ae1b46
      2016-04-20  Arnaud Charlet  <charlet@adacore.com>
      
      	* snames.ads-tmpl (Internal_Attribute_Id, Attribute_Class_Array): Fix
      	indentation.
      	* sem_util.adb (Is_Unchecked_Conversion_Instance):
      	defense against library-level renamings of other functions,
      	which are never instances of Unchecked_Conversion.
      	* einfo.ads: minor fix of casing in comment
      
      2016-04-20  Ed Schonberg  <schonberg@adacore.com>
      
      	* exp_ch6.adb (Expand_N_Subprogram_Stub): Do not expand a body
      	that has been analyzed and expanded already. Qualify the names
      	in the proper body for use in the generation of C code.
      
      From-SVN: r235244
      Arnaud Charlet committed
    • [multiple changes] · 1ba563f5
      2016-04-20  Javier Miranda  <miranda@adacore.com>
      
      	* contracts.adb (Build_Postconditions_Procedure): Force its
      	inlining when generating C code.
      	* sem_attr.adb (Analyze_Attribute_Old_Result): Handle inlined
      	_postconditions when generating C code.
      	* exp_ch6.adb (Inlined_Subprogram): Inline calls to
      	_postconditions when generating C code.
      	* sinfo.ads, sinfo.adb (Corresponding_Spec, Set_Corresponding_Spec):
      	types of return value and argument changed from Node_Id to
      	Entity_Id.
      
      2016-04-20  Vincent Celier  <celier@adacore.com>
      
      	* make.adb, clean.adb, gnatname.adb: Revert previous change for now.
      
      2016-04-20  Eric Botcazou  <ebotcazou@adacore.com>
      
      	* sem_ch12.adb (Analyze_Instance_And_Renamings): Do not reset
      	the Has_Delayed_Freeze flag on the anonymous instance node.
      
      From-SVN: r235243
      Arnaud Charlet committed
    • [multiple changes] · e361e9a1
      2016-04-20  Javier Miranda  <miranda@adacore.com>
      
      	* sem_ch5.adb (Analyze_Iterator_Specification): Remove transient
      	scope associated with the renaming object declaration.
      	* exp_util.adb (Insert_Actions): Remove handling of iterator
      	loop marked as requiring the secondary stack.
      
      2016-04-20  Ed Schonberg  <schonberg@adacore.com>
      
      	* sem_attr.adb (Analyze_Attribute, case 'Image): Implement
      	AI12-0124, which extends the functionality of the attribute so it
      	reflects the semantics of GNAT 'Img when applied to scalar types.
      	* lib-xref.adb: minor whitespace layout fix.
      
      From-SVN: r235242
      Arnaud Charlet committed
    • [multiple changes] · d67ffa88
      2016-04-20  Vincent Celier  <celier@adacore.com>
      
      	* clean.adb (Gnatclean): Fail if project file specified and
      	gprclean is not available.
      	* gnatname.adb: Fail is -P is used and gprname is not available.
      	* make.adb (Initialize): Fail if project file specified and
      	gprbuild is not available.
      
      2016-04-20  Bob Duff  <duff@adacore.com>
      
      	* sem_ch5.adb (Analyze_Iterator_Specification): Do not use secondary
      	stack when possible.
      
      From-SVN: r235241
      Arnaud Charlet committed
    • [multiple changes] · 93e90bf4
      2016-04-20  Gary Dismukes  <dismukes@adacore.com>
      
      	* par_sco.adb, sem_util.adb, sem_ch13.adb: Minor typo corrections and
      	reformatting.
      
      2016-04-20  Ed Schonberg  <schonberg@adacore.com>
      
      	* sem_prag.adb (Analyze_Pragma, case Default_Storage_Pool):
      	If the pragma comes from an aspect specification, verify that
      	the aspect applies to an entity with a declarative part.
      	* exp_ch5.adb: Code cleanup.
      
      2016-04-20  Ed Schonberg  <schonberg@adacore.com>
      
      	* sem_res.adb (Resolve_If_Expression): If first expression is
      	universal, resolve subsequent ones with the corresponding class
      	type (Any_Integer or Any_Real).
      
      2016-04-20  Ed Schonberg  <schonberg@adacore.com>
      
      	* sem_ch5.adb (Analyze_Iterator_Specification): If expansion is
      	disabled, complete the analysis of the iterator name to ensure
      	that reference for entities within are properly generated.
      
      2016-04-20  Arnaud Charlet  <charlet@adacore.com>
      
      	* a-dispat.ads (Yield): add Global contract.
      	* a-calend.ads, a-reatim.ads: Added Initializes => Clock_Time.
      	* a-taside.adb: Added Initializes => Tasking_State.
      
      From-SVN: r235240
      Arnaud Charlet committed
    • sem_ch13.adb (Build_Invariant_Procedure): Reimplement the invariant procedure… · ae3d8837
      sem_ch13.adb (Build_Invariant_Procedure): Reimplement the invariant procedure spec and body insertion.
      
      2016-04-20  Hristian Kirtchev  <kirtchev@adacore.com>
      
      	* sem_ch13.adb (Build_Invariant_Procedure):
      	Reimplement the invariant procedure spec and body insertion.
      
      From-SVN: r235239
      Hristian Kirtchev committed
    • [multiple changes] · 776fbb74
      2016-04-20  Hristian Kirtchev  <kirtchev@adacore.com>
      
      	* sem_ch13.adb (Add_Invariant): Do not replace
      	the saved expression of an invariatn aspect when inheriting
      	a class-wide type invariant as this clobbers the existing
      	expression. Do not use New_Copy_List as it is unnecessary
      	and leaves the parent pointers referencing the wrong part of
      	the tree. Do not replace the type references for ASIS when
      	inheriting a class-wide type invariant as this clobbers the
      	existing replacement.
      
      2016-04-20  Ed Schonberg  <schonberg@adacore.com>
      
      	* sem_util.adb (Build_Explicit_Dereference): If the designated
      	expression is an entity name, generate reference to the entity
      	because it will not be resolved again.
      
      From-SVN: r235238
      Arnaud Charlet committed
    • re PR tree-optimization/70726 (Internal compiler error (ICE) on valid code) · 60d393e8
      2016-04-20  Richard Biener  <rguenther@suse.de>
      
      	PR tree-optimization/70726
      	* tree-vect-stmts.c (vectorizable_shift): Do not use scalar
      	shift amounts from a pattern stmt operand.
      
      	* g++.dg/vect/pr70726.cc: New testcase.
      
      From-SVN: r235236
      Richard Biener committed
    • PR70674: S/390: Add memory barrier to stack pointer restore from fpr. · 82c6f58a
      This patches fixes a problem with stack variable accesses being
      scheduled after the stack pointer restore instructions.  In the
      testcase this happened with the stack variable 'a' accessed through the
      frame pointer.
      
      The existing stack_tie we have in the backend is basically useless
      when trying to block stack variable accesses from being scheduled
      across an insn.  The alias set of stack variables and the frame alias
      set usually differ and hence aren't in conflict with each other.  The
      solution appears to be a magic MEM term with a scratch register which
      is handled as a full memory barrier when analyzing scheduling
      dependencies.
      
      With the patch a (clobber (mem:BLK (scratch))) is being added to the
      restore instruction in order to prevent any memory operations to be
      scheduled across the insn.  The patch does that only for the one case
      where the stack pointer is restored from an FPR.  Theoretically this
      might happen also in the case where the stack pointer gets restored
      using a load multiple.  However, triggering that problem with
      load-multiple appears to be much harder since the load-multiple will
      restore the frame pointer as well.  So in order to see the problem a
      different call-clobbered register would need to be used as temporary
      stack pointer.
      
      Another case which needs to be handled some day is the stack pointer
      allocation part.  It needs to be a memory barrier as well.
      
      Bootstrapped and regression tested with --with-arch z196 and z13 on
      s390 and s390x.
      
      -Andreas-
      
      gcc/ChangeLog:
      
      2016-04-20  Andreas Krebbel  <krebbel@linux.vnet.ibm.com>
      
      	PR target/70674
      	* config/s390/s390.c (s390_restore_gprs_from_fprs): Pick the new
      	stack_restore_from_fpr pattern when restoring r15.
      	(s390_optimize_prologue): Strip away the memory barrier in the
      	parallel when trying to get rid of restore insns.
      	* config/s390/s390.md ("stack_restore_from_fpr"): New insn
      	definition for loading the stack pointer from an FPR.  Compared to
      	the normal move insn this pattern includes a full memory barrier.
      
      gcc/testsuite/ChangeLog:
      
      2016-04-20  Andreas Krebbel  <krebbel@linux.vnet.ibm.com>
      
      	PR target/70674
      	* gcc.target/s390/pr70674.c: New test.
      
      From-SVN: r235234
      Andreas Krebbel committed
    • re PR middle-end/70680 (OpenMP SIMD linear variable privatized too eagerly) · 84311083
      	PR middle-end/70680
      	* gimplify.c (gimplify_omp_for): Call omp_notice_variable for
      	implicitly linear or lastprivate iterator on the outer context.
      
      	* testsuite/libgomp.c/pr70680-1.c: New test.
      	* testsuite/libgomp.c/pr70680-2.c: New test.
      
      From-SVN: r235232
      Jakub Jelinek committed
    • Attach PR number to most recent entry. · 743af971
      From-SVN: r235231
      Ben Elliston committed
    • Daily bump. · afe0fab2
      From-SVN: r235230
      GCC Administrator committed
  2. 19 Apr, 2016 20 commits
    • Remove ssememalign · 6048e2ed
      From INSTRUCTION EXCEPTION SPECIFICATION section in Intel software
      developer manual volume 2, only legacy SSE instructions with memory
      operand not 16-byte aligned get General Protection fault.  There is
      no need to check 1, 2, 4, 8 byte alignments.  Since x86 backend has
      accurate constraints and predicates for 16-byte alignment, we can
      remove alignment check in ix86_legitimate_combined_insn.
      
      	* config/i386/i386.c (ix86_legitimate_combined_insn): Remove
      	alignment check.
      	* config/i386/i386.md (ssememalign): Removed.
      	* config/i386/sse.md: Remove ssememalign attribute from patterns.
      
      From-SVN: r235224
      H.J. Lu committed
    • libjava.exp (libjava_arguments): Use 'file normalize' rather than the defunct… · 14f0f2fc
      libjava.exp (libjava_arguments): Use 'file normalize' rather than the defunct DejaGnu 'absolute' proc.
      
      	* testsuite/lib/libjava.exp (libjava_arguments): Use 'file
      	normalize' rather than the defunct DejaGnu 'absolute' proc.
      
      From-SVN: r235222
      Ben Elliston committed
    • PR c++/66543 - -Wunused-but-set* false positives · 76f39440
      	* expr.c (mark_exp_read): Handle NON_DEPENDENT_EXPR.
      	* pt.c (make_pack_expansion): Call mark_exp_read.
      	* semantics.c (finish_id_expression): Call mark_type_use in
      	unevaluated context.
      
      From-SVN: r235221
      Jason Merrill committed
    • re PR libfortran/70684 (incorrect reading of values from file on Windows) · 90eeab20
      2016-04-19  Jerry DeLisle  <jvdelisle@gcc.gnu.org>
      
      	PR libgfortran/70684
      	* io/list_read (check_buffers): Add '\r' to check for end of line.
      	factor.
      
      	* gfortran.dg/list_read_14.f90: New test.
      
      From-SVN: r235220
      Jerry DeLisle committed
    • DR 2137 - copy-constructor rank in list-initialization · 218e9dde
      	* call.c (implicit_conversion): If we choose a copy constructor
      	for list-initialization from the same type, the conversion is an
      	exact match.
      
      From-SVN: r235219
      Jason Merrill committed
    • Improve constexpr handling of other loop forms. · 06ec22b7
      	* constexpr.c (breaks): Handle EXIT_EXPR.
      	(cxx_eval_loop_expr): Handle COMPOUND_EXPR body.
      	(cxx_eval_constant_expression): Handle EXIT_EXPR, improve handling
      	of COMPOUND_EXPR.
      
      From-SVN: r235218
      Jason Merrill committed
    • PR c++/68206 - Fix constexpr diagnostics with loops. · f937929e
      	PR c++/68530
      	* constexpr.c (potential_constant_expression_1): Handle LOOP_EXPR
      	and GOTO_EXPR.
      
      From-SVN: r235217
      Jason Merrill committed
    • libstdc++/69703 ignore endianness in codecvt_utf8 · 29ca91f7
      	PR libstdc++/69703
      	* src/c++11/codecvt.cc (__codecvt_utf8_base<char16_t>::do_in)):
      	Override endianness bit in mode.
      	* testsuite/22_locale/codecvt/codecvt_utf8/69703.cc: New test.
      	* testsuite/22_locale/codecvt/codecvt_utf8_utf16/66855.cc: Test
      	that little_endian mode is ignored.
      	* testsuite/experimental/filesystem/path/native/string.cc: New test.
      
      From-SVN: r235216
      Jonathan Wakely committed
    • libstdc++/70609 fix filesystem::copy() · 14905251
      	PR libstdc++/70609
      	* src/filesystem/ops.cc (close_fd): New function.
      	(do_copy_file): Set permissions before copying file contents. Check
      	result of closing file descriptors. Don't copy streambuf when file
      	is empty.
      	(copy(const path&, const path&, copy_options, error_code&)): Use
      	lstat for source file when copy_symlinks is set.
      	* testsuite/experimental/filesystem/operations/copy.cc: Test copy().
      
      From-SVN: r235215
      Jonathan Wakely committed
    • Add noexcept to Filesystem TS operators · 9c476ad4
      	* include/experimental/bits/fs_fwd.h (operator&, operator|, operator^,
      	operator~ operator&=, operator|=, operator^=): Add noexcept to
      	overloaded operators for copy_options, perms and directory_options.
      	* src/filesystem/ops.cc (make_file_type, make_file_status,
      	is_not_found_errno, file_time): Add noexcept.
      
      From-SVN: r235214
      Jonathan Wakely committed
    • Tiny C++ cleanups. · b1e47084
      	* pt.c (tsubst_expr): Remove shadowing declaration.
      	(tsubst_pack_expansion): Add assert.
      	* semantics.c (add_decl_expr): Use DECL_SOURCE_LOCATION.
      
      From-SVN: r235213
      Jason Merrill committed
    • Allocate memory on cache line if requested · 831698b8
      Since GTM::gtm_thread has
      
      gtm_thread *next_thread __attribute__((__aligned__(HW_CACHELINE_SIZE)));
      
      GTM::gtm_thread::operator new () calls xmalloc with separate_cl == true.
      xmalloc must return memory on cache line in this case.
      
      	PR libitm/70456
      	* util.cc (xmalloc): Use posix_memalign to allocate memory on
      	on cache line if requested.
      
      From-SVN: r235211
      H.J. Lu committed
    • c++14_warning.h: Do not refer C++14 as experimental. · d855ad89
      2016-04-19  Edward Smith-Rowland  <3dw4rd@verizon.net>
      
      	* include/bits/c++14_warning.h: Do not refer C++14 as experimental.
      
      From-SVN: r235210
      Edward Smith-Rowland committed
    • Remove UNSPEC_LOADU and UNSPEC_STOREU · fc9cf6da
      Since *mov<mode>_internal and <avx512>_(load|store)<mode>_mask patterns
      can handle unaligned load and store, we can remove UNSPEC_LOADU and
      UNSPEC_STOREU.  We use function prototypes with pointer to scalar for
      unaligned load/store builtin functions so that memory passed to
      *mov<mode>_internal is unaligned.
      
      gcc/
      
      	PR target/69201
      	* config/i386/avx512bwintrin.h (_mm512_mask_loadu_epi16): Pass
      	const short * to __builtin_ia32_loaddquhi512_mask.
      	(_mm512_maskz_loadu_epi16): Likewise.
      	(_mm512_mask_storeu_epi16): Pass short * to
      	__builtin_ia32_storedquhi512_mask.
      	(_mm512_mask_loadu_epi8): Pass const char * to
      	__builtin_ia32_loaddquqi512_mask.
      	(_mm512_maskz_loadu_epi8): Likewise.
      	(_mm512_mask_storeu_epi8): Pass char * to
      	__builtin_ia32_storedquqi512_mask.
      	* config/i386/avx512fintrin.h (_mm512_loadu_pd): Pass
      	const double * to __builtin_ia32_loadupd512_mask.
      	(_mm512_mask_loadu_pd): Likewise.
      	(_mm512_maskz_loadu_pd): Likewise.
      	(_mm512_storeu_pd): Pass double * to
      	__builtin_ia32_storeupd512_mask.
      	(_mm512_mask_storeu_pd): Likewise.
      	(_mm512_loadu_ps): Pass const float * to
      	__builtin_ia32_loadups512_mask.
      	(_mm512_mask_loadu_ps): Likewise.
      	(_mm512_maskz_loadu_ps): Likewise.
      	(_mm512_storeu_ps): Pass float * to
      	__builtin_ia32_storeups512_mask.
      	(_mm512_mask_storeu_ps): Likewise.
      	(_mm512_mask_loadu_epi64): Pass const long long * to
      	__builtin_ia32_loaddqudi512_mask.
      	(_mm512_maskz_loadu_epi64): Likewise.
      	(_mm512_mask_storeu_epi64): Pass long long *
      	to __builtin_ia32_storedqudi512_mask.
      	(_mm512_loadu_si512): Pass const int * to
      	__builtin_ia32_loaddqusi512_mask.
      	(_mm512_mask_loadu_epi32): Likewise.
      	(_mm512_maskz_loadu_epi32): Likewise.
      	(_mm512_storeu_si512): Pass int * to
      	__builtin_ia32_storedqusi512_mask.
      	(_mm512_mask_storeu_epi32): Likewise.
      	* config/i386/avx512vlbwintrin.h (_mm256_mask_storeu_epi8): Pass
      	char * to __builtin_ia32_storedquqi256_mask.
      	(_mm_mask_storeu_epi8): Likewise.
      	(_mm256_mask_loadu_epi16): Pass const short * to
      	__builtin_ia32_loaddquhi256_mask.
      	(_mm256_maskz_loadu_epi16): Likewise.
      	(_mm_mask_loadu_epi16): Pass const short * to
      	__builtin_ia32_loaddquhi128_mask.
      	(_mm_maskz_loadu_epi16): Likewise.
      	(_mm256_mask_loadu_epi8): Pass const char * to
      	__builtin_ia32_loaddquqi256_mask.
      	(_mm256_maskz_loadu_epi8): Likewise.
      	(_mm_mask_loadu_epi8): Pass const char * to
      	__builtin_ia32_loaddquqi128_mask.
      	(_mm_maskz_loadu_epi8): Likewise.
      	(_mm256_mask_storeu_epi16): Pass short * to.
      	__builtin_ia32_storedquhi256_mask.
      	(_mm_mask_storeu_epi16): Pass short * to.
      	__builtin_ia32_storedquhi128_mask.
      	* config/i386/avx512vlintrin.h (_mm256_mask_loadu_pd): Pass
      	const double * to __builtin_ia32_loadupd256_mask.
      	(_mm256_maskz_loadu_pd): Likewise.
      	(_mm_mask_loadu_pd): Pass onst double * to
      	__builtin_ia32_loadupd128_mask.
      	(_mm_maskz_loadu_pd): Likewise.
      	(_mm256_mask_storeu_pd): Pass double * to
      	__builtin_ia32_storeupd256_mask.
      	(_mm_mask_storeu_pd): Pass double * to
      	__builtin_ia32_storeupd128_mask.
      	(_mm256_mask_loadu_ps): Pass const float * to
      	__builtin_ia32_loadups256_mask.
      	(_mm256_maskz_loadu_ps): Likewise.
      	(_mm_mask_loadu_ps): Pass const float * to
      	__builtin_ia32_loadups128_mask.
      	(_mm_maskz_loadu_ps): Likewise.
      	(_mm256_mask_storeu_ps): Pass float * to
      	__builtin_ia32_storeups256_mask.
      	(_mm_mask_storeu_ps): ass float * to
      	__builtin_ia32_storeups128_mask.
      	(_mm256_mask_loadu_epi64): Pass const long long * to
      	__builtin_ia32_loaddqudi256_mask.
      	(_mm256_maskz_loadu_epi64): Likewise.
      	(_mm_mask_loadu_epi64): Pass const long long * to
      	__builtin_ia32_loaddqudi128_mask.
      	(_mm_maskz_loadu_epi64): Likewise.
      	(_mm256_mask_storeu_epi64): Pass long long * to
      	__builtin_ia32_storedqudi256_mask.
      	(_mm_mask_storeu_epi64): Pass long long * to
      	__builtin_ia32_storedqudi128_mask.
      	(_mm256_mask_loadu_epi32): Pass const int * to
      	__builtin_ia32_loaddqusi256_mask.
      	(_mm256_maskz_loadu_epi32): Likewise.
      	(_mm_mask_loadu_epi32): Pass const int * to
      	__builtin_ia32_loaddqusi128_mask.
      	(_mm_maskz_loadu_epi32): Likewise.
      	(_mm256_mask_storeu_epi32): Pass int * to
      	__builtin_ia32_storedqusi256_mask.
      	(_mm_mask_storeu_epi32): Pass int * to
      	__builtin_ia32_storedqusi128_mask.
      	* config/i386/i386-builtin-types.def (PCSHORT): New.
      	(PINT64): Likewise.
      	(V64QI_FTYPE_PCCHAR_V64QI_UDI): Likewise.
      	(V32HI_FTYPE_PCSHORT_V32HI_USI): Likewise.
      	(V32QI_FTYPE_PCCHAR_V32QI_USI): Likewise.
      	(V16SF_FTYPE_PCFLOAT_V16SF_UHI): Likewise.
      	(V8DF_FTYPE_PCDOUBLE_V8DF_UQI): Likewise.
      	(V16SI_FTYPE_PCINT_V16SI_UHI): Likewise.
      	(V16HI_FTYPE_PCSHORT_V16HI_UHI): Likewise.
      	(V16QI_FTYPE_PCCHAR_V16QI_UHI): Likewise.
      	(V8SF_FTYPE_PCFLOAT_V8SF_UQI): Likewise.
      	(V8DI_FTYPE_PCINT64_V8DI_UQI): Likewise.
      	(V8SI_FTYPE_PCINT_V8SI_UQI): Likewise.
      	(V8HI_FTYPE_PCSHORT_V8HI_UQI): Likewise.
      	(V4DF_FTYPE_PCDOUBLE_V4DF_UQI): Likewise.
      	(V4SF_FTYPE_PCFLOAT_V4SF_UQI): Likewise.
      	(V4DI_FTYPE_PCINT64_V4DI_UQI): Likewise.
      	(V4SI_FTYPE_PCINT_V4SI_UQI): Likewise.
      	(V2DF_FTYPE_PCDOUBLE_V2DF_UQI): Likewise.
      	(V2DI_FTYPE_PCINT64_V2DI_UQI): Likewise.
      	(VOID_FTYPE_PDOUBLE_V8DF_UQI): Likewise.
      	(VOID_FTYPE_PDOUBLE_V4DF_UQI): Likewise.
      	(VOID_FTYPE_PDOUBLE_V2DF_UQI): Likewise.
      	(VOID_FTYPE_PFLOAT_V16SF_UHI): Likewise.
      	(VOID_FTYPE_PFLOAT_V8SF_UQI): Likewise.
      	(VOID_FTYPE_PFLOAT_V4SF_UQI): Likewise.
      	(VOID_FTYPE_PINT64_V8DI_UQI): Likewise.
      	(VOID_FTYPE_PINT64_V4DI_UQI): Likewise.
      	(VOID_FTYPE_PINT64_V2DI_UQI): Likewise.
      	(VOID_FTYPE_PINT_V16SI_UHI): Likewise.
      	(VOID_FTYPE_PINT_V8SI_UHI): Likewise.
      	(VOID_FTYPE_PINT_V4SI_UHI): Likewise.
      	(VOID_FTYPE_PSHORT_V32HI_USI): Likewise.
      	(VOID_FTYPE_PSHORT_V16HI_UHI): Likewise.
      	(VOID_FTYPE_PSHORT_V8HI_UQI): Likewise.
      	(VOID_FTYPE_PCHAR_V64QI_UDI): Likewise.
      	(VOID_FTYPE_PCHAR_V32QI_USI): Likewise.
      	(VOID_FTYPE_PCHAR_V16QI_UHI): Likewise.
      	(V64QI_FTYPE_PCV64QI_V64QI_UDI): Removed.
      	(V32HI_FTYPE_PCV32HI_V32HI_USI): Likewise.
      	(V32QI_FTYPE_PCV32QI_V32QI_USI): Likewise.
      	(V16HI_FTYPE_PCV16HI_V16HI_UHI): Likewise.
      	(V16QI_FTYPE_PCV16QI_V16QI_UHI): Likewise.
      	(V8HI_FTYPE_PCV8HI_V8HI_UQI): Likewise.
      	(VOID_FTYPE_PV32HI_V32HI_USI): Likewise.
      	(VOID_FTYPE_PV16HI_V16HI_UHI): Likewise.
      	(VOID_FTYPE_PV8HI_V8HI_UQI): Likewise.
      	(VOID_FTYPE_PV64QI_V64QI_UDI): Likewise.
      	(VOID_FTYPE_PV32QI_V32QI_USI): Likewise.
      	(VOID_FTYPE_PV16QI_V16QI_UHI): Likewise.
      	* config/i386/i386.c (ix86_emit_save_reg_using_mov): Don't
      	use UNSPEC_STOREU.
      	(ix86_emit_restore_sse_regs_using_mov): Don't use UNSPEC_LOADU.
      	(ix86_avx256_split_vector_move_misalign): Don't use unaligned
      	load nor store.
      	(ix86_expand_vector_move_misalign): Likewise.
      	(bdesc_special_args): Use CODE_FOR_movvNXY_internal and pointer
      	to scalar function prototype for unaligned load/store builtins.
      	(ix86_expand_special_args_builtin): Updated.
      	* config/i386/sse.md (UNSPEC_LOADU): Removed.
      	(UNSPEC_STOREU): Likewise.
      	(VI_ULOADSTORE_BW_AVX512VL): Likewise.
      	(VI_ULOADSTORE_F_AVX512VL): Likewise.
      	(ssescalarsize): Handle V4TI, V2TI and V1TI.
      	(<sse>_loadu<ssemodesuffix><avxsizesuffix><mask_name>): Likewise.
      	(*<sse>_loadu<ssemodesuffix><avxsizesuffix><mask_name>): Likewise.
      	(<sse>_storeu<ssemodesuffix><avxsizesuffix>): Likewise.
      	(<avx512>_storeu<ssemodesuffix><avxsizesuffix>_mask): Likewise.
      	(<sse2_avx_avx512f>_loaddqu<mode><mask_name>): Likewise.
      	(*<sse2_avx_avx512f>_loaddqu<mode><mask_name>"): Likewise.
      	(sse2_avx_avx512f>_storedqu<mode>): Likewise.
      	(<avx512>_storedqu<mode>_mask): Likewise.
      	(*sse4_2_pcmpestr_unaligned): Likewise.
      	(*sse4_2_pcmpistr_unaligned): Likewise.
      	(*mov<mode>_internal): Renamed to ...
      	(mov<mode>_internal): This.  Remove check of AVX and IAMCU on
      	misaligned operand.  Replace vmovdqu64 with vmovdqu<ssescalarsize>.
      	(movsd/movhpd to movupd peephole): Don't use UNSPEC_LOADU.
      	(movlpd/movhpd to movupd peephole): Don't use UNSPEC_STOREU.
      
      gcc/testsuite/
      
      	PR target/69201
      	* gcc.target/i386/avx256-unaligned-store-1.c (a): Make it
      	extern to force it misaligned.
      	(b): Likewise.
      	(c): Likewise.
      	(d): Likewise.
      	Check vmovups.*movv8sf_internal/3 instead of avx_storeups256.
      	Don't check `*' before movv4sf_internal.
      	* gcc.target/i386/avx256-unaligned-store-2.c: Check
      	vmovups.*movv32qi_internal/3 instead of avx_storeups256.
      	Don't check `*' before movv16qi_internal.
      	* gcc.target/i386/avx256-unaligned-store-3.c (a): Make it
      	extern to force it misaligned.
      	(b): Likewise.
      	(c): Likewise.
      	(d): Likewise.
      	Check vmovups.*movv4df_internal/3 instead of avx_storeupd256.
      	Don't check `*' before movv2df_internal.
      	* gcc.target/i386/avx256-unaligned-store-4.c (a): Make it
      	extern to force it misaligned.
      	(b): Likewise.
      	(c): Likewise.
      	(d): Likewise.
      	Check movv8sf_internal instead of avx_storeups256.
      	Check movups.*movv4sf_internal/3 instead of avx_storeups256.
      
      From-SVN: r235209
      H.J. Lu committed
    • re PR tree-optimization/70171 (Poor code generated when return struct using ternary operator) · ea8927ea
      2016-04-19  Richard Biener  <rguenther@suse.de>
      
      	PR tree-optimization/70171
      	* tree-ssa-phiprop.c: Include stor-layout.h.
      	(phiprop_insert_phi): Handle the aggregate copy case.
      	(propagate_with_phi): Likewise.
      
      	* g++.dg/tree-ssa/pr70171.C: New testcase.
      
      From-SVN: r235208
      Richard Biener committed
    • i386.c (ix86_decompose_address): Use lowpart_subreg instead of simplify_gen_subreg (... · 9a81dba6
      	* config/i386/i386.c (ix86_decompose_address): Use lowpart_subreg
      	instead of simplify_gen_subreg (... , 0).
      	(ix86_delegitimize_address): Ditto.
      	(ix86_split_divmod): Ditto.
      	(ix86_split_copysign_const): Ditto.
      	(ix86_split_copysign_var): Ditto.
      	(ix86_expand_args_builtin): Ditto.
      	(ix86_expand_round_builtin): Ditto.
      	(ix86_expand_special_args_builtin): Ditto.
      	* config/i386/i386.md (TARGET_USE_VECTOR_FP_CONVERTS splitters): Ditto.
      	(TARGET_SSE_PARTIAL_REG_DEPENDENCY splitters and peephole2s): Ditto.
      	(udivmodqi4): Ditto.
      	(absneg splitters): Ditto.
      	(*jcc_bt<mode>_1): Ditto.
      
      From-SVN: r235207
      Uros Bizjak committed
    • re PR c++/70522 (Hidden friend functions block qualified name lookup into nested unnamed namespace) · 3ba065e8
      	PR c++/70522
      
      	* name-lookup.c (qualified_lookup_using_namespace): Look through
      	hidden names.
      
      From-SVN: r235206
      Jason Merrill committed
    • standard_and_implementation_defined_restrictions.rst, [...]: Update documentation. · a0176903
              * doc/gnat_rm/standard_and_implementation_defined_restrictions.rst,
              gnat_rm.texi: Update documentation.
      
      From-SVN: r235205
      Arnaud Charlet committed
    • [multiple changes] · 009c0268
      2016-04-19  Olivier Hainque  <hainque@adacore.com>
      
      	* par_sco.adb (Traverse_One, case N_Case_Statement):
      	Skip pragmas before the first alternative.
      	(Traverse_Handled_Statement_Sequence, Exception_Handlers): Likewise.
      
      2016-04-19  Tristan Gingold  <gingold@adacore.com>
      
      	* adaint.c (__gnat_lwp_self): New function (for darwin).
      	* s-osinte-darwin.ads, s-osinte-darwin.adb (lwp_self): Import
      	of __gnat_lwp_self.
      
      From-SVN: r235204
      Arnaud Charlet committed
    • re PR tree-optimization/70724 (Miscompiles python3 with FDO) · 65f52ee9
      2016-04-19  Richard Biener  <rguenther@suse.de>
      
      	PR tree-optimization/70724
      	* tree-ssa-sccvn.c (scc_vn_restore_ssa_info): Split SSA info
      	restoring out from ...
      	(free_scc_vn): ... here.
      	* tree-ssa-sccvn.h (scc_vn_restore_ssa_info): Declare.
      	* tres-ssa-pre.c (pass_pre::execute): Restore SSA info before
      	tail merging.
      	(pass_fre::execute): Restore SSA info.
      
      	* gcc.dg/torture/pr70724.c: New testcase.
      
      From-SVN: r235203
      Richard Biener committed