x86: Add IBT/SHSTK bits to cpu-features
authorH.J. Lu <hjl.tools@gmail.com>
Mon, 14 Aug 2017 12:54:25 +0000 (05:54 -0700)
committerH.J. Lu <hjl.tools@gmail.com>
Mon, 14 Aug 2017 12:54:38 +0000 (05:54 -0700)
Add IBT/SHSTK bits to cpu-features for Shadow Stack in Intel Control-flow
Enforcement Technology (CET) instructions:

https://software.intel.com/sites/default/files/managed/4d/2a/control-flow-enforcement-technology-preview.pdf

* sysdeps/x86/cpu-features.h (bit_cpu_BIT): New.
(bit_cpu_SHSTK): Likewise.
(index_cpu_IBT): Likewise.
(index_cpu_SHSTK): Likewise.
(reg_IBT): Likewise.
(reg_SHSTK): Likewise.
* sysdeps/x86/cpu-tunables.c (TUNABLE_CALLBACK (set_hwcaps)):
Handle index_cpu_IBT and index_cpu_SHSTK.

ChangeLog
sysdeps/x86/cpu-features.h
sysdeps/x86/cpu-tunables.c

index 40678622adc05a9950a6abdc83a7a136e9e865d1..7527943446987158f1a5eb9e94a8a9b5be89bcfb 100644 (file)
--- a/ChangeLog
+++ b/ChangeLog
@@ -1,3 +1,14 @@
+2017-08-14  H.J. Lu  <hongjiu.lu@intel.com>
+
+       * sysdeps/x86/cpu-features.h (bit_cpu_BIT): New.
+       (bit_cpu_SHSTK): Likewise.
+       (index_cpu_IBT): Likewise.
+       (index_cpu_SHSTK): Likewise.
+       (reg_IBT): Likewise.
+       (reg_SHSTK): Likewise.
+       * sysdeps/x86/cpu-tunables.c (TUNABLE_CALLBACK (set_hwcaps)):
+       Handle index_cpu_IBT and index_cpu_SHSTK.
+
 2017-08-14  Mike FABIAN  <mfabian@redhat.com>
 
        [BZ #19982]
index af526891234835e277b839a2d8e961f4920aa798..9733e6ee665dd30674ceef0e1b63e627dd6d5525 100644 (file)
@@ -74,6 +74,8 @@
 #define bit_cpu_AVX512CD       (1 << 28)
 #define bit_cpu_AVX512BW       (1 << 30)
 #define bit_cpu_AVX512VL       (1u << 31)
+#define bit_cpu_IBT            (1u << 20)
+#define bit_cpu_SHSTK          (1u << 7)
 
 /* XCR0 Feature flags.  */
 #define bit_XMM_state          (1 << 1)
 # define index_cpu_AVX2        COMMON_CPUID_INDEX_7*CPUID_SIZE+CPUID_EBX_OFFSET
 # define index_cpu_ERMS        COMMON_CPUID_INDEX_7*CPUID_SIZE+CPUID_EBX_OFFSET
 # define index_cpu_MOVBE COMMON_CPUID_INDEX_1*CPUID_SIZE+CPUID_ECX_OFFSET
+# define index_cpu_IBT COMMON_CPUID_INDEX_7*CPUID_SIZE+CPUID_EDX_OFFSET
+# define index_cpu_SHSTK COMMON_CPUID_INDEX_7*CPUID_SIZE+CPUID_ECX_OFFSET
 
 # define index_arch_Fast_Rep_String    FEATURE_INDEX_1*FEATURE_SIZE
 # define index_arch_Fast_Copy_Backward FEATURE_INDEX_1*FEATURE_SIZE
@@ -220,6 +224,8 @@ extern const struct cpu_features *__get_cpu_features (void)
 # define index_cpu_LZCNT       COMMON_CPUID_INDEX_1
 # define index_cpu_MOVBE       COMMON_CPUID_INDEX_1
 # define index_cpu_POPCNT      COMMON_CPUID_INDEX_1
+# define index_cpu_IBT         COMMON_CPUID_INDEX_7
+# define index_cpu_SHSTK       COMMON_CPUID_INDEX_7
 
 # define reg_CX8               edx
 # define reg_CMOV              edx
@@ -249,6 +255,8 @@ extern const struct cpu_features *__get_cpu_features (void)
 # define reg_LZCNT             ecx
 # define reg_MOVBE             ecx
 # define reg_POPCNT            ecx
+# define reg_IBT               edx
+# define reg_SHSTK             ecx
 
 # define index_arch_Fast_Rep_String    FEATURE_INDEX_1
 # define index_arch_Fast_Copy_Backward FEATURE_INDEX_1
index 872dd1267f1cc4c2db3215d1e31dc376339653d8..0ab708cca80b0417ca3fdc88ae5a4c070524f61a 100644 (file)
@@ -164,6 +164,7 @@ TUNABLE_CALLBACK (set_hwcaps) (tunable_val_t *valp)
              CHECK_GLIBC_IFUNC_CPU_OFF (n, cpu_features, CX8, 3);
              CHECK_GLIBC_IFUNC_CPU_OFF (n, cpu_features, FMA, 3);
              CHECK_GLIBC_IFUNC_CPU_OFF (n, cpu_features, HTT, 3);
+             CHECK_GLIBC_IFUNC_CPU_OFF (n, cpu_features, IBT, 3);
              CHECK_GLIBC_IFUNC_CPU_OFF (n, cpu_features, RTM, 3);
            }
          break;
@@ -186,6 +187,7 @@ TUNABLE_CALLBACK (set_hwcaps) (tunable_val_t *valp)
            {
              CHECK_GLIBC_IFUNC_CPU_OFF (n, cpu_features, LZCNT, 5);
              CHECK_GLIBC_IFUNC_CPU_OFF (n, cpu_features, MOVBE, 5);
+             CHECK_GLIBC_IFUNC_CPU_OFF (n, cpu_features, SHSTK, 5);
              CHECK_GLIBC_IFUNC_CPU_OFF (n, cpu_features, SSSE3, 5);
            }
          break;