On Fri, Aug 24, 2018 at 03:56:27PM +0200, Uros Bizjak wrote:
> 2018-08-23  Uros Bizjak  <ubiz...@gmail.com>
> 
>     * emit-rtl.c (init_emit_once): Do not emit MODE_POINTER_BOUNDS RTXes.
>     * emit-rtl.h (rtl_data): Remove return_bnd.
>     * explow.c (trunc_int_for_mode): Do not handle POINTER_BOUNDS_MODE_P.
>     * function.c (diddle_return_value): Do not handle crtl->return_bnd.
>     * genmodes.c (complete_mode): Do not handle MODE_POINTER_BOUNDS.
>     (POINTER_BOUNDS_MODE): Remove definition.
>     (make_pointer_bounds_mode): Remove.
>     (get_mode_class): Do not handle MODE_POINTER_BOUNDS.
>     * machmode.h (POINTER_BOUNDS_MODE_P): Remove definition.
>     (scalare_mode::includes_p): Do not handle MODE_POINTER_BOUNDS.
>     * mode-classes.def: Do not define MODE_POINTER_BOUNDS.
>     * stor-layout.c (int_mode_for_mode): Do not handle MODE_POINTER_BOUNDS.
>     * tree-core.h (enum tree_index): Remove TI_POINTER_BOUNDS_TYPE.
>     * varasm.c (output_constant_pool_2): Do not handle MODE_POINTER_BOUNDS.
> 
>     * config/i386/i386-modes.def (BND32, BND64): Remove.
>     * config/i386/i386.c (dbx_register_map): Remove bound registers.
>     (dbx64_register_map): Ditto.
>     (svr4_dbx_register_map): Ditto.
>     (indirect_thunk_bnd_needed): Remove.
>     (indirect_thunks_bnd_used): Ditto.
>     (indirect_return_bnd_needed): Ditto.
>     (indirect_return_via_cx_bnd): Ditto.
>     (enum indirect_thunk_prefix): Remove indirect_thunk_prefix_bnd.
>     (indirect_thunk_name): Remove handling of indirect_thunk_prefix_bnd.
>     (output_indirect_thunk): Ditto.  Remove need_prefix argument.
>     (output_indirect_thunk_function): Remove handling of
>     indirect_return_bnd_needed, indirect_return_via_cx_bnd,
>     indirect_thunk_bnd_needed and indirect_thunks_bnd_used variables.
>     (ix86_save_reg): Remove handling of crtl->return_bnd.
>     (ix86_legitimate_constant_p): Remove handling of POINTER_BOUNDS_MODE_P.
>     (ix86_print_operand_address_as): Remove handling of UNSPEC_BNDMK_ADDR
>     and UNSPEC_BNDLX_ADDR.
>     (ix86_output_indirect_branch_via_reg): Remove handling of
>     indirect_thunk_prefix_bnd.
>     (ix86_output_indirect_branch_via_push): Ditto.
>     (ix86_output_function_return): Ditto.
>     (ix86_output_indirect_function_return): Ditto.
>     (avoid_func_arg_motion): Do not handle UNSPEC_BNDSTX.
>     * config/i386/i386.h (FIXED_REGISTERS): Remove bound registers.
>     (CALL_USED_REGISTERS): Ditto.
>     (REG_ALLOC_ORDER): Update for removal of bound registers.
>     (HI_REGISTER_NAMES): Ditto.
>     * config/i386/i386.md (UNSPEC_BNDMK, UNSPEC_BNDMK_ADDR, UNSPEC_BNDSTX)
>     (UNSPEC_BNDLDX, UNSPEC_BNDLDX_ADDR, UNSPEC_BNDCL, UNSPEC_BNDCU)
>     (UNSPEC_BNDCN, UNSPEC_MPX_FENCE): Remove.
>     (BND0_REG, BND1_REG, BND2_REG, BND3_REG): Remove
>     (FIRST_PSEUDO_REG): Update.
>     (BND): Remove mode iterator.
>     * config/i386/predicates.md (bnd_mem_operator): Remove.
> 
> Bootstrapped and regression tested on x86_64-linux-gnu {,-m32}.
> 
> OK for mainline?

OPk, thanks.

        Jakub

Reply via email to