1. 25 Oct, 2013 8 commits
    • recog.c (search_ofs): New static variable moved from... · e86a8146
      	* recog.c (search_ofs): New static variable moved from...
      	(peep2_find_free_register): ...here.
      	(peephole2_optimize): Initialize it.
      
      From-SVN: r204050
      Eric Botcazou committed
    • invoke.texi (fopenmp): Change supported OpenMP version to 4.0. · 24ebcbc8
      2013-10-25  Tobias Burnus  <burnus@net-b.de>
      
              * doc/invoke.texi (fopenmp): Change supported OpenMP version
              to 4.0.
      
      From-SVN: r204049
      Tobias Burnus committed
    • i386.h (TARGET_MPX): New define. · cb610367
      	* config/i386/i386.h (TARGET_MPX): New define.
      	(TARGET_MPX_P): Ditto.
      
      From-SVN: r204048
      Uros Bizjak committed
    • re PR other/33426 (Support of #pragma ivdep) · 43ae206c
      2013-10-25  Tobias Burnus  <burnus@net-b.de>
      
              PR other/33426
              * parser.c (cp_parser_iteration_statement,
              cp_parser_for, cp_parser_c_for, cp_parser_pragma): Handle
              IVDEP pragma.
      
              * g++.dg/parse/ivdep.C: New.
              * g++.dg/vect/pr33426-ivdep.cc: New.
      
      From-SVN: r204047
      Tobias Burnus committed
    • constraints.md (B): New. · 66d6cbaa
      	* config/i386/constraints.md (B): New.
      	(Ti): New.
      	(Tb): New.
      	* config/i386/i386-c.c (ix86_target_macros_internal): Add __MPX__.
      	* config/i386/i386-modes.def (BND32): New.
      	(BND64): New.
      	* config/i386/i386-protos.h (ix86_bnd_prefixed_insn_p): New.
      	* config/i386/i386.c (isa_opts): Add mmpx.
      	(regclass_map): Add bound registers.
      	(dbx_register_map): Likewise.
      	(dbx64_register_map): Likewise.
      	(svr4_dbx_register_map): Likewise.
      	(PTA_MPX): New.
      	(ix86_option_override_internal): Support MPX ISA.
      	(ix86_conditional_register_usage): Support bound registers.
      	(print_reg): Likewise.
      	(ix86_code_end): Add MPX bnd prefix.
      	(output_set_got): Likewise.
      	(ix86_output_call_insn): Likewise.
      	(ix86_print_operand): Add '!' (MPX bnd) print prefix support.
      	(ix86_print_operand_punct_valid_p): Likewise.
      	(ix86_print_operand_address): Support UNSPEC_BNDMK_ADDR and
      	UNSPEC_BNDMK_ADDR.
      	(ix86_class_likely_spilled_p): Add bound regs support.
      	(ix86_hard_regno_mode_ok): Likewise.
      	(x86_order_regs_for_local_alloc): Likewise.
      	(ix86_bnd_prefixed_insn_p): New.
      	* config/i386/i386.h (FIRST_PSEUDO_REGISTER): Fix to new value.
      	(FIXED_REGISTERS): Add bound registers.
      	(CALL_USED_REGISTERS): Likewise.
      	(REG_ALLOC_ORDER): Likewise.
      	(HARD_REGNO_NREGS): Likewise.
      	(TARGET_MPX): New.
      	(VALID_BND_REG_MODE): New.
      	(FIRST_BND_REG): New.
      	(LAST_BND_REG): New.
      	(reg_class): Add BND_REGS.
      	(REG_CLASS_NAMES): Likewise.
      	(REG_CLASS_CONTENTS): Likewise.
      	(BND_REGNO_P): New.
      	(ANY_BND_REG_P): New.
      	(BNDmode): New.
      	(HI_REGISTER_NAMES): Add bound registers.
      	* config/i386/i386.md (UNSPEC_BNDMK): New.
      	(UNSPEC_BNDMK_ADDR): New.
      	(UNSPEC_BNDSTX): New.
      	(UNSPEC_BNDLDX): New.
      	(UNSPEC_BNDLDX_ADDR): New.
      	(UNSPEC_BNDCL): New.
      	(UNSPEC_BNDCU): New.
      	(UNSPEC_BNDCN): New.
      	(UNSPEC_MPX_FENCE): New.
      	(BND0_REG): New.
      	(BND1_REG): New.
      	(type): Add mpxmov, mpxmk, mpxchk, mpxld, mpxst.
      	(length_immediate): Likewise.
      	(prefix_0f): Likewise.
      	(memory): Likewise.
      	(prefix_rep): Check for bnd prefix.
      	(length_nobnd): New.
      	(length): Use length_nobnd if specified.
      	(BND): New.
      	(bnd_ptr): New.
      	(BNDCHECK): New.
      	(bndcheck): New.
      	(*jcc_1): Add bnd prefix and rename length attr to length_nobnd.
      	(*jcc_2): Likewise.
      	(jump): Likewise.
      	(simple_return_internal): Likewise.
      	(simple_return_pop_internal): Likewise.
      	(*indirect_jump): Add MPX bnd prefix.
      	(*tablejump_1): Likewise.
      	(simple_return_internal_long): Likewise.
      	(simple_return_indirect_internal): Likewise.
      	(<mode>_mk): New.
      	(*<mode>_mk): New.
      	(mov<mode>): New.
      	(*mov<mode>_internal_mpx): New.
      	(<mode>_<bndcheck>): New.
      	(*<mode>_<bndcheck>): New.
      	(<mode>_ldx): New.
      	(*<mode>_ldx): New.
      	(<mode>_stx): New.
      	(*<mode>_stx): New.
      	* config/i386/predicates.md (lea_address_operand): Rename to...
      	(address_no_seg_operand): ... this.
      	(address_mpx_no_base_operand): New.
      	(address_mpx_no_index_operand): New.
      	(bnd_mem_operator): New.
      	* config/i386/i386.opt (mmpx): New.
      	* doc/invoke.texi: Add documentation for the flags -mmpx, -mno-mpx.
      	* doc/rtl.texi Add documentation for BND32mode and BND64mode.
      
      From-SVN: r204046
      Ilya Enkovich committed
    • mode-classes.def (MODE_POINTER_BOUNDS): New. · 65f55bac
              * mode-classes.def (MODE_POINTER_BOUNDS): New.
              * tree.def (POINTER_BOUNDS_TYPE): New.
              * genmodes.c (complete_mode): Support MODE_POINTER_BOUNDS.
              (POINTER_BOUNDS_MODE): New.
              (make_pointer_bounds_mode): New.
              * machmode.h (POINTER_BOUNDS_MODE_P): New.
              * stor-layout.c (int_mode_for_mode): Support MODE_POINTER_BOUNDS.
              (layout_type): Support POINTER_BOUNDS_TYPE.
              * tree-pretty-print.c (dump_generic_node): Support POINTER_BOUNDS_TYPE.
              * tree.c (build_int_cst_wide): Support POINTER_BOUNDS_TYPE.
              (type_contains_placeholder_1): Likewise.
              * tree.h (POINTER_BOUNDS_TYPE_P): New.
              * varasm.c (output_constant): Support POINTER_BOUNDS_TYPE.
              * doc/rtl.texi (MODE_POINTER_BOUNDS): New.
      
      From-SVN: r204045
      Ilya Enkovich committed
    • expr.c (expand_expr_real_1): Use mode of memory reference rather than mode of… · ca9f3779
      expr.c (expand_expr_real_1): Use mode of memory reference rather than mode of address computation when...
      
              * expr.c (expand_expr_real_1): Use mode of memory reference rather
              than mode of address computation when calling memory_address_addr_space.
      
      From-SVN: r204044
      Igor Shevlyakov committed
    • Daily bump. · 0e855edf
      From-SVN: r204043
      GCC Administrator committed
  2. 24 Oct, 2013 25 commits
  3. 23 Oct, 2013 7 commits