Blame SOURCES/rh1566890-CVE_2018_3639-speculative_store_bypass.patch

d7d101
diff --git openjdk/src/hotspot/os/linux/os_linux.cpp openjdk/src/hotspot/os/linux/os_linux.cpp
d7d101
--- openjdk/src/hotspot/os/linux/os_linux.cpp
d7d101
+++ openjdk/src/hotspot/os/linux/os_linux.cpp
d7d101
@@ -107,6 +107,8 @@
d7d101
 # include <inttypes.h>
d7d101
 # include <sys/ioctl.h>
d7d101
 
d7d101
+#include <sys/prctl.h>
d7d101
+
d7d101
 #ifndef _GNU_SOURCE
d7d101
   #define _GNU_SOURCE
d7d101
   #include <sched.h>
d7d101
@@ -4984,6 +4986,48 @@
d7d101
 extern void report_error(char* file_name, int line_no, char* title,
d7d101
                          char* format, ...);
d7d101
 
d7d101
+/* Per task speculation control */
d7d101
+#ifndef PR_GET_SPECULATION_CTRL
d7d101
+# define PR_GET_SPECULATION_CTRL    52
d7d101
+#endif
d7d101
+#ifndef PR_SET_SPECULATION_CTRL
d7d101
+# define PR_SET_SPECULATION_CTRL    53
d7d101
+#endif
d7d101
+/* Speculation control variants */
d7d101
+#ifndef PR_SPEC_STORE_BYPASS
d7d101
+# define PR_SPEC_STORE_BYPASS          0
d7d101
+#endif
d7d101
+/* Return and control values for PR_SET/GET_SPECULATION_CTRL */
d7d101
+
d7d101
+#ifndef PR_SPEC_NOT_AFFECTED
d7d101
+# define PR_SPEC_NOT_AFFECTED          0
d7d101
+#endif
d7d101
+#ifndef PR_SPEC_PRCTL
d7d101
+# define PR_SPEC_PRCTL                 (1UL << 0)
d7d101
+#endif
d7d101
+#ifndef PR_SPEC_ENABLE
d7d101
+# define PR_SPEC_ENABLE                (1UL << 1)
d7d101
+#endif
d7d101
+#ifndef PR_SPEC_DISABLE
d7d101
+# define PR_SPEC_DISABLE               (1UL << 2)
d7d101
+#endif
d7d101
+#ifndef PR_SPEC_FORCE_DISABLE
d7d101
+# define PR_SPEC_FORCE_DISABLE         (1UL << 3)
d7d101
+#endif
d7d101
+#ifndef PR_SPEC_DISABLE_NOEXEC
d7d101
+# define PR_SPEC_DISABLE_NOEXEC        (1UL << 4)
d7d101
+#endif
d7d101
+
d7d101
+static void set_speculation() __attribute__((constructor));
d7d101
+static void set_speculation() {
d7d101
+  if ( prctl(PR_SET_SPECULATION_CTRL,
d7d101
+             PR_SPEC_STORE_BYPASS,
d7d101
+             PR_SPEC_DISABLE_NOEXEC, 0, 0) == 0 ) {
d7d101
+    return;
d7d101
+  }
d7d101
+  prctl(PR_SET_SPECULATION_CTRL, PR_SPEC_STORE_BYPASS, PR_SPEC_DISABLE, 0, 0);
d7d101
+}
d7d101
+
d7d101
 // this is called _before_ most of the global arguments have been parsed
d7d101
 void os::init(void) {
d7d101
   char dummy;   // used to get a guess on initial stack address