|
|
56d343 |
2015-12-24 Kirill Yukhin <kirill.yukhin@intel.com>
|
|
|
56d343 |
|
|
|
56d343 |
* common/config/i386/i386-common.c (OPTION_MASK_ISA_PKU_SET): New.
|
|
|
56d343 |
(OPTION_MASK_ISA_PKU_UNSET): Ditto.
|
|
|
56d343 |
(ix86_handle_option): Handle OPT_mpku.
|
|
|
56d343 |
* config.gcc: Add pkuintrin.h to i[34567]86-*-* and x86_64-*-*
|
|
|
56d343 |
targets.
|
|
|
56d343 |
* config/i386/cpuid.h (host_detect_local_cpu): Detect PKU feature.
|
|
|
56d343 |
* config/i386/i386-c.c (ix86_target_macros_internal): Handle PKU ISA
|
|
|
56d343 |
flag.
|
|
|
56d343 |
* config/i386/i386.c (ix86_target_string): Add "-mpku" to
|
|
|
56d343 |
ix86_target_opts.
|
|
|
56d343 |
(ix86_option_override_internal): Define PTA_PKU, mention new key
|
|
|
56d343 |
in skylake-avx512. Handle new ISA bits.
|
|
|
56d343 |
(ix86_valid_target_attribute_inner_p): Add "pku".
|
|
|
56d343 |
(enum ix86_builtins): Add IX86_BUILTIN_RDPKRU and IX86_BUILTIN_WRPKRU.
|
|
|
56d343 |
(builtin_description bdesc_special_args[]): Add new built-ins.
|
|
|
56d343 |
* config/i386/i386.h (define TARGET_PKU): New.
|
|
|
56d343 |
(define TARGET_PKU_P): Ditto.
|
|
|
56d343 |
* config/i386/i386.md (define_c_enum "unspecv"): Add UNSPEC_PKU.
|
|
|
56d343 |
(define_expand "rdpkru"): New.
|
|
|
56d343 |
(define_insn "*rdpkru"): Ditto.
|
|
|
56d343 |
(define_expand "wrpkru"): Ditto.
|
|
|
56d343 |
(define_insn "*wrpkru"): Ditto.
|
|
|
56d343 |
* config/i386/i386.opt (mpku): Ditto.
|
|
|
56d343 |
* config/i386/pkuintrin.h: New file.
|
|
|
56d343 |
* config/i386/x86intrin.h: Include pkuintrin.h
|
|
|
56d343 |
* doc/extend.texi: Describe new built-ins.
|
|
|
56d343 |
* doc/invoke.texi: Describe new switches.
|
|
|
56d343 |
|
|
|
56d343 |
* g++.dg/other/i386-2.C: Add -mpku.
|
|
|
56d343 |
* g++.dg/other/i386-3.C: Ditto.
|
|
|
56d343 |
* gcc.target/i386/rdpku-1.c: New test.
|
|
|
56d343 |
* gcc.target/i386/sse-12.c: Add -mpku.
|
|
|
56d343 |
* gcc.target/i386/sse-13.c: Ditto.
|
|
|
56d343 |
* gcc.target/i386/sse-22.c: Ditto.
|
|
|
56d343 |
* gcc.target/i386/sse-33.c: Ditto.
|
|
|
56d343 |
* gcc.target/i386/wrpku-1.c: New test.
|
|
|
56d343 |
|
|
|
56d343 |
--- gcc/config.gcc (revision 231943)
|
|
|
56d343 |
+++ gcc/config.gcc (revision 231945)
|
|
|
56d343 |
@@ -368,7 +368,7 @@ i[34567]86-*-*)
|
|
|
56d343 |
lzcntintrin.h bmiintrin.h bmi2intrin.h tbmintrin.h
|
|
|
56d343 |
avx2intrin.h fmaintrin.h f16cintrin.h rtmintrin.h
|
|
|
56d343 |
xtestintrin.h rdseedintrin.h prfchwintrin.h adxintrin.h
|
|
|
56d343 |
- fxsrintrin.h xsaveintrin.h xsaveoptintrin.h"
|
|
|
56d343 |
+ fxsrintrin.h xsaveintrin.h xsaveoptintrin.h pkuintrin.h"
|
|
|
56d343 |
;;
|
|
|
56d343 |
x86_64-*-*)
|
|
|
56d343 |
cpu_type=i386
|
|
|
56d343 |
@@ -383,7 +383,7 @@ x86_64-*-*)
|
|
|
56d343 |
lzcntintrin.h bmiintrin.h tbmintrin.h bmi2intrin.h
|
|
|
56d343 |
avx2intrin.h fmaintrin.h f16cintrin.h rtmintrin.h
|
|
|
56d343 |
xtestintrin.h rdseedintrin.h prfchwintrin.h adxintrin.h
|
|
|
56d343 |
- fxsrintrin.h xsaveintrin.h xsaveoptintrin.h"
|
|
|
56d343 |
+ fxsrintrin.h xsaveintrin.h xsaveoptintrin.h pkuintrin.h"
|
|
|
56d343 |
need_64bit_hwint=yes
|
|
|
56d343 |
;;
|
|
|
56d343 |
ia64-*-*)
|
|
|
56d343 |
--- gcc/common/config/i386/i386-common.c (revision 231943)
|
|
|
56d343 |
+++ gcc/common/config/i386/i386-common.c (revision 231945)
|
|
|
56d343 |
@@ -98,6 +98,7 @@ along with GCC; see the file COPYING3.
|
|
|
56d343 |
#define OPTION_MASK_ISA_RDRND_SET OPTION_MASK_ISA_RDRND
|
|
|
56d343 |
#define OPTION_MASK_ISA_F16C_SET \
|
|
|
56d343 |
(OPTION_MASK_ISA_F16C | OPTION_MASK_ISA_AVX_SET)
|
|
|
56d343 |
+#define OPTION_MASK_ISA_PKU_SET OPTION_MASK_ISA_PKU
|
|
|
56d343 |
|
|
|
56d343 |
/* Define a set of ISAs which aren't available when a given ISA is
|
|
|
56d343 |
disabled. MMX and SSE ISAs are handled separately. */
|
|
|
56d343 |
@@ -164,6 +165,7 @@ along with GCC; see the file COPYING3.
|
|
|
56d343 |
#define OPTION_MASK_ISA_FSGSBASE_UNSET OPTION_MASK_ISA_FSGSBASE
|
|
|
56d343 |
#define OPTION_MASK_ISA_RDRND_UNSET OPTION_MASK_ISA_RDRND
|
|
|
56d343 |
#define OPTION_MASK_ISA_F16C_UNSET OPTION_MASK_ISA_F16C
|
|
|
56d343 |
+#define OPTION_MASK_ISA_PKU_UNSET OPTION_MASK_ISA_PKU
|
|
|
56d343 |
|
|
|
56d343 |
/* Implement TARGET_HANDLE_OPTION. */
|
|
|
56d343 |
|
|
|
56d343 |
@@ -659,6 +661,19 @@ ix86_handle_option (struct gcc_options *
|
|
|
56d343 |
}
|
|
|
56d343 |
return true;
|
|
|
56d343 |
|
|
|
56d343 |
+ case OPT_mpku:
|
|
|
56d343 |
+ if (value)
|
|
|
56d343 |
+ {
|
|
|
56d343 |
+ opts->x_ix86_isa_flags |= OPTION_MASK_ISA_PKU_SET;
|
|
|
56d343 |
+ opts->x_ix86_isa_flags_explicit |= OPTION_MASK_ISA_PKU_SET;
|
|
|
56d343 |
+ }
|
|
|
56d343 |
+ else
|
|
|
56d343 |
+ {
|
|
|
56d343 |
+ opts->x_ix86_isa_flags &= ~OPTION_MASK_ISA_PKU_UNSET;
|
|
|
56d343 |
+ opts->x_ix86_isa_flags_explicit |= OPTION_MASK_ISA_PKU_UNSET;
|
|
|
56d343 |
+ }
|
|
|
56d343 |
+ return true;
|
|
|
56d343 |
+
|
|
|
56d343 |
/* Comes from final.c -- no real reason to change it. */
|
|
|
56d343 |
#define MAX_CODE_ALIGN 16
|
|
|
56d343 |
|
|
|
56d343 |
--- gcc/config/i386/i386.h (revision 231943)
|
|
|
56d343 |
+++ gcc/config/i386/i386.h (revision 231945)
|
|
|
56d343 |
@@ -80,6 +80,7 @@ see the files COPYING3 and COPYING.RUNTI
|
|
|
56d343 |
#define TARGET_FXSR TARGET_ISA_FXSR
|
|
|
56d343 |
#define TARGET_XSAVE TARGET_ISA_XSAVE
|
|
|
56d343 |
#define TARGET_XSAVEOPT TARGET_ISA_XSAVEOPT
|
|
|
56d343 |
+#define TARGET_PKU TARGET_ISA_PKU
|
|
|
56d343 |
|
|
|
56d343 |
#define TARGET_LP64 TARGET_ABI_64
|
|
|
56d343 |
#define TARGET_X32 TARGET_ABI_X32
|
|
|
56d343 |
--- gcc/config/i386/i386.md (revision 231943)
|
|
|
56d343 |
+++ gcc/config/i386/i386.md (revision 231945)
|
|
|
56d343 |
@@ -224,6 +224,9 @@ (define_c_enum "unspecv" [
|
|
|
56d343 |
UNSPECV_XTEST
|
|
|
56d343 |
|
|
|
56d343 |
UNSPECV_NLGR
|
|
|
56d343 |
+
|
|
|
56d343 |
+ ;; For RDPKRU and WRPKRU support
|
|
|
56d343 |
+ UNSPECV_PKU
|
|
|
56d343 |
])
|
|
|
56d343 |
|
|
|
56d343 |
;; Constants to represent rounding modes in the ROUND instruction
|
|
|
56d343 |
@@ -18289,6 +18292,48 @@ (define_insn "xtest_1"
|
|
|
56d343 |
[(set_attr "type" "other")
|
|
|
56d343 |
(set_attr "length" "3")])
|
|
|
56d343 |
|
|
|
56d343 |
+;; RDPKRU and WRPKRU
|
|
|
56d343 |
+
|
|
|
56d343 |
+(define_expand "rdpkru"
|
|
|
56d343 |
+ [(parallel
|
|
|
56d343 |
+ [(set (match_operand:SI 0 "register_operand")
|
|
|
56d343 |
+ (unspec_volatile:SI [(match_dup 1)] UNSPECV_PKU))
|
|
|
56d343 |
+ (set (match_dup 2) (const_int 0))])]
|
|
|
56d343 |
+ "TARGET_PKU"
|
|
|
56d343 |
+{
|
|
|
56d343 |
+ operands[1] = force_reg (SImode, const0_rtx);
|
|
|
56d343 |
+ operands[2] = gen_reg_rtx (SImode);
|
|
|
56d343 |
+})
|
|
|
56d343 |
+
|
|
|
56d343 |
+(define_insn "*rdpkru"
|
|
|
56d343 |
+ [(set (match_operand:SI 0 "register_operand" "=a")
|
|
|
56d343 |
+ (unspec_volatile:SI [(match_operand:SI 2 "register_operand" "c")]
|
|
|
56d343 |
+ UNSPECV_PKU))
|
|
|
56d343 |
+ (set (match_operand:SI 1 "register_operand" "=d")
|
|
|
56d343 |
+ (const_int 0))]
|
|
|
56d343 |
+ "TARGET_PKU"
|
|
|
56d343 |
+ "rdpkru"
|
|
|
56d343 |
+ [(set_attr "type" "other")])
|
|
|
56d343 |
+
|
|
|
56d343 |
+(define_expand "wrpkru"
|
|
|
56d343 |
+ [(unspec_volatile:SI
|
|
|
56d343 |
+ [(match_operand:SI 0 "register_operand")
|
|
|
56d343 |
+ (match_dup 1) (match_dup 2)] UNSPECV_PKU)]
|
|
|
56d343 |
+ "TARGET_PKU"
|
|
|
56d343 |
+{
|
|
|
56d343 |
+ operands[1] = force_reg (SImode, const0_rtx);
|
|
|
56d343 |
+ operands[2] = force_reg (SImode, const0_rtx);
|
|
|
56d343 |
+})
|
|
|
56d343 |
+
|
|
|
56d343 |
+(define_insn "*wrpkru"
|
|
|
56d343 |
+ [(unspec_volatile:SI
|
|
|
56d343 |
+ [(match_operand:SI 0 "register_operand" "a")
|
|
|
56d343 |
+ (match_operand:SI 1 "register_operand" "d")
|
|
|
56d343 |
+ (match_operand:SI 2 "register_operand" "c")] UNSPECV_PKU)]
|
|
|
56d343 |
+ "TARGET_PKU"
|
|
|
56d343 |
+ "wrpkru"
|
|
|
56d343 |
+ [(set_attr "type" "other")])
|
|
|
56d343 |
+
|
|
|
56d343 |
(include "mmx.md")
|
|
|
56d343 |
(include "sse.md")
|
|
|
56d343 |
(include "sync.md")
|
|
|
56d343 |
--- gcc/config/i386/pkuintrin.h (revision 0)
|
|
|
56d343 |
+++ gcc/config/i386/pkuintrin.h (revision 231945)
|
|
|
56d343 |
@@ -0,0 +1,45 @@
|
|
|
56d343 |
+/* Copyright (C) 2015 Free Software Foundation, Inc.
|
|
|
56d343 |
+
|
|
|
56d343 |
+ This file is part of GCC.
|
|
|
56d343 |
+
|
|
|
56d343 |
+ GCC is free software; you can redistribute it and/or modify
|
|
|
56d343 |
+ it under the terms of the GNU General Public License as published by
|
|
|
56d343 |
+ the Free Software Foundation; either version 3, or (at your option)
|
|
|
56d343 |
+ any later version.
|
|
|
56d343 |
+
|
|
|
56d343 |
+ GCC is distributed in the hope that it will be useful,
|
|
|
56d343 |
+ but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
|
56d343 |
+ MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
|
56d343 |
+ GNU General Public License for more details.
|
|
|
56d343 |
+
|
|
|
56d343 |
+ Under Section 7 of GPL version 3, you are granted additional
|
|
|
56d343 |
+ permissions described in the GCC Runtime Library Exception, version
|
|
|
56d343 |
+ 3.1, as published by the Free Software Foundation.
|
|
|
56d343 |
+
|
|
|
56d343 |
+ You should have received a copy of the GNU General Public License and
|
|
|
56d343 |
+ a copy of the GCC Runtime Library Exception along with this program;
|
|
|
56d343 |
+ see the files COPYING3 and COPYING.RUNTIME respectively. If not, see
|
|
|
56d343 |
+ <http://www.gnu.org/licenses/>. */
|
|
|
56d343 |
+
|
|
|
56d343 |
+#if !defined _X86INTRIN_H_INCLUDED
|
|
|
56d343 |
+# error "Never use <pkuintrin.h> directly; include <x86intrin.h> instead."
|
|
|
56d343 |
+#endif
|
|
|
56d343 |
+
|
|
|
56d343 |
+#ifndef _PKUINTRIN_H_INCLUDED
|
|
|
56d343 |
+#define _PKUINTRIN_H_INCLUDED
|
|
|
56d343 |
+
|
|
|
56d343 |
+extern __inline unsigned int
|
|
|
56d343 |
+__attribute__((__gnu_inline__, __always_inline__, __artificial__))
|
|
|
56d343 |
+_rdpkru_u32(void)
|
|
|
56d343 |
+{
|
|
|
56d343 |
+ return __builtin_ia32_rdpkru ();
|
|
|
56d343 |
+}
|
|
|
56d343 |
+
|
|
|
56d343 |
+extern __inline void
|
|
|
56d343 |
+__attribute__((__gnu_inline__, __always_inline__, __artificial__))
|
|
|
56d343 |
+_wrpkru(unsigned int key)
|
|
|
56d343 |
+{
|
|
|
56d343 |
+ return __builtin_ia32_wrpkru (key);
|
|
|
56d343 |
+}
|
|
|
56d343 |
+
|
|
|
56d343 |
+#endif /* _PKUINTRIN_H_INCLUDED */
|
|
|
56d343 |
--- gcc/config/i386/cpuid.h (revision 231943)
|
|
|
56d343 |
+++ gcc/config/i386/cpuid.h (revision 231945)
|
|
|
56d343 |
@@ -74,6 +74,10 @@
|
|
|
56d343 |
#define bit_RDSEED (1 << 18)
|
|
|
56d343 |
#define bit_ADX (1 << 19)
|
|
|
56d343 |
|
|
|
56d343 |
+/* %ecx */
|
|
|
56d343 |
+#define bit_PKU (1 << 3)
|
|
|
56d343 |
+#define bit_OSPKE (1 << 4)
|
|
|
56d343 |
+
|
|
|
56d343 |
/* Extended State Enumeration Sub-leaf (%eax == 13, %ecx == 1) */
|
|
|
56d343 |
#define bit_XSAVEOPT (1 << 0)
|
|
|
56d343 |
|
|
|
56d343 |
--- gcc/config/i386/x86intrin.h (revision 231943)
|
|
|
56d343 |
+++ gcc/config/i386/x86intrin.h (revision 231945)
|
|
|
56d343 |
@@ -119,4 +119,8 @@
|
|
|
56d343 |
|
|
|
56d343 |
#include <adxintrin.h>
|
|
|
56d343 |
|
|
|
56d343 |
+#ifdef __PKU__
|
|
|
56d343 |
+#include <pkuintrin.h>
|
|
|
56d343 |
+#endif
|
|
|
56d343 |
+
|
|
|
56d343 |
#endif /* _X86INTRIN_H_INCLUDED */
|
|
|
56d343 |
--- gcc/config/i386/i386-c.c (revision 231943)
|
|
|
56d343 |
+++ gcc/config/i386/i386-c.c (revision 231945)
|
|
|
56d343 |
@@ -348,6 +348,8 @@ ix86_target_macros_internal (HOST_WIDE_I
|
|
|
56d343 |
def_or_undef (parse_in, "__XSAVE__");
|
|
|
56d343 |
if (isa_flag & OPTION_MASK_ISA_XSAVEOPT)
|
|
|
56d343 |
def_or_undef (parse_in, "__XSAVEOPT__");
|
|
|
56d343 |
+ if (isa_flag & OPTION_MASK_ISA_PKU)
|
|
|
56d343 |
+ def_or_undef (parse_in, "__PKU__");
|
|
|
56d343 |
if ((fpmath & FPMATH_SSE) && (isa_flag & OPTION_MASK_ISA_SSE))
|
|
|
56d343 |
def_or_undef (parse_in, "__SSE_MATH__");
|
|
|
56d343 |
if ((fpmath & FPMATH_SSE) && (isa_flag & OPTION_MASK_ISA_SSE2))
|
|
|
56d343 |
--- gcc/config/i386/i386.opt (revision 231943)
|
|
|
56d343 |
+++ gcc/config/i386/i386.opt (revision 231945)
|
|
|
56d343 |
@@ -626,3 +626,7 @@ Split 32-byte AVX unaligned store
|
|
|
56d343 |
mrtm
|
|
|
56d343 |
Target Report Mask(ISA_RTM) Var(ix86_isa_flags) Save
|
|
|
56d343 |
Support RTM built-in functions and code generation
|
|
|
56d343 |
+
|
|
|
56d343 |
+mpku
|
|
|
56d343 |
+Target Report Mask(ISA_PKU) Var(ix86_isa_flags) Save
|
|
|
56d343 |
+Support PKU built-in functions and code generation
|
|
|
56d343 |
--- gcc/config/i386/driver-i386.c (revision 231943)
|
|
|
56d343 |
+++ gcc/config/i386/driver-i386.c (revision 231945)
|
|
|
56d343 |
@@ -408,6 +408,7 @@ const char *host_detect_local_cpu (int a
|
|
|
56d343 |
unsigned int has_rdrnd = 0, has_f16c = 0, has_fsgsbase = 0;
|
|
|
56d343 |
unsigned int has_rdseed = 0, has_prfchw = 0, has_adx = 0;
|
|
|
56d343 |
unsigned int has_osxsave = 0, has_fxsr = 0, has_xsave = 0, has_xsaveopt = 0;
|
|
|
56d343 |
+ unsigned int has_pku = 0;
|
|
|
56d343 |
|
|
|
56d343 |
bool arch;
|
|
|
56d343 |
|
|
|
56d343 |
@@ -479,6 +480,8 @@ const char *host_detect_local_cpu (int a
|
|
|
56d343 |
has_fsgsbase = ebx & bit_FSGSBASE;
|
|
|
56d343 |
has_rdseed = ebx & bit_RDSEED;
|
|
|
56d343 |
has_adx = ebx & bit_ADX;
|
|
|
56d343 |
+
|
|
|
56d343 |
+ has_pku = ecx & bit_OSPKE;
|
|
|
56d343 |
}
|
|
|
56d343 |
|
|
|
56d343 |
if (max_level >= 13)
|
|
|
56d343 |
@@ -855,12 +858,13 @@ const char *host_detect_local_cpu (int a
|
|
|
56d343 |
const char *fxsr = has_fxsr ? " -mfxsr" : " -mno-fxsr";
|
|
|
56d343 |
const char *xsave = has_xsave ? " -mxsave" : " -mno-xsave";
|
|
|
56d343 |
const char *xsaveopt = has_xsaveopt ? " -mxsaveopt" : " -mno-xsaveopt";
|
|
|
56d343 |
+ const char *pku = has_pku ? " -mpku" : " -mno-pku";
|
|
|
56d343 |
|
|
|
56d343 |
options = concat (options, cx16, sahf, movbe, ase, pclmul,
|
|
|
56d343 |
popcnt, abm, lwp, fma, fma4, xop, bmi, bmi2,
|
|
|
56d343 |
tbm, avx, avx2, sse4_2, sse4_1, lzcnt, rtm,
|
|
|
56d343 |
hle, rdrnd, f16c, fsgsbase, rdseed, prfchw, adx,
|
|
|
56d343 |
- fxsr, xsave, xsaveopt, NULL);
|
|
|
56d343 |
+ fxsr, xsave, xsaveopt, pku, NULL);
|
|
|
56d343 |
}
|
|
|
56d343 |
|
|
|
56d343 |
done:
|
|
|
56d343 |
--- gcc/config/i386/i386.c (revision 231943)
|
|
|
56d343 |
+++ gcc/config/i386/i386.c (revision 231945)
|
|
|
56d343 |
@@ -2632,6 +2632,7 @@ ix86_target_string (HOST_WIDE_INT isa, i
|
|
|
56d343 |
{ "-mrtm", OPTION_MASK_ISA_RTM },
|
|
|
56d343 |
{ "-mxsave", OPTION_MASK_ISA_XSAVE },
|
|
|
56d343 |
{ "-mxsaveopt", OPTION_MASK_ISA_XSAVEOPT },
|
|
|
56d343 |
+ { "-mpku", OPTION_MASK_ISA_PKU },
|
|
|
56d343 |
};
|
|
|
56d343 |
|
|
|
56d343 |
/* Flag options. */
|
|
|
56d343 |
@@ -2905,6 +2906,7 @@ ix86_option_override_internal (bool main
|
|
|
56d343 |
#define PTA_FXSR (HOST_WIDE_INT_1 << 37)
|
|
|
56d343 |
#define PTA_XSAVE (HOST_WIDE_INT_1 << 38)
|
|
|
56d343 |
#define PTA_XSAVEOPT (HOST_WIDE_INT_1 << 39)
|
|
|
56d343 |
+#define PTA_PKU (HOST_WIDE_INT_1 << 60)
|
|
|
56d343 |
|
|
|
56d343 |
/* if this reaches 64, need to widen struct pta flags below */
|
|
|
56d343 |
|
|
|
56d343 |
@@ -3429,6 +3431,9 @@ ix86_option_override_internal (bool main
|
|
|
56d343 |
if (processor_alias_table[i].flags & PTA_XSAVEOPT
|
|
|
56d343 |
&& !(ix86_isa_flags_explicit & OPTION_MASK_ISA_XSAVEOPT))
|
|
|
56d343 |
ix86_isa_flags |= OPTION_MASK_ISA_XSAVEOPT;
|
|
|
56d343 |
+ if (processor_alias_table[i].flags & PTA_PKU
|
|
|
56d343 |
+ && !(ix86_isa_flags_explicit & OPTION_MASK_ISA_PKU))
|
|
|
56d343 |
+ ix86_isa_flags |= OPTION_MASK_ISA_PKU;
|
|
|
56d343 |
if (processor_alias_table[i].flags & (PTA_PREFETCH_SSE | PTA_SSE))
|
|
|
56d343 |
x86_prefetch_sse = true;
|
|
|
56d343 |
|
|
|
56d343 |
@@ -4220,6 +4225,7 @@ ix86_valid_target_attribute_inner_p (tre
|
|
|
56d343 |
IX86_ATTR_ISA ("fxsr", OPT_mfxsr),
|
|
|
56d343 |
IX86_ATTR_ISA ("xsave", OPT_mxsave),
|
|
|
56d343 |
IX86_ATTR_ISA ("xsaveopt", OPT_mxsaveopt),
|
|
|
56d343 |
+ IX86_ATTR_ISA ("pku", OPT_mpku),
|
|
|
56d343 |
|
|
|
56d343 |
/* enum options */
|
|
|
56d343 |
IX86_ATTR_ENUM ("fpmath=", OPT_mfpmath_),
|
|
|
56d343 |
@@ -27042,6 +27048,10 @@ enum ix86_builtins
|
|
|
56d343 |
IX86_BUILTIN_CPU_IS,
|
|
|
56d343 |
IX86_BUILTIN_CPU_SUPPORTS,
|
|
|
56d343 |
|
|
|
56d343 |
+ /* PKU instructions. */
|
|
|
56d343 |
+ IX86_BUILTIN_RDPKRU,
|
|
|
56d343 |
+ IX86_BUILTIN_WRPKRU,
|
|
|
56d343 |
+
|
|
|
56d343 |
IX86_BUILTIN_MAX
|
|
|
56d343 |
};
|
|
|
56d343 |
|
|
|
56d343 |
@@ -27357,6 +27367,10 @@ static const struct builtin_description
|
|
|
56d343 |
{ OPTION_MASK_ISA_RTM, CODE_FOR_xbegin, "__builtin_ia32_xbegin", IX86_BUILTIN_XBEGIN, UNKNOWN, (int) UNSIGNED_FTYPE_VOID },
|
|
|
56d343 |
{ OPTION_MASK_ISA_RTM, CODE_FOR_xend, "__builtin_ia32_xend", IX86_BUILTIN_XEND, UNKNOWN, (int) VOID_FTYPE_VOID },
|
|
|
56d343 |
{ OPTION_MASK_ISA_RTM, CODE_FOR_xtest, "__builtin_ia32_xtest", IX86_BUILTIN_XTEST, UNKNOWN, (int) INT_FTYPE_VOID },
|
|
|
56d343 |
+
|
|
|
56d343 |
+ /* RDPKRU and WRPKRU. */
|
|
|
56d343 |
+ { OPTION_MASK_ISA_PKU, CODE_FOR_rdpkru, "__builtin_ia32_rdpkru", IX86_BUILTIN_RDPKRU, UNKNOWN, (int) UNSIGNED_FTYPE_VOID },
|
|
|
56d343 |
+ { OPTION_MASK_ISA_PKU, CODE_FOR_wrpkru, "__builtin_ia32_wrpkru", IX86_BUILTIN_WRPKRU, UNKNOWN, (int) VOID_FTYPE_UNSIGNED },
|
|
|
56d343 |
};
|
|
|
56d343 |
|
|
|
56d343 |
/* Builtins with variable number of arguments. */
|
|
|
56d343 |
--- gcc/doc/extend.texi (revision 231943)
|
|
|
56d343 |
+++ gcc/doc/extend.texi (revision 231945)
|
|
|
56d343 |
@@ -10996,6 +10996,13 @@ void __builtin_ia32_xabort (status)
|
|
|
56d343 |
int __builtin_ia32_xtest ()
|
|
|
56d343 |
@end smallexample
|
|
|
56d343 |
|
|
|
56d343 |
+The following built-in functions are available when @option{-mpku} is used.
|
|
|
56d343 |
+They generate reads and writes to PKRU.
|
|
|
56d343 |
+@smallexample
|
|
|
56d343 |
+void __builtin_ia32_wrpkru (unsigned int)
|
|
|
56d343 |
+unsigned int __builtin_ia32_rdpkru ()
|
|
|
56d343 |
+@end smallexample
|
|
|
56d343 |
+
|
|
|
56d343 |
@node X86 transactional memory intrinsics
|
|
|
56d343 |
@subsection X86 transaction memory intrinsics
|
|
|
56d343 |
|
|
|
56d343 |
--- gcc/doc/invoke.texi (revision 231943)
|
|
|
56d343 |
+++ gcc/doc/invoke.texi (revision 231945)
|
|
|
56d343 |
@@ -645,7 +645,7 @@ Objective-C and Objective-C++ Dialects}.
|
|
|
56d343 |
-mmmx -msse -msse2 -msse3 -mssse3 -msse4.1 -msse4.2 -msse4 -mavx @gol
|
|
|
56d343 |
-mavx2 -maes -mpclmul -mfsgsbase -mrdrnd -mf16c -mfma @gol
|
|
|
56d343 |
-msse4a -m3dnow -mpopcnt -mabm -mbmi -mtbm -mfma4 -mxop -mlzcnt @gol
|
|
|
56d343 |
--mbmi2 -mrtm -mlwp -mthreads @gol
|
|
|
56d343 |
+-mbmi2 -mrtm -mlwp -mpku -mthreads @gol
|
|
|
56d343 |
-mno-align-stringops -minline-all-stringops @gol
|
|
|
56d343 |
-minline-stringops-dynamically -mstringop-strategy=@var{alg} @gol
|
|
|
56d343 |
-mpush-args -maccumulate-outgoing-args -m128bit-long-double @gol
|
|
|
56d343 |
@@ -14326,6 +14326,8 @@ preferred alignment to @option{-mpreferr
|
|
|
56d343 |
@itemx -mlzcnt
|
|
|
56d343 |
@itemx -mno-lzcnt
|
|
|
56d343 |
@itemx -mrtm
|
|
|
56d343 |
+@itemx -mpku
|
|
|
56d343 |
+@itemx -mno-pku
|
|
|
56d343 |
@itemx -mtbm
|
|
|
56d343 |
@itemx -mno-tbm
|
|
|
56d343 |
@opindex mmmx
|
|
|
56d343 |
@@ -14336,7 +14338,7 @@ preferred alignment to @option{-mpreferr
|
|
|
56d343 |
@opindex mno-3dnow
|
|
|
56d343 |
These switches enable or disable the use of instructions in the MMX, SSE,
|
|
|
56d343 |
SSE2, SSE3, SSSE3, SSE4.1, AVX, AVX2, AES, PCLMUL, FSGSBASE, RDRND, F16C,
|
|
|
56d343 |
-FMA, SSE4A, FMA4, XOP, LWP, ABM, BMI, BMI2, LZCNT, RTM or 3DNow!@:
|
|
|
56d343 |
+FMA, SSE4A, FMA4, XOP, LWP, ABM, BMI, BMI2, LZCNT, RTM, PKU or 3DNow!@:
|
|
|
56d343 |
extended instruction sets.
|
|
|
56d343 |
These extensions are also available as built-in functions: see
|
|
|
56d343 |
@ref{X86 Built-in Functions}, for details of the functions enabled and
|
|
|
56d343 |
--- gcc/testsuite/gcc.target/i386/sse-12.c (revision 231943)
|
|
|
56d343 |
+++ gcc/testsuite/gcc.target/i386/sse-12.c (revision 231945)
|
|
|
56d343 |
@@ -3,7 +3,7 @@
|
|
|
56d343 |
popcntintrin.h and mm_malloc.h are usable
|
|
|
56d343 |
with -O -std=c89 -pedantic-errors. */
|
|
|
56d343 |
/* { dg-do compile } */
|
|
|
56d343 |
-/* { dg-options "-O -std=c89 -pedantic-errors -march=k8 -msse4a -m3dnow -mavx -mavx2 -mfma4 -mxop -maes -mpclmul -mpopcnt -mabm -mlzcnt -mbmi -mbmi2 -mtbm -mlwp -mfsgsbase -mrdrnd -mf16c -mfma -mrtm -mrdseed -mprfchw -madx -mfxsr -mxsaveopt" } */
|
|
|
56d343 |
+/* { dg-options "-O -std=c89 -pedantic-errors -march=k8 -msse4a -m3dnow -mavx -mavx2 -mfma4 -mxop -maes -mpclmul -mpopcnt -mabm -mlzcnt -mbmi -mbmi2 -mtbm -mlwp -mfsgsbase -mrdrnd -mf16c -mfma -mrtm -mrdseed -mprfchw -madx -mfxsr -mxsaveopt -mpku" } */
|
|
|
56d343 |
|
|
|
56d343 |
#include <x86intrin.h>
|
|
|
56d343 |
|
|
|
56d343 |
--- gcc/testsuite/gcc.target/i386/sse-13.c (revision 231943)
|
|
|
56d343 |
+++ gcc/testsuite/gcc.target/i386/sse-13.c (revision 231945)
|
|
|
56d343 |
@@ -1,5 +1,5 @@
|
|
|
56d343 |
/* { dg-do compile } */
|
|
|
56d343 |
-/* { dg-options "-O2 -Werror-implicit-function-declaration -march=k8 -msse4a -m3dnow -mavx -mavx2 -mfma4 -mxop -maes -mpclmul -mpopcnt -mabm -mlzcnt -mbmi -mbmi2 -mtbm -mlwp -mfsgsbase -mrdrnd -mf16c -mfma -mrtm -mrdseed -mprfchw -madx -mfxsr -mxsaveopt" } */
|
|
|
56d343 |
+/* { dg-options "-O2 -Werror-implicit-function-declaration -march=k8 -msse4a -m3dnow -mavx -mavx2 -mfma4 -mxop -maes -mpclmul -mpopcnt -mabm -mlzcnt -mbmi -mbmi2 -mtbm -mlwp -mfsgsbase -mrdrnd -mf16c -mfma -mrtm -mrdseed -mprfchw -madx -mfxsr -mxsaveopt -mpku" } */
|
|
|
56d343 |
|
|
|
56d343 |
#include <mm_malloc.h>
|
|
|
56d343 |
|
|
|
56d343 |
--- gcc/testsuite/gcc.target/i386/sse-22.c (revision 231943)
|
|
|
56d343 |
+++ gcc/testsuite/gcc.target/i386/sse-22.c (revision 231945)
|
|
|
56d343 |
@@ -268,7 +268,7 @@ test_2 (_mm_clmulepi64_si128, __m128i, _
|
|
|
56d343 |
|
|
|
56d343 |
/* x86intrin.h (FMA4/XOP/LWP/BMI/BMI2/TBM/LZCNT/FMA). */
|
|
|
56d343 |
#ifdef DIFFERENT_PRAGMAS
|
|
|
56d343 |
-#pragma GCC target ("fma4,xop,lwp,bmi,bmi2,tbm,lzcnt,fma,rdseed,prfchw,adx,fxsr,xsaveopt")
|
|
|
56d343 |
+#pragma GCC target ("fma4,xop,lwp,bmi,bmi2,tbm,lzcnt,fma,rdseed,prfchw,adx,fxsr,xsaveopt,pku")
|
|
|
56d343 |
#endif
|
|
|
56d343 |
#include <x86intrin.h>
|
|
|
56d343 |
/* xopintrin.h */
|
|
|
56d343 |
--- gcc/testsuite/gcc.target/i386/sse-23.c (revision 231943)
|
|
|
56d343 |
+++ gcc/testsuite/gcc.target/i386/sse-23.c (revision 231945)
|
|
|
56d343 |
@@ -183,7 +183,7 @@
|
|
|
56d343 |
/* rtmintrin.h */
|
|
|
56d343 |
#define __builtin_ia32_xabort(M) __builtin_ia32_xabort(1)
|
|
|
56d343 |
|
|
|
56d343 |
-#pragma GCC target ("sse4a,3dnow,avx,avx2,fma4,xop,aes,pclmul,popcnt,abm,lzcnt,bmi,bmi2,tbm,lwp,fsgsbase,rdrnd,f16c,fma,rtm,rdseed,prfchw,adx,fxsr,xsaveopt")
|
|
|
56d343 |
+#pragma GCC target ("sse4a,3dnow,avx,avx2,fma4,xop,aes,pclmul,popcnt,abm,lzcnt,bmi,bmi2,tbm,lwp,fsgsbase,rdrnd,f16c,fma,rtm,rdseed,prfchw,adx,fxsr,xsaveopt,pku")
|
|
|
56d343 |
#include <wmmintrin.h>
|
|
|
56d343 |
#include <smmintrin.h>
|
|
|
56d343 |
#include <mm3dnow.h>
|
|
|
56d343 |
--- gcc/testsuite/gcc.target/i386/rdpku-1.c (revision 0)
|
|
|
56d343 |
+++ gcc/testsuite/gcc.target/i386/rdpku-1.c (revision 231945)
|
|
|
56d343 |
@@ -0,0 +1,11 @@
|
|
|
56d343 |
+/* { dg-do compile } */
|
|
|
56d343 |
+/* { dg-options "-mpku -O2" } */
|
|
|
56d343 |
+/* { dg-final { scan-assembler "rdpkru\n" } } */
|
|
|
56d343 |
+
|
|
|
56d343 |
+#include <x86intrin.h>
|
|
|
56d343 |
+
|
|
|
56d343 |
+unsigned extern
|
|
|
56d343 |
+rdpku_test (void)
|
|
|
56d343 |
+{
|
|
|
56d343 |
+ return _rdpkru_u32 ();
|
|
|
56d343 |
+}
|
|
|
56d343 |
--- gcc/testsuite/gcc.target/i386/wrpku-1.c (revision 0)
|
|
|
56d343 |
+++ gcc/testsuite/gcc.target/i386/wrpku-1.c (revision 231945)
|
|
|
56d343 |
@@ -0,0 +1,11 @@
|
|
|
56d343 |
+/* { dg-do compile } */
|
|
|
56d343 |
+/* { dg-options "-mpku -O2" } */
|
|
|
56d343 |
+/* { dg-final { scan-assembler "wrpkru\n" } } */
|
|
|
56d343 |
+
|
|
|
56d343 |
+#include <x86intrin.h>
|
|
|
56d343 |
+
|
|
|
56d343 |
+void extern
|
|
|
56d343 |
+wrpku_test (unsigned int key)
|
|
|
56d343 |
+{
|
|
|
56d343 |
+ _wrpkru (key);
|
|
|
56d343 |
+}
|
|
|
56d343 |
--- gcc/testsuite/g++.dg/other/i386-2.C (revision 231943)
|
|
|
56d343 |
+++ gcc/testsuite/g++.dg/other/i386-2.C (revision 231945)
|
|
|
56d343 |
@@ -1,9 +1,9 @@
|
|
|
56d343 |
/* { dg-do compile { target i?86-*-* x86_64-*-* } } */
|
|
|
56d343 |
-/* { dg-options "-O -pedantic-errors -march=k8 -msse4a -m3dnow -mavx -mavx2 -mfma4 -mxop -maes -mpclmul -mpopcnt -mabm -mlzcnt -mbmi -mbmi2 -mtbm -mlwp -mfsgsbase -mrdrnd -mf16c -mfma -mrtm -mrdseed -mprfchw -madx -mfxsr -mxsaveopt" } */
|
|
|
56d343 |
+/* { dg-options "-O -pedantic-errors -march=k8 -msse4a -m3dnow -mavx -mavx2 -mfma4 -mxop -maes -mpclmul -mpopcnt -mabm -mlzcnt -mbmi -mbmi2 -mtbm -mlwp -mfsgsbase -mrdrnd -mf16c -mfma -mrtm -mrdseed -mprfchw -madx -mfxsr -mxsaveopt -mpku" } */
|
|
|
56d343 |
|
|
|
56d343 |
/* Test that {,x,e,p,t,s,w,a,b,i}mmintrin.h, mm3dnow.h, fma4intrin.h,
|
|
|
56d343 |
xopintrin.h, abmintrin.h, bmiintrin.h, tbmintrin.h, lwpintrin.h,
|
|
|
56d343 |
- popcntintrin.h, fmaintrin.h and mm_malloc.h.h are usable with
|
|
|
56d343 |
+ popcntintrin.h, fmaintrin.h, pkuintrin.h and mm_malloc.h.h are usable with
|
|
|
56d343 |
-O -pedantic-errors. */
|
|
|
56d343 |
|
|
|
56d343 |
#include <x86intrin.h>
|
|
|
56d343 |
--- gcc/testsuite/g++.dg/other/i386-3.C (revision 231943)
|
|
|
56d343 |
+++ gcc/testsuite/g++.dg/other/i386-3.C (revision 231945)
|
|
|
56d343 |
@@ -1,9 +1,9 @@
|
|
|
56d343 |
/* { dg-do compile { target i?86-*-* x86_64-*-* } } */
|
|
|
56d343 |
-/* { dg-options "-O -fkeep-inline-functions -march=k8 -msse4a -m3dnow -mavx -mavx2 -mfma4 -mxop -maes -mpclmul -mpopcnt -mabm -mlzcnt -mbmi -mbmi2 -mtbm -mlwp -mfsgsbase -mrdrnd -mf16c -mfma -mrtm -mrdseed -mprfchw -madx -mfxsr -mxsaveopt" } */
|
|
|
56d343 |
+/* { dg-options "-O -fkeep-inline-functions -march=k8 -msse4a -m3dnow -mavx -mavx2 -mfma4 -mxop -maes -mpclmul -mpopcnt -mabm -mlzcnt -mbmi -mbmi2 -mtbm -mlwp -mfsgsbase -mrdrnd -mf16c -mfma -mrtm -mrdseed -mprfchw -madx -mfxsr -mxsaveopt -mpku" } */
|
|
|
56d343 |
|
|
|
56d343 |
/* Test that {,x,e,p,t,s,w,a,b,i}mmintrin.h, mm3dnow.h, fma4intrin.h,
|
|
|
56d343 |
xopintrin.h, abmintrin.h, bmiintrin.h, tbmintrin.h, lwpintrin.h,
|
|
|
56d343 |
- popcntintrin.h, fmaintrin.h and mm_malloc.h are usable with
|
|
|
56d343 |
+ popcntintrin.h, fmaintrin.h, pkuintrin.h and mm_malloc.h are usable with
|
|
|
56d343 |
-O -fkeep-inline-functions. */
|
|
|
56d343 |
|
|
|
56d343 |
#include <x86intrin.h>
|