aboutsummaryrefslogtreecommitdiffstats
path: root/community/openjdk8/icedtea-JDK-6515172_0_revert-jdk8-version.patch
diff options
context:
space:
mode:
Diffstat (limited to 'community/openjdk8/icedtea-JDK-6515172_0_revert-jdk8-version.patch')
-rw-r--r--community/openjdk8/icedtea-JDK-6515172_0_revert-jdk8-version.patch182
1 files changed, 182 insertions, 0 deletions
diff --git a/community/openjdk8/icedtea-JDK-6515172_0_revert-jdk8-version.patch b/community/openjdk8/icedtea-JDK-6515172_0_revert-jdk8-version.patch
new file mode 100644
index 00000000000..24366045419
--- /dev/null
+++ b/community/openjdk8/icedtea-JDK-6515172_0_revert-jdk8-version.patch
@@ -0,0 +1,182 @@
+From 05a1b8a93c790026dbc8785903ceaeba1396e708 Mon Sep 17 00:00:00 2001
+From: Shafi Ahmad <shshahma@openjdk.org>
+Date: Thu, 22 Sep 2016 02:04:40 -0700
+Subject: [PATCH] 6515172: Runtime.availableProcessors() ignores Linux taskset
+ command
+
+Extract processor count from sched_getaffinity mask
+
+Revert patch created by Simon Frankenberger <simon-alpine@fraho.eu>
+
+diff --git a/hotspot/src/os/linux/vm/globals_linux.hpp b/hotspot/src/os/linux/vm/globals_linux.hpp
+--- openjdk/hotspot/src/os/linux/vm/os_linux.cpp
++++ openjdk/hotspot/src/os/linux/vm/os_linux.cpp
+@@ -107,14 +107,6 @@
+
+ PRAGMA_FORMAT_MUTE_WARNINGS_FOR_GCC
+
+-#ifndef _GNU_SOURCE
+- #define _GNU_SOURCE
+- #include <sched.h>
+- #undef _GNU_SOURCE
+-#else
+- #include <sched.h>
+-#endif
+-
+ // if RUSAGE_THREAD for getrusage() has not been defined, do it here. The code calling
+ // getrusage() is prepared to handle the associated failure.
+ #ifndef RUSAGE_THREAD
+@@ -5331,42 +5323,12 @@
+ }
+ };
+
+-static int os_cpu_count(const cpu_set_t* cpus) {
+- int count = 0;
+- // only look up to the number of configured processors
+- for (int i = 0; i < os::processor_count(); i++) {
+- if (CPU_ISSET(i, cpus)) {
+- count++;
+- }
+- }
+- return count;
+-}
+-
+-// Get the current number of available processors for this process.
+-// This value can change at any time during a process's lifetime.
+-// sched_getaffinity gives an accurate answer as it accounts for cpusets.
+-// If anything goes wrong we fallback to returning the number of online
+-// processors - which can be greater than the number available to the process.
+ int os::Linux::active_processor_count() {
+- cpu_set_t cpus; // can represent at most 1024 (CPU_SETSIZE) processors
+- int cpus_size = sizeof(cpu_set_t);
+- int cpu_count = 0;
+-
+- // pid 0 means the current thread - which we have to assume represents the process
+- if (sched_getaffinity(0, cpus_size, &cpus) == 0) {
+- cpu_count = os_cpu_count(&cpus);
+- if (PrintActiveCpus) {
+- tty->print_cr("active_processor_count: sched_getaffinity processor count: %d", cpu_count);
+- }
+- }
+- else {
+- cpu_count = ::sysconf(_SC_NPROCESSORS_ONLN);
+- warning("sched_getaffinity failed (%s)- using online processor count (%d) "
+- "which may exceed available processors", strerror(errno), cpu_count);
+- }
+-
+- assert(cpu_count > 0 && cpu_count <= os::processor_count(), "sanity check");
+- return cpu_count;
++ // Linux doesn't yet have a (official) notion of processor sets,
++ // so just return the number of online processors.
++ int online_cpus = ::sysconf(_SC_NPROCESSORS_ONLN);
++ assert(online_cpus > 0 && online_cpus <= processor_count(), "sanity check");
++ return online_cpus;
+ }
+
+ // Determine the active processor count from one of
+--- openjdk/hotspot/test/runtime/os/AvailableProcessors.java
++++ /dev/null
+@@ -1,103 +0,0 @@
+-/*
+- * Copyright (c) 2016, Oracle and/or its affiliates. All rights reserved.
+- * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+- *
+- * This code is free software; you can redistribute it and/or modify it
+- * under the terms of the GNU General Public License version 2 only, as
+- * published by the Free Software Foundation.
+- *
+- * This code is distributed in the hope that it will be useful, but WITHOUT
+- * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+- * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
+- * version 2 for more details (a copy is included in the LICENSE file that
+- * accompanied this code).
+- *
+- * You should have received a copy of the GNU General Public License version
+- * 2 along with this work; if not, write to the Free Software Foundation,
+- * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
+- *
+- * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
+- * or visit www.oracle.com if you need additional information or have any
+- * questions.
+- */
+-import java.io.File;
+-import com.oracle.java.testlibrary.ProcessTools;
+-import com.oracle.java.testlibrary.OutputAnalyzer;
+-import java.util.ArrayList;
+-
+-/*
+- * @test
+- * @bug 6515172
+- * @summary Check that availableProcessors reports the correct value when running in a cpuset on linux
+- * @requires os.family == "linux"
+- * @library /testlibrary
+- * @build com.oracle.java.testlibrary.*
+- * @run driver AvailableProcessors
+- */
+-public class AvailableProcessors {
+-
+- static final String SUCCESS_STRING = "Found expected processors: ";
+-
+- public static void main(String[] args) throws Throwable {
+- if (args.length > 0)
+- checkProcessors(Integer.parseInt(args[0]));
+- else {
+- // run ourselves under different cpu configurations
+- // using the taskset command
+- String taskset;
+- final String taskset1 = "/bin/taskset";
+- final String taskset2 = "/usr/bin/taskset";
+- if (new File(taskset1).exists())
+- taskset = taskset1;
+- else if (new File(taskset2).exists())
+- taskset = taskset2;
+- else {
+- System.out.println("Skipping test: could not find taskset command");
+- return;
+- }
+-
+- int available = Runtime.getRuntime().availableProcessors();
+-
+- if (available == 1) {
+- System.out.println("Skipping test: only one processor available");
+- return;
+- }
+-
+- // Get the java command we want to execute
+- // Enable logging for easier failure diagnosis
+- ProcessBuilder master =
+- ProcessTools.createJavaProcessBuilder(false,
+- "-XX:+UnlockDiagnosticVMOptions",
+- "-XX:+PrintActiveCpus",
+- "AvailableProcessors");
+-
+- int[] expected = new int[] { 1, available/2, available-1, available };
+-
+- for (int i : expected) {
+- System.out.println("Testing for " + i + " processors ...");
+- int max = i - 1;
+- ArrayList<String> cmdline = new ArrayList<>(master.command());
+- // prepend taskset command
+- cmdline.add(0, "0-" + max);
+- cmdline.add(0, "-c");
+- cmdline.add(0, taskset);
+- // append expected processor count
+- cmdline.add(String.valueOf(i));
+- ProcessBuilder pb = new ProcessBuilder(cmdline);
+- System.out.println("Final command line: " +
+- ProcessTools.getCommandLine(pb));
+- OutputAnalyzer output = ProcessTools.executeProcess(pb);
+- output.shouldContain(SUCCESS_STRING);
+- }
+- }
+- }
+-
+- static void checkProcessors(int expected) {
+- int available = Runtime.getRuntime().availableProcessors();
+- if (available != expected)
+- throw new Error("Expected " + expected + " processors, but found "
+- + available);
+- else
+- System.out.println(SUCCESS_STRING + available);
+- }
+-}