From 5b898702339f20d11633a088ebde2c4b79f69f4a Mon Sep 17 00:00:00 2001 From: Mikael Auno Date: Wed, 4 Feb 2015 16:09:49 +0100 Subject: [PATCH 001/116] 8072472: serviceability/dcmd/framework/* should be quarantined Reviewed-by: jbachorik --- hotspot/test/serviceability/dcmd/framework/HelpTest.java | 1 + .../test/serviceability/dcmd/framework/InvalidCommandTest.java | 1 + hotspot/test/serviceability/dcmd/framework/VMVersionTest.java | 1 + 3 files changed, 3 insertions(+) diff --git a/hotspot/test/serviceability/dcmd/framework/HelpTest.java b/hotspot/test/serviceability/dcmd/framework/HelpTest.java index fd0a57d607a..323dae74e21 100644 --- a/hotspot/test/serviceability/dcmd/framework/HelpTest.java +++ b/hotspot/test/serviceability/dcmd/framework/HelpTest.java @@ -33,6 +33,7 @@ import org.testng.annotations.Test; * @test * @summary Test of diagnostic command help (tests all DCMD executors) * @library /testlibrary + * @ignore 8072440 * @build com.oracle.java.testlibrary.* * @build com.oracle.java.testlibrary.dcmd.* * @run testng/othervm -XX:+UsePerfData HelpTest diff --git a/hotspot/test/serviceability/dcmd/framework/InvalidCommandTest.java b/hotspot/test/serviceability/dcmd/framework/InvalidCommandTest.java index b584308ed1a..8c5d68cdae7 100644 --- a/hotspot/test/serviceability/dcmd/framework/InvalidCommandTest.java +++ b/hotspot/test/serviceability/dcmd/framework/InvalidCommandTest.java @@ -33,6 +33,7 @@ import org.testng.annotations.Test; * @test * @summary Test of invalid diagnostic command (tests all DCMD executors) * @library /testlibrary + * @ignore 8072440 * @build com.oracle.java.testlibrary.* * @build com.oracle.java.testlibrary.dcmd.* * @run testng/othervm -XX:+UsePerfData InvalidCommandTest diff --git a/hotspot/test/serviceability/dcmd/framework/VMVersionTest.java b/hotspot/test/serviceability/dcmd/framework/VMVersionTest.java index c46faae3287..8d0f2eaa5ab 100644 --- a/hotspot/test/serviceability/dcmd/framework/VMVersionTest.java +++ b/hotspot/test/serviceability/dcmd/framework/VMVersionTest.java @@ -34,6 +34,7 @@ import org.testng.annotations.Test; * @test * @summary Test of diagnostic command VM.version (tests all DCMD executors) * @library /testlibrary + * @ignore 8072440 * @build com.oracle.java.testlibrary.* * @build com.oracle.java.testlibrary.dcmd.* * @run testng/othervm -XX:+UsePerfData VMVersionTest From 3bd56fc1a695d2f4bd0d7044b6b8309f8592a060 Mon Sep 17 00:00:00 2001 From: Thomas Stuefe Date: Wed, 4 Feb 2015 18:47:42 -0500 Subject: [PATCH 002/116] 8065895: Synchronous signals during error reporting may terminate or hang VM process Reviewed-by: dholmes, gziemski --- hotspot/src/os/aix/vm/vmError_aix.cpp | 11 +++-- hotspot/src/os/bsd/vm/vmError_bsd.cpp | 47 +++++++++++------- hotspot/src/os/linux/vm/vmError_linux.cpp | 48 ++++++++++++------- hotspot/src/os/solaris/vm/vmError_solaris.cpp | 48 ++++++++++++------- hotspot/src/share/vm/runtime/globals.hpp | 4 ++ hotspot/src/share/vm/utilities/debug.cpp | 48 ++++++++++++++++--- hotspot/src/share/vm/utilities/debug.hpp | 18 +++++++ hotspot/src/share/vm/utilities/vmError.cpp | 29 +++++++++++ 8 files changed, 196 insertions(+), 57 deletions(-) diff --git a/hotspot/src/os/aix/vm/vmError_aix.cpp b/hotspot/src/os/aix/vm/vmError_aix.cpp index d99436ebc1c..34709134a56 100644 --- a/hotspot/src/os/aix/vm/vmError_aix.cpp +++ b/hotspot/src/os/aix/vm/vmError_aix.cpp @@ -80,7 +80,6 @@ static void save_signal(int idx, int sig) { } int VMError::get_resetted_sigflags(int sig) { - // Handle all program errors. for (int i = 0; i < NUM_SIGNALS; i++) { if (SIGNALS[i] == sig) { return resettedSigflags[i]; @@ -90,7 +89,6 @@ int VMError::get_resetted_sigflags(int sig) { } address VMError::get_resetted_sighandler(int sig) { - // Handle all program errors. for (int i = 0; i < NUM_SIGNALS; i++) { if (SIGNALS[i] == sig) { return resettedSighandler[i]; @@ -100,12 +98,19 @@ address VMError::get_resetted_sighandler(int sig) { } static void crash_handler(int sig, siginfo_t* info, void* ucVoid) { + // Unmask current signal. sigset_t newset; sigemptyset(&newset); sigaddset(&newset, sig); + // and all other synchronous signals too. + for (int i = 0; i < NUM_SIGNALS; i++) { + sigaddset(&newset, SIGNALS[i]); + } + sigthreadmask(SIG_UNBLOCK, &newset, NULL); - Unimplemented(); + VMError err(NULL, sig, NULL, info, ucVoid); + err.report_and_die(); } void VMError::reset_signal_handlers() { diff --git a/hotspot/src/os/bsd/vm/vmError_bsd.cpp b/hotspot/src/os/bsd/vm/vmError_bsd.cpp index 8ec6ca04c25..f09e1163f6b 100644 --- a/hotspot/src/os/bsd/vm/vmError_bsd.cpp +++ b/hotspot/src/os/bsd/vm/vmError_bsd.cpp @@ -63,9 +63,15 @@ void VMError::show_message_box(char *buf, int buflen) { } while (yes); } +// handle all synchronous program error signals which may happen during error +// reporting. They must be unblocked, caught, handled. + +static const int SIGNALS[] = { SIGSEGV, SIGBUS, SIGILL, SIGFPE, SIGTRAP }; // add more if needed +static const int NUM_SIGNALS = sizeof(SIGNALS) / sizeof(int); + // Space for our "saved" signal flags and handlers -static int resettedSigflags[2]; -static address resettedSighandler[2]; +static int resettedSigflags[NUM_SIGNALS]; +static address resettedSighandler[NUM_SIGNALS]; static void save_signal(int idx, int sig) { @@ -78,19 +84,19 @@ static void save_signal(int idx, int sig) } int VMError::get_resetted_sigflags(int sig) { - if(SIGSEGV == sig) { - return resettedSigflags[0]; - } else if(SIGBUS == sig) { - return resettedSigflags[1]; + for (int i = 0; i < NUM_SIGNALS; i++) { + if (SIGNALS[i] == sig) { + return resettedSigflags[i]; + } } return -1; } address VMError::get_resetted_sighandler(int sig) { - if(SIGSEGV == sig) { - return resettedSighandler[0]; - } else if(SIGBUS == sig) { - return resettedSighandler[1]; + for (int i = 0; i < NUM_SIGNALS; i++) { + if (SIGNALS[i] == sig) { + return resettedSighandler[i]; + } } return NULL; } @@ -100,16 +106,25 @@ static void crash_handler(int sig, siginfo_t* info, void* ucVoid) { sigset_t newset; sigemptyset(&newset); sigaddset(&newset, sig); - sigprocmask(SIG_UNBLOCK, &newset, NULL); + // also unmask other synchronous signals + for (int i = 0; i < NUM_SIGNALS; i++) { + sigaddset(&newset, SIGNALS[i]); + } + pthread_sigmask(SIG_UNBLOCK, &newset, NULL); VMError err(NULL, sig, NULL, info, ucVoid); err.report_and_die(); } void VMError::reset_signal_handlers() { - // Save sigflags for resetted signals - save_signal(0, SIGSEGV); - save_signal(1, SIGBUS); - os::signal(SIGSEGV, CAST_FROM_FN_PTR(void *, crash_handler)); - os::signal(SIGBUS, CAST_FROM_FN_PTR(void *, crash_handler)); + // install signal handlers for all synchronous program error signals + sigset_t newset; + sigemptyset(&newset); + + for (int i = 0; i < NUM_SIGNALS; i++) { + save_signal(i, SIGNALS[i]); + os::signal(SIGNALS[i], CAST_FROM_FN_PTR(void *, crash_handler)); + sigaddset(&newset, SIGNALS[i]); + } + pthread_sigmask(SIG_UNBLOCK, &newset, NULL); } diff --git a/hotspot/src/os/linux/vm/vmError_linux.cpp b/hotspot/src/os/linux/vm/vmError_linux.cpp index 378c9a6ab6a..fca239c7e9f 100644 --- a/hotspot/src/os/linux/vm/vmError_linux.cpp +++ b/hotspot/src/os/linux/vm/vmError_linux.cpp @@ -63,9 +63,15 @@ void VMError::show_message_box(char *buf, int buflen) { } while (yes); } +// handle all synchronous program error signals which may happen during error +// reporting. They must be unblocked, caught, handled. + +static const int SIGNALS[] = { SIGSEGV, SIGBUS, SIGILL, SIGFPE, SIGTRAP }; // add more if needed +static const int NUM_SIGNALS = sizeof(SIGNALS) / sizeof(int); + // Space for our "saved" signal flags and handlers -static int resettedSigflags[2]; -static address resettedSighandler[2]; +static int resettedSigflags[NUM_SIGNALS]; +static address resettedSighandler[NUM_SIGNALS]; static void save_signal(int idx, int sig) { @@ -78,19 +84,19 @@ static void save_signal(int idx, int sig) } int VMError::get_resetted_sigflags(int sig) { - if(SIGSEGV == sig) { - return resettedSigflags[0]; - } else if(SIGBUS == sig) { - return resettedSigflags[1]; + for (int i = 0; i < NUM_SIGNALS; i++) { + if (SIGNALS[i] == sig) { + return resettedSigflags[i]; + } } return -1; } address VMError::get_resetted_sighandler(int sig) { - if(SIGSEGV == sig) { - return resettedSighandler[0]; - } else if(SIGBUS == sig) { - return resettedSighandler[1]; + for (int i = 0; i < NUM_SIGNALS; i++) { + if (SIGNALS[i] == sig) { + return resettedSighandler[i]; + } } return NULL; } @@ -100,16 +106,26 @@ static void crash_handler(int sig, siginfo_t* info, void* ucVoid) { sigset_t newset; sigemptyset(&newset); sigaddset(&newset, sig); - sigprocmask(SIG_UNBLOCK, &newset, NULL); + // also unmask other synchronous signals + for (int i = 0; i < NUM_SIGNALS; i++) { + sigaddset(&newset, SIGNALS[i]); + } + pthread_sigmask(SIG_UNBLOCK, &newset, NULL); VMError err(NULL, sig, NULL, info, ucVoid); err.report_and_die(); } void VMError::reset_signal_handlers() { - // Save sigflags for resetted signals - save_signal(0, SIGSEGV); - save_signal(1, SIGBUS); - os::signal(SIGSEGV, CAST_FROM_FN_PTR(void *, crash_handler)); - os::signal(SIGBUS, CAST_FROM_FN_PTR(void *, crash_handler)); + // install signal handlers for all synchronous program error signals + sigset_t newset; + sigemptyset(&newset); + + for (int i = 0; i < NUM_SIGNALS; i++) { + save_signal(i, SIGNALS[i]); + os::signal(SIGNALS[i], CAST_FROM_FN_PTR(void *, crash_handler)); + sigaddset(&newset, SIGNALS[i]); + } + pthread_sigmask(SIG_UNBLOCK, &newset, NULL); + } diff --git a/hotspot/src/os/solaris/vm/vmError_solaris.cpp b/hotspot/src/os/solaris/vm/vmError_solaris.cpp index 6f3f5b06fe6..e24e5f6bf4c 100644 --- a/hotspot/src/os/solaris/vm/vmError_solaris.cpp +++ b/hotspot/src/os/solaris/vm/vmError_solaris.cpp @@ -30,6 +30,7 @@ #include #include +#include #include void VMError::show_message_box(char *buf, int buflen) { @@ -59,9 +60,15 @@ void VMError::show_message_box(char *buf, int buflen) { } while (yes); } +// handle all synchronous program error signals which may happen during error +// reporting. They must be unblocked, caught, handled. + +static const int SIGNALS[] = { SIGSEGV, SIGBUS, SIGILL, SIGFPE, SIGTRAP }; // add more if needed +static const int NUM_SIGNALS = sizeof(SIGNALS) / sizeof(int); + // Space for our "saved" signal flags and handlers -static int resettedSigflags[2]; -static address resettedSighandler[2]; +static int resettedSigflags[NUM_SIGNALS]; +static address resettedSighandler[NUM_SIGNALS]; static void save_signal(int idx, int sig) { @@ -74,19 +81,19 @@ static void save_signal(int idx, int sig) } int VMError::get_resetted_sigflags(int sig) { - if(SIGSEGV == sig) { - return resettedSigflags[0]; - } else if(SIGBUS == sig) { - return resettedSigflags[1]; + for (int i = 0; i < NUM_SIGNALS; i++) { + if (SIGNALS[i] == sig) { + return resettedSigflags[i]; + } } return -1; } address VMError::get_resetted_sighandler(int sig) { - if(SIGSEGV == sig) { - return resettedSighandler[0]; - } else if(SIGBUS == sig) { - return resettedSighandler[1]; + for (int i = 0; i < NUM_SIGNALS; i++) { + if (SIGNALS[i] == sig) { + return resettedSighandler[i]; + } } return NULL; } @@ -96,16 +103,25 @@ static void crash_handler(int sig, siginfo_t* info, void* ucVoid) { sigset_t newset; sigemptyset(&newset); sigaddset(&newset, sig); - sigprocmask(SIG_UNBLOCK, &newset, NULL); + // also unmask other synchronous signals + for (int i = 0; i < NUM_SIGNALS; i++) { + sigaddset(&newset, SIGNALS[i]); + } + thr_sigsetmask(SIG_UNBLOCK, &newset, NULL); VMError err(NULL, sig, NULL, info, ucVoid); err.report_and_die(); } void VMError::reset_signal_handlers() { - // Save sigflags for resetted signals - save_signal(0, SIGSEGV); - save_signal(1, SIGBUS); - os::signal(SIGSEGV, CAST_FROM_FN_PTR(void *, crash_handler)); - os::signal(SIGBUS, CAST_FROM_FN_PTR(void *, crash_handler)); + // install signal handlers for all synchronous program error signals + sigset_t newset; + sigemptyset(&newset); + + for (int i = 0; i < NUM_SIGNALS; i++) { + save_signal(i, SIGNALS[i]); + os::signal(SIGNALS[i], CAST_FROM_FN_PTR(void *, crash_handler)); + sigaddset(&newset, SIGNALS[i]); + } + thr_sigsetmask(SIG_UNBLOCK, &newset, NULL); } diff --git a/hotspot/src/share/vm/runtime/globals.hpp b/hotspot/src/share/vm/runtime/globals.hpp index dd014368f69..7e27b03dbf9 100644 --- a/hotspot/src/share/vm/runtime/globals.hpp +++ b/hotspot/src/share/vm/runtime/globals.hpp @@ -905,6 +905,10 @@ class CommandLineFlags { "determines which error to provoke. See test_error_handler() " \ "in debug.cpp.") \ \ + notproduct(uintx, TestCrashInErrorHandler, 0, \ + "If > 0, provokes an error inside VM error handler (a secondary " \ + "crash). see test_error_handler() in debug.cpp.") \ + \ develop(bool, Verbose, false, \ "Print additional debugging information from other modes") \ \ diff --git a/hotspot/src/share/vm/utilities/debug.cpp b/hotspot/src/share/vm/utilities/debug.cpp index 260aadfb7b2..3e6c9303f83 100644 --- a/hotspot/src/share/vm/utilities/debug.cpp +++ b/hotspot/src/share/vm/utilities/debug.cpp @@ -316,13 +316,47 @@ bool is_error_reported() { #ifndef PRODUCT #include +typedef void (*voidfun_t)(); +// Crash with an authentic sigfpe +static void crash_with_sigfpe() { + // generate a native synchronous SIGFPE where possible; + // if that did not cause a signal (e.g. on ppc), just + // raise the signal. + volatile int x = 0; + volatile int y = 1/x; +#ifndef _WIN32 + raise(SIGFPE); +#endif +} // end: crash_with_sigfpe + +// crash with sigsegv at non-null address. +static void crash_with_segfault() { + + char* const crash_addr = (char*) get_segfault_address(); + *crash_addr = 'X'; + +} // end: crash_with_segfault + +// returns an address which is guaranteed to generate a SIGSEGV on read, +// for test purposes, which is not NULL and contains bits in every word +void* get_segfault_address() { + return (void*) +#ifdef _LP64 + 0xABC0000000000ABCULL; +#else + 0x00000ABC; +#endif +} + void test_error_handler() { - uintx test_num = ErrorHandlerTest; - if (test_num == 0) return; + controlled_crash(ErrorHandlerTest); +} + +void controlled_crash(int how) { + if (how == 0) return; // If asserts are disabled, use the corresponding guarantee instead. - size_t n = test_num; - NOT_DEBUG(if (n <= 2) n += 2); + NOT_DEBUG(if (how <= 2) how += 2); const char* const str = "hello"; const size_t num = (size_t)os::vm_page_size(); @@ -333,7 +367,7 @@ void test_error_handler() { const void (*funcPtr)(void) = (const void(*)()) 0xF; // bad function pointer // Keep this in sync with test/runtime/6888954/vmerrors.sh. - switch (n) { + switch (how) { case 1: vmassert(str == NULL, "expected null"); case 2: vmassert(num == 1023 && *str == 'X', err_msg("num=" SIZE_FORMAT " str=\"%s\"", num, str)); @@ -358,8 +392,10 @@ void test_error_handler() { // There's no guarantee the bad function pointer will crash us // so "break" out to the ShouldNotReachHere(). case 13: (*funcPtr)(); break; + case 14: crash_with_segfault(); break; + case 15: crash_with_sigfpe(); break; - default: tty->print_cr("ERROR: %d: unexpected test_num value.", n); + default: tty->print_cr("ERROR: %d: unexpected test_num value.", how); } ShouldNotReachHere(); } diff --git a/hotspot/src/share/vm/utilities/debug.hpp b/hotspot/src/share/vm/utilities/debug.hpp index 85fae1733a5..381cfd63bae 100644 --- a/hotspot/src/share/vm/utilities/debug.hpp +++ b/hotspot/src/share/vm/utilities/debug.hpp @@ -248,6 +248,24 @@ void set_error_reported(); /* Test vmassert(), fatal(), guarantee(), etc. */ NOT_PRODUCT(void test_error_handler();) +// crash in a controlled way: +// how can be one of: +// 1,2 - asserts +// 3,4 - guarantee +// 5-7 - fatal +// 8 - vm_exit_out_of_memory +// 9 - ShouldNotCallThis +// 10 - ShouldNotReachHere +// 11 - Unimplemented +// 12,13 - (not guaranteed) crashes +// 14 - SIGSEGV +// 15 - SIGFPE +NOT_PRODUCT(void controlled_crash(int how);) + +// returns an address which is guaranteed to generate a SIGSEGV on read, +// for test purposes, which is not NULL and contains bits in every word +NOT_PRODUCT(void* get_segfault_address();) + void pd_ps(frame f); void pd_obfuscate_location(char *buf, size_t buflen); diff --git a/hotspot/src/share/vm/utilities/vmError.cpp b/hotspot/src/share/vm/utilities/vmError.cpp index 00e8b783c62..cc6508a208a 100644 --- a/hotspot/src/share/vm/utilities/vmError.cpp +++ b/hotspot/src/share/vm/utilities/vmError.cpp @@ -353,6 +353,26 @@ void VMError::report(outputStream* st) { "Runtime Environment to continue."); } +#ifndef PRODUCT + // Error handler self tests + + // test secondary error handling. Test it twice, to test that resetting + // error handler after a secondary crash works. + STEP(13, "(test secondary crash 1)") + if (_verbose && TestCrashInErrorHandler != 0) { + st->print_cr("Will crash now (TestCrashInErrorHandler=%d)...", + TestCrashInErrorHandler); + controlled_crash(TestCrashInErrorHandler); + } + + STEP(14, "(test secondary crash 2)") + if (_verbose && TestCrashInErrorHandler != 0) { + st->print_cr("Will crash now (TestCrashInErrorHandler=%d)...", + TestCrashInErrorHandler); + controlled_crash(TestCrashInErrorHandler); + } +#endif // PRODUCT + STEP(15, "(printing type of error)") switch(_id) { @@ -786,6 +806,15 @@ void VMError::report(outputStream* st) { st->cr(); } +#ifndef PRODUCT + // print a defined marker to show that error handling finished correctly. + STEP(290, "(printing end marker)" ) + + if (_verbose) { + st->print_cr("END."); + } +#endif + END # undef BEGIN From de0f1ccb8607a4015dbdbe9bd7e8898d7146ba87 Mon Sep 17 00:00:00 2001 From: Thomas Stuefe Date: Wed, 4 Feb 2015 21:33:22 -0500 Subject: [PATCH 003/116] 8072575: Add missing test for 8065895 Reviewed-by: dholmes, gziemski --- .../ErrorHandling/SecondaryErrorTest.java | 105 ++++++++++++++++++ 1 file changed, 105 insertions(+) create mode 100644 hotspot/test/runtime/ErrorHandling/SecondaryErrorTest.java diff --git a/hotspot/test/runtime/ErrorHandling/SecondaryErrorTest.java b/hotspot/test/runtime/ErrorHandling/SecondaryErrorTest.java new file mode 100644 index 00000000000..380809b365c --- /dev/null +++ b/hotspot/test/runtime/ErrorHandling/SecondaryErrorTest.java @@ -0,0 +1,105 @@ +import java.io.BufferedReader; +import java.io.File; +import java.io.FileInputStream; +import java.io.InputStreamReader; +import java.util.regex.Pattern; + +import com.oracle.java.testlibrary.OutputAnalyzer; +import com.oracle.java.testlibrary.Platform; +import com.oracle.java.testlibrary.ProcessTools; + +/* + * @test + * @bug 8065896 + * @summary Synchronous signals during error reporting may terminate or hang VM process + * @library /testlibrary + * @author Thomas Stuefe (SAP) + */ + +public class SecondaryErrorTest { + + + public static void main(String[] args) throws Exception { + + // Do not execute for windows, nor for non-debug builds + if (Platform.isWindows()) { + return; + } + + if (!Platform.isDebugBuild()) { + return; + } + + ProcessBuilder pb = ProcessTools.createJavaProcessBuilder( + "-XX:+UnlockDiagnosticVMOptions", + "-Xmx100M", + "-XX:ErrorHandlerTest=15", + "-XX:TestCrashInErrorHandler=14", + "-version"); + + OutputAnalyzer output_detail = new OutputAnalyzer(pb.start()); + + // we should have crashed with a SIGFPE + output_detail.shouldMatch("# A fatal error has been detected by the Java Runtime Environment:.*"); + output_detail.shouldMatch("# +SIGFPE.*"); + + // extract hs-err file + String hs_err_file = output_detail.firstMatch("# *(\\S*hs_err_pid\\d+\\.log)", 1); + if (hs_err_file == null) { + throw new RuntimeException("Did not find hs-err file in output.\n"); + } + + // scan hs-err file: File should contain the "[error occurred during error reporting..]" + // markers which show that the secondary error handling kicked in and handled the + // error successfully. As an added test, we check that the last line contains "END.", + // which is an end marker written in the last step and proves that hs-err file was + // completely written. + File f = new File(hs_err_file); + if (!f.exists()) { + throw new RuntimeException("hs-err file missing at " + + f.getAbsolutePath() + ".\n"); + } + + System.out.println("Found hs_err file. Scanning..."); + + FileInputStream fis = new FileInputStream(f); + BufferedReader br = new BufferedReader(new InputStreamReader(fis)); + String line = null; + + Pattern [] pattern = new Pattern[] { + Pattern.compile("Will crash now \\(TestCrashInErrorHandler=14\\)..."), + Pattern.compile("\\[error occurred during error reporting \\(test secondary crash 1\\).*\\]"), + Pattern.compile("Will crash now \\(TestCrashInErrorHandler=14\\)..."), + Pattern.compile("\\[error occurred during error reporting \\(test secondary crash 2\\).*\\]"), + }; + int currentPattern = 0; + + String lastLine = null; + while ((line = br.readLine()) != null) { + if (currentPattern < pattern.length) { + if (pattern[currentPattern].matcher(line).matches()) { + System.out.println("Found: " + line + "."); + currentPattern ++; + } + } + lastLine = line; + } + br.close(); + + if (currentPattern < pattern.length) { + throw new RuntimeException("hs-err file incomplete (first missing pattern: " + currentPattern + ")"); + } + + if (!lastLine.equals("END.")) { + throw new RuntimeException("hs-err file incomplete (missing END marker.)"); + } else { + System.out.println("End marker found."); + } + + System.out.println("OK."); + + } + +} + + From 483815ed11371273e51a6f024c0255705321e2b9 Mon Sep 17 00:00:00 2001 From: Staffan Larsen Date: Thu, 5 Feb 2015 12:54:34 +0100 Subject: [PATCH 004/116] 8072455: Use jtreg's requiredVersion tag in hotspot/test/TEST.ROOT Reviewed-by: dholmes, ctornqvi --- hotspot/test/TEST.ROOT | 3 +++ 1 file changed, 3 insertions(+) diff --git a/hotspot/test/TEST.ROOT b/hotspot/test/TEST.ROOT index d9414f507e1..fc23ac90061 100644 --- a/hotspot/test/TEST.ROOT +++ b/hotspot/test/TEST.ROOT @@ -31,3 +31,6 @@ keys=cte_test jcmd nmt regression gc stress groups=TEST.groups [closed/TEST.groups] requires.properties=sun.arch.data.model + +# Tests using jtreg 4.1 b10 features +requiredVersion=4.1 b10 From 3a8d0b8ce00beb379167360dc90d944143cac03e Mon Sep 17 00:00:00 2001 From: Goetz Lindenmaier Date: Wed, 4 Feb 2015 16:26:38 +0100 Subject: [PATCH 005/116] 8072434: 8064457: introduces performance regressions in 9-b47 Reviewed-by: coleenp, kvn --- hotspot/src/share/vm/runtime/virtualspace.cpp | 5 +++-- 1 file changed, 3 insertions(+), 2 deletions(-) diff --git a/hotspot/src/share/vm/runtime/virtualspace.cpp b/hotspot/src/share/vm/runtime/virtualspace.cpp index d57f1be3973..fe3219f1a8b 100644 --- a/hotspot/src/share/vm/runtime/virtualspace.cpp +++ b/hotspot/src/share/vm/runtime/virtualspace.cpp @@ -503,11 +503,12 @@ void ReservedHeapSpace::initialize_compressed_heap(const size_t size, size_t ali // But leave room for the compressed class pointers, which is allocated above // the heap. char *zerobased_max = (char *)OopEncodingHeapMax; + const size_t class_space = align_size_up(CompressedClassSpaceSize, alignment); // For small heaps, save some space for compressed class pointer // space so it can be decoded with no base. if (UseCompressedClassPointers && !UseSharedSpaces && - OopEncodingHeapMax <= KlassEncodingMetaspaceMax) { - const size_t class_space = align_size_up(CompressedClassSpaceSize, alignment); + OopEncodingHeapMax <= KlassEncodingMetaspaceMax && + (uint64_t)(aligned_heap_base_min_address + size + class_space) <= KlassEncodingMetaspaceMax) { zerobased_max = (char *)OopEncodingHeapMax - class_space; } From 48639428ce82f37e18f52fbf0033be2d4e0ea590 Mon Sep 17 00:00:00 2001 From: Jaroslav Bachorik Date: Mon, 12 Jan 2015 14:05:16 +0100 Subject: [PATCH 006/116] 8068976: Remove JSDT implementation Reviewed-by: sla, mchung, dholmes --- hotspot/make/aix/makefiles/mapfile-vers-debug | 5 - .../make/aix/makefiles/mapfile-vers-product | 5 - .../bsd/makefiles/mapfile-vers-darwin-debug | 5 - .../bsd/makefiles/mapfile-vers-darwin-product | 5 - hotspot/make/bsd/makefiles/mapfile-vers-debug | 5 - .../make/bsd/makefiles/mapfile-vers-product | 5 - .../make/linux/makefiles/mapfile-vers-debug | 5 - .../make/linux/makefiles/mapfile-vers-product | 5 - hotspot/make/solaris/makefiles/dtrace.make | 6 - hotspot/make/solaris/makefiles/mapfile-vers | 5 - hotspot/src/cpu/sparc/vm/nativeInst_sparc.cpp | 5 - hotspot/src/cpu/sparc/vm/nativeInst_sparc.hpp | 1 - .../src/cpu/sparc/vm/sharedRuntime_sparc.cpp | 534 -------------- hotspot/src/cpu/x86/vm/nativeInst_x86.cpp | 4 - hotspot/src/cpu/x86/vm/nativeInst_x86.hpp | 1 - .../src/cpu/x86/vm/sharedRuntime_x86_32.cpp | 375 ---------- .../src/cpu/x86/vm/sharedRuntime_x86_64.cpp | 624 ----------------- hotspot/src/os/bsd/vm/dtraceJSDT_bsd.cpp | 54 -- hotspot/src/os/linux/vm/dtraceJSDT_linux.cpp | 47 -- .../src/os/solaris/vm/dtraceJSDT_solaris.cpp | 655 ------------------ .../src/os/windows/vm/dtraceJSDT_windows.cpp | 47 -- hotspot/src/share/vm/asm/codeBuffer.hpp | 1 - hotspot/src/share/vm/code/nmethod.cpp | 126 ---- hotspot/src/share/vm/code/nmethod.hpp | 28 - hotspot/src/share/vm/prims/jvm.cpp | 31 - hotspot/src/share/vm/prims/jvm.h | 77 -- hotspot/src/share/vm/runtime/dtraceJSDT.cpp | 132 ---- hotspot/src/share/vm/runtime/dtraceJSDT.hpp | 96 --- hotspot/src/share/vm/runtime/globals.hpp | 3 - .../src/share/vm/runtime/sharedRuntime.cpp | 62 -- .../src/share/vm/runtime/sharedRuntime.hpp | 17 - 31 files changed, 2971 deletions(-) delete mode 100644 hotspot/src/os/bsd/vm/dtraceJSDT_bsd.cpp delete mode 100644 hotspot/src/os/linux/vm/dtraceJSDT_linux.cpp delete mode 100644 hotspot/src/os/solaris/vm/dtraceJSDT_solaris.cpp delete mode 100644 hotspot/src/os/windows/vm/dtraceJSDT_windows.cpp delete mode 100644 hotspot/src/share/vm/runtime/dtraceJSDT.cpp delete mode 100644 hotspot/src/share/vm/runtime/dtraceJSDT.hpp diff --git a/hotspot/make/aix/makefiles/mapfile-vers-debug b/hotspot/make/aix/makefiles/mapfile-vers-debug index 1b3409a6de0..81c7c5b7fd2 100644 --- a/hotspot/make/aix/makefiles/mapfile-vers-debug +++ b/hotspot/make/aix/makefiles/mapfile-vers-debug @@ -62,11 +62,6 @@ SUNWprivate_1.1 { JVM_DefineClassWithSourceCond; JVM_DesiredAssertionStatus; JVM_DoPrivileged; - JVM_DTraceGetVersion; - JVM_DTraceActivate; - JVM_DTraceIsProbeEnabled; - JVM_DTraceIsSupported; - JVM_DTraceDispose; JVM_DumpAllStacks; JVM_DumpThreads; JVM_FillInStackTrace; diff --git a/hotspot/make/aix/makefiles/mapfile-vers-product b/hotspot/make/aix/makefiles/mapfile-vers-product index 966060f7de6..745901bb4d6 100644 --- a/hotspot/make/aix/makefiles/mapfile-vers-product +++ b/hotspot/make/aix/makefiles/mapfile-vers-product @@ -62,11 +62,6 @@ SUNWprivate_1.1 { JVM_DefineClassWithSourceCond; JVM_DesiredAssertionStatus; JVM_DoPrivileged; - JVM_DTraceGetVersion; - JVM_DTraceActivate; - JVM_DTraceIsProbeEnabled; - JVM_DTraceIsSupported; - JVM_DTraceDispose; JVM_DumpAllStacks; JVM_DumpThreads; JVM_FillInStackTrace; diff --git a/hotspot/make/bsd/makefiles/mapfile-vers-darwin-debug b/hotspot/make/bsd/makefiles/mapfile-vers-darwin-debug index 8779ec5ff1d..99880a19f4a 100644 --- a/hotspot/make/bsd/makefiles/mapfile-vers-darwin-debug +++ b/hotspot/make/bsd/makefiles/mapfile-vers-darwin-debug @@ -60,11 +60,6 @@ _JVM_DefineClassWithSourceCond _JVM_DesiredAssertionStatus _JVM_DoPrivileged - _JVM_DTraceGetVersion - _JVM_DTraceActivate - _JVM_DTraceIsProbeEnabled - _JVM_DTraceIsSupported - _JVM_DTraceDispose _JVM_DumpAllStacks _JVM_DumpThreads _JVM_FillInStackTrace diff --git a/hotspot/make/bsd/makefiles/mapfile-vers-darwin-product b/hotspot/make/bsd/makefiles/mapfile-vers-darwin-product index 8779ec5ff1d..99880a19f4a 100644 --- a/hotspot/make/bsd/makefiles/mapfile-vers-darwin-product +++ b/hotspot/make/bsd/makefiles/mapfile-vers-darwin-product @@ -60,11 +60,6 @@ _JVM_DefineClassWithSourceCond _JVM_DesiredAssertionStatus _JVM_DoPrivileged - _JVM_DTraceGetVersion - _JVM_DTraceActivate - _JVM_DTraceIsProbeEnabled - _JVM_DTraceIsSupported - _JVM_DTraceDispose _JVM_DumpAllStacks _JVM_DumpThreads _JVM_FillInStackTrace diff --git a/hotspot/make/bsd/makefiles/mapfile-vers-debug b/hotspot/make/bsd/makefiles/mapfile-vers-debug index 7a5c5430436..950cf57a64a 100644 --- a/hotspot/make/bsd/makefiles/mapfile-vers-debug +++ b/hotspot/make/bsd/makefiles/mapfile-vers-debug @@ -62,11 +62,6 @@ SUNWprivate_1.1 { JVM_DefineClassWithSourceCond; JVM_DesiredAssertionStatus; JVM_DoPrivileged; - JVM_DTraceGetVersion; - JVM_DTraceActivate; - JVM_DTraceIsProbeEnabled; - JVM_DTraceIsSupported; - JVM_DTraceDispose; JVM_DumpAllStacks; JVM_DumpThreads; JVM_FillInStackTrace; diff --git a/hotspot/make/bsd/makefiles/mapfile-vers-product b/hotspot/make/bsd/makefiles/mapfile-vers-product index 7a5c5430436..950cf57a64a 100644 --- a/hotspot/make/bsd/makefiles/mapfile-vers-product +++ b/hotspot/make/bsd/makefiles/mapfile-vers-product @@ -62,11 +62,6 @@ SUNWprivate_1.1 { JVM_DefineClassWithSourceCond; JVM_DesiredAssertionStatus; JVM_DoPrivileged; - JVM_DTraceGetVersion; - JVM_DTraceActivate; - JVM_DTraceIsProbeEnabled; - JVM_DTraceIsSupported; - JVM_DTraceDispose; JVM_DumpAllStacks; JVM_DumpThreads; JVM_FillInStackTrace; diff --git a/hotspot/make/linux/makefiles/mapfile-vers-debug b/hotspot/make/linux/makefiles/mapfile-vers-debug index 7a5c5430436..950cf57a64a 100644 --- a/hotspot/make/linux/makefiles/mapfile-vers-debug +++ b/hotspot/make/linux/makefiles/mapfile-vers-debug @@ -62,11 +62,6 @@ SUNWprivate_1.1 { JVM_DefineClassWithSourceCond; JVM_DesiredAssertionStatus; JVM_DoPrivileged; - JVM_DTraceGetVersion; - JVM_DTraceActivate; - JVM_DTraceIsProbeEnabled; - JVM_DTraceIsSupported; - JVM_DTraceDispose; JVM_DumpAllStacks; JVM_DumpThreads; JVM_FillInStackTrace; diff --git a/hotspot/make/linux/makefiles/mapfile-vers-product b/hotspot/make/linux/makefiles/mapfile-vers-product index 7a5c5430436..950cf57a64a 100644 --- a/hotspot/make/linux/makefiles/mapfile-vers-product +++ b/hotspot/make/linux/makefiles/mapfile-vers-product @@ -62,11 +62,6 @@ SUNWprivate_1.1 { JVM_DefineClassWithSourceCond; JVM_DesiredAssertionStatus; JVM_DoPrivileged; - JVM_DTraceGetVersion; - JVM_DTraceActivate; - JVM_DTraceIsProbeEnabled; - JVM_DTraceIsSupported; - JVM_DTraceDispose; JVM_DumpAllStacks; JVM_DumpThreads; JVM_FillInStackTrace; diff --git a/hotspot/make/solaris/makefiles/dtrace.make b/hotspot/make/solaris/makefiles/dtrace.make index 1b76dc74d6a..1da02fa01c4 100644 --- a/hotspot/make/solaris/makefiles/dtrace.make +++ b/hotspot/make/solaris/makefiles/dtrace.make @@ -336,16 +336,10 @@ $(DTRACE_JHELPER.o) : $(DTRACE_JHELPER).d $(JVMOFFS).h $(JVMOFFS)Index.h .PHONY: dtraceCheck -SYSTEM_DTRACE_H = /usr/include/dtrace.h SYSTEM_DTRACE_PROG = /usr/sbin/dtrace PATCH_DTRACE_PROG = /opt/SUNWdtrd/sbin/dtrace systemDtraceFound := $(wildcard ${SYSTEM_DTRACE_PROG}) patchDtraceFound := $(wildcard ${PATCH_DTRACE_PROG}) -systemDtraceHdrFound := $(wildcard $(SYSTEM_DTRACE_H)) - -ifneq ("$(systemDtraceHdrFound)", "") -CFLAGS += -DHAVE_DTRACE_H -endif ifneq ("$(patchDtraceFound)", "") DTRACE_PROG=$(PATCH_DTRACE_PROG) diff --git a/hotspot/make/solaris/makefiles/mapfile-vers b/hotspot/make/solaris/makefiles/mapfile-vers index 02cf70f3958..1d7838465f2 100644 --- a/hotspot/make/solaris/makefiles/mapfile-vers +++ b/hotspot/make/solaris/makefiles/mapfile-vers @@ -62,11 +62,6 @@ SUNWprivate_1.1 { JVM_DefineClassWithSourceCond; JVM_DesiredAssertionStatus; JVM_DoPrivileged; - JVM_DTraceGetVersion; - JVM_DTraceActivate; - JVM_DTraceIsProbeEnabled; - JVM_DTraceIsSupported; - JVM_DTraceDispose; JVM_DumpAllStacks; JVM_DumpThreads; JVM_FillInStackTrace; diff --git a/hotspot/src/cpu/sparc/vm/nativeInst_sparc.cpp b/hotspot/src/cpu/sparc/vm/nativeInst_sparc.cpp index 2ec40f8fd0d..c7b89b110e9 100644 --- a/hotspot/src/cpu/sparc/vm/nativeInst_sparc.cpp +++ b/hotspot/src/cpu/sparc/vm/nativeInst_sparc.cpp @@ -36,11 +36,6 @@ #include "c1/c1_Runtime1.hpp" #endif - -bool NativeInstruction::is_dtrace_trap() { - return !is_nop(); -} - void NativeInstruction::set_data64_sethi(address instaddr, intptr_t x) { ResourceMark rm; CodeBuffer buf(instaddr, 10 * BytesPerInstWord ); diff --git a/hotspot/src/cpu/sparc/vm/nativeInst_sparc.hpp b/hotspot/src/cpu/sparc/vm/nativeInst_sparc.hpp index 698b448de9a..eaf543e128b 100644 --- a/hotspot/src/cpu/sparc/vm/nativeInst_sparc.hpp +++ b/hotspot/src/cpu/sparc/vm/nativeInst_sparc.hpp @@ -51,7 +51,6 @@ class NativeInstruction VALUE_OBJ_CLASS_SPEC { nop_instruction_size = 4 }; - bool is_dtrace_trap(); bool is_nop() { return long_at(0) == nop_instruction(); } bool is_call() { return is_op(long_at(0), Assembler::call_op); } bool is_sethi() { return (is_op2(long_at(0), Assembler::sethi_op2) diff --git a/hotspot/src/cpu/sparc/vm/sharedRuntime_sparc.cpp b/hotspot/src/cpu/sparc/vm/sharedRuntime_sparc.cpp index bc67a72c1fd..b3dcb8b98c9 100644 --- a/hotspot/src/cpu/sparc/vm/sharedRuntime_sparc.cpp +++ b/hotspot/src/cpu/sparc/vm/sharedRuntime_sparc.cpp @@ -2758,540 +2758,6 @@ nmethod* SharedRuntime::generate_native_wrapper(MacroAssembler* masm, } -#ifdef HAVE_DTRACE_H -// --------------------------------------------------------------------------- -// Generate a dtrace nmethod for a given signature. The method takes arguments -// in the Java compiled code convention, marshals them to the native -// abi and then leaves nops at the position you would expect to call a native -// function. When the probe is enabled the nops are replaced with a trap -// instruction that dtrace inserts and the trace will cause a notification -// to dtrace. -// -// The probes are only able to take primitive types and java/lang/String as -// arguments. No other java types are allowed. Strings are converted to utf8 -// strings so that from dtrace point of view java strings are converted to C -// strings. There is an arbitrary fixed limit on the total space that a method -// can use for converting the strings. (256 chars per string in the signature). -// So any java string larger then this is truncated. - -static int fp_offset[ConcreteRegisterImpl::number_of_registers] = { 0 }; -static bool offsets_initialized = false; - -nmethod *SharedRuntime::generate_dtrace_nmethod( - MacroAssembler *masm, methodHandle method) { - - - // generate_dtrace_nmethod is guarded by a mutex so we are sure to - // be single threaded in this method. - assert(AdapterHandlerLibrary_lock->owned_by_self(), "must be"); - - // Fill in the signature array, for the calling-convention call. - int total_args_passed = method->size_of_parameters(); - - BasicType* in_sig_bt = NEW_RESOURCE_ARRAY(BasicType, total_args_passed); - VMRegPair *in_regs = NEW_RESOURCE_ARRAY(VMRegPair, total_args_passed); - - // The signature we are going to use for the trap that dtrace will see - // java/lang/String is converted. We drop "this" and any other object - // is converted to NULL. (A one-slot java/lang/Long object reference - // is converted to a two-slot long, which is why we double the allocation). - BasicType* out_sig_bt = NEW_RESOURCE_ARRAY(BasicType, total_args_passed * 2); - VMRegPair* out_regs = NEW_RESOURCE_ARRAY(VMRegPair, total_args_passed * 2); - - int i=0; - int total_strings = 0; - int first_arg_to_pass = 0; - int total_c_args = 0; - - // Skip the receiver as dtrace doesn't want to see it - if( !method->is_static() ) { - in_sig_bt[i++] = T_OBJECT; - first_arg_to_pass = 1; - } - - SignatureStream ss(method->signature()); - for ( ; !ss.at_return_type(); ss.next()) { - BasicType bt = ss.type(); - in_sig_bt[i++] = bt; // Collect remaining bits of signature - out_sig_bt[total_c_args++] = bt; - if( bt == T_OBJECT) { - Symbol* s = ss.as_symbol_or_null(); - if (s == vmSymbols::java_lang_String()) { - total_strings++; - out_sig_bt[total_c_args-1] = T_ADDRESS; - } else if (s == vmSymbols::java_lang_Boolean() || - s == vmSymbols::java_lang_Byte()) { - out_sig_bt[total_c_args-1] = T_BYTE; - } else if (s == vmSymbols::java_lang_Character() || - s == vmSymbols::java_lang_Short()) { - out_sig_bt[total_c_args-1] = T_SHORT; - } else if (s == vmSymbols::java_lang_Integer() || - s == vmSymbols::java_lang_Float()) { - out_sig_bt[total_c_args-1] = T_INT; - } else if (s == vmSymbols::java_lang_Long() || - s == vmSymbols::java_lang_Double()) { - out_sig_bt[total_c_args-1] = T_LONG; - out_sig_bt[total_c_args++] = T_VOID; - } - } else if ( bt == T_LONG || bt == T_DOUBLE ) { - in_sig_bt[i++] = T_VOID; // Longs & doubles take 2 Java slots - // We convert double to long - out_sig_bt[total_c_args-1] = T_LONG; - out_sig_bt[total_c_args++] = T_VOID; - } else if ( bt == T_FLOAT) { - // We convert float to int - out_sig_bt[total_c_args-1] = T_INT; - } - } - - assert(i==total_args_passed, "validly parsed signature"); - - // Now get the compiled-Java layout as input arguments - int comp_args_on_stack; - comp_args_on_stack = SharedRuntime::java_calling_convention( - in_sig_bt, in_regs, total_args_passed, false); - - // We have received a description of where all the java arg are located - // on entry to the wrapper. We need to convert these args to where - // the a native (non-jni) function would expect them. To figure out - // where they go we convert the java signature to a C signature and remove - // T_VOID for any long/double we might have received. - - - // Now figure out where the args must be stored and how much stack space - // they require (neglecting out_preserve_stack_slots but space for storing - // the 1st six register arguments). It's weird see int_stk_helper. - // - int out_arg_slots; - out_arg_slots = c_calling_convention(out_sig_bt, out_regs, NULL, total_c_args); - - // Calculate the total number of stack slots we will need. - - // First count the abi requirement plus all of the outgoing args - int stack_slots = SharedRuntime::out_preserve_stack_slots() + out_arg_slots; - - // Plus a temp for possible converion of float/double/long register args - - int conversion_temp = stack_slots; - stack_slots += 2; - - - // Now space for the string(s) we must convert - - int string_locs = stack_slots; - stack_slots += total_strings * - (max_dtrace_string_size / VMRegImpl::stack_slot_size); - - // Ok The space we have allocated will look like: - // - // - // FP-> | | - // |---------------------| - // | string[n] | - // |---------------------| <- string_locs[n] - // | string[n-1] | - // |---------------------| <- string_locs[n-1] - // | ... | - // | ... | - // |---------------------| <- string_locs[1] - // | string[0] | - // |---------------------| <- string_locs[0] - // | temp | - // |---------------------| <- conversion_temp - // | outbound memory | - // | based arguments | - // | | - // |---------------------| - // | | - // SP-> | out_preserved_slots | - // - // - - // Now compute actual number of stack words we need rounding to make - // stack properly aligned. - stack_slots = round_to(stack_slots, 4 * VMRegImpl::slots_per_word); - - int stack_size = stack_slots * VMRegImpl::stack_slot_size; - - intptr_t start = (intptr_t)__ pc(); - - // First thing make an ic check to see if we should even be here - - { - Label L; - const Register temp_reg = G3_scratch; - AddressLiteral ic_miss(SharedRuntime::get_ic_miss_stub()); - __ verify_oop(O0); - __ ld_ptr(O0, oopDesc::klass_offset_in_bytes(), temp_reg); - __ cmp_and_brx_short(temp_reg, G5_inline_cache_reg, Assembler::equal, Assembler::pt, L); - - __ jump_to(ic_miss, temp_reg); - __ delayed()->nop(); - __ align(CodeEntryAlignment); - __ bind(L); - } - - int vep_offset = ((intptr_t)__ pc()) - start; - - - // The instruction at the verified entry point must be 5 bytes or longer - // because it can be patched on the fly by make_non_entrant. The stack bang - // instruction fits that requirement. - - // Generate stack overflow check before creating frame - __ generate_stack_overflow_check(stack_size); - - assert(((intptr_t)__ pc() - start - vep_offset) >= 5, - "valid size for make_non_entrant"); - - // Generate a new frame for the wrapper. - __ save(SP, -stack_size, SP); - - // Frame is now completed as far a size and linkage. - - int frame_complete = ((intptr_t)__ pc()) - start; - -#ifdef ASSERT - bool reg_destroyed[RegisterImpl::number_of_registers]; - bool freg_destroyed[FloatRegisterImpl::number_of_registers]; - for ( int r = 0 ; r < RegisterImpl::number_of_registers ; r++ ) { - reg_destroyed[r] = false; - } - for ( int f = 0 ; f < FloatRegisterImpl::number_of_registers ; f++ ) { - freg_destroyed[f] = false; - } - -#endif /* ASSERT */ - - VMRegPair zero; - const Register g0 = G0; // without this we get a compiler warning (why??) - zero.set2(g0->as_VMReg()); - - int c_arg, j_arg; - - Register conversion_off = noreg; - - for (j_arg = first_arg_to_pass, c_arg = 0 ; - j_arg < total_args_passed ; j_arg++, c_arg++ ) { - - VMRegPair src = in_regs[j_arg]; - VMRegPair dst = out_regs[c_arg]; - -#ifdef ASSERT - if (src.first()->is_Register()) { - assert(!reg_destroyed[src.first()->as_Register()->encoding()], "ack!"); - } else if (src.first()->is_FloatRegister()) { - assert(!freg_destroyed[src.first()->as_FloatRegister()->encoding( - FloatRegisterImpl::S)], "ack!"); - } - if (dst.first()->is_Register()) { - reg_destroyed[dst.first()->as_Register()->encoding()] = true; - } else if (dst.first()->is_FloatRegister()) { - freg_destroyed[dst.first()->as_FloatRegister()->encoding( - FloatRegisterImpl::S)] = true; - } -#endif /* ASSERT */ - - switch (in_sig_bt[j_arg]) { - case T_ARRAY: - case T_OBJECT: - { - if (out_sig_bt[c_arg] == T_BYTE || out_sig_bt[c_arg] == T_SHORT || - out_sig_bt[c_arg] == T_INT || out_sig_bt[c_arg] == T_LONG) { - // need to unbox a one-slot value - Register in_reg = L0; - Register tmp = L2; - if ( src.first()->is_reg() ) { - in_reg = src.first()->as_Register(); - } else { - assert(Assembler::is_simm13(reg2offset(src.first()) + STACK_BIAS), - "must be"); - __ ld_ptr(FP, reg2offset(src.first()) + STACK_BIAS, in_reg); - } - // If the final destination is an acceptable register - if ( dst.first()->is_reg() ) { - if ( dst.is_single_phys_reg() || out_sig_bt[c_arg] != T_LONG ) { - tmp = dst.first()->as_Register(); - } - } - - Label skipUnbox; - if ( wordSize == 4 && out_sig_bt[c_arg] == T_LONG ) { - __ mov(G0, tmp->successor()); - } - __ br_null(in_reg, true, Assembler::pn, skipUnbox); - __ delayed()->mov(G0, tmp); - - BasicType bt = out_sig_bt[c_arg]; - int box_offset = java_lang_boxing_object::value_offset_in_bytes(bt); - switch (bt) { - case T_BYTE: - __ ldub(in_reg, box_offset, tmp); break; - case T_SHORT: - __ lduh(in_reg, box_offset, tmp); break; - case T_INT: - __ ld(in_reg, box_offset, tmp); break; - case T_LONG: - __ ld_long(in_reg, box_offset, tmp); break; - default: ShouldNotReachHere(); - } - - __ bind(skipUnbox); - // If tmp wasn't final destination copy to final destination - if (tmp == L2) { - VMRegPair tmp_as_VM = reg64_to_VMRegPair(L2); - if (out_sig_bt[c_arg] == T_LONG) { - long_move(masm, tmp_as_VM, dst); - } else { - move32_64(masm, tmp_as_VM, out_regs[c_arg]); - } - } - if (out_sig_bt[c_arg] == T_LONG) { - assert(out_sig_bt[c_arg+1] == T_VOID, "must be"); - ++c_arg; // move over the T_VOID to keep the loop indices in sync - } - } else if (out_sig_bt[c_arg] == T_ADDRESS) { - Register s = - src.first()->is_reg() ? src.first()->as_Register() : L2; - Register d = - dst.first()->is_reg() ? dst.first()->as_Register() : L2; - - // We store the oop now so that the conversion pass can reach - // while in the inner frame. This will be the only store if - // the oop is NULL. - if (s != L2) { - // src is register - if (d != L2) { - // dst is register - __ mov(s, d); - } else { - assert(Assembler::is_simm13(reg2offset(dst.first()) + - STACK_BIAS), "must be"); - __ st_ptr(s, SP, reg2offset(dst.first()) + STACK_BIAS); - } - } else { - // src not a register - assert(Assembler::is_simm13(reg2offset(src.first()) + - STACK_BIAS), "must be"); - __ ld_ptr(FP, reg2offset(src.first()) + STACK_BIAS, d); - if (d == L2) { - assert(Assembler::is_simm13(reg2offset(dst.first()) + - STACK_BIAS), "must be"); - __ st_ptr(d, SP, reg2offset(dst.first()) + STACK_BIAS); - } - } - } else if (out_sig_bt[c_arg] != T_VOID) { - // Convert the arg to NULL - if (dst.first()->is_reg()) { - __ mov(G0, dst.first()->as_Register()); - } else { - assert(Assembler::is_simm13(reg2offset(dst.first()) + - STACK_BIAS), "must be"); - __ st_ptr(G0, SP, reg2offset(dst.first()) + STACK_BIAS); - } - } - } - break; - case T_VOID: - break; - - case T_FLOAT: - if (src.first()->is_stack()) { - // Stack to stack/reg is simple - move32_64(masm, src, dst); - } else { - if (dst.first()->is_reg()) { - // freg -> reg - int off = - STACK_BIAS + conversion_temp * VMRegImpl::stack_slot_size; - Register d = dst.first()->as_Register(); - if (Assembler::is_simm13(off)) { - __ stf(FloatRegisterImpl::S, src.first()->as_FloatRegister(), - SP, off); - __ ld(SP, off, d); - } else { - if (conversion_off == noreg) { - __ set(off, L6); - conversion_off = L6; - } - __ stf(FloatRegisterImpl::S, src.first()->as_FloatRegister(), - SP, conversion_off); - __ ld(SP, conversion_off , d); - } - } else { - // freg -> mem - int off = STACK_BIAS + reg2offset(dst.first()); - if (Assembler::is_simm13(off)) { - __ stf(FloatRegisterImpl::S, src.first()->as_FloatRegister(), - SP, off); - } else { - if (conversion_off == noreg) { - __ set(off, L6); - conversion_off = L6; - } - __ stf(FloatRegisterImpl::S, src.first()->as_FloatRegister(), - SP, conversion_off); - } - } - } - break; - - case T_DOUBLE: - assert( j_arg + 1 < total_args_passed && - in_sig_bt[j_arg + 1] == T_VOID && - out_sig_bt[c_arg+1] == T_VOID, "bad arg list"); - if (src.first()->is_stack()) { - // Stack to stack/reg is simple - long_move(masm, src, dst); - } else { - Register d = dst.first()->is_reg() ? dst.first()->as_Register() : L2; - - // Destination could be an odd reg on 32bit in which case - // we can't load direct to the destination. - - if (!d->is_even() && wordSize == 4) { - d = L2; - } - int off = STACK_BIAS + conversion_temp * VMRegImpl::stack_slot_size; - if (Assembler::is_simm13(off)) { - __ stf(FloatRegisterImpl::D, src.first()->as_FloatRegister(), - SP, off); - __ ld_long(SP, off, d); - } else { - if (conversion_off == noreg) { - __ set(off, L6); - conversion_off = L6; - } - __ stf(FloatRegisterImpl::D, src.first()->as_FloatRegister(), - SP, conversion_off); - __ ld_long(SP, conversion_off, d); - } - if (d == L2) { - long_move(masm, reg64_to_VMRegPair(L2), dst); - } - } - break; - - case T_LONG : - // 32bit can't do a split move of something like g1 -> O0, O1 - // so use a memory temp - if (src.is_single_phys_reg() && wordSize == 4) { - Register tmp = L2; - if (dst.first()->is_reg() && - (wordSize == 8 || dst.first()->as_Register()->is_even())) { - tmp = dst.first()->as_Register(); - } - - int off = STACK_BIAS + conversion_temp * VMRegImpl::stack_slot_size; - if (Assembler::is_simm13(off)) { - __ stx(src.first()->as_Register(), SP, off); - __ ld_long(SP, off, tmp); - } else { - if (conversion_off == noreg) { - __ set(off, L6); - conversion_off = L6; - } - __ stx(src.first()->as_Register(), SP, conversion_off); - __ ld_long(SP, conversion_off, tmp); - } - - if (tmp == L2) { - long_move(masm, reg64_to_VMRegPair(L2), dst); - } - } else { - long_move(masm, src, dst); - } - break; - - case T_ADDRESS: assert(false, "found T_ADDRESS in java args"); - - default: - move32_64(masm, src, dst); - } - } - - - // If we have any strings we must store any register based arg to the stack - // This includes any still live xmm registers too. - - if (total_strings > 0 ) { - - // protect all the arg registers - __ save_frame(0); - __ mov(G2_thread, L7_thread_cache); - const Register L2_string_off = L2; - - // Get first string offset - __ set(string_locs * VMRegImpl::stack_slot_size, L2_string_off); - - for (c_arg = 0 ; c_arg < total_c_args ; c_arg++ ) { - if (out_sig_bt[c_arg] == T_ADDRESS) { - - VMRegPair dst = out_regs[c_arg]; - const Register d = dst.first()->is_reg() ? - dst.first()->as_Register()->after_save() : noreg; - - // It's a string the oop and it was already copied to the out arg - // position - if (d != noreg) { - __ mov(d, O0); - } else { - assert(Assembler::is_simm13(reg2offset(dst.first()) + STACK_BIAS), - "must be"); - __ ld_ptr(FP, reg2offset(dst.first()) + STACK_BIAS, O0); - } - Label skip; - - __ br_null(O0, false, Assembler::pn, skip); - __ delayed()->add(FP, L2_string_off, O1); - - if (d != noreg) { - __ mov(O1, d); - } else { - assert(Assembler::is_simm13(reg2offset(dst.first()) + STACK_BIAS), - "must be"); - __ st_ptr(O1, FP, reg2offset(dst.first()) + STACK_BIAS); - } - - __ call(CAST_FROM_FN_PTR(address, SharedRuntime::get_utf), - relocInfo::runtime_call_type); - __ delayed()->add(L2_string_off, max_dtrace_string_size, L2_string_off); - - __ bind(skip); - - } - - } - __ mov(L7_thread_cache, G2_thread); - __ restore(); - - } - - - // Ok now we are done. Need to place the nop that dtrace wants in order to - // patch in the trap - - int patch_offset = ((intptr_t)__ pc()) - start; - - __ nop(); - - - // Return - - __ ret(); - __ delayed()->restore(); - - __ flush(); - - nmethod *nm = nmethod::new_dtrace_nmethod( - method, masm->code(), vep_offset, patch_offset, frame_complete, - stack_slots / VMRegImpl::slots_per_word); - return nm; - -} - -#endif // HAVE_DTRACE_H - // this function returns the adjust size (in number of words) to a c2i adapter // activation for use during deoptimization int Deoptimization::last_frame_adjust(int callee_parameters, int callee_locals) { diff --git a/hotspot/src/cpu/x86/vm/nativeInst_x86.cpp b/hotspot/src/cpu/x86/vm/nativeInst_x86.cpp index cc1573e720a..c38455f1fca 100644 --- a/hotspot/src/cpu/x86/vm/nativeInst_x86.cpp +++ b/hotspot/src/cpu/x86/vm/nativeInst_x86.cpp @@ -602,7 +602,3 @@ address NativeGeneralJump::jump_destination() const { else return addr_at(0) + length + sbyte_at(offset); } - -bool NativeInstruction::is_dtrace_trap() { - return (*(int32_t*)this & 0xff) == 0xcc; -} diff --git a/hotspot/src/cpu/x86/vm/nativeInst_x86.hpp b/hotspot/src/cpu/x86/vm/nativeInst_x86.hpp index 4a4de7116bd..529512731cf 100644 --- a/hotspot/src/cpu/x86/vm/nativeInst_x86.hpp +++ b/hotspot/src/cpu/x86/vm/nativeInst_x86.hpp @@ -59,7 +59,6 @@ class NativeInstruction VALUE_OBJ_CLASS_SPEC { }; bool is_nop() { return ubyte_at(0) == nop_instruction_code; } - bool is_dtrace_trap(); inline bool is_call(); inline bool is_illegal(); inline bool is_return(); diff --git a/hotspot/src/cpu/x86/vm/sharedRuntime_x86_32.cpp b/hotspot/src/cpu/x86/vm/sharedRuntime_x86_32.cpp index c97b4309782..a4b8fbc8cfd 100644 --- a/hotspot/src/cpu/x86/vm/sharedRuntime_x86_32.cpp +++ b/hotspot/src/cpu/x86/vm/sharedRuntime_x86_32.cpp @@ -2415,381 +2415,6 @@ nmethod* SharedRuntime::generate_native_wrapper(MacroAssembler* masm, } -#ifdef HAVE_DTRACE_H -// --------------------------------------------------------------------------- -// Generate a dtrace nmethod for a given signature. The method takes arguments -// in the Java compiled code convention, marshals them to the native -// abi and then leaves nops at the position you would expect to call a native -// function. When the probe is enabled the nops are replaced with a trap -// instruction that dtrace inserts and the trace will cause a notification -// to dtrace. -// -// The probes are only able to take primitive types and java/lang/String as -// arguments. No other java types are allowed. Strings are converted to utf8 -// strings so that from dtrace point of view java strings are converted to C -// strings. There is an arbitrary fixed limit on the total space that a method -// can use for converting the strings. (256 chars per string in the signature). -// So any java string larger then this is truncated. - -nmethod *SharedRuntime::generate_dtrace_nmethod( - MacroAssembler *masm, methodHandle method) { - - // generate_dtrace_nmethod is guarded by a mutex so we are sure to - // be single threaded in this method. - assert(AdapterHandlerLibrary_lock->owned_by_self(), "must be"); - - // Fill in the signature array, for the calling-convention call. - int total_args_passed = method->size_of_parameters(); - - BasicType* in_sig_bt = NEW_RESOURCE_ARRAY(BasicType, total_args_passed); - VMRegPair *in_regs = NEW_RESOURCE_ARRAY(VMRegPair, total_args_passed); - - // The signature we are going to use for the trap that dtrace will see - // java/lang/String is converted. We drop "this" and any other object - // is converted to NULL. (A one-slot java/lang/Long object reference - // is converted to a two-slot long, which is why we double the allocation). - BasicType* out_sig_bt = NEW_RESOURCE_ARRAY(BasicType, total_args_passed * 2); - VMRegPair* out_regs = NEW_RESOURCE_ARRAY(VMRegPair, total_args_passed * 2); - - int i=0; - int total_strings = 0; - int first_arg_to_pass = 0; - int total_c_args = 0; - - if( !method->is_static() ) { // Pass in receiver first - in_sig_bt[i++] = T_OBJECT; - first_arg_to_pass = 1; - } - - // We need to convert the java args to where a native (non-jni) function - // would expect them. To figure out where they go we convert the java - // signature to a C signature. - - SignatureStream ss(method->signature()); - for ( ; !ss.at_return_type(); ss.next()) { - BasicType bt = ss.type(); - in_sig_bt[i++] = bt; // Collect remaining bits of signature - out_sig_bt[total_c_args++] = bt; - if( bt == T_OBJECT) { - Symbol* s = ss.as_symbol_or_null(); // symbol is created - if (s == vmSymbols::java_lang_String()) { - total_strings++; - out_sig_bt[total_c_args-1] = T_ADDRESS; - } else if (s == vmSymbols::java_lang_Boolean() || - s == vmSymbols::java_lang_Character() || - s == vmSymbols::java_lang_Byte() || - s == vmSymbols::java_lang_Short() || - s == vmSymbols::java_lang_Integer() || - s == vmSymbols::java_lang_Float()) { - out_sig_bt[total_c_args-1] = T_INT; - } else if (s == vmSymbols::java_lang_Long() || - s == vmSymbols::java_lang_Double()) { - out_sig_bt[total_c_args-1] = T_LONG; - out_sig_bt[total_c_args++] = T_VOID; - } - } else if ( bt == T_LONG || bt == T_DOUBLE ) { - in_sig_bt[i++] = T_VOID; // Longs & doubles take 2 Java slots - out_sig_bt[total_c_args++] = T_VOID; - } - } - - assert(i==total_args_passed, "validly parsed signature"); - - // Now get the compiled-Java layout as input arguments - int comp_args_on_stack; - comp_args_on_stack = SharedRuntime::java_calling_convention( - in_sig_bt, in_regs, total_args_passed, false); - - // Now figure out where the args must be stored and how much stack space - // they require (neglecting out_preserve_stack_slots). - - int out_arg_slots; - out_arg_slots = c_calling_convention(out_sig_bt, out_regs, NULL, total_c_args); - - // Calculate the total number of stack slots we will need. - - // First count the abi requirement plus all of the outgoing args - int stack_slots = SharedRuntime::out_preserve_stack_slots() + out_arg_slots; - - // Now space for the string(s) we must convert - - int* string_locs = NEW_RESOURCE_ARRAY(int, total_strings + 1); - for (i = 0; i < total_strings ; i++) { - string_locs[i] = stack_slots; - stack_slots += max_dtrace_string_size / VMRegImpl::stack_slot_size; - } - - // + 2 for return address (which we own) and saved rbp, - - stack_slots += 2; - - // Ok The space we have allocated will look like: - // - // - // FP-> | | - // |---------------------| - // | string[n] | - // |---------------------| <- string_locs[n] - // | string[n-1] | - // |---------------------| <- string_locs[n-1] - // | ... | - // | ... | - // |---------------------| <- string_locs[1] - // | string[0] | - // |---------------------| <- string_locs[0] - // | outbound memory | - // | based arguments | - // | | - // |---------------------| - // | | - // SP-> | out_preserved_slots | - // - // - - // Now compute actual number of stack words we need rounding to make - // stack properly aligned. - stack_slots = round_to(stack_slots, 2 * VMRegImpl::slots_per_word); - - int stack_size = stack_slots * VMRegImpl::stack_slot_size; - - intptr_t start = (intptr_t)__ pc(); - - // First thing make an ic check to see if we should even be here - - // We are free to use all registers as temps without saving them and - // restoring them except rbp. rbp, is the only callee save register - // as far as the interpreter and the compiler(s) are concerned. - - const Register ic_reg = rax; - const Register receiver = rcx; - Label hit; - Label exception_pending; - - - __ verify_oop(receiver); - __ cmpl(ic_reg, Address(receiver, oopDesc::klass_offset_in_bytes())); - __ jcc(Assembler::equal, hit); - - __ jump(RuntimeAddress(SharedRuntime::get_ic_miss_stub())); - - // verified entry must be aligned for code patching. - // and the first 5 bytes must be in the same cache line - // if we align at 8 then we will be sure 5 bytes are in the same line - __ align(8); - - __ bind(hit); - - int vep_offset = ((intptr_t)__ pc()) - start; - - - // The instruction at the verified entry point must be 5 bytes or longer - // because it can be patched on the fly by make_non_entrant. The stack bang - // instruction fits that requirement. - - // Generate stack overflow check - - - if (UseStackBanging) { - if (stack_size <= StackShadowPages*os::vm_page_size()) { - __ bang_stack_with_offset(StackShadowPages*os::vm_page_size()); - } else { - __ movl(rax, stack_size); - __ bang_stack_size(rax, rbx); - } - } else { - // need a 5 byte instruction to allow MT safe patching to non-entrant - __ fat_nop(); - } - - assert(((int)__ pc() - start - vep_offset) >= 5, - "valid size for make_non_entrant"); - - // Generate a new frame for the wrapper. - __ enter(); - - // -2 because return address is already present and so is saved rbp, - if (stack_size - 2*wordSize != 0) { - __ subl(rsp, stack_size - 2*wordSize); - } - - // Frame is now completed as far a size and linkage. - - int frame_complete = ((intptr_t)__ pc()) - start; - - // First thing we do store all the args as if we are doing the call. - // Since the C calling convention is stack based that ensures that - // all the Java register args are stored before we need to convert any - // string we might have. - - int sid = 0; - int c_arg, j_arg; - int string_reg = 0; - - for (j_arg = first_arg_to_pass, c_arg = 0 ; - j_arg < total_args_passed ; j_arg++, c_arg++ ) { - - VMRegPair src = in_regs[j_arg]; - VMRegPair dst = out_regs[c_arg]; - assert(dst.first()->is_stack() || in_sig_bt[j_arg] == T_VOID, - "stack based abi assumed"); - - switch (in_sig_bt[j_arg]) { - - case T_ARRAY: - case T_OBJECT: - if (out_sig_bt[c_arg] == T_ADDRESS) { - // Any register based arg for a java string after the first - // will be destroyed by the call to get_utf so we store - // the original value in the location the utf string address - // will eventually be stored. - if (src.first()->is_reg()) { - if (string_reg++ != 0) { - simple_move32(masm, src, dst); - } - } - } else if (out_sig_bt[c_arg] == T_INT || out_sig_bt[c_arg] == T_LONG) { - // need to unbox a one-word value - Register in_reg = rax; - if ( src.first()->is_reg() ) { - in_reg = src.first()->as_Register(); - } else { - simple_move32(masm, src, in_reg->as_VMReg()); - } - Label skipUnbox; - __ movl(Address(rsp, reg2offset_out(dst.first())), NULL_WORD); - if ( out_sig_bt[c_arg] == T_LONG ) { - __ movl(Address(rsp, reg2offset_out(dst.second())), NULL_WORD); - } - __ testl(in_reg, in_reg); - __ jcc(Assembler::zero, skipUnbox); - assert(dst.first()->is_stack() && - (!dst.second()->is_valid() || dst.second()->is_stack()), - "value(s) must go into stack slots"); - - BasicType bt = out_sig_bt[c_arg]; - int box_offset = java_lang_boxing_object::value_offset_in_bytes(bt); - if ( bt == T_LONG ) { - __ movl(rbx, Address(in_reg, - box_offset + VMRegImpl::stack_slot_size)); - __ movl(Address(rsp, reg2offset_out(dst.second())), rbx); - } - __ movl(in_reg, Address(in_reg, box_offset)); - __ movl(Address(rsp, reg2offset_out(dst.first())), in_reg); - __ bind(skipUnbox); - } else { - // Convert the arg to NULL - __ movl(Address(rsp, reg2offset_out(dst.first())), NULL_WORD); - } - if (out_sig_bt[c_arg] == T_LONG) { - assert(out_sig_bt[c_arg+1] == T_VOID, "must be"); - ++c_arg; // Move over the T_VOID To keep the loop indices in sync - } - break; - - case T_VOID: - break; - - case T_FLOAT: - float_move(masm, src, dst); - break; - - case T_DOUBLE: - assert( j_arg + 1 < total_args_passed && - in_sig_bt[j_arg + 1] == T_VOID, "bad arg list"); - double_move(masm, src, dst); - break; - - case T_LONG : - long_move(masm, src, dst); - break; - - case T_ADDRESS: assert(false, "found T_ADDRESS in java args"); - - default: - simple_move32(masm, src, dst); - } - } - - // Now we must convert any string we have to utf8 - // - - for (sid = 0, j_arg = first_arg_to_pass, c_arg = 0 ; - sid < total_strings ; j_arg++, c_arg++ ) { - - if (out_sig_bt[c_arg] == T_ADDRESS) { - - Address utf8_addr = Address( - rsp, string_locs[sid++] * VMRegImpl::stack_slot_size); - __ leal(rax, utf8_addr); - - // The first string we find might still be in the original java arg - // register - VMReg orig_loc = in_regs[j_arg].first(); - Register string_oop; - - // This is where the argument will eventually reside - Address dest = Address(rsp, reg2offset_out(out_regs[c_arg].first())); - - if (sid == 1 && orig_loc->is_reg()) { - string_oop = orig_loc->as_Register(); - assert(string_oop != rax, "smashed arg"); - } else { - - if (orig_loc->is_reg()) { - // Get the copy of the jls object - __ movl(rcx, dest); - } else { - // arg is still in the original location - __ movl(rcx, Address(rbp, reg2offset_in(orig_loc))); - } - string_oop = rcx; - - } - Label nullString; - __ movl(dest, NULL_WORD); - __ testl(string_oop, string_oop); - __ jcc(Assembler::zero, nullString); - - // Now we can store the address of the utf string as the argument - __ movl(dest, rax); - - // And do the conversion - __ call_VM_leaf(CAST_FROM_FN_PTR( - address, SharedRuntime::get_utf), string_oop, rax); - __ bind(nullString); - } - - if (in_sig_bt[j_arg] == T_OBJECT && out_sig_bt[c_arg] == T_LONG) { - assert(out_sig_bt[c_arg+1] == T_VOID, "must be"); - ++c_arg; // Move over the T_VOID To keep the loop indices in sync - } - } - - - // Ok now we are done. Need to place the nop that dtrace wants in order to - // patch in the trap - - int patch_offset = ((intptr_t)__ pc()) - start; - - __ nop(); - - - // Return - - __ leave(); - __ ret(0); - - __ flush(); - - nmethod *nm = nmethod::new_dtrace_nmethod( - method, masm->code(), vep_offset, patch_offset, frame_complete, - stack_slots / VMRegImpl::slots_per_word); - return nm; - -} - -#endif // HAVE_DTRACE_H - // this function returns the adjust size (in number of words) to a c2i adapter // activation for use during deoptimization int Deoptimization::last_frame_adjust(int callee_parameters, int callee_locals ) { diff --git a/hotspot/src/cpu/x86/vm/sharedRuntime_x86_64.cpp b/hotspot/src/cpu/x86/vm/sharedRuntime_x86_64.cpp index be2bfcfa02d..afc137b69c2 100644 --- a/hotspot/src/cpu/x86/vm/sharedRuntime_x86_64.cpp +++ b/hotspot/src/cpu/x86/vm/sharedRuntime_x86_64.cpp @@ -2650,630 +2650,6 @@ nmethod* SharedRuntime::generate_native_wrapper(MacroAssembler* masm, } -#ifdef HAVE_DTRACE_H -// --------------------------------------------------------------------------- -// Generate a dtrace nmethod for a given signature. The method takes arguments -// in the Java compiled code convention, marshals them to the native -// abi and then leaves nops at the position you would expect to call a native -// function. When the probe is enabled the nops are replaced with a trap -// instruction that dtrace inserts and the trace will cause a notification -// to dtrace. -// -// The probes are only able to take primitive types and java/lang/String as -// arguments. No other java types are allowed. Strings are converted to utf8 -// strings so that from dtrace point of view java strings are converted to C -// strings. There is an arbitrary fixed limit on the total space that a method -// can use for converting the strings. (256 chars per string in the signature). -// So any java string larger then this is truncated. - -static int fp_offset[ConcreteRegisterImpl::number_of_registers] = { 0 }; -static bool offsets_initialized = false; - - -nmethod *SharedRuntime::generate_dtrace_nmethod(MacroAssembler *masm, - methodHandle method) { - - - // generate_dtrace_nmethod is guarded by a mutex so we are sure to - // be single threaded in this method. - assert(AdapterHandlerLibrary_lock->owned_by_self(), "must be"); - - if (!offsets_initialized) { - fp_offset[c_rarg0->as_VMReg()->value()] = -1 * wordSize; - fp_offset[c_rarg1->as_VMReg()->value()] = -2 * wordSize; - fp_offset[c_rarg2->as_VMReg()->value()] = -3 * wordSize; - fp_offset[c_rarg3->as_VMReg()->value()] = -4 * wordSize; - fp_offset[c_rarg4->as_VMReg()->value()] = -5 * wordSize; - fp_offset[c_rarg5->as_VMReg()->value()] = -6 * wordSize; - - fp_offset[c_farg0->as_VMReg()->value()] = -7 * wordSize; - fp_offset[c_farg1->as_VMReg()->value()] = -8 * wordSize; - fp_offset[c_farg2->as_VMReg()->value()] = -9 * wordSize; - fp_offset[c_farg3->as_VMReg()->value()] = -10 * wordSize; - fp_offset[c_farg4->as_VMReg()->value()] = -11 * wordSize; - fp_offset[c_farg5->as_VMReg()->value()] = -12 * wordSize; - fp_offset[c_farg6->as_VMReg()->value()] = -13 * wordSize; - fp_offset[c_farg7->as_VMReg()->value()] = -14 * wordSize; - - offsets_initialized = true; - } - // Fill in the signature array, for the calling-convention call. - int total_args_passed = method->size_of_parameters(); - - BasicType* in_sig_bt = NEW_RESOURCE_ARRAY(BasicType, total_args_passed); - VMRegPair *in_regs = NEW_RESOURCE_ARRAY(VMRegPair, total_args_passed); - - // The signature we are going to use for the trap that dtrace will see - // java/lang/String is converted. We drop "this" and any other object - // is converted to NULL. (A one-slot java/lang/Long object reference - // is converted to a two-slot long, which is why we double the allocation). - BasicType* out_sig_bt = NEW_RESOURCE_ARRAY(BasicType, total_args_passed * 2); - VMRegPair* out_regs = NEW_RESOURCE_ARRAY(VMRegPair, total_args_passed * 2); - - int i=0; - int total_strings = 0; - int first_arg_to_pass = 0; - int total_c_args = 0; - - // Skip the receiver as dtrace doesn't want to see it - if( !method->is_static() ) { - in_sig_bt[i++] = T_OBJECT; - first_arg_to_pass = 1; - } - - // We need to convert the java args to where a native (non-jni) function - // would expect them. To figure out where they go we convert the java - // signature to a C signature. - - SignatureStream ss(method->signature()); - for ( ; !ss.at_return_type(); ss.next()) { - BasicType bt = ss.type(); - in_sig_bt[i++] = bt; // Collect remaining bits of signature - out_sig_bt[total_c_args++] = bt; - if( bt == T_OBJECT) { - Symbol* s = ss.as_symbol_or_null(); // symbol is created - if (s == vmSymbols::java_lang_String()) { - total_strings++; - out_sig_bt[total_c_args-1] = T_ADDRESS; - } else if (s == vmSymbols::java_lang_Boolean() || - s == vmSymbols::java_lang_Character() || - s == vmSymbols::java_lang_Byte() || - s == vmSymbols::java_lang_Short() || - s == vmSymbols::java_lang_Integer() || - s == vmSymbols::java_lang_Float()) { - out_sig_bt[total_c_args-1] = T_INT; - } else if (s == vmSymbols::java_lang_Long() || - s == vmSymbols::java_lang_Double()) { - out_sig_bt[total_c_args-1] = T_LONG; - out_sig_bt[total_c_args++] = T_VOID; - } - } else if ( bt == T_LONG || bt == T_DOUBLE ) { - in_sig_bt[i++] = T_VOID; // Longs & doubles take 2 Java slots - // We convert double to long - out_sig_bt[total_c_args-1] = T_LONG; - out_sig_bt[total_c_args++] = T_VOID; - } else if ( bt == T_FLOAT) { - // We convert float to int - out_sig_bt[total_c_args-1] = T_INT; - } - } - - assert(i==total_args_passed, "validly parsed signature"); - - // Now get the compiled-Java layout as input arguments - int comp_args_on_stack; - comp_args_on_stack = SharedRuntime::java_calling_convention( - in_sig_bt, in_regs, total_args_passed, false); - - // Now figure out where the args must be stored and how much stack space - // they require (neglecting out_preserve_stack_slots but space for storing - // the 1st six register arguments). It's weird see int_stk_helper. - - int out_arg_slots; - out_arg_slots = c_calling_convention(out_sig_bt, out_regs, NULL, total_c_args); - - // Calculate the total number of stack slots we will need. - - // First count the abi requirement plus all of the outgoing args - int stack_slots = SharedRuntime::out_preserve_stack_slots() + out_arg_slots; - - // Now space for the string(s) we must convert - int* string_locs = NEW_RESOURCE_ARRAY(int, total_strings + 1); - for (i = 0; i < total_strings ; i++) { - string_locs[i] = stack_slots; - stack_slots += max_dtrace_string_size / VMRegImpl::stack_slot_size; - } - - // Plus the temps we might need to juggle register args - // regs take two slots each - stack_slots += (Argument::n_int_register_parameters_c + - Argument::n_float_register_parameters_c) * 2; - - - // + 4 for return address (which we own) and saved rbp, - - stack_slots += 4; - - // Ok The space we have allocated will look like: - // - // - // FP-> | | - // |---------------------| - // | string[n] | - // |---------------------| <- string_locs[n] - // | string[n-1] | - // |---------------------| <- string_locs[n-1] - // | ... | - // | ... | - // |---------------------| <- string_locs[1] - // | string[0] | - // |---------------------| <- string_locs[0] - // | outbound memory | - // | based arguments | - // | | - // |---------------------| - // | | - // SP-> | out_preserved_slots | - // - // - - // Now compute actual number of stack words we need rounding to make - // stack properly aligned. - stack_slots = round_to(stack_slots, 4 * VMRegImpl::slots_per_word); - - int stack_size = stack_slots * VMRegImpl::stack_slot_size; - - intptr_t start = (intptr_t)__ pc(); - - // First thing make an ic check to see if we should even be here - - // We are free to use all registers as temps without saving them and - // restoring them except rbp. rbp, is the only callee save register - // as far as the interpreter and the compiler(s) are concerned. - - const Register ic_reg = rax; - const Register receiver = rcx; - Label hit; - Label exception_pending; - - - __ verify_oop(receiver); - __ cmpl(ic_reg, Address(receiver, oopDesc::klass_offset_in_bytes())); - __ jcc(Assembler::equal, hit); - - __ jump(RuntimeAddress(SharedRuntime::get_ic_miss_stub())); - - // verified entry must be aligned for code patching. - // and the first 5 bytes must be in the same cache line - // if we align at 8 then we will be sure 5 bytes are in the same line - __ align(8); - - __ bind(hit); - - int vep_offset = ((intptr_t)__ pc()) - start; - - - // The instruction at the verified entry point must be 5 bytes or longer - // because it can be patched on the fly by make_non_entrant. The stack bang - // instruction fits that requirement. - - // Generate stack overflow check - - if (UseStackBanging) { - if (stack_size <= StackShadowPages*os::vm_page_size()) { - __ bang_stack_with_offset(StackShadowPages*os::vm_page_size()); - } else { - __ movl(rax, stack_size); - __ bang_stack_size(rax, rbx); - } - } else { - // need a 5 byte instruction to allow MT safe patching to non-entrant - __ fat_nop(); - } - - assert(((uintptr_t)__ pc() - start - vep_offset) >= 5, - "valid size for make_non_entrant"); - - // Generate a new frame for the wrapper. - __ enter(); - - // -4 because return address is already present and so is saved rbp, - if (stack_size - 2*wordSize != 0) { - __ subq(rsp, stack_size - 2*wordSize); - } - - // Frame is now completed as far a size and linkage. - - int frame_complete = ((intptr_t)__ pc()) - start; - - int c_arg, j_arg; - - // State of input register args - - bool live[ConcreteRegisterImpl::number_of_registers]; - - live[j_rarg0->as_VMReg()->value()] = false; - live[j_rarg1->as_VMReg()->value()] = false; - live[j_rarg2->as_VMReg()->value()] = false; - live[j_rarg3->as_VMReg()->value()] = false; - live[j_rarg4->as_VMReg()->value()] = false; - live[j_rarg5->as_VMReg()->value()] = false; - - live[j_farg0->as_VMReg()->value()] = false; - live[j_farg1->as_VMReg()->value()] = false; - live[j_farg2->as_VMReg()->value()] = false; - live[j_farg3->as_VMReg()->value()] = false; - live[j_farg4->as_VMReg()->value()] = false; - live[j_farg5->as_VMReg()->value()] = false; - live[j_farg6->as_VMReg()->value()] = false; - live[j_farg7->as_VMReg()->value()] = false; - - - bool rax_is_zero = false; - - // All args (except strings) destined for the stack are moved first - for (j_arg = first_arg_to_pass, c_arg = 0 ; - j_arg < total_args_passed ; j_arg++, c_arg++ ) { - VMRegPair src = in_regs[j_arg]; - VMRegPair dst = out_regs[c_arg]; - - // Get the real reg value or a dummy (rsp) - - int src_reg = src.first()->is_reg() ? - src.first()->value() : - rsp->as_VMReg()->value(); - - bool useless = in_sig_bt[j_arg] == T_ARRAY || - (in_sig_bt[j_arg] == T_OBJECT && - out_sig_bt[c_arg] != T_INT && - out_sig_bt[c_arg] != T_ADDRESS && - out_sig_bt[c_arg] != T_LONG); - - live[src_reg] = !useless; - - if (dst.first()->is_stack()) { - - // Even though a string arg in a register is still live after this loop - // after the string conversion loop (next) it will be dead so we take - // advantage of that now for simpler code to manage live. - - live[src_reg] = false; - switch (in_sig_bt[j_arg]) { - - case T_ARRAY: - case T_OBJECT: - { - Address stack_dst(rsp, reg2offset_out(dst.first())); - - if (out_sig_bt[c_arg] == T_INT || out_sig_bt[c_arg] == T_LONG) { - // need to unbox a one-word value - Register in_reg = rax; - if ( src.first()->is_reg() ) { - in_reg = src.first()->as_Register(); - } else { - __ movq(rax, Address(rbp, reg2offset_in(src.first()))); - rax_is_zero = false; - } - Label skipUnbox; - __ movptr(Address(rsp, reg2offset_out(dst.first())), - (int32_t)NULL_WORD); - __ testq(in_reg, in_reg); - __ jcc(Assembler::zero, skipUnbox); - - BasicType bt = out_sig_bt[c_arg]; - int box_offset = java_lang_boxing_object::value_offset_in_bytes(bt); - Address src1(in_reg, box_offset); - if ( bt == T_LONG ) { - __ movq(in_reg, src1); - __ movq(stack_dst, in_reg); - assert(out_sig_bt[c_arg+1] == T_VOID, "must be"); - ++c_arg; // skip over T_VOID to keep the loop indices in sync - } else { - __ movl(in_reg, src1); - __ movl(stack_dst, in_reg); - } - - __ bind(skipUnbox); - } else if (out_sig_bt[c_arg] != T_ADDRESS) { - // Convert the arg to NULL - if (!rax_is_zero) { - __ xorq(rax, rax); - rax_is_zero = true; - } - __ movq(stack_dst, rax); - } - } - break; - - case T_VOID: - break; - - case T_FLOAT: - // This does the right thing since we know it is destined for the - // stack - float_move(masm, src, dst); - break; - - case T_DOUBLE: - // This does the right thing since we know it is destined for the - // stack - double_move(masm, src, dst); - break; - - case T_LONG : - long_move(masm, src, dst); - break; - - case T_ADDRESS: assert(false, "found T_ADDRESS in java args"); - - default: - move32_64(masm, src, dst); - } - } - - } - - // If we have any strings we must store any register based arg to the stack - // This includes any still live xmm registers too. - - int sid = 0; - - if (total_strings > 0 ) { - for (j_arg = first_arg_to_pass, c_arg = 0 ; - j_arg < total_args_passed ; j_arg++, c_arg++ ) { - VMRegPair src = in_regs[j_arg]; - VMRegPair dst = out_regs[c_arg]; - - if (src.first()->is_reg()) { - Address src_tmp(rbp, fp_offset[src.first()->value()]); - - // string oops were left untouched by the previous loop even if the - // eventual (converted) arg is destined for the stack so park them - // away now (except for first) - - if (out_sig_bt[c_arg] == T_ADDRESS) { - Address utf8_addr = Address( - rsp, string_locs[sid++] * VMRegImpl::stack_slot_size); - if (sid != 1) { - // The first string arg won't be killed until after the utf8 - // conversion - __ movq(utf8_addr, src.first()->as_Register()); - } - } else if (dst.first()->is_reg()) { - if (in_sig_bt[j_arg] == T_FLOAT || in_sig_bt[j_arg] == T_DOUBLE) { - - // Convert the xmm register to an int and store it in the reserved - // location for the eventual c register arg - XMMRegister f = src.first()->as_XMMRegister(); - if (in_sig_bt[j_arg] == T_FLOAT) { - __ movflt(src_tmp, f); - } else { - __ movdbl(src_tmp, f); - } - } else { - // If the arg is an oop type we don't support don't bother to store - // it remember string was handled above. - bool useless = in_sig_bt[j_arg] == T_ARRAY || - (in_sig_bt[j_arg] == T_OBJECT && - out_sig_bt[c_arg] != T_INT && - out_sig_bt[c_arg] != T_LONG); - - if (!useless) { - __ movq(src_tmp, src.first()->as_Register()); - } - } - } - } - if (in_sig_bt[j_arg] == T_OBJECT && out_sig_bt[c_arg] == T_LONG) { - assert(out_sig_bt[c_arg+1] == T_VOID, "must be"); - ++c_arg; // skip over T_VOID to keep the loop indices in sync - } - } - - // Now that the volatile registers are safe, convert all the strings - sid = 0; - - for (j_arg = first_arg_to_pass, c_arg = 0 ; - j_arg < total_args_passed ; j_arg++, c_arg++ ) { - if (out_sig_bt[c_arg] == T_ADDRESS) { - // It's a string - Address utf8_addr = Address( - rsp, string_locs[sid++] * VMRegImpl::stack_slot_size); - // The first string we find might still be in the original java arg - // register - - VMReg src = in_regs[j_arg].first(); - - // We will need to eventually save the final argument to the trap - // in the von-volatile location dedicated to src. This is the offset - // from fp we will use. - int src_off = src->is_reg() ? - fp_offset[src->value()] : reg2offset_in(src); - - // This is where the argument will eventually reside - VMRegPair dst = out_regs[c_arg]; - - if (src->is_reg()) { - if (sid == 1) { - __ movq(c_rarg0, src->as_Register()); - } else { - __ movq(c_rarg0, utf8_addr); - } - } else { - // arg is still in the original location - __ movq(c_rarg0, Address(rbp, reg2offset_in(src))); - } - Label done, convert; - - // see if the oop is NULL - __ testq(c_rarg0, c_rarg0); - __ jcc(Assembler::notEqual, convert); - - if (dst.first()->is_reg()) { - // Save the ptr to utf string in the origina src loc or the tmp - // dedicated to it - __ movq(Address(rbp, src_off), c_rarg0); - } else { - __ movq(Address(rsp, reg2offset_out(dst.first())), c_rarg0); - } - __ jmp(done); - - __ bind(convert); - - __ lea(c_rarg1, utf8_addr); - if (dst.first()->is_reg()) { - __ movq(Address(rbp, src_off), c_rarg1); - } else { - __ movq(Address(rsp, reg2offset_out(dst.first())), c_rarg1); - } - // And do the conversion - __ call(RuntimeAddress( - CAST_FROM_FN_PTR(address, SharedRuntime::get_utf))); - - __ bind(done); - } - if (in_sig_bt[j_arg] == T_OBJECT && out_sig_bt[c_arg] == T_LONG) { - assert(out_sig_bt[c_arg+1] == T_VOID, "must be"); - ++c_arg; // skip over T_VOID to keep the loop indices in sync - } - } - // The get_utf call killed all the c_arg registers - live[c_rarg0->as_VMReg()->value()] = false; - live[c_rarg1->as_VMReg()->value()] = false; - live[c_rarg2->as_VMReg()->value()] = false; - live[c_rarg3->as_VMReg()->value()] = false; - live[c_rarg4->as_VMReg()->value()] = false; - live[c_rarg5->as_VMReg()->value()] = false; - - live[c_farg0->as_VMReg()->value()] = false; - live[c_farg1->as_VMReg()->value()] = false; - live[c_farg2->as_VMReg()->value()] = false; - live[c_farg3->as_VMReg()->value()] = false; - live[c_farg4->as_VMReg()->value()] = false; - live[c_farg5->as_VMReg()->value()] = false; - live[c_farg6->as_VMReg()->value()] = false; - live[c_farg7->as_VMReg()->value()] = false; - } - - // Now we can finally move the register args to their desired locations - - rax_is_zero = false; - - for (j_arg = first_arg_to_pass, c_arg = 0 ; - j_arg < total_args_passed ; j_arg++, c_arg++ ) { - - VMRegPair src = in_regs[j_arg]; - VMRegPair dst = out_regs[c_arg]; - - // Only need to look for args destined for the interger registers (since we - // convert float/double args to look like int/long outbound) - if (dst.first()->is_reg()) { - Register r = dst.first()->as_Register(); - - // Check if the java arg is unsupported and thereofre useless - bool useless = in_sig_bt[j_arg] == T_ARRAY || - (in_sig_bt[j_arg] == T_OBJECT && - out_sig_bt[c_arg] != T_INT && - out_sig_bt[c_arg] != T_ADDRESS && - out_sig_bt[c_arg] != T_LONG); - - - // If we're going to kill an existing arg save it first - if (live[dst.first()->value()]) { - // you can't kill yourself - if (src.first() != dst.first()) { - __ movq(Address(rbp, fp_offset[dst.first()->value()]), r); - } - } - if (src.first()->is_reg()) { - if (live[src.first()->value()] ) { - if (in_sig_bt[j_arg] == T_FLOAT) { - __ movdl(r, src.first()->as_XMMRegister()); - } else if (in_sig_bt[j_arg] == T_DOUBLE) { - __ movdq(r, src.first()->as_XMMRegister()); - } else if (r != src.first()->as_Register()) { - if (!useless) { - __ movq(r, src.first()->as_Register()); - } - } - } else { - // If the arg is an oop type we don't support don't bother to store - // it - if (!useless) { - if (in_sig_bt[j_arg] == T_DOUBLE || - in_sig_bt[j_arg] == T_LONG || - in_sig_bt[j_arg] == T_OBJECT ) { - __ movq(r, Address(rbp, fp_offset[src.first()->value()])); - } else { - __ movl(r, Address(rbp, fp_offset[src.first()->value()])); - } - } - } - live[src.first()->value()] = false; - } else if (!useless) { - // full sized move even for int should be ok - __ movq(r, Address(rbp, reg2offset_in(src.first()))); - } - - // At this point r has the original java arg in the final location - // (assuming it wasn't useless). If the java arg was an oop - // we have a bit more to do - - if (in_sig_bt[j_arg] == T_ARRAY || in_sig_bt[j_arg] == T_OBJECT ) { - if (out_sig_bt[c_arg] == T_INT || out_sig_bt[c_arg] == T_LONG) { - // need to unbox a one-word value - Label skip; - __ testq(r, r); - __ jcc(Assembler::equal, skip); - BasicType bt = out_sig_bt[c_arg]; - int box_offset = java_lang_boxing_object::value_offset_in_bytes(bt); - Address src1(r, box_offset); - if ( bt == T_LONG ) { - __ movq(r, src1); - } else { - __ movl(r, src1); - } - __ bind(skip); - - } else if (out_sig_bt[c_arg] != T_ADDRESS) { - // Convert the arg to NULL - __ xorq(r, r); - } - } - - // dst can longer be holding an input value - live[dst.first()->value()] = false; - } - if (in_sig_bt[j_arg] == T_OBJECT && out_sig_bt[c_arg] == T_LONG) { - assert(out_sig_bt[c_arg+1] == T_VOID, "must be"); - ++c_arg; // skip over T_VOID to keep the loop indices in sync - } - } - - - // Ok now we are done. Need to place the nop that dtrace wants in order to - // patch in the trap - int patch_offset = ((intptr_t)__ pc()) - start; - - __ nop(); - - - // Return - - __ leave(); - __ ret(0); - - __ flush(); - - nmethod *nm = nmethod::new_dtrace_nmethod( - method, masm->code(), vep_offset, patch_offset, frame_complete, - stack_slots / VMRegImpl::slots_per_word); - return nm; - -} - -#endif // HAVE_DTRACE_H - // this function returns the adjust size (in number of words) to a c2i adapter // activation for use during deoptimization int Deoptimization::last_frame_adjust(int callee_parameters, int callee_locals ) { diff --git a/hotspot/src/os/bsd/vm/dtraceJSDT_bsd.cpp b/hotspot/src/os/bsd/vm/dtraceJSDT_bsd.cpp deleted file mode 100644 index d6c091b126b..00000000000 --- a/hotspot/src/os/bsd/vm/dtraceJSDT_bsd.cpp +++ /dev/null @@ -1,54 +0,0 @@ -/* - * Copyright (c) 1997, 2010, 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. - * - */ - -#include "precompiled.hpp" -#include "classfile/javaClasses.hpp" -#include "code/codeBlob.hpp" -#include "memory/allocation.hpp" -#include "prims/jvm.h" -#include "runtime/dtraceJSDT.hpp" -#include "runtime/jniHandles.hpp" -#include "runtime/os.hpp" -#include "runtime/signature.hpp" -#include "utilities/globalDefinitions.hpp" - -/* - * JSDT java dtrace probes have never been implemented in macosx. It is unknown if the solaris implementation - * is close or if significant implementation work is necessary. The future of the solaris implementation also - * appears to be unclear since compiling code with JSDT probes produces the following warning: - * "warning: ProviderFactory is internal proprietary API and may be removed in a future release" - */ - -int DTraceJSDT::pd_activate( - void* baseAddress, jstring module, - jint providers_count, JVM_DTraceProvider* providers) { - return -1; -} - -void DTraceJSDT::pd_dispose(int handle) { -} - -jboolean DTraceJSDT::pd_is_supported() { - return false; -} diff --git a/hotspot/src/os/linux/vm/dtraceJSDT_linux.cpp b/hotspot/src/os/linux/vm/dtraceJSDT_linux.cpp deleted file mode 100644 index 0f340fb5730..00000000000 --- a/hotspot/src/os/linux/vm/dtraceJSDT_linux.cpp +++ /dev/null @@ -1,47 +0,0 @@ -/* - * Copyright (c) 1997, 2010, 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. - * - */ - -#include "precompiled.hpp" -#include "classfile/javaClasses.hpp" -#include "code/codeBlob.hpp" -#include "memory/allocation.hpp" -#include "prims/jvm.h" -#include "runtime/dtraceJSDT.hpp" -#include "runtime/jniHandles.hpp" -#include "runtime/os.hpp" -#include "runtime/signature.hpp" -#include "utilities/globalDefinitions.hpp" - -int DTraceJSDT::pd_activate( - void* baseAddress, jstring module, - jint providers_count, JVM_DTraceProvider* providers) { - return -1; -} - -void DTraceJSDT::pd_dispose(int handle) { -} - -jboolean DTraceJSDT::pd_is_supported() { - return false; -} diff --git a/hotspot/src/os/solaris/vm/dtraceJSDT_solaris.cpp b/hotspot/src/os/solaris/vm/dtraceJSDT_solaris.cpp deleted file mode 100644 index 5d4fc9b2580..00000000000 --- a/hotspot/src/os/solaris/vm/dtraceJSDT_solaris.cpp +++ /dev/null @@ -1,655 +0,0 @@ -/* - * Copyright (c) 2005, 2012, 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. - * - */ - -#include "precompiled.hpp" -#include "classfile/javaClasses.hpp" -#include "code/codeBlob.hpp" -#include "memory/allocation.hpp" -#include "prims/jvm.h" -#include "runtime/dtraceJSDT.hpp" -#include "runtime/jniHandles.hpp" -#include "runtime/os.hpp" -#include "runtime/signature.hpp" -#include "utilities/globalDefinitions.hpp" - -#ifdef HAVE_DTRACE_H - -#include -#include -#include -#include -#include - -static const char* devname = "/dev/dtrace/helper"; -static const char* olddevname = "/devices/pseudo/dtrace@0:helper"; - -static const char* string_sig = "uintptr_t"; -static const char* int_sig = "long"; -static const char* long_sig = "long long"; - -static void printDOFHelper(dof_helper_t* helper); - -static int dofhelper_open() { - int fd; - if ((fd = open64(devname, O_RDWR)) < 0) { - // Optimize next calls - devname = olddevname; - if ((fd = open64(devname, O_RDWR)) < 0) { - return -1; - } - } - return fd; -} - -static jint dof_register(jstring module, uint8_t* dof, void* modaddr) { - int probe; - dof_helper_t dh; - int fd; - - memset(&dh, 0, sizeof(dh)); - - char* module_name = java_lang_String::as_utf8_string( - JNIHandles::resolve_non_null(module)); - jio_snprintf(dh.dofhp_mod, sizeof(dh.dofhp_mod), "%s", module_name); - dh.dofhp_dof = (uint64_t)dof; - dh.dofhp_addr = (uint64_t)modaddr; - - fd = dofhelper_open(); - if (fd < 0) - return -1; - probe = ioctl(fd, DTRACEHIOC_ADDDOF, &dh); - close(fd); - if (PrintDTraceDOF) { - printDOFHelper(&dh); - tty->print_cr("DOF helper id = %d", probe); - } - return probe; -} - -int DTraceJSDT::pd_activate( - void* moduleBaseAddress, jstring module, - jint providers_count, JVM_DTraceProvider* providers) { - - // We need sections: - // (1) STRTAB - // ( - // (2) PROVIDER - // (3) PROBES - // (4) PROBOFFS - // (5) PROBARGS - // ) * Number of Providers - - // Type of sections we create - enum { - STRTAB = 0, - PROVIDERS = 1, - PROBES = 2, - PROBE_OFFSETS = 3, - ARG_OFFSETS = 4, - NUM_SECTIONS = 5 - }; - - static int alignment_for[NUM_SECTIONS] = { 1, 4, 8, 4, 1 }; - - ResourceMark rm; - - uint32_t num_sections = 1 + 4 * providers_count; - uint32_t offset = sizeof(dof_hdr_t) + (num_sections * sizeof(dof_sec_t)); - uint32_t* secoffs = NEW_RESOURCE_ARRAY(uint32_t, num_sections); - uint32_t* secsize = NEW_RESOURCE_ARRAY(uint32_t, num_sections); - - // Store offsets of all strings here in such order: - // zero-string (always 0) - // provider1-name - // probe1-function - // probe1-name - // arg-1 - // arg-2 - // ... - // probe2-function - // probe2-name - // arg-1 - // arg-2 - // provider2-name - // ... - - uint32_t strcount = 0; - // Count the number of strings we'll need - for(int prvc = 0; prvc < providers_count; ++prvc) { - JVM_DTraceProvider* provider = &providers[prvc]; - // Provider name - ++strcount; - for(int prbc = 0; prbc < provider->probe_count; ++prbc) { - JVM_DTraceProbe* p = &(provider->probes[prbc]); - Symbol* sig = Method::resolve_jmethod_id(p->method)->signature(); - // function + name + one per argument - strcount += 2 + ArgumentCount(sig).size(); - } - } - - // Create place for string offsets - uint32_t* stroffs = NEW_RESOURCE_ARRAY(uint32_t, strcount + 1); - uint32_t string_index = 0; - uint32_t curstr = 0; - - // First we need an empty string: "" - stroffs[curstr++] = string_index; - string_index += strlen("") + 1; - - for(int prvc = 0; prvc < providers_count; ++prvc) { - JVM_DTraceProvider* provider = &providers[prvc]; - char* provider_name = java_lang_String::as_utf8_string( - JNIHandles::resolve_non_null(provider->name)); - stroffs[curstr++] = string_index; - string_index += strlen(provider_name) + 1; - - // All probes - for(int prbc = 0; prbc < provider->probe_count; ++prbc) { - JVM_DTraceProbe* p = &(provider->probes[prbc]); - - char* function = java_lang_String::as_utf8_string( - JNIHandles::resolve_non_null(p->function)); - stroffs[curstr++] = string_index; - string_index += strlen(function) + 1; - - char* name = java_lang_String::as_utf8_string( - JNIHandles::resolve_non_null(p->name)); - stroffs[curstr++] = string_index; - string_index += strlen(name) + 1; - - Symbol* sig = Method::resolve_jmethod_id(p->method)->signature(); - SignatureStream ss(sig); - for ( ; !ss.at_return_type(); ss.next()) { - BasicType bt = ss.type(); - const char* t = NULL; - if (bt == T_OBJECT && - ss.as_symbol_or_null() == vmSymbols::java_lang_String()) { - t = string_sig; - } else if (bt == T_LONG) { - t = long_sig; - } else { - t = int_sig; - } - stroffs[curstr++] = string_index; - string_index += strlen(t) + 1; - } - } - } - secoffs[STRTAB] = offset; - secsize[STRTAB] = string_index; - offset += string_index; - - // Calculate the size of the rest - for(int prvc = 0; prvc < providers_count; ++prvc) { - JVM_DTraceProvider* provider = &providers[prvc]; - size_t provider_sec = PROVIDERS + prvc * 4; - size_t probe_sec = PROBES + prvc * 4; - size_t probeoffs_sec = PROBE_OFFSETS + prvc * 4; - size_t argoffs_sec = ARG_OFFSETS + prvc * 4; - - // Allocate space for the provider data struction - secoffs[provider_sec] = align_size_up(offset, alignment_for[PROVIDERS]); - secsize[provider_sec] = sizeof(dof_provider_t); - offset = secoffs[provider_sec] + secsize[provider_sec]; - - // Allocate space for all the probes - secoffs[probe_sec] = align_size_up(offset, alignment_for[PROBES]); - secsize[probe_sec] = sizeof(dof_probe_t) * provider->probe_count; - offset = secoffs[probe_sec] + secsize[probe_sec]; - - // Allocate space for the probe offsets - secoffs[probeoffs_sec] = align_size_up(offset, alignment_for[PROBE_OFFSETS]); - secsize[probeoffs_sec] = sizeof(uint32_t) * provider->probe_count; - offset = secoffs[probeoffs_sec] + secsize[probeoffs_sec]; - - // We need number of arguments argoffs - uint32_t argscount = 0; - for(int prbc = 0; prbc < provider->probe_count; ++prbc) { - JVM_DTraceProbe* p = &(provider->probes[prbc]); - Symbol* sig = Method::resolve_jmethod_id(p->method)->signature(); - argscount += ArgumentCount(sig).size(); - } - secoffs[argoffs_sec] = align_size_up(offset, alignment_for[ARG_OFFSETS]); - secsize[argoffs_sec] = sizeof(uint8_t) * argscount; - offset = secoffs[argoffs_sec] + secsize[argoffs_sec]; - } - - uint32_t size = offset; - - uint8_t* dof = NEW_RESOURCE_ARRAY(uint8_t, size); - if (!dof) { - return -1; - } - memset((void*)dof, 0, size); - - // Fill memory with proper values - dof_hdr_t* hdr = (dof_hdr_t*)dof; - hdr->dofh_ident[DOF_ID_MAG0] = DOF_MAG_MAG0; - hdr->dofh_ident[DOF_ID_MAG1] = DOF_MAG_MAG1; - hdr->dofh_ident[DOF_ID_MAG2] = DOF_MAG_MAG2; - hdr->dofh_ident[DOF_ID_MAG3] = DOF_MAG_MAG3; - hdr->dofh_ident[DOF_ID_MODEL] = DOF_MODEL_NATIVE; // No variants - hdr->dofh_ident[DOF_ID_ENCODING] = DOF_ENCODE_NATIVE; // No variants - hdr->dofh_ident[DOF_ID_VERSION] = DOF_VERSION_1; // No variants - hdr->dofh_ident[DOF_ID_DIFVERS] = DIF_VERSION_2; // No variants - // all other fields of ident to zero - - hdr->dofh_flags = 0; - hdr->dofh_hdrsize = sizeof(dof_hdr_t); - hdr->dofh_secsize = sizeof(dof_sec_t); - hdr->dofh_secnum = num_sections; - hdr->dofh_secoff = sizeof(dof_hdr_t); - hdr->dofh_loadsz = size; - hdr->dofh_filesz = size; - - // First section: STRTAB - dof_sec_t* sec = (dof_sec_t*)(dof + sizeof(dof_hdr_t)); - sec->dofs_type = DOF_SECT_STRTAB; - sec->dofs_align = alignment_for[STRTAB]; - sec->dofs_flags = DOF_SECF_LOAD; - sec->dofs_entsize = 0; - sec->dofs_offset = secoffs[STRTAB]; - sec->dofs_size = secsize[STRTAB]; - // Make data for this section - char* str = (char*)(dof + sec->dofs_offset); - - *str = 0; str += 1; // "" - - // Run through all strings again - for(int prvc = 0; prvc < providers_count; ++prvc) { - JVM_DTraceProvider* provider = &providers[prvc]; - char* provider_name = java_lang_String::as_utf8_string( - JNIHandles::resolve_non_null(provider->name)); - strcpy(str, provider_name); - str += strlen(provider_name) + 1; - - // All probes - for(int prbc = 0; prbc < provider->probe_count; ++prbc) { - JVM_DTraceProbe* p = &(provider->probes[prbc]); - - char* function = java_lang_String::as_utf8_string( - JNIHandles::resolve_non_null(p->function)); - strcpy(str, function); - str += strlen(str) + 1; - - char* name = java_lang_String::as_utf8_string( - JNIHandles::resolve_non_null(p->name)); - strcpy(str, name); - str += strlen(name) + 1; - - Symbol* sig = Method::resolve_jmethod_id(p->method)->signature(); - SignatureStream ss(sig); - for ( ; !ss.at_return_type(); ss.next()) { - BasicType bt = ss.type(); - const char* t; - if (bt == T_OBJECT && - ss.as_symbol_or_null() == vmSymbols::java_lang_String()) { - t = string_sig; - } else if (bt == T_LONG) { - t = long_sig; - } else { - t = int_sig; - } - strcpy(str, t); - str += strlen(t) + 1; - } - } - } - - curstr = 1; - for(int prvc = 0; prvc < providers_count; ++prvc) { - JVM_DTraceProvider* provider = &providers[prvc]; - size_t provider_sec = PROVIDERS + prvc * 4; - size_t probe_sec = PROBES + prvc * 4; - size_t probeoffs_sec = PROBE_OFFSETS + prvc * 4; - size_t argoffs_sec = ARG_OFFSETS + prvc * 4; - - // PROVIDER /////////////////////////////////////////////////////////////// - // Section header - sec = (dof_sec_t*) - (dof + sizeof(dof_hdr_t) + sizeof(dof_sec_t) * provider_sec); - sec->dofs_type = DOF_SECT_PROVIDER; - sec->dofs_align = alignment_for[PROVIDERS]; - sec->dofs_flags = DOF_SECF_LOAD; - sec->dofs_entsize = 0; - sec->dofs_offset = secoffs[provider_sec]; - sec->dofs_size = secsize[provider_sec]; - // Make provider decriiption - dof_provider_t* prv = (dof_provider_t*)(dof + sec->dofs_offset); - prv->dofpv_strtab = STRTAB; - prv->dofpv_probes = probe_sec; - prv->dofpv_prargs = argoffs_sec; - prv->dofpv_proffs = probeoffs_sec; - prv->dofpv_name = stroffs[curstr++]; // Index in string table - prv->dofpv_provattr = DOF_ATTR( - provider->providerAttributes.nameStability, - provider->providerAttributes.dataStability, - provider->providerAttributes.dependencyClass); - prv->dofpv_modattr = DOF_ATTR( - provider->moduleAttributes.nameStability, - provider->moduleAttributes.dataStability, - provider->moduleAttributes.dependencyClass); - prv->dofpv_funcattr = DOF_ATTR( - provider->functionAttributes.nameStability, - provider->functionAttributes.dataStability, - provider->functionAttributes.dependencyClass); - prv->dofpv_nameattr = DOF_ATTR( - provider->nameAttributes.nameStability, - provider->nameAttributes.dataStability, - provider->nameAttributes.dependencyClass); - prv->dofpv_argsattr = DOF_ATTR( - provider->argsAttributes.nameStability, - provider->argsAttributes.dataStability, - provider->argsAttributes.dependencyClass); - - // PROBES ///////////////////////////////////////////////////////////////// - // Section header - sec = (dof_sec_t*) - (dof + sizeof(dof_hdr_t) + sizeof(dof_sec_t) * probe_sec); - sec->dofs_type = DOF_SECT_PROBES; - sec->dofs_align = alignment_for[PROBES]; - sec->dofs_flags = DOF_SECF_LOAD; - sec->dofs_entsize = sizeof(dof_probe_t); - sec->dofs_offset = secoffs[probe_sec]; - sec->dofs_size = secsize[probe_sec]; - // Make probes descriptions - uint32_t argsoffs = 0; - for(int prbc = 0; prbc < provider->probe_count; ++prbc) { - JVM_DTraceProbe* probe = &(provider->probes[prbc]); - Method* m = Method::resolve_jmethod_id(probe->method); - int arg_count = ArgumentCount(m->signature()).size(); - assert(m->code() != NULL, "must have an nmethod"); - - dof_probe_t* prb = - (dof_probe_t*)(dof + sec->dofs_offset + prbc * sizeof(dof_probe_t)); - - prb->dofpr_addr = (uint64_t)m->code()->entry_point(); - prb->dofpr_func = stroffs[curstr++]; // Index in string table - prb->dofpr_name = stroffs[curstr++]; // Index in string table - prb->dofpr_nargv = stroffs[curstr ]; // Index in string table - // We spent siglen strings here - curstr += arg_count; - prb->dofpr_xargv = prb->dofpr_nargv; // Same bunch of strings - prb->dofpr_argidx = argsoffs; - prb->dofpr_offidx = prbc; - prb->dofpr_nargc = arg_count; - prb->dofpr_xargc = arg_count; - prb->dofpr_noffs = 1; // Number of offsets - // Next bunch of offsets - argsoffs += arg_count; - } - - // PROFFS ///////////////////////////////////////////////////////////////// - // Section header - sec = (dof_sec_t*) - (dof + sizeof(dof_hdr_t) + sizeof(dof_sec_t) * probeoffs_sec); - sec->dofs_type = DOF_SECT_PROFFS; - sec->dofs_align = alignment_for[PROBE_OFFSETS]; - sec->dofs_flags = DOF_SECF_LOAD; - sec->dofs_entsize = sizeof(uint32_t); - sec->dofs_offset = secoffs[probeoffs_sec]; - sec->dofs_size = secsize[probeoffs_sec]; - // Make offsets - for (int prbc = 0; prbc < provider->probe_count; ++prbc) { - uint32_t* pof = - (uint32_t*)(dof + sec->dofs_offset + sizeof(uint32_t) * prbc); - JVM_DTraceProbe* probe = &(provider->probes[prbc]); - Method* m = Method::resolve_jmethod_id(probe->method); - *pof = m->code()->trap_offset(); - } - - // PRARGS ///////////////////////////////////////////////////////////////// - // Section header - sec = (dof_sec_t*) - (dof + sizeof(dof_hdr_t) + sizeof(dof_sec_t) * argoffs_sec); - sec->dofs_type = DOF_SECT_PRARGS; - sec->dofs_align = alignment_for[ARG_OFFSETS]; - sec->dofs_flags = DOF_SECF_LOAD; - sec->dofs_entsize = sizeof(uint8_t); - sec->dofs_offset = secoffs[argoffs_sec]; - sec->dofs_size = secsize[argoffs_sec]; - // Make arguments - uint8_t* par = (uint8_t*)(dof + sec->dofs_offset); - for (int prbc = 0; prbc < provider->probe_count; ++prbc) { - JVM_DTraceProbe* p = &(provider->probes[prbc]); - Symbol* sig = Method::resolve_jmethod_id(p->method)->signature(); - uint8_t count = (uint8_t)ArgumentCount(sig).size(); - for (uint8_t i = 0; i < count; ++i) { - *par++ = i; - } - } - } - - // Register module - return dof_register(module, dof, moduleBaseAddress); -} - - -void DTraceJSDT::pd_dispose(int handle) { - int fd; - if (handle == -1) { - return; - } - fd = dofhelper_open(); - if (fd < 0) - return; - ioctl(fd, DTRACEHIOC_REMOVE, handle); - close(fd); -} - -jboolean DTraceJSDT::pd_is_supported() { - int fd = dofhelper_open(); - if (fd < 0) { - return false; - } - close(fd); - return true; -} - -static const char* dofSecTypeFor(uint32_t type) { - switch (type) { - case 0: return "DOF_SECT_NONE"; - case 1: return "DOF_SECT_COMMENTS"; - case 2: return "DOF_SECT_SOURCE"; - case 3: return "DOF_SECT_ECBDESC"; - case 4: return "DOF_SECT_PROBEDESC"; - case 5: return "DOF_SECT_ACTDESC"; - case 6: return "DOF_SECT_DIFOHDR"; - case 7: return "DOF_SECT_DIF"; - case 8: return "DOF_SECT_STRTAB"; - case 9: return "DOF_SECT_VARTAB"; - case 10: return "DOF_SECT_RELTAB"; - case 11: return "DOF_SECT_TYPETAB"; - case 12: return "DOF_SECT_URELHDR"; - case 13: return "DOF_SECT_KRELHDR"; - case 14: return "DOF_SECT_OPTDESC"; - case 15: return "DOF_SECT_PROVIDER"; - case 16: return "DOF_SECT_PROBES"; - case 17: return "DOF_SECT_PRARGS"; - case 18: return "DOF_SECT_PROFFS"; - case 19: return "DOF_SECT_INTTAB"; - case 20: return "DOF_SECT_UTSNAME"; - case 21: return "DOF_SECT_XLTAB"; - case 22: return "DOF_SECT_XLMEMBERS"; - case 23: return "DOF_SECT_XLIMPORT"; - case 24: return "DOF_SECT_XLEXPORT"; - case 25: return "DOF_SECT_PREXPORT"; - case 26: return "DOF_SECT_PRENOFFS"; - default: return ""; - } -} - -static void printDOFStringTabSec(void* dof, dof_sec_t* sec) { - size_t tab = sec->dofs_offset; - size_t limit = sec->dofs_size; - tty->print_cr("// String Table:"); - for (size_t idx = 0; idx < limit; /*empty*/) { - char* str = ((char*)dof) + tab + idx; - tty->print_cr("// [0x%x + 0x%x] '%s'", tab, idx, str); - idx += strlen(str) + 1; - } -} - -static void printDOFProviderSec(void* dof, dof_sec_t* sec) { - dof_provider_t* prov = (dof_provider_t*)((char*)dof + sec->dofs_offset); - tty->print_cr("// dof_provider_t {"); - tty->print_cr("// dofpv_strtab = %d", prov->dofpv_strtab); - tty->print_cr("// dofpv_probes = %d", prov->dofpv_probes); - tty->print_cr("// dofpv_prargs = %d", prov->dofpv_prargs); - tty->print_cr("// dofpv_proffs = %d", prov->dofpv_proffs); - tty->print_cr("// dofpv_name = 0x%x", prov->dofpv_name); - tty->print_cr("// dofpv_provattr = 0x%08x", prov->dofpv_provattr); - tty->print_cr("// dofpv_modattr = 0x%08x", prov->dofpv_modattr); - tty->print_cr("// dofpv_funcattr = 0x%08x", prov->dofpv_funcattr); - tty->print_cr("// dofpv_nameattr = 0x%08x", prov->dofpv_nameattr); - tty->print_cr("// dofpv_argsattr = 0x%08x", prov->dofpv_argsattr); - tty->print_cr("// }"); -} - -static void printDOFProbesSec(void* dof, dof_sec_t* sec) { - size_t idx = sec->dofs_offset; - size_t limit = idx + sec->dofs_size; - for (size_t idx = sec->dofs_offset; idx < limit; idx += sec->dofs_entsize) { - dof_probe_t* prb = (dof_probe_t*)((char*)dof + idx); - tty->print_cr("// dof_probe_t {"); - tty->print_cr("// dofpr_addr = 0x%016llx", prb->dofpr_addr); - tty->print_cr("// dofpr_func = 0x%x", prb->dofpr_func); - tty->print_cr("// dofpr_name = 0x%x", prb->dofpr_name); - tty->print_cr("// dofpr_nargv = 0x%x", prb->dofpr_nargv); - tty->print_cr("// dofpr_xargv = 0x%x", prb->dofpr_xargv); - tty->print_cr("// dofpr_argidx = 0x%x", prb->dofpr_argidx); - tty->print_cr("// dofpr_offidx = 0x%x", prb->dofpr_offidx); - tty->print_cr("// dofpr_nargc = %d", prb->dofpr_nargc); - tty->print_cr("// dofpr_xargc = %d", prb->dofpr_xargc); - tty->print_cr("// dofpr_noffs = %d", prb->dofpr_noffs); - tty->print_cr("// }"); - } -} - -static void printDOFOffsetsSec(void* dof, dof_sec_t* sec) { - size_t tab = sec->dofs_offset; - size_t limit = sec->dofs_size; - tty->print_cr("// Offsets:"); - for (size_t idx = 0; idx < limit; idx += sec->dofs_entsize) { - uint32_t* off = (uint32_t*)((char*)dof + tab + idx); - tty->print_cr("// [0x%x + 0x%x]: %d", tab, idx, *off); - } -} - -static void printDOFArgsSec(void* dof, dof_sec_t* sec) { - size_t tab = sec->dofs_offset; - size_t limit = sec->dofs_size; - tty->print_cr("// Arguments:"); - for (size_t idx = 0; idx < limit; idx += sec->dofs_entsize) { - uint8_t* arg = (uint8_t*)((char*)dof + tab + idx); - tty->print_cr("// [0x%x + 0x%x]: %d", tab, idx, *arg); - } -} - -static void printDOFSection(void* dof, dof_sec_t* sec) { - tty->print_cr("// dof_sec_t {"); - tty->print_cr("// dofs_type = 0x%x /* %s */", - sec->dofs_type, dofSecTypeFor(sec->dofs_type)); - tty->print_cr("// dofs_align = %d", sec->dofs_align); - tty->print_cr("// dofs_flags = 0x%x", sec->dofs_flags); - tty->print_cr("// dofs_entsize = %d", sec->dofs_entsize); - tty->print_cr("// dofs_offset = 0x%llx", sec->dofs_offset); - tty->print_cr("// dofs_size = %lld", sec->dofs_size); - tty->print_cr("// }"); - switch (sec->dofs_type) { - case DOF_SECT_STRTAB: printDOFStringTabSec(dof, sec); break; - case DOF_SECT_PROVIDER: printDOFProviderSec(dof, sec); break; - case DOF_SECT_PROBES: printDOFProbesSec(dof, sec); break; - case DOF_SECT_PROFFS: printDOFOffsetsSec(dof, sec); break; - case DOF_SECT_PRARGS: printDOFArgsSec(dof, sec); break; - default: tty->print_cr("//
"); - } -} - -static void printDOFHeader(dof_hdr_t* hdr) { - tty->print_cr("// dof_hdr_t {"); - tty->print_cr("// dofh_ident[DOF_ID_MAG0] = 0x%x", - hdr->dofh_ident[DOF_ID_MAG0]); - tty->print_cr("// dofh_ident[DOF_ID_MAG1] = 0x%x", - hdr->dofh_ident[DOF_ID_MAG1]); - tty->print_cr("// dofh_ident[DOF_ID_MAG2] = 0x%x", - hdr->dofh_ident[DOF_ID_MAG2]); - tty->print_cr("// dofh_ident[DOF_ID_MAG3] = 0x%x", - hdr->dofh_ident[DOF_ID_MAG3]); - tty->print_cr("// dofh_ident[DOF_ID_MODEL] = 0x%x", - hdr->dofh_ident[DOF_ID_MODEL]); - tty->print_cr("// dofh_ident[DOF_ID_ENCODING] = 0x%x", - hdr->dofh_ident[DOF_ID_ENCODING]); - tty->print_cr("// dofh_ident[DOF_ID_VERSION] = 0x%x", - hdr->dofh_ident[DOF_ID_VERSION]); - tty->print_cr("// dofh_ident[DOF_ID_DIFVERS] = 0x%x", - hdr->dofh_ident[DOF_ID_DIFVERS]); - tty->print_cr("// dofh_flags = 0x%x", hdr->dofh_flags); - tty->print_cr("// dofh_hdrsize = %d", hdr->dofh_hdrsize); - tty->print_cr("// dofh_secsize = %d", hdr->dofh_secsize); - tty->print_cr("// dofh_secnum = %d", hdr->dofh_secnum); - tty->print_cr("// dofh_secoff = %lld", hdr->dofh_secoff); - tty->print_cr("// dofh_loadsz = %lld", hdr->dofh_loadsz); - tty->print_cr("// dofh_filesz = %lld", hdr->dofh_filesz); - tty->print_cr("// }"); -} - -static void printDOF(void* dof) { - dof_hdr_t* hdr = (dof_hdr_t*)dof; - printDOFHeader(hdr); - for (int i = 0; i < hdr->dofh_secnum; ++i) { - dof_sec_t* sec = - (dof_sec_t*)((char*)dof + sizeof(dof_hdr_t) + i * sizeof(dof_sec_t)); - tty->print_cr("// [Section #%d]", i); - printDOFSection(dof, sec); - } -} - -static void printDOFHelper(dof_helper_t* helper) { - tty->print_cr("// dof_helper_t {"); - tty->print_cr("// dofhp_mod = \"%s\"", helper->dofhp_mod); - tty->print_cr("// dofhp_addr = 0x%016llx", helper->dofhp_addr); - tty->print_cr("// dofhp_dof = 0x%016llx", helper->dofhp_dof); - printDOF((void*)helper->dofhp_dof); - tty->print_cr("// }"); - size_t len = ((dof_hdr_t*)helper)->dofh_loadsz; - tty->print_data((void*)helper->dofhp_dof, len, true); -} - -#else // ndef HAVE_DTRACE_H - -// Get here if we're not building on at least Solaris 10 -int DTraceJSDT::pd_activate( - void* baseAddress, jstring module, - jint provider_count, JVM_DTraceProvider* providers) { - return -1; -} - -void DTraceJSDT::pd_dispose(int handle) { -} - -jboolean DTraceJSDT::pd_is_supported() { - return false; -} -#endif diff --git a/hotspot/src/os/windows/vm/dtraceJSDT_windows.cpp b/hotspot/src/os/windows/vm/dtraceJSDT_windows.cpp deleted file mode 100644 index 0f340fb5730..00000000000 --- a/hotspot/src/os/windows/vm/dtraceJSDT_windows.cpp +++ /dev/null @@ -1,47 +0,0 @@ -/* - * Copyright (c) 1997, 2010, 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. - * - */ - -#include "precompiled.hpp" -#include "classfile/javaClasses.hpp" -#include "code/codeBlob.hpp" -#include "memory/allocation.hpp" -#include "prims/jvm.h" -#include "runtime/dtraceJSDT.hpp" -#include "runtime/jniHandles.hpp" -#include "runtime/os.hpp" -#include "runtime/signature.hpp" -#include "utilities/globalDefinitions.hpp" - -int DTraceJSDT::pd_activate( - void* baseAddress, jstring module, - jint providers_count, JVM_DTraceProvider* providers) { - return -1; -} - -void DTraceJSDT::pd_dispose(int handle) { -} - -jboolean DTraceJSDT::pd_is_supported() { - return false; -} diff --git a/hotspot/src/share/vm/asm/codeBuffer.hpp b/hotspot/src/share/vm/asm/codeBuffer.hpp index 023360ee67c..bb9c5c79af4 100644 --- a/hotspot/src/share/vm/asm/codeBuffer.hpp +++ b/hotspot/src/share/vm/asm/codeBuffer.hpp @@ -42,7 +42,6 @@ public: Verified_Entry, Frame_Complete, // Offset in the code where the frame setup is (for forte stackwalks) is complete OSR_Entry, - Dtrace_trap = OSR_Entry, // dtrace probes can never have an OSR entry so reuse it Exceptions, // Offset where exception handler lives Deopt, // Offset where deopt handler lives DeoptMH, // Offset where MethodHandle deopt handler lives diff --git a/hotspot/src/share/vm/code/nmethod.cpp b/hotspot/src/share/vm/code/nmethod.cpp index 835b3dc831d..761a39d5bd1 100644 --- a/hotspot/src/share/vm/code/nmethod.cpp +++ b/hotspot/src/share/vm/code/nmethod.cpp @@ -477,9 +477,6 @@ void nmethod::init_defaults() { #if INCLUDE_RTM_OPT _rtm_state = NoRTM; #endif -#ifdef HAVE_DTRACE_H - _trap_offset = 0; -#endif // def HAVE_DTRACE_H } nmethod* nmethod::new_native_nmethod(methodHandle method, @@ -520,44 +517,6 @@ nmethod* nmethod::new_native_nmethod(methodHandle method, return nm; } -#ifdef HAVE_DTRACE_H -nmethod* nmethod::new_dtrace_nmethod(methodHandle method, - CodeBuffer *code_buffer, - int vep_offset, - int trap_offset, - int frame_complete, - int frame_size) { - code_buffer->finalize_oop_references(method); - // create nmethod - nmethod* nm = NULL; - { - MutexLockerEx mu(CodeCache_lock, Mutex::_no_safepoint_check_flag); - int nmethod_size = allocation_size(code_buffer, sizeof(nmethod)); - CodeOffsets offsets; - offsets.set_value(CodeOffsets::Verified_Entry, vep_offset); - offsets.set_value(CodeOffsets::Dtrace_trap, trap_offset); - offsets.set_value(CodeOffsets::Frame_Complete, frame_complete); - - nm = new (nmethod_size, CompLevel_none) nmethod(method(), nmethod_size, - &offsets, code_buffer, frame_size); - - NOT_PRODUCT(if (nm != NULL) nmethod_stats.note_nmethod(nm)); - if (PrintAssembly && nm != NULL) { - Disassembler::decode(nm); - } - } - // verify nmethod - debug_only(if (nm) nm->verify();) // might block - - if (nm != NULL) { - nm->log_new_nmethod(); - } - - return nm; -} - -#endif // def HAVE_DTRACE_H - nmethod* nmethod::new_nmethod(methodHandle method, int compile_id, int entry_bci, @@ -718,91 +677,6 @@ nmethod::nmethod( } } -// For dtrace wrappers -#ifdef HAVE_DTRACE_H -nmethod::nmethod( - Method* method, - int nmethod_size, - CodeOffsets* offsets, - CodeBuffer* code_buffer, - int frame_size) - : CodeBlob("dtrace nmethod", code_buffer, sizeof(nmethod), - nmethod_size, offsets->value(CodeOffsets::Frame_Complete), frame_size, NULL), - _native_receiver_sp_offset(in_ByteSize(-1)), - _native_basic_lock_sp_offset(in_ByteSize(-1)) -{ - { - debug_only(No_Safepoint_Verifier nsv;) - assert_locked_or_safepoint(CodeCache_lock); - - init_defaults(); - _method = method; - _entry_bci = InvocationEntryBci; - // We have no exception handler or deopt handler make the - // values something that will never match a pc like the nmethod vtable entry - _exception_offset = 0; - _deoptimize_offset = 0; - _deoptimize_mh_offset = 0; - _unwind_handler_offset = -1; - _trap_offset = offsets->value(CodeOffsets::Dtrace_trap); - _orig_pc_offset = 0; - _consts_offset = data_offset(); - _stub_offset = data_offset(); - _oops_offset = data_offset(); - _metadata_offset = _oops_offset + round_to(code_buffer->total_oop_size(), oopSize); - _scopes_data_offset = _metadata_offset + round_to(code_buffer->total_metadata_size(), wordSize); - _scopes_pcs_offset = _scopes_data_offset; - _dependencies_offset = _scopes_pcs_offset; - _handler_table_offset = _dependencies_offset; - _nul_chk_table_offset = _handler_table_offset; - _nmethod_end_offset = _nul_chk_table_offset; - _compile_id = 0; // default - _comp_level = CompLevel_none; - _entry_point = code_begin() + offsets->value(CodeOffsets::Entry); - _verified_entry_point = code_begin() + offsets->value(CodeOffsets::Verified_Entry); - _osr_entry_point = NULL; - _exception_cache = NULL; - _pc_desc_cache.reset_to(NULL); - _hotness_counter = NMethodSweeper::hotness_counter_reset_val(); - - code_buffer->copy_values_to(this); - if (ScavengeRootsInCode) { - if (detect_scavenge_root_oops()) { - CodeCache::add_scavenge_root_nmethod(this); - } - Universe::heap()->register_nmethod(this); - } - DEBUG_ONLY(verify_scavenge_root_oops();) - CodeCache::commit(this); - } - - if (PrintNMethods || PrintDebugInfo || PrintRelocations || PrintDependencies) { - ttyLocker ttyl; // keep the following output all in one block - // This output goes directly to the tty, not the compiler log. - // To enable tools to match it up with the compilation activity, - // be sure to tag this tty output with the compile ID. - if (xtty != NULL) { - xtty->begin_head("print_dtrace_nmethod"); - xtty->method(_method); - xtty->stamp(); - xtty->end_head(" address='" INTPTR_FORMAT "'", (intptr_t) this); - } - // print the header part first - print(); - // then print the requested information - if (PrintNMethods) { - print_code(); - } - if (PrintRelocations) { - print_relocations(); - } - if (xtty != NULL) { - xtty->tail("print_dtrace_nmethod"); - } - } -} -#endif // def HAVE_DTRACE_H - void* nmethod::operator new(size_t size, int nmethod_size, int comp_level) throw () { return CodeCache::allocate(nmethod_size, CodeCache::get_code_blob_type(comp_level)); } diff --git a/hotspot/src/share/vm/code/nmethod.hpp b/hotspot/src/share/vm/code/nmethod.hpp index c95679649fd..59dda5e2ae2 100644 --- a/hotspot/src/share/vm/code/nmethod.hpp +++ b/hotspot/src/share/vm/code/nmethod.hpp @@ -157,9 +157,6 @@ class nmethod : public CodeBlob { // Offset of the unwind handler if it exists int _unwind_handler_offset; -#ifdef HAVE_DTRACE_H - int _trap_offset; -#endif // def HAVE_DTRACE_H int _consts_offset; int _stub_offset; int _oops_offset; // offset to where embedded oop table begins (inside data) @@ -261,15 +258,6 @@ class nmethod : public CodeBlob { ByteSize basic_lock_sp_offset, /* synchronized natives only */ OopMapSet* oop_maps); -#ifdef HAVE_DTRACE_H - // For native wrappers - nmethod(Method* method, - int nmethod_size, - CodeOffsets* offsets, - CodeBuffer *code_buffer, - int frame_size); -#endif // def HAVE_DTRACE_H - // Creation support nmethod(Method* method, int nmethod_size, @@ -333,22 +321,6 @@ class nmethod : public CodeBlob { ByteSize basic_lock_sp_offset, OopMapSet* oop_maps); -#ifdef HAVE_DTRACE_H - // The method we generate for a dtrace probe has to look - // like an nmethod as far as the rest of the system is concerned - // which is somewhat unfortunate. - static nmethod* new_dtrace_nmethod(methodHandle method, - CodeBuffer *code_buffer, - int vep_offset, - int trap_offset, - int frame_complete, - int frame_size); - - int trap_offset() const { return _trap_offset; } - address trap_address() const { return insts_begin() + _trap_offset; } - -#endif // def HAVE_DTRACE_H - // accessors Method* method() const { return _method; } AbstractCompiler* compiler() const { return _compiler; } diff --git a/hotspot/src/share/vm/prims/jvm.cpp b/hotspot/src/share/vm/prims/jvm.cpp index 2d52d7e0723..f9c2eba7b0d 100644 --- a/hotspot/src/share/vm/prims/jvm.cpp +++ b/hotspot/src/share/vm/prims/jvm.cpp @@ -45,7 +45,6 @@ #include "prims/privilegedStack.hpp" #include "runtime/arguments.hpp" #include "runtime/atomic.inline.hpp" -#include "runtime/dtraceJSDT.hpp" #include "runtime/handles.inline.hpp" #include "runtime/init.hpp" #include "runtime/interfaceSupport.hpp" @@ -3562,36 +3561,6 @@ JVM_LEAF(jboolean, JVM_SupportsCX8()) return VM_Version::supports_cx8(); JVM_END -// DTrace /////////////////////////////////////////////////////////////////// - -JVM_ENTRY(jint, JVM_DTraceGetVersion(JNIEnv* env)) - JVMWrapper("JVM_DTraceGetVersion"); - return (jint)JVM_TRACING_DTRACE_VERSION; -JVM_END - -JVM_ENTRY(jlong,JVM_DTraceActivate( - JNIEnv* env, jint version, jstring module_name, jint providers_count, - JVM_DTraceProvider* providers)) - JVMWrapper("JVM_DTraceActivate"); - return DTraceJSDT::activate( - version, module_name, providers_count, providers, THREAD); -JVM_END - -JVM_ENTRY(jboolean,JVM_DTraceIsProbeEnabled(JNIEnv* env, jmethodID method)) - JVMWrapper("JVM_DTraceIsProbeEnabled"); - return DTraceJSDT::is_probe_enabled(method); -JVM_END - -JVM_ENTRY(void,JVM_DTraceDispose(JNIEnv* env, jlong handle)) - JVMWrapper("JVM_DTraceDispose"); - DTraceJSDT::dispose(handle); -JVM_END - -JVM_ENTRY(jboolean,JVM_DTraceIsSupported(JNIEnv* env)) - JVMWrapper("JVM_DTraceIsSupported"); - return DTraceJSDT::is_supported(); -JVM_END - // Returns an array of all live Thread objects (VM internal JavaThreads, // jvmti agent threads, and JNI attaching threads are skipped) // See CR 6404306 regarding JNI attaching threads diff --git a/hotspot/src/share/vm/prims/jvm.h b/hotspot/src/share/vm/prims/jvm.h index 9df1e3bfabf..0bfce5ec62e 100644 --- a/hotspot/src/share/vm/prims/jvm.h +++ b/hotspot/src/share/vm/prims/jvm.h @@ -568,83 +568,6 @@ JVM_AssertionStatusDirectives(JNIEnv *env, jclass unused); JNIEXPORT jboolean JNICALL JVM_SupportsCX8(void); -/* - * com.sun.dtrace.jsdt support - */ - -#define JVM_TRACING_DTRACE_VERSION 1 - -/* - * Structure to pass one probe description to JVM. - * - * The VM will overwrite the definition of the referenced method with - * code that will fire the probe. - */ -typedef struct { - jmethodID method; - jstring function; - jstring name; - void* reserved[4]; // for future use -} JVM_DTraceProbe; - -/** - * Encapsulates the stability ratings for a DTrace provider field - */ -typedef struct { - jint nameStability; - jint dataStability; - jint dependencyClass; -} JVM_DTraceInterfaceAttributes; - -/* - * Structure to pass one provider description to JVM - */ -typedef struct { - jstring name; - JVM_DTraceProbe* probes; - jint probe_count; - JVM_DTraceInterfaceAttributes providerAttributes; - JVM_DTraceInterfaceAttributes moduleAttributes; - JVM_DTraceInterfaceAttributes functionAttributes; - JVM_DTraceInterfaceAttributes nameAttributes; - JVM_DTraceInterfaceAttributes argsAttributes; - void* reserved[4]; // for future use -} JVM_DTraceProvider; - -/* - * Get the version number the JVM was built with - */ -JNIEXPORT jint JNICALL -JVM_DTraceGetVersion(JNIEnv* env); - -/* - * Register new probe with given signature, return global handle - * - * The version passed in is the version that the library code was - * built with. - */ -JNIEXPORT jlong JNICALL -JVM_DTraceActivate(JNIEnv* env, jint version, jstring module_name, - jint providers_count, JVM_DTraceProvider* providers); - -/* - * Check JSDT probe - */ -JNIEXPORT jboolean JNICALL -JVM_DTraceIsProbeEnabled(JNIEnv* env, jmethodID method); - -/* - * Destroy custom DOF - */ -JNIEXPORT void JNICALL -JVM_DTraceDispose(JNIEnv* env, jlong handle); - -/* - * Check to see if DTrace is supported by OS - */ -JNIEXPORT jboolean JNICALL -JVM_DTraceIsSupported(JNIEnv* env); - /************************************************************************* PART 2: Support for the Verifier and Class File Format Checker ************************************************************************/ diff --git a/hotspot/src/share/vm/runtime/dtraceJSDT.cpp b/hotspot/src/share/vm/runtime/dtraceJSDT.cpp deleted file mode 100644 index 51ae25d0c34..00000000000 --- a/hotspot/src/share/vm/runtime/dtraceJSDT.cpp +++ /dev/null @@ -1,132 +0,0 @@ -/* - * Copyright (c) 1997, 2012, 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. - * - */ - -#include "precompiled.hpp" -#include "classfile/javaClasses.hpp" -#include "code/codeBlob.hpp" -#include "code/nativeInst.hpp" -#include "memory/allocation.hpp" -#include "prims/jvm.h" -#include "runtime/dtraceJSDT.hpp" -#include "runtime/jniHandles.hpp" -#include "runtime/os.hpp" -#include "utilities/exceptions.hpp" -#include "utilities/globalDefinitions.hpp" -#include "utilities/utf8.hpp" - -#ifdef HAVE_DTRACE_H - -jlong DTraceJSDT::activate( - jint version, jstring module_name, jint providers_count, - JVM_DTraceProvider* providers, TRAPS) { - - size_t count = 0; - RegisteredProbes* probes = NULL; - - if (!is_supported()) { - return 0; - } - - assert(module_name != NULL, "valid module name"); - assert(providers != NULL, "valid provider array"); - - for (int i = 0; i < providers_count; ++i) { - count += providers[i].probe_count; - } - probes = new RegisteredProbes(count); - count = 0; - - for (int i = 0; i < providers_count; ++i) { - assert(providers[i].name != NULL, "valid provider name"); - assert(providers[i].probe_count == 0 || providers[i].probes != NULL, - "valid probe count"); - for (int j = 0; j < providers[i].probe_count; ++j) { - JVM_DTraceProbe* probe = &(providers[i].probes[j]); - assert(probe != NULL, "valid probe"); - assert(probe->method != NULL, "valid method"); - assert(probe->name != NULL, "valid probe name"); - assert(probe->function != NULL, "valid probe function spec"); - methodHandle h_method = - methodHandle(THREAD, Method::resolve_jmethod_id(probe->method)); - nmethod* nm = AdapterHandlerLibrary::create_dtrace_nmethod(h_method); - if (nm == NULL) { - delete probes; - THROW_MSG_0(vmSymbols::java_lang_RuntimeException(), - "Unable to register DTrace probes (CodeCache: no room for DTrace nmethods)."); - } - h_method()->set_not_compilable(); - h_method()->set_code(h_method, nm); - probes->nmethod_at_put(count++, nm); - } - } - - int handle = pd_activate((void*)probes, - module_name, providers_count, providers); - if (handle < 0) { - delete probes; - THROW_MSG_0(vmSymbols::java_lang_RuntimeException(), - "Unable to register DTrace probes (internal error)."); - } - probes->set_helper_handle(handle); - return RegisteredProbes::toOpaqueProbes(probes); -} - -jboolean DTraceJSDT::is_probe_enabled(jmethodID method) { - Method* m = Method::resolve_jmethod_id(method); - return nativeInstruction_at(m->code()->trap_address())->is_dtrace_trap(); -} - -void DTraceJSDT::dispose(OpaqueProbes probes) { - RegisteredProbes* p = RegisteredProbes::toRegisteredProbes(probes); - if (probes != -1 && p != NULL) { - pd_dispose(p->helper_handle()); - delete p; - } -} - -jboolean DTraceJSDT::is_supported() { - return pd_is_supported(); -} - -#else // HAVE_DTRACE_H - -jlong DTraceJSDT::activate( - jint version, jstring module_name, jint providers_count, - JVM_DTraceProvider* providers, TRAPS) { - return 0; -} - -jboolean DTraceJSDT::is_probe_enabled(jmethodID method) { - return false; -} - -void DTraceJSDT::dispose(OpaqueProbes probes) { - return; -} - -jboolean DTraceJSDT::is_supported() { - return false; -} - -#endif // ndef HAVE_DTRACE_H diff --git a/hotspot/src/share/vm/runtime/dtraceJSDT.hpp b/hotspot/src/share/vm/runtime/dtraceJSDT.hpp deleted file mode 100644 index 71828d029e5..00000000000 --- a/hotspot/src/share/vm/runtime/dtraceJSDT.hpp +++ /dev/null @@ -1,96 +0,0 @@ -/* - * Copyright (c) 1997, 2014, 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. - * - */ - -#ifndef SHARE_VM_RUNTIME_DTRACEJSDT_HPP -#define SHARE_VM_RUNTIME_DTRACEJSDT_HPP - -#include "code/nmethod.hpp" - -class RegisteredProbes; -typedef jlong OpaqueProbes; - -class DTraceJSDT : AllStatic { - private: - - static int pd_activate(void* moduleBaseAddress, jstring module, - jint providers_count, JVM_DTraceProvider* providers); - static void pd_dispose(int handle); - static jboolean pd_is_supported(); - - public: - - static OpaqueProbes activate( - jint version, jstring module_name, jint providers_count, - JVM_DTraceProvider* providers, TRAPS); - static jboolean is_probe_enabled(jmethodID method); - static void dispose(OpaqueProbes handle); - static jboolean is_supported(); -}; - -class RegisteredProbes : public CHeapObj { - private: - nmethod** _nmethods; // all the probe methods - size_t _count; // number of probe methods - int _helper_handle; // DTrace-assigned identifier - - public: - RegisteredProbes(size_t count) { - _count = count; - _nmethods = NEW_C_HEAP_ARRAY(nmethod*, count, mtInternal); - } - - ~RegisteredProbes() { - for (size_t i = 0; i < _count; ++i) { - // Let the sweeper reclaim it - _nmethods[i]->make_not_entrant(); - _nmethods[i]->method()->clear_code(); - } - FREE_C_HEAP_ARRAY(nmethod*, _nmethods); - _nmethods = NULL; - _count = 0; - } - - static RegisteredProbes* toRegisteredProbes(OpaqueProbes p) { - return (RegisteredProbes*)(intptr_t)p; - } - - static OpaqueProbes toOpaqueProbes(RegisteredProbes* p) { - return (OpaqueProbes)(intptr_t)p; - } - - void set_helper_handle(int handle) { _helper_handle = handle; } - int helper_handle() const { return _helper_handle; } - - nmethod* nmethod_at(size_t i) { - assert(i >= 0 && i < _count, "bad nmethod index"); - return _nmethods[i]; - } - - void nmethod_at_put(size_t i, nmethod* nm) { - assert(i >= 0 && i < _count, "bad nmethod index"); - _nmethods[i] = nm; - } -}; - -#endif // SHARE_VM_RUNTIME_DTRACEJSDT_HPP diff --git a/hotspot/src/share/vm/runtime/globals.hpp b/hotspot/src/share/vm/runtime/globals.hpp index 7e27b03dbf9..5baf54b67bb 100644 --- a/hotspot/src/share/vm/runtime/globals.hpp +++ b/hotspot/src/share/vm/runtime/globals.hpp @@ -3847,9 +3847,6 @@ class CommandLineFlags { product(bool, RelaxAccessControlCheck, false, \ "Relax the access control checks in the verifier") \ \ - diagnostic(bool, PrintDTraceDOF, false, \ - "Print the DTrace DOF passed to the system for JSDT probes") \ - \ product(uintx, StringTableSize, defaultStringTableSize, \ "Number of buckets in the interned String table") \ \ diff --git a/hotspot/src/share/vm/runtime/sharedRuntime.cpp b/hotspot/src/share/vm/runtime/sharedRuntime.cpp index fa1f5672292..c2b72937a8f 100644 --- a/hotspot/src/share/vm/runtime/sharedRuntime.cpp +++ b/hotspot/src/share/vm/runtime/sharedRuntime.cpp @@ -2610,68 +2610,6 @@ JRT_ENTRY_NO_ASYNC(void, SharedRuntime::block_for_jni_critical(JavaThread* threa GC_locker::unlock_critical(thread); JRT_END -#ifdef HAVE_DTRACE_H -/** - * Create a dtrace nmethod for this method. The wrapper converts the - * Java-compiled calling convention to the native convention, makes a dummy call - * (actually nops for the size of the call instruction, which become a trap if - * probe is enabled), and finally returns to the caller. Since this all looks like a - * leaf, no thread transition is needed. - */ -nmethod *AdapterHandlerLibrary::create_dtrace_nmethod(methodHandle method) { - ResourceMark rm; - nmethod* nm = NULL; - - if (PrintCompilation) { - ttyLocker ttyl; - tty->print("--- n "); - method->print_short_name(tty); - if (method->is_static()) { - tty->print(" (static)"); - } - tty->cr(); - } - - { - // perform the work while holding the lock, but perform any printing - // outside the lock - MutexLocker mu(AdapterHandlerLibrary_lock); - // See if somebody beat us to it - nm = method->code(); - if (nm) { - return nm; - } - - ResourceMark rm; - - BufferBlob* buf = buffer_blob(); // the temporary code buffer in CodeCache - if (buf != NULL) { - CodeBuffer buffer(buf); - // Need a few relocation entries - double locs_buf[20]; - buffer.insts()->initialize_shared_locs( - (relocInfo*)locs_buf, sizeof(locs_buf) / sizeof(relocInfo)); - MacroAssembler _masm(&buffer); - - // Generate the compiled-to-native wrapper code - nm = SharedRuntime::generate_dtrace_nmethod(&_masm, method); - } - } - return nm; -} - -// the dtrace method needs to convert java lang string to utf8 string. -void SharedRuntime::get_utf(oopDesc* src, address dst) { - typeArrayOop jlsValue = java_lang_String::value(src); - int jlsOffset = java_lang_String::offset(src); - int jlsLen = java_lang_String::length(src); - jchar* jlsPos = (jlsLen == 0) ? NULL : - jlsValue->char_at_addr(jlsOffset); - assert(TypeArrayKlass::cast(jlsValue->klass())->element_type() == T_CHAR, "compressed string"); - (void) UNICODE::as_utf8(jlsPos, jlsLen, (char *)dst, max_dtrace_string_size); -} -#endif // ndef HAVE_DTRACE_H - int SharedRuntime::convert_ints_to_longints_argcnt(int in_args_count, BasicType* in_sig_bt) { int argcnt = in_args_count; if (CCallingConventionRequiresIntsAsLongs) { diff --git a/hotspot/src/share/vm/runtime/sharedRuntime.hpp b/hotspot/src/share/vm/runtime/sharedRuntime.hpp index 0d3335413cb..c370a9f7a67 100644 --- a/hotspot/src/share/vm/runtime/sharedRuntime.hpp +++ b/hotspot/src/share/vm/runtime/sharedRuntime.hpp @@ -466,19 +466,6 @@ class SharedRuntime: AllStatic { // Block before entering a JNI critical method static void block_for_jni_critical(JavaThread* thread); -#ifdef HAVE_DTRACE_H - // Generate a dtrace wrapper for a given method. The method takes arguments - // in the Java compiled code convention, marshals them to the native - // convention (handlizes oops, etc), transitions to native, makes the call, - // returns to java state (possibly blocking), unhandlizes any result and - // returns. - static nmethod *generate_dtrace_nmethod(MacroAssembler* masm, - methodHandle method); - - // dtrace support to convert a Java string to utf8 - static void get_utf(oopDesc* src, address dst); -#endif // def HAVE_DTRACE_H - // A compiled caller has just called the interpreter, but compiled code // exists. Patch the caller so he no longer calls into the interpreter. static void fixup_callers_callsite(Method* moop, address ret_pc); @@ -680,10 +667,6 @@ class AdapterHandlerLibrary: public AllStatic { static void create_native_wrapper(methodHandle method); static AdapterHandlerEntry* get_adapter(methodHandle method); -#ifdef HAVE_DTRACE_H - static nmethod* create_dtrace_nmethod (methodHandle method); -#endif // HAVE_DTRACE_H - static void print_handler(CodeBlob* b) { print_handler_on(tty, b); } static void print_handler_on(outputStream* st, CodeBlob* b); static bool contains(CodeBlob* b); From c6b7e46d0dcd6943652fdbd80892d079083e62f6 Mon Sep 17 00:00:00 2001 From: Jaroslav Bachorik Date: Tue, 2 Dec 2014 19:47:45 +0100 Subject: [PATCH 007/116] 8067447: Factor out the shared implementation of the VM flags manipulation code Reviewed-by: sla, dholmes --- .../src/share/vm/services/attachListener.cpp | 160 ++----------- hotspot/src/share/vm/services/management.cpp | 58 +---- .../src/share/vm/services/writeableFlags.cpp | 226 ++++++++++++++++++ .../src/share/vm/services/writeableFlags.hpp | 97 ++++++++ 4 files changed, 349 insertions(+), 192 deletions(-) create mode 100644 hotspot/src/share/vm/services/writeableFlags.cpp create mode 100644 hotspot/src/share/vm/services/writeableFlags.hpp diff --git a/hotspot/src/share/vm/services/attachListener.cpp b/hotspot/src/share/vm/services/attachListener.cpp index 241914cd6cc..85e01341398 100644 --- a/hotspot/src/share/vm/services/attachListener.cpp +++ b/hotspot/src/share/vm/services/attachListener.cpp @@ -1,5 +1,5 @@ /* - * Copyright (c) 2005, 2014, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2005, 2015, 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 @@ -35,6 +35,7 @@ #include "runtime/os.hpp" #include "services/attachListener.hpp" #include "services/diagnosticCommand.hpp" +#include "services/writeableFlags.hpp" #include "services/heapDumper.hpp" volatile bool AttachListener::_initialized; @@ -229,133 +230,6 @@ static jint heap_inspection(AttachOperation* op, outputStream* out) { return JNI_OK; } -// set a boolean global flag using value from AttachOperation -static jint set_bool_flag(const char* name, AttachOperation* op, outputStream* out) { - bool value = true; - const char* arg1; - if ((arg1 = op->arg(1)) != NULL) { - int tmp; - int n = sscanf(arg1, "%d", &tmp); - if (n != 1) { - out->print_cr("flag value must be a boolean (1 or 0)"); - return JNI_ERR; - } - value = (tmp != 0); - } - bool res = CommandLineFlags::boolAtPut((char*)name, &value, Flag::ATTACH_ON_DEMAND); - if (! res) { - out->print_cr("setting flag %s failed", name); - } - return res? JNI_OK : JNI_ERR; -} - -// set a intx global flag using value from AttachOperation -static jint set_intx_flag(const char* name, AttachOperation* op, outputStream* out) { - intx value; - const char* arg1; - if ((arg1 = op->arg(1)) != NULL) { - int n = sscanf(arg1, INTX_FORMAT, &value); - if (n != 1) { - out->print_cr("flag value must be an integer"); - return JNI_ERR; - } - } - bool res = CommandLineFlags::intxAtPut((char*)name, &value, Flag::ATTACH_ON_DEMAND); - if (! res) { - out->print_cr("setting flag %s failed", name); - } - - return res? JNI_OK : JNI_ERR; -} - -// set a uintx global flag using value from AttachOperation -static jint set_uintx_flag(const char* name, AttachOperation* op, outputStream* out) { - uintx value; - const char* arg1; - if ((arg1 = op->arg(1)) != NULL) { - int n = sscanf(arg1, UINTX_FORMAT, &value); - if (n != 1) { - out->print_cr("flag value must be an unsigned integer"); - return JNI_ERR; - } - } - - if (strncmp(name, "MaxHeapFreeRatio", 17) == 0) { - FormatBuffer<80> err_msg("%s", ""); - if (!Arguments::verify_MaxHeapFreeRatio(err_msg, value)) { - out->print_cr("%s", err_msg.buffer()); - return JNI_ERR; - } - } else if (strncmp(name, "MinHeapFreeRatio", 17) == 0) { - FormatBuffer<80> err_msg("%s", ""); - if (!Arguments::verify_MinHeapFreeRatio(err_msg, value)) { - out->print_cr("%s", err_msg.buffer()); - return JNI_ERR; - } - } - bool res = CommandLineFlags::uintxAtPut((char*)name, &value, Flag::ATTACH_ON_DEMAND); - if (! res) { - out->print_cr("setting flag %s failed", name); - } - - return res? JNI_OK : JNI_ERR; -} - -// set a uint64_t global flag using value from AttachOperation -static jint set_uint64_t_flag(const char* name, AttachOperation* op, outputStream* out) { - uint64_t value; - const char* arg1; - if ((arg1 = op->arg(1)) != NULL) { - int n = sscanf(arg1, UINT64_FORMAT, &value); - if (n != 1) { - out->print_cr("flag value must be an unsigned 64-bit integer"); - return JNI_ERR; - } - } - bool res = CommandLineFlags::uint64_tAtPut((char*)name, &value, Flag::ATTACH_ON_DEMAND); - if (! res) { - out->print_cr("setting flag %s failed", name); - } - - return res? JNI_OK : JNI_ERR; -} - -// set a size_t global flag using value from AttachOperation -static jint set_size_t_flag(const char* name, AttachOperation* op, outputStream* out) { - size_t value; - const char* arg1; - if ((arg1 = op->arg(1)) != NULL) { - int n = sscanf(arg1, SIZE_FORMAT, &value); - if (n != 1) { - out->print_cr("flag value must be an unsigned integer"); - return JNI_ERR; - } - } - bool res = CommandLineFlags::size_tAtPut((char*)name, &value, Flag::ATTACH_ON_DEMAND); - if (! res) { - out->print_cr("setting flag %s failed", name); - } - - return res? JNI_OK : JNI_ERR; -} - -// set a string global flag using value from AttachOperation -static jint set_ccstr_flag(const char* name, AttachOperation* op, outputStream* out) { - const char* value; - if ((value = op->arg(1)) == NULL) { - out->print_cr("flag value must be a string"); - return JNI_ERR; - } - bool res = CommandLineFlags::ccstrAtPut((char*)name, &value, Flag::ATTACH_ON_DEMAND); - if (res) { - FREE_C_HEAP_ARRAY(char, value); - } else { - out->print_cr("setting flag %s failed", name); - } - - return res? JNI_OK : JNI_ERR; -} - // Implementation of "setflag" command static jint set_flag(AttachOperation* op, outputStream* out) { @@ -365,27 +239,21 @@ static jint set_flag(AttachOperation* op, outputStream* out) { return JNI_ERR; } - Flag* f = Flag::find_flag((char*)name, strlen(name)); - if (f && f->is_external() && f->is_writeable()) { - if (f->is_bool()) { - return set_bool_flag(name, op, out); - } else if (f->is_intx()) { - return set_intx_flag(name, op, out); - } else if (f->is_uintx()) { - return set_uintx_flag(name, op, out); - } else if (f->is_uint64_t()) { - return set_uint64_t_flag(name, op, out); - } else if (f->is_size_t()) { - return set_size_t_flag(name, op, out); - } else if (f->is_ccstr()) { - return set_ccstr_flag(name, op, out); + FormatBuffer<80> err_msg("%s", ""); + + int ret = WriteableFlags::set_flag(op->arg(0), op->arg(1), Flag::ATTACH_ON_DEMAND, err_msg); + if (ret != WriteableFlags::SUCCESS) { + if (ret == WriteableFlags::NON_WRITABLE) { + // if the flag is not manageable try to change it through + // the platform dependent implementation + return AttachListener::pd_set_flag(op, out); } else { - ShouldNotReachHere(); - return JNI_ERR; + out->print_cr("%s", err_msg.buffer()); } - } else { - return AttachListener::pd_set_flag(op, out); + + return JNI_ERR; } + return JNI_OK; } // Implementation of "printflag" command diff --git a/hotspot/src/share/vm/services/management.cpp b/hotspot/src/share/vm/services/management.cpp index c5127a889da..81bf6e15ff9 100644 --- a/hotspot/src/share/vm/services/management.cpp +++ b/hotspot/src/share/vm/services/management.cpp @@ -1,5 +1,5 @@ /* - * Copyright (c) 2003, 2014, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2003, 2015, 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 @@ -43,6 +43,7 @@ #include "services/classLoadingService.hpp" #include "services/diagnosticCommand.hpp" #include "services/diagnosticFramework.hpp" +#include "services/writeableFlags.hpp" #include "services/heapDumper.hpp" #include "services/jmm.h" #include "services/lowMemoryDetector.hpp" @@ -1698,56 +1699,21 @@ JVM_ENTRY(void, jmm_SetVMGlobal(JNIEnv *env, jstring flag_name, jvalue new_value "The flag name cannot be null."); } char* name = java_lang_String::as_utf8_string(fn); - Flag* flag = Flag::find_flag(name, strlen(name)); - if (flag == NULL) { - THROW_MSG(vmSymbols::java_lang_IllegalArgumentException(), - "Flag does not exist."); - } - if (!flag->is_writeable()) { - THROW_MSG(vmSymbols::java_lang_IllegalArgumentException(), - "This flag is not writeable."); - } - bool succeed = false; - if (flag->is_bool()) { - bool bvalue = (new_value.z == JNI_TRUE ? true : false); - succeed = CommandLineFlags::boolAtPut(name, &bvalue, Flag::MANAGEMENT); - } else if (flag->is_intx()) { - intx ivalue = (intx)new_value.j; - succeed = CommandLineFlags::intxAtPut(name, &ivalue, Flag::MANAGEMENT); - } else if (flag->is_uintx()) { - uintx uvalue = (uintx)new_value.j; + FormatBuffer<80> err_msg("%s", ""); + int succeed = WriteableFlags::set_flag(name, new_value, Flag::MANAGEMENT, err_msg); - if (strncmp(name, "MaxHeapFreeRatio", 17) == 0) { - FormatBuffer<80> err_msg("%s", ""); - if (!Arguments::verify_MaxHeapFreeRatio(err_msg, uvalue)) { - THROW_MSG(vmSymbols::java_lang_IllegalArgumentException(), err_msg.buffer()); - } - } else if (strncmp(name, "MinHeapFreeRatio", 17) == 0) { - FormatBuffer<80> err_msg("%s", ""); - if (!Arguments::verify_MinHeapFreeRatio(err_msg, uvalue)) { - THROW_MSG(vmSymbols::java_lang_IllegalArgumentException(), err_msg.buffer()); - } - } - succeed = CommandLineFlags::uintxAtPut(name, &uvalue, Flag::MANAGEMENT); - } else if (flag->is_uint64_t()) { - uint64_t uvalue = (uint64_t)new_value.j; - succeed = CommandLineFlags::uint64_tAtPut(name, &uvalue, Flag::MANAGEMENT); - } else if (flag->is_size_t()) { - size_t svalue = (size_t)new_value.j; - succeed = CommandLineFlags::size_tAtPut(name, &svalue, Flag::MANAGEMENT); - } else if (flag->is_ccstr()) { - oop str = JNIHandles::resolve_external_guard(new_value.l); - if (str == NULL) { + if (succeed != WriteableFlags::SUCCESS) { + if (succeed == WriteableFlags::MISSING_VALUE) { + // missing value causes NPE to be thrown THROW(vmSymbols::java_lang_NullPointerException()); - } - ccstr svalue = java_lang_String::as_utf8_string(str); - succeed = CommandLineFlags::ccstrAtPut(name, &svalue, Flag::MANAGEMENT); - if (succeed) { - FREE_C_HEAP_ARRAY(char, svalue); + } else { + // all the other errors are reported as IAE with the appropriate error message + THROW_MSG(vmSymbols::java_lang_IllegalArgumentException(), + err_msg.buffer()); } } - assert(succeed, "Setting flag should succeed"); + assert(succeed == WriteableFlags::SUCCESS, "Setting flag should succeed"); JVM_END class ThreadTimesClosure: public ThreadClosure { diff --git a/hotspot/src/share/vm/services/writeableFlags.cpp b/hotspot/src/share/vm/services/writeableFlags.cpp new file mode 100644 index 00000000000..d674a0081b3 --- /dev/null +++ b/hotspot/src/share/vm/services/writeableFlags.cpp @@ -0,0 +1,226 @@ +/* + * Copyright (c) 2015, 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. + * + */ + +#include "precompiled.hpp" +#include "classfile/javaClasses.hpp" +#include "runtime/arguments.hpp" +#include "runtime/java.hpp" +#include "runtime/jniHandles.hpp" +#include "services/writeableFlags.hpp" + +// set a boolean global flag +int WriteableFlags::set_bool_flag(const char* name, const char* arg, Flag::Flags origin, FormatBuffer<80>& err_msg) { + int value = true; + + if (sscanf(arg, "%d", &value)) { + return set_bool_flag(name, value != 0, origin, err_msg); + } + err_msg.print("flag value must be a boolean (1 or 0)"); + return WRONG_FORMAT; +} + +int WriteableFlags::set_bool_flag(const char* name, bool value, Flag::Flags origin, FormatBuffer<80>& err_msg) { + return CommandLineFlags::boolAtPut((char*)name, &value, origin) ? SUCCESS : ERR_OTHER; +} + +// set a intx global flag +int WriteableFlags::set_intx_flag(const char* name, const char* arg, Flag::Flags origin, FormatBuffer<80>& err_msg) { + intx value; + + if (sscanf(arg, INTX_FORMAT, &value)) { + return set_intx_flag(name, value, origin, err_msg); + } + err_msg.print("flag value must be an integer"); + return WRONG_FORMAT; +} + +int WriteableFlags::set_intx_flag(const char* name, intx value, Flag::Flags origin, FormatBuffer<80>& err_msg) { + return CommandLineFlags::intxAtPut((char*)name, &value, origin) ? SUCCESS : ERR_OTHER; +} + +// set a uintx global flag +int WriteableFlags::set_uintx_flag(const char* name, const char* arg, Flag::Flags origin, FormatBuffer<80>& err_msg) { + uintx value; + + if (sscanf(arg, UINTX_FORMAT, &value)) { + return set_uintx_flag(name, value, origin, err_msg); + } + err_msg.print("flag value must be an unsigned integer"); + return WRONG_FORMAT; +} + +int WriteableFlags::set_uintx_flag(const char* name, uintx value, Flag::Flags origin, FormatBuffer<80>& err_msg) { + if (strncmp(name, "MaxHeapFreeRatio", 17) == 0) { + if (!Arguments::verify_MaxHeapFreeRatio(err_msg, value)) { + return OUT_OF_BOUNDS; + } + } else if (strncmp(name, "MinHeapFreeRatio", 17) == 0) { + if (!Arguments::verify_MinHeapFreeRatio(err_msg, value)) { + return OUT_OF_BOUNDS; + } + } + return CommandLineFlags::uintxAtPut((char*)name, &value, origin) ? SUCCESS : ERR_OTHER; +} + +// set a uint64_t global flag +int WriteableFlags::set_uint64_t_flag(const char* name, const char* arg, Flag::Flags origin, FormatBuffer<80>& err_msg) { + uint64_t value; + + if (sscanf(arg, UINT64_FORMAT, &value)) { + return set_uint64_t_flag(name, value, origin, err_msg); + } + err_msg.print("flag value must be an unsigned 64-bit integer"); + return WRONG_FORMAT; +} + +int WriteableFlags::set_uint64_t_flag(const char* name, uint64_t value, Flag::Flags origin, FormatBuffer<80>& err_msg) { + return CommandLineFlags::uint64_tAtPut((char*)name, &value, origin) ? SUCCESS : ERR_OTHER; +} + +// set a size_t global flag +int WriteableFlags::set_size_t_flag(const char* name, const char* arg, Flag::Flags origin, FormatBuffer<80>& err_msg) { + size_t value; + + if (sscanf(arg, SIZE_FORMAT, &value)) { + return set_size_t_flag(name, value, origin, err_msg); + } + err_msg.print("flag value must be an unsigned integer"); + return WRONG_FORMAT; +} + +int WriteableFlags::set_size_t_flag(const char* name, size_t value, Flag::Flags origin, FormatBuffer<80>& err_msg) { + return CommandLineFlags::size_tAtPut((char*)name, &value, origin) ? SUCCESS : ERR_OTHER; +} + +// set a string global flag using value from AttachOperation +int WriteableFlags::set_ccstr_flag(const char* name, const char* arg, Flag::Flags origin, FormatBuffer<80>& err_msg) { + bool res = CommandLineFlags::ccstrAtPut((char*)name, &arg, origin); + + return res? SUCCESS : ERR_OTHER; +} + +/* sets a writeable flag to the provided value + * + * - return status is one of the WriteableFlags::err enum values + * - an eventual error message will be generated to the provided err_msg buffer + */ +int WriteableFlags::set_flag(const char* flag_name, const char* flag_value, Flag::Flags origin, FormatBuffer<80>& err_msg) { + return set_flag(flag_name, &flag_value, set_flag_from_char, origin, err_msg); +} + +/* sets a writeable flag to the provided value + * + * - return status is one of the WriteableFlags::err enum values + * - an eventual error message will be generated to the provided err_msg buffer + */ +int WriteableFlags::set_flag(const char* flag_name, jvalue flag_value, Flag::Flags origin, FormatBuffer<80>& err_msg) { + return set_flag(flag_name, &flag_value, set_flag_from_jvalue, origin, err_msg); +} + +// a writeable flag setter accepting either 'jvalue' or 'char *' values +int WriteableFlags::set_flag(const char* name, const void* value, int(*setter)(Flag*,const void*,Flag::Flags,FormatBuffer<80>&), Flag::Flags origin, FormatBuffer<80>& err_msg) { + if (name == NULL) { + err_msg.print("flag name is missing"); + return MISSING_NAME; + } + if (value == NULL) { + err_msg.print("flag value is missing"); + return MISSING_VALUE; + } + + Flag* f = Flag::find_flag((char*)name, strlen(name)); + if (f) { + // only writeable flags are allowed to be set + if (f->is_writeable()) { + return setter(f, value, origin, err_msg); + } else { + err_msg.print("only 'writeable' flags can be set"); + return NON_WRITABLE; + } + } + + err_msg.print("flag %s does not exist", name); + return INVALID_FLAG; +} + +// a writeable flag setter accepting 'char *' values +int WriteableFlags::set_flag_from_char(Flag* f, const void* value, Flag::Flags origin, FormatBuffer<80>& err_msg) { + char* flag_value = *(char**)value; + if (flag_value == NULL) { + err_msg.print("flag value is missing"); + return MISSING_VALUE; + } + if (f->is_bool()) { + return set_bool_flag(f->_name, flag_value, origin, err_msg); + } else if (f->is_intx()) { + return set_intx_flag(f->_name, flag_value, origin, err_msg); + } else if (f->is_uintx()) { + return set_uintx_flag(f->_name, flag_value, origin, err_msg); + } else if (f->is_uint64_t()) { + return set_uint64_t_flag(f->_name, flag_value, origin, err_msg); + } else if (f->is_size_t()) { + return set_size_t_flag(f->_name, flag_value, origin, err_msg); + } else if (f->is_ccstr()) { + return set_ccstr_flag(f->_name, flag_value, origin, err_msg); + } else { + ShouldNotReachHere(); + } + return ERR_OTHER; +} + +// a writeable flag setter accepting 'jvalue' values +int WriteableFlags::set_flag_from_jvalue(Flag* f, const void* value, Flag::Flags origin, FormatBuffer<80>& err_msg) { + jvalue new_value = *(jvalue*)value; + if (f->is_bool()) { + bool bvalue = (new_value.z == JNI_TRUE ? true : false); + return set_bool_flag(f->_name, bvalue, origin, err_msg); + } else if (f->is_intx()) { + intx ivalue = (intx)new_value.j; + return set_intx_flag(f->_name, ivalue, origin, err_msg); + } else if (f->is_uintx()) { + uintx uvalue = (uintx)new_value.j; + return set_uintx_flag(f->_name, uvalue, origin, err_msg); + } else if (f->is_uint64_t()) { + uint64_t uvalue = (uint64_t)new_value.j; + return set_uint64_t_flag(f->_name, uvalue, origin, err_msg); + } else if (f->is_size_t()) { + size_t svalue = (size_t)new_value.j; + return set_size_t_flag(f->_name, svalue, origin, err_msg); + } else if (f->is_ccstr()) { + oop str = JNIHandles::resolve_external_guard(new_value.l); + if (str == NULL) { + err_msg.print("flag value is missing"); + return MISSING_VALUE; + } + ccstr svalue = java_lang_String::as_utf8_string(str); + int ret = WriteableFlags::set_ccstr_flag(f->_name, svalue, origin, err_msg); + if (ret != SUCCESS) { + FREE_C_HEAP_ARRAY(char, svalue); + } + return ret; + } else { + ShouldNotReachHere(); + } + return ERR_OTHER; +} \ No newline at end of file diff --git a/hotspot/src/share/vm/services/writeableFlags.hpp b/hotspot/src/share/vm/services/writeableFlags.hpp new file mode 100644 index 00000000000..eb38c6431da --- /dev/null +++ b/hotspot/src/share/vm/services/writeableFlags.hpp @@ -0,0 +1,97 @@ +/* + * Copyright (c) 2015, 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. + * + */ + +#ifndef SHARE_VM_SERVICES_WRITEABLEFLAG_HPP +#define SHARE_VM_SERVICES_WRITEABLEFLAG_HPP + +class WriteableFlags : AllStatic { +public: + enum error { + // no error + SUCCESS, + // flag name is missing + MISSING_NAME, + // flag value is missing + MISSING_VALUE, + // error parsing the textual form of the value + WRONG_FORMAT, + // flag is not writeable + NON_WRITABLE, + // flag value is outside of its bounds + OUT_OF_BOUNDS, + // there is no flag with the given name + INVALID_FLAG, + // other, unspecified error related to setting the flag + ERR_OTHER + } err; + +private: + // a writeable flag setter accepting either 'jvalue' or 'char *' values + static int set_flag(const char* name, const void* value, int(*setter)(Flag*, const void*, Flag::Flags, FormatBuffer<80>&), Flag::Flags origin, FormatBuffer<80>& err_msg); + // a writeable flag setter accepting 'char *' values + static int set_flag_from_char(Flag* f, const void* value, Flag::Flags origin, FormatBuffer<80>& err_msg); + // a writeable flag setter accepting 'jvalue' values + static int set_flag_from_jvalue(Flag* f, const void* value, Flag::Flags origin, FormatBuffer<80>& err_msg); + + // set a boolean global flag + static int set_bool_flag(const char* name, const char* value, Flag::Flags origin, FormatBuffer<80>& err_msg); + // set a intx global flag + static int set_intx_flag(const char* name, const char* value, Flag::Flags origin, FormatBuffer<80>& err_msg); + // set a uintx global flag + static int set_uintx_flag(const char* name, const char* value, Flag::Flags origin, FormatBuffer<80>& err_msg); + // set a uint64_t global flag + static int set_uint64_t_flag(const char* name, const char* value, Flag::Flags origin, FormatBuffer<80>& err_msg); + // set a size_t global flag using value from AttachOperation + static int set_size_t_flag(const char* name, const char* value, Flag::Flags origin, FormatBuffer<80>& err_msg); + // set a boolean global flag + static int set_bool_flag(const char* name, bool value, Flag::Flags origin, FormatBuffer<80>& err_msg); + // set a intx global flag + static int set_intx_flag(const char* name, intx value, Flag::Flags origin, FormatBuffer<80>& err_msg); + // set a uintx global flag + static int set_uintx_flag(const char* name, uintx value, Flag::Flags origin, FormatBuffer<80>& err_msg); + // set a uint64_t global flag + static int set_uint64_t_flag(const char* name, uint64_t value, Flag::Flags origin, FormatBuffer<80>& err_msg); + // set a size_t global flag using value from AttachOperation + static int set_size_t_flag(const char* name, size_t value, Flag::Flags origin, FormatBuffer<80>& err_msg); + // set a string global flag + static int set_ccstr_flag(const char* name, const char* value, Flag::Flags origin, FormatBuffer<80>& err_msg); + +public: + /* sets a writeable flag to the provided value + * + * - return status is one of the WriteableFlags::err enum values + * - an eventual error message will be generated to the provided err_msg buffer + */ + static int set_flag(const char* flag_name, const char* flag_value, Flag::Flags origin, FormatBuffer<80>& err_msg); + + /* sets a writeable flag to the provided value + * + * - return status is one of the WriteableFlags::err enum values + * - an eventual error message will be generated to the provided err_msg buffer + */ + static int set_flag(const char* flag_name, jvalue flag_value, Flag::Flags origin, FormatBuffer<80>& err_msg); +}; + +#endif /* SHARE_VM_SERVICES_WRITEABLEFLAG_HPP */ + From 59c9d50129c98c92202ad7c7ec8c61dea1d26d95 Mon Sep 17 00:00:00 2001 From: Jaroslav Bachorik Date: Thu, 11 Dec 2014 10:47:36 +0100 Subject: [PATCH 008/116] 8062303: Remove com.sun.tracing API Reviewed-by: sla, alanb, mchung, dholmes --- jdk/make/lib/Lib-jdk.runtime.gmk | 34 -- .../share/classes/com/sun/tracing/Probe.java | 71 ---- .../classes/com/sun/tracing/ProbeName.java | 48 --- .../classes/com/sun/tracing/Provider.java | 76 ---- .../com/sun/tracing/ProviderFactory.java | 114 ------ .../classes/com/sun/tracing/ProviderName.java | 48 --- .../sun/tracing/dtrace/ArgsAttributes.java | 53 --- .../com/sun/tracing/dtrace/Attributes.java | 66 ---- .../sun/tracing/dtrace/DependencyClass.java | 77 ---- .../tracing/dtrace/FunctionAttributes.java | 51 --- .../com/sun/tracing/dtrace/FunctionName.java | 47 --- .../sun/tracing/dtrace/ModuleAttributes.java | 51 --- .../com/sun/tracing/dtrace/ModuleName.java | 47 --- .../sun/tracing/dtrace/NameAttributes.java | 51 --- .../tracing/dtrace/ProviderAttributes.java | 51 --- .../sun/tracing/dtrace/StabilityLevel.java | 88 ----- .../com/sun/tracing/dtrace/package-info.java | 82 ----- .../classes/com/sun/tracing/package-info.java | 183 ---------- .../sun/tracing/MultiplexProviderFactory.java | 137 ------- .../sun/tracing/NullProviderFactory.java | 84 ----- .../tracing/PrintStreamProviderFactory.java | 120 ------- .../classes/sun/tracing/ProbeSkeleton.java | 90 ----- .../classes/sun/tracing/ProviderSkeleton.java | 273 -------------- .../sun/tracing/dtrace/Activation.java | 107 ------ .../sun/tracing/dtrace/DTraceProbe.java | 82 ----- .../sun/tracing/dtrace/DTraceProvider.java | 210 ----------- .../tracing/dtrace/DTraceProviderFactory.java | 156 -------- .../share/classes/sun/tracing/dtrace/JVM.java | 75 ---- .../classes/sun/tracing/package-info.java | 57 --- .../jdk.runtime/share/native/libjsdt/JVM.c | 334 ------------------ .../share/native/libjsdt/jvm_symbols.h | 50 --- .../unix/native/libjsdt/jvm_symbols_md.c | 55 --- .../windows/native/libjsdt/jvm_symbols_md.c | 64 ---- jdk/test/ProblemList.txt | 3 - jdk/test/TEST.groups | 2 - .../com/sun/tracing/BasicFunctionality.java | 147 -------- .../com/sun/tracing/BasicWithSecurityMgr.java | 149 -------- 37 files changed, 3433 deletions(-) delete mode 100644 jdk/src/jdk.runtime/share/classes/com/sun/tracing/Probe.java delete mode 100644 jdk/src/jdk.runtime/share/classes/com/sun/tracing/ProbeName.java delete mode 100644 jdk/src/jdk.runtime/share/classes/com/sun/tracing/Provider.java delete mode 100644 jdk/src/jdk.runtime/share/classes/com/sun/tracing/ProviderFactory.java delete mode 100644 jdk/src/jdk.runtime/share/classes/com/sun/tracing/ProviderName.java delete mode 100644 jdk/src/jdk.runtime/share/classes/com/sun/tracing/dtrace/ArgsAttributes.java delete mode 100644 jdk/src/jdk.runtime/share/classes/com/sun/tracing/dtrace/Attributes.java delete mode 100644 jdk/src/jdk.runtime/share/classes/com/sun/tracing/dtrace/DependencyClass.java delete mode 100644 jdk/src/jdk.runtime/share/classes/com/sun/tracing/dtrace/FunctionAttributes.java delete mode 100644 jdk/src/jdk.runtime/share/classes/com/sun/tracing/dtrace/FunctionName.java delete mode 100644 jdk/src/jdk.runtime/share/classes/com/sun/tracing/dtrace/ModuleAttributes.java delete mode 100644 jdk/src/jdk.runtime/share/classes/com/sun/tracing/dtrace/ModuleName.java delete mode 100644 jdk/src/jdk.runtime/share/classes/com/sun/tracing/dtrace/NameAttributes.java delete mode 100644 jdk/src/jdk.runtime/share/classes/com/sun/tracing/dtrace/ProviderAttributes.java delete mode 100644 jdk/src/jdk.runtime/share/classes/com/sun/tracing/dtrace/StabilityLevel.java delete mode 100644 jdk/src/jdk.runtime/share/classes/com/sun/tracing/dtrace/package-info.java delete mode 100644 jdk/src/jdk.runtime/share/classes/com/sun/tracing/package-info.java delete mode 100644 jdk/src/jdk.runtime/share/classes/sun/tracing/MultiplexProviderFactory.java delete mode 100644 jdk/src/jdk.runtime/share/classes/sun/tracing/NullProviderFactory.java delete mode 100644 jdk/src/jdk.runtime/share/classes/sun/tracing/PrintStreamProviderFactory.java delete mode 100644 jdk/src/jdk.runtime/share/classes/sun/tracing/ProbeSkeleton.java delete mode 100644 jdk/src/jdk.runtime/share/classes/sun/tracing/ProviderSkeleton.java delete mode 100644 jdk/src/jdk.runtime/share/classes/sun/tracing/dtrace/Activation.java delete mode 100644 jdk/src/jdk.runtime/share/classes/sun/tracing/dtrace/DTraceProbe.java delete mode 100644 jdk/src/jdk.runtime/share/classes/sun/tracing/dtrace/DTraceProvider.java delete mode 100644 jdk/src/jdk.runtime/share/classes/sun/tracing/dtrace/DTraceProviderFactory.java delete mode 100644 jdk/src/jdk.runtime/share/classes/sun/tracing/dtrace/JVM.java delete mode 100644 jdk/src/jdk.runtime/share/classes/sun/tracing/package-info.java delete mode 100644 jdk/src/jdk.runtime/share/native/libjsdt/JVM.c delete mode 100644 jdk/src/jdk.runtime/share/native/libjsdt/jvm_symbols.h delete mode 100644 jdk/src/jdk.runtime/unix/native/libjsdt/jvm_symbols_md.c delete mode 100644 jdk/src/jdk.runtime/windows/native/libjsdt/jvm_symbols_md.c delete mode 100644 jdk/test/com/sun/tracing/BasicFunctionality.java delete mode 100644 jdk/test/com/sun/tracing/BasicWithSecurityMgr.java diff --git a/jdk/make/lib/Lib-jdk.runtime.gmk b/jdk/make/lib/Lib-jdk.runtime.gmk index 927db9bf334..4bf9b026cc1 100644 --- a/jdk/make/lib/Lib-jdk.runtime.gmk +++ b/jdk/make/lib/Lib-jdk.runtime.gmk @@ -59,37 +59,3 @@ $(BUILD_LIBUNPACK): $(call FindLib, java.base, java) TARGETS += $(BUILD_LIBUNPACK) ################################################################################ - -LIBJSDT_SRC := $(JDK_TOPDIR)/src/jdk.runtime/share/native/libjsdt \ - $(JDK_TOPDIR)/src/jdk.runtime/$(OPENJDK_TARGET_OS_TYPE)/native/libjsdt - -$(eval $(call SetupNativeCompilation,BUILD_LIBJSDT, \ - LIBRARY := jsdt, \ - OUTPUT_DIR := $(INSTALL_LIBRARIES_HERE), \ - SRC := $(LIBJSDT_SRC), \ - LANG := C, \ - OPTIMIZATION := LOW, \ - CFLAGS := $(CFLAGS_JDKLIB) $(CFLAGS_WARNINGS_ARE_ERRORS) \ - $(addprefix -I, $(LIBJSDT_SRC)) \ - $(LIBJAVA_HEADER_FLAGS) \ - -I$(SUPPORT_OUTPUTDIR)/headers/jdk.runtime, \ - MAPFILE := $(JDK_TOPDIR)/make/mapfiles/libjsdt/mapfile-vers, \ - LDFLAGS := $(LDFLAGS_JDKLIB) \ - $(call SET_SHARED_LIBRARY_ORIGIN), \ - LDFLAGS_SUFFIX_linux := $(LIBDL), \ - LDFLAGS_SUFFIX_windows := $(LDFLAGS_JDKLIB_SUFFIX) $(LIBDL), \ - LDFLAGS_SUFFIX_macosx := $(LIBDL), \ - LDFLAGS_SUFFIX_solaris := -lc, \ - VERSIONINFO_RESOURCE := $(GLOBAL_VERSION_INFO_RESOURCE), \ - RC_FLAGS := $(RC_FLAGS) \ - -D "JDK_FNAME=jsdt.dll" \ - -D "JDK_INTERNAL_NAME=jsdt" \ - -D "JDK_FTYPE=0x2L", \ - OBJECT_DIR := $(SUPPORT_OUTPUTDIR)/native/$(MODULE)/libjsdt, \ - DEBUG_SYMBOLS := true)) - -$(BUILD_LIBJSDT): $(call FindLib, java.base, java) - -TARGETS += $(BUILD_LIBJSDT) - -################################################################################ diff --git a/jdk/src/jdk.runtime/share/classes/com/sun/tracing/Probe.java b/jdk/src/jdk.runtime/share/classes/com/sun/tracing/Probe.java deleted file mode 100644 index d5c51b5175f..00000000000 --- a/jdk/src/jdk.runtime/share/classes/com/sun/tracing/Probe.java +++ /dev/null @@ -1,71 +0,0 @@ -/* - * Copyright (c) 2008, 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. Oracle designates this - * particular file as subject to the "Classpath" exception as provided - * by Oracle in the LICENSE file that accompanied this code. - * - * 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. - */ - -package com.sun.tracing; - -/** - * The {@code Probe} interface represents a tracepoint. - * - * A {@code Probe} instance is obtained by calling the - * {@code Provider.getProbe()} method of a provider instance created by - * {@code ProviderFactory.createProvider()}. A {@code Probe} can be used to - * trigger a probe manually (provided the correct arguments are passed to - * it), or to check a probe to see if anything is currently tracing it. - *

- * A tracing check can be used to avoid lengthy work that might be - * needed to set up the probe's arguments. However, checking - * whether the probe is enabled generally takes the same amount of time - * as actually triggering the probe. So, you should only check a probe's status - * without triggering it if setting up the arguments is very expensive. - *

- * Users do not need to implement this interface: instances are - * created automatically by the system when a {@code Provider)} instance is - * created. - *

- * @since 1.7 - */ - -public interface Probe { - /** - * Checks whether there is an active trace of this probe. - * - * @return true if an active trace is detected. - */ - boolean isEnabled(); - - /** - * Determines whether a tracepoint is enabled. - * - * Typically, users do not need to use this method. It is called - * automatically when a Provider's instance method is called. Calls to - * this method expect the arguments to match the declared parameters for - * the method associated with the probe. - * - * @param args the parameters to pass to the method. - * @throws IllegalArgumentException if the provided parameters do not - * match the method declaration for this probe. - */ - void trigger(Object ... args); -} diff --git a/jdk/src/jdk.runtime/share/classes/com/sun/tracing/ProbeName.java b/jdk/src/jdk.runtime/share/classes/com/sun/tracing/ProbeName.java deleted file mode 100644 index e9a4fa57570..00000000000 --- a/jdk/src/jdk.runtime/share/classes/com/sun/tracing/ProbeName.java +++ /dev/null @@ -1,48 +0,0 @@ -/* - * Copyright (c) 2008, 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. Oracle designates this - * particular file as subject to the "Classpath" exception as provided - * by Oracle in the LICENSE file that accompanied this code. - * - * 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. - */ - -package com.sun.tracing; - -import java.lang.annotation.Target; -import java.lang.annotation.Retention; -import java.lang.annotation.RetentionPolicy; -import java.lang.annotation.ElementType; - -/** - * An annotation used to override the name of a probe. - *

- * This annotation can be added to a method in a user-defined {@code Provider} - * interface, to set the name that will be used for the generated probe - * associated with that method. Without this annotation, the name will be the - * name of the method. - *

- * @since 1.7 - */ -@Retention(RetentionPolicy.RUNTIME) -@Target(ElementType.METHOD) -public @interface ProbeName { - String value(); -} - diff --git a/jdk/src/jdk.runtime/share/classes/com/sun/tracing/Provider.java b/jdk/src/jdk.runtime/share/classes/com/sun/tracing/Provider.java deleted file mode 100644 index bf035690cfc..00000000000 --- a/jdk/src/jdk.runtime/share/classes/com/sun/tracing/Provider.java +++ /dev/null @@ -1,76 +0,0 @@ -/* - * Copyright (c) 2008, 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. Oracle designates this - * particular file as subject to the "Classpath" exception as provided - * by Oracle in the LICENSE file that accompanied this code. - * - * 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. - */ - -package com.sun.tracing; - -/** - * {@code Provider} is a superinterface for user-defined tracing providers. - *

- * To define tracepoints, users must extend this interface - * and then use a {@code ProviderFactory} to create an instance of the - * newly-defined interface. Each method in the defined interface represents a - * tracepoint (or probe), which can be triggered by calling the associated - * method on the returned instance. - *

- * This interface also contains a {@code getProbe()} method, which can be - * used to get direct handles to the {@code Probe} objects themselves. - * {@code Probe} objects can be triggered manually, or they can be queried to - * check their state. - *

- * When an application has finished triggering probes, it should call - * {@code dispose()} to free up any system resources associated with the - * Provider. - *

- * All methods declared in a subclass of this interface should have a - * {@code void} return type. Methods can have parameters, and when called the - * values of the arguments will be passed to the tracing implementation. - * If any methods do not have a {@code void} return type, an - * {@code java.lang.IllegalArgumentException} will be thrown when the - * provider is registered. - * @since 1.7 - */ - -public interface Provider { - /** - * Retrieves a reference to a Probe object, which is used to check status - * or to trigger the probe manually. - * - * If the provided method parameter is not a method of the provider - * interface, or if the provider interface has been disposed, then - * this returns null - * - * @param method a method declared in the provider. - * @return the specified probe represented by that method, or null. - */ - Probe getProbe(java.lang.reflect.Method method); - - /** - * Disposes system resources associated with this provider. - * - * After calling this method, triggering the probes will have no effect. - * Additional calls to this method after the first call are ignored. - */ - void dispose(); -} diff --git a/jdk/src/jdk.runtime/share/classes/com/sun/tracing/ProviderFactory.java b/jdk/src/jdk.runtime/share/classes/com/sun/tracing/ProviderFactory.java deleted file mode 100644 index dabc1dd22f8..00000000000 --- a/jdk/src/jdk.runtime/share/classes/com/sun/tracing/ProviderFactory.java +++ /dev/null @@ -1,114 +0,0 @@ - -package com.sun.tracing; - -import java.util.HashSet; -import java.io.PrintStream; -import java.lang.reflect.Field; -import java.security.AccessController; -import java.security.PrivilegedAction; -import java.security.PrivilegedActionException; -import java.security.PrivilegedExceptionAction; - -import sun.tracing.NullProviderFactory; -import sun.tracing.PrintStreamProviderFactory; -import sun.tracing.MultiplexProviderFactory; -import sun.tracing.dtrace.DTraceProviderFactory; - -/** - * {@code ProviderFactory} is a factory class used to create instances of - * providers. - * - * To enable tracing in an application, this class must be used to create - * instances of the provider interfaces defined by users. - * The system-defined factory is obtained by using the - * {@code getDefaultFactory()} static method. The resulting instance can be - * used to create any number of providers. - * - * @since 1.7 - */ -public abstract class ProviderFactory { - - protected ProviderFactory() {} - - /** - * Creates an implementation of a Provider interface. - * - * @param cls the provider interface to be defined. - * @return an implementation of {@code cls}, whose methods, when called, - * will trigger tracepoints in the application. - * @throws NullPointerException if cls is null - * @throws IllegalArgumentException if the class definition contains - * non-void methods - */ - public abstract T createProvider(Class cls); - - /** - * Returns an implementation of a {@code ProviderFactory} which - * creates instances of Providers. - * - * The created Provider instances will be linked to all appropriate - * and enabled system-defined tracing mechanisms in the JDK. - * - * @return a {@code ProviderFactory} that is used to create Providers. - */ - public static ProviderFactory getDefaultFactory() { - HashSet factories = new HashSet(); - - // Try to instantiate a DTraceProviderFactory - String prop = AccessController.doPrivileged( - (PrivilegedAction) () -> System.getProperty("com.sun.tracing.dtrace")); - - if ( (prop == null || !prop.equals("disable")) && - DTraceProviderFactory.isSupported() ) { - factories.add(new DTraceProviderFactory()); - } - - // Try to instantiate an output stream factory - prop = AccessController.doPrivileged( - (PrivilegedAction) () -> System.getProperty("sun.tracing.stream")); - if (prop != null) { - for (String spec : prop.split(",")) { - PrintStream ps = getPrintStreamFromSpec(spec); - if (ps != null) { - factories.add(new PrintStreamProviderFactory(ps)); - } - } - } - - // See how many factories we instantiated, and return an appropriate - // factory that encapsulates that. - if (factories.size() == 0) { - return new NullProviderFactory(); - } else if (factories.size() == 1) { - return factories.toArray(new ProviderFactory[1])[0]; - } else { - return new MultiplexProviderFactory(factories); - } - } - - private static PrintStream getPrintStreamFromSpec(final String spec) { - try { - // spec is in the form of ., where is - // a fully specified class name, and is a static member - // in that class. The must be a 'PrintStream' or subtype - // in order to be used. - final int fieldpos = spec.lastIndexOf('.'); - final Class cls = Class.forName(spec.substring(0, fieldpos)); - - Field f = AccessController.doPrivileged(new PrivilegedExceptionAction() { - public Field run() throws NoSuchFieldException { - return cls.getField(spec.substring(fieldpos + 1)); - } - }); - - return (PrintStream)f.get(null); - } catch (ClassNotFoundException e) { - throw new AssertionError(e); - } catch (IllegalAccessException e) { - throw new AssertionError(e); - } catch (PrivilegedActionException e) { - throw new AssertionError(e); - } - } -} - diff --git a/jdk/src/jdk.runtime/share/classes/com/sun/tracing/ProviderName.java b/jdk/src/jdk.runtime/share/classes/com/sun/tracing/ProviderName.java deleted file mode 100644 index 3941c76edc0..00000000000 --- a/jdk/src/jdk.runtime/share/classes/com/sun/tracing/ProviderName.java +++ /dev/null @@ -1,48 +0,0 @@ -/* - * Copyright (c) 2008, 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. Oracle designates this - * particular file as subject to the "Classpath" exception as provided - * by Oracle in the LICENSE file that accompanied this code. - * - * 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. - */ - -package com.sun.tracing; - -import java.lang.annotation.Target; -import java.lang.annotation.Retention; -import java.lang.annotation.RetentionPolicy; -import java.lang.annotation.ElementType; - -/** - * An annotation used to specify the name of a provider. - *

- * This annotation can be added to a user-defined {@code Provider} - * interface, to set the name that will be used - * for the provider in the generated probes. Without this annotation, - * the simple class name of the provider interface is used. - *

- * @since 1.7 - */ -@Retention(RetentionPolicy.RUNTIME) -@Target(ElementType.TYPE) -public @interface ProviderName { - String value(); -} - diff --git a/jdk/src/jdk.runtime/share/classes/com/sun/tracing/dtrace/ArgsAttributes.java b/jdk/src/jdk.runtime/share/classes/com/sun/tracing/dtrace/ArgsAttributes.java deleted file mode 100644 index 4adeb35a49d..00000000000 --- a/jdk/src/jdk.runtime/share/classes/com/sun/tracing/dtrace/ArgsAttributes.java +++ /dev/null @@ -1,53 +0,0 @@ -/* - * Copyright (c) 2008, 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. Oracle designates this - * particular file as subject to the "Classpath" exception as provided - * by Oracle in the LICENSE file that accompanied this code. - * - * 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. - */ - -package com.sun.tracing.dtrace; - -import java.lang.annotation.Target; -import java.lang.annotation.Retention; -import java.lang.annotation.RetentionPolicy; -import java.lang.annotation.ElementType; - - -/** - * This annotation describes the interface attributes of the probe arguments in - * a single provider. - * - * This annotation can be added to a user-defined {@code Provider} specification - * interface to set the stability attributes of the probe arguments, for - * all the probes specified in that provider. - *

- * If this annotation is not present, the interface attributes for the - * arguments are Private/Private/Unknown. - *

- * @see Solaris Dynamic Tracing Guide, Chapter 39: Stability - * @since 1.7 - */ - -@Retention(RetentionPolicy.RUNTIME) -@Target({ ElementType.TYPE }) -public @interface ArgsAttributes { - Attributes value(); -} diff --git a/jdk/src/jdk.runtime/share/classes/com/sun/tracing/dtrace/Attributes.java b/jdk/src/jdk.runtime/share/classes/com/sun/tracing/dtrace/Attributes.java deleted file mode 100644 index 500ac375080..00000000000 --- a/jdk/src/jdk.runtime/share/classes/com/sun/tracing/dtrace/Attributes.java +++ /dev/null @@ -1,66 +0,0 @@ -/* - * Copyright (c) 2008, 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. Oracle designates this - * particular file as subject to the "Classpath" exception as provided - * by Oracle in the LICENSE file that accompanied this code. - * - * 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. - */ - -package com.sun.tracing.dtrace; - -import java.lang.annotation.Target; -import java.lang.annotation.Retention; -import java.lang.annotation.RetentionPolicy; -import java.lang.annotation.ElementType; - - -/** - * This annotation describes the interface's field attributes - * for the probes in a provider. - * - * This annotation provides the contents of field-specific annotations - * that specify the stability attributes and dependency class of a - * particular field, for the probes in a provider. - *

- * The default interface attributes for unspecified fields is - * Private/Private/Unknown. - *

- * @see Solaris Dynamic Tracing Guide, Chapter 39: Stability - * @since 1.7 - */ - -@Retention(RetentionPolicy.RUNTIME) -@Target({}) -public @interface Attributes { - /** - * The stability level of the name. - */ - StabilityLevel name() default StabilityLevel.PRIVATE; - - /** - * The stability level of the data. - */ - StabilityLevel data() default StabilityLevel.PRIVATE; - - /** - * The interface attribute's dependency class. - */ - DependencyClass dependency() default DependencyClass.UNKNOWN; -} diff --git a/jdk/src/jdk.runtime/share/classes/com/sun/tracing/dtrace/DependencyClass.java b/jdk/src/jdk.runtime/share/classes/com/sun/tracing/dtrace/DependencyClass.java deleted file mode 100644 index ed275131406..00000000000 --- a/jdk/src/jdk.runtime/share/classes/com/sun/tracing/dtrace/DependencyClass.java +++ /dev/null @@ -1,77 +0,0 @@ -/* - * Copyright (c) 2008, 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. Oracle designates this - * particular file as subject to the "Classpath" exception as provided - * by Oracle in the LICENSE file that accompanied this code. - * - * 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. - */ - -package com.sun.tracing.dtrace; - -/** - * Enumeration for the DTrace dependency classes. - * - * @see Solaris Dynamic Tracing Guide for details, Chapter 39: Stability - * @since 1.7 - */ -public enum DependencyClass { - /** - * The interface has an unknown set of architectural dependencies. - */ - UNKNOWN (0), - /** - * The interface is specific to the CPU model of the current system. - */ - CPU (1), - /** - * The interface is specific to the hardware platform of the current - * system. - */ - PLATFORM (2), - /** - * The interface is specific to the hardware platform group of the - * current system. - */ - GROUP (3), - /** - * The interface is specific to the instruction set architecture (ISA) - * supported by the microprocessors on this system. - */ - ISA (4), - /** - * The interface is common to all Solaris systems regardless of the - * underlying hardware. - */ - COMMON (5); - - public String toDisplayString() { - return toString().substring(0,1) + - toString().substring(1).toLowerCase(); - } - - public int getEncoding() { return encoding; } - - private int encoding; - - private DependencyClass(int encoding) { - this.encoding = encoding; - } -} - diff --git a/jdk/src/jdk.runtime/share/classes/com/sun/tracing/dtrace/FunctionAttributes.java b/jdk/src/jdk.runtime/share/classes/com/sun/tracing/dtrace/FunctionAttributes.java deleted file mode 100644 index ee4f85a7bf4..00000000000 --- a/jdk/src/jdk.runtime/share/classes/com/sun/tracing/dtrace/FunctionAttributes.java +++ /dev/null @@ -1,51 +0,0 @@ -/* - * Copyright (c) 2008, 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. Oracle designates this - * particular file as subject to the "Classpath" exception as provided - * by Oracle in the LICENSE file that accompanied this code. - * - * 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. - */ - -package com.sun.tracing.dtrace; - -import java.lang.annotation.Target; -import java.lang.annotation.Retention; -import java.lang.annotation.RetentionPolicy; -import java.lang.annotation.ElementType; - -/** - * This annotation describes the interface attributes of the - * {@code function} field for a single provider. - * - * This annotation can be added to a user-defined {@code Provider} specification - * interface to set the stability attributes of the {@code function} field for - * all probes specified in that provider. - *

- * If this annotation is not present, the interface attributes for the - * {@code function} field are Private/Private/Unknown. - *

- * @see Solaris Dynamic Tracing Guide, Chapter 39: Stability - * @since 1.7 - */ -@Retention(RetentionPolicy.RUNTIME) -@Target({ ElementType.TYPE }) -public @interface FunctionAttributes { - Attributes value(); -} diff --git a/jdk/src/jdk.runtime/share/classes/com/sun/tracing/dtrace/FunctionName.java b/jdk/src/jdk.runtime/share/classes/com/sun/tracing/dtrace/FunctionName.java deleted file mode 100644 index a1ad675e8c0..00000000000 --- a/jdk/src/jdk.runtime/share/classes/com/sun/tracing/dtrace/FunctionName.java +++ /dev/null @@ -1,47 +0,0 @@ -/* - * Copyright (c) 2008, 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. Oracle designates this - * particular file as subject to the "Classpath" exception as provided - * by Oracle in the LICENSE file that accompanied this code. - * - * 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. - */ - -package com.sun.tracing.dtrace; - -import java.lang.annotation.Target; -import java.lang.annotation.Retention; -import java.lang.annotation.RetentionPolicy; -import java.lang.annotation.ElementType; - -/** - * An annotation used to specify the {@code function} field for a DTrace probe. - * - * This annotation can be added to a method in a user-defined Provider - * specification interface to set the {@code function} field that is used - * for the generated DTrace probe associated with that method. - *

- * @since 1.7 - */ -@Retention(RetentionPolicy.RUNTIME) -@Target(ElementType.METHOD) -public @interface FunctionName { - String value(); -} - diff --git a/jdk/src/jdk.runtime/share/classes/com/sun/tracing/dtrace/ModuleAttributes.java b/jdk/src/jdk.runtime/share/classes/com/sun/tracing/dtrace/ModuleAttributes.java deleted file mode 100644 index af2f795d0df..00000000000 --- a/jdk/src/jdk.runtime/share/classes/com/sun/tracing/dtrace/ModuleAttributes.java +++ /dev/null @@ -1,51 +0,0 @@ -/* - * Copyright (c) 2008, 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. Oracle designates this - * particular file as subject to the "Classpath" exception as provided - * by Oracle in the LICENSE file that accompanied this code. - * - * 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. - */ - -package com.sun.tracing.dtrace; - -import java.lang.annotation.Target; -import java.lang.annotation.Retention; -import java.lang.annotation.RetentionPolicy; -import java.lang.annotation.ElementType; - -/** - * This annotation is used to describe the interface attributes of the - * {@code module} field for a single provider. - * - * This annotation can be added to a user-defined Provider specification - * interface to set the stability attributes of the {@code module} field for - * all probes specified in that provider. - *

- * If this annotation is not present, the interface attributes for the - * {@code module} field is Private/Private/Unknown. - *

- * @see Solaris Dynamic Tracing Guide, Chapter 39: Stability - * @since 1.7 - */ -@Retention(RetentionPolicy.RUNTIME) -@Target({ ElementType.TYPE }) -public @interface ModuleAttributes { - Attributes value(); -} diff --git a/jdk/src/jdk.runtime/share/classes/com/sun/tracing/dtrace/ModuleName.java b/jdk/src/jdk.runtime/share/classes/com/sun/tracing/dtrace/ModuleName.java deleted file mode 100644 index ed511eb1a72..00000000000 --- a/jdk/src/jdk.runtime/share/classes/com/sun/tracing/dtrace/ModuleName.java +++ /dev/null @@ -1,47 +0,0 @@ -/* - * Copyright (c) 2008, 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. Oracle designates this - * particular file as subject to the "Classpath" exception as provided - * by Oracle in the LICENSE file that accompanied this code. - * - * 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. - */ - -package com.sun.tracing.dtrace; - -import java.lang.annotation.Target; -import java.lang.annotation.Retention; -import java.lang.annotation.RetentionPolicy; -import java.lang.annotation.ElementType; - -/** - * An annotation used to specify the {@code module} field for a DTrace probe. - * - * This annotation can be added to a method in a user-defined Provider - * specification interface to set the {@code module} field that will be used - * for the generated DTrace probe associated with that method. - *

- * @since 1.7 - */ -@Retention(RetentionPolicy.RUNTIME) -@Target(ElementType.TYPE) -public @interface ModuleName { - String value(); -} - diff --git a/jdk/src/jdk.runtime/share/classes/com/sun/tracing/dtrace/NameAttributes.java b/jdk/src/jdk.runtime/share/classes/com/sun/tracing/dtrace/NameAttributes.java deleted file mode 100644 index 0752c2b1a3f..00000000000 --- a/jdk/src/jdk.runtime/share/classes/com/sun/tracing/dtrace/NameAttributes.java +++ /dev/null @@ -1,51 +0,0 @@ -/* - * Copyright (c) 2008, 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. Oracle designates this - * particular file as subject to the "Classpath" exception as provided - * by Oracle in the LICENSE file that accompanied this code. - * - * 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. - */ - -package com.sun.tracing.dtrace; - -import java.lang.annotation.Target; -import java.lang.annotation.Retention; -import java.lang.annotation.RetentionPolicy; -import java.lang.annotation.ElementType; - -/** - * This annotation describes the interface attributes of the - * {@code name} field for a single provider. - * - * This annotation can be added to a user-defined Provider specification - * interface to set the stability attributes of the {@code name} field for - * all probes specified in that provider. - *

- * If this annotation is not present, the interface attributes for the - * {@code name} field will be Private/Private/Unknown. - *

- * @see Solaris Dynamic Tracing Guide, Chapter 39: Stability - * @since 1.7 - */ -@Retention(RetentionPolicy.RUNTIME) -@Target({ ElementType.TYPE }) -public @interface NameAttributes { - Attributes value(); -} diff --git a/jdk/src/jdk.runtime/share/classes/com/sun/tracing/dtrace/ProviderAttributes.java b/jdk/src/jdk.runtime/share/classes/com/sun/tracing/dtrace/ProviderAttributes.java deleted file mode 100644 index 31982ab468c..00000000000 --- a/jdk/src/jdk.runtime/share/classes/com/sun/tracing/dtrace/ProviderAttributes.java +++ /dev/null @@ -1,51 +0,0 @@ -/* - * Copyright (c) 2008, 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. Oracle designates this - * particular file as subject to the "Classpath" exception as provided - * by Oracle in the LICENSE file that accompanied this code. - * - * 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. - */ - -package com.sun.tracing.dtrace; - -import java.lang.annotation.Target; -import java.lang.annotation.Retention; -import java.lang.annotation.RetentionPolicy; -import java.lang.annotation.ElementType; - -/** - * This annotation is used to describe the interface attributes of the - * {@code provider} field for a single provider. - * - * This annotation can be added to a user-defined Provider specification - * interface to set the stability attributes of the {@code provider} field for - * all probes specified in that provider. - *

- * If this annotation is not present, the interface attributes for the - * {@code provider} field will be Private/Private/Unknown. - *

- * @see Solaris Dynamic Tracing Guide, Chapter 39: Stability - * @since 1.7 - */ -@Retention(RetentionPolicy.RUNTIME) -@Target({ ElementType.TYPE }) -public @interface ProviderAttributes { - Attributes value(); -} diff --git a/jdk/src/jdk.runtime/share/classes/com/sun/tracing/dtrace/StabilityLevel.java b/jdk/src/jdk.runtime/share/classes/com/sun/tracing/dtrace/StabilityLevel.java deleted file mode 100644 index ad029cd455f..00000000000 --- a/jdk/src/jdk.runtime/share/classes/com/sun/tracing/dtrace/StabilityLevel.java +++ /dev/null @@ -1,88 +0,0 @@ -/* - * Copyright (c) 2008, 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. Oracle designates this - * particular file as subject to the "Classpath" exception as provided - * by Oracle in the LICENSE file that accompanied this code. - * - * 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. - */ - -package com.sun.tracing.dtrace; - -/** - * Enumeration for the DTrace stability levels. - * - * @see Solaris Dynamic Tracing Guide, Chapter 39: Stability - * @since 1.7 - */ -public enum StabilityLevel { - /** - * The interface is private to DTrace and represents an implementation - * detail of DTrace. - */ - INTERNAL (0), - /** - * The interface is private to Sun for use by other Sun products. It is - * not yet publicly documented for use by customers and ISVs. - */ - PRIVATE (1), - /** - * The interface is supported in the current release but is scheduled - * to be removed, most likely in a future minor release. - */ - OBSOLETE (2), - /** - * The interface is controlled by an entity other than Sun. - */ - EXTERNAL (3), - /** - * The interface gives developers early access to new or - * rapidly changing technology or to an implementation artifact that is - * essential for observing or debugging system behavior. A more - * stable solution is anticipated in the future. - */ - UNSTABLE (4), - /** - * The interface might eventually become Standard or Stable but is - * still in transition. - */ - EVOLVING (5), - /** - * The interface is a mature interface under Sun's control. - */ - STABLE (6), - /** - * The interface complies with an industry standard. - */ - STANDARD (7); - - String toDisplayString() { - return toString().substring(0,1) + - toString().substring(1).toLowerCase(); - } - - public int getEncoding() { return encoding; } - - private int encoding; - - private StabilityLevel(int encoding) { - this.encoding = encoding; - } -} - diff --git a/jdk/src/jdk.runtime/share/classes/com/sun/tracing/dtrace/package-info.java b/jdk/src/jdk.runtime/share/classes/com/sun/tracing/dtrace/package-info.java deleted file mode 100644 index 1a0c10d4bcd..00000000000 --- a/jdk/src/jdk.runtime/share/classes/com/sun/tracing/dtrace/package-info.java +++ /dev/null @@ -1,82 +0,0 @@ -/* - * Copyright (c) 2008, 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. Oracle designates this - * particular file as subject to the "Classpath" exception as provided - * by Oracle in the LICENSE file that accompanied this code. - * - * 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. - */ - -/** - * This package contains annotations and enumerations that are used to - * add DTrace-specific information to a tracing provider. - *

- * The DTrace-specific annotations modify the attributes of a DTrace provider - * implementation when it is used by the tracing subsystem. The annotations are - * added to a {@code com.sun.tracing} provider specification to control - * specific attributes of the provider as it relates to DTrace. - *

- * Any other tracing subsystems supported by the system will ignore these - * annotations. - *

- * DTrace probes have additional fields and stability attributes that are - * not accounted for in the generic tracing package. If unspecified, the - * default values are used for the stability and dependency attributes of - * probes, as well as for the module and field names of the generated probes. - * The values can be specified by adding the appropriate annotations to the - * provider specification. - *

- * The {@code FunctionName} annotation is used to annotate the tracepoint - * methods defined in the provider specification. The value of this annotation - * is used as the {@code function} field in the generated DTrace probes. It - * is typically set to the name of the enclosing function where the - * tracepoint is triggered. - *

- * The {@code ModuleName} annotation is used to annotate the provider - * specification itself and applies to all the probes in the provider. It - * sets the value of the {@code module} field in the generated DTrace probes. - *

- * The remaining annotations, are also applied to the provider itself, and - * are used to set the stability and dependency attributes of all probes in - * that provider. Each probe field and the probe arguments can be - * independently assigned interface attributes to control the stability - * ratings of the probes. - *

- * Here is an example of how to declare a provider, specifying additional DTrace - * data: -

-    @ProviderName("my_app_provider")
-    @ModuleName("app.jar")
-    @ProviderAttributes(@Attributes={
-        name=StabilityLevel.STABLE,data=StabilityLevel.STABLE,
-        dependency=DependencyClass.COMMON})
-    @ProbeAttributes(@Attributes={
-        name=StabilityLevel.STABLE,data=StabilityLevel.STABLE,
-        dependency=DependencyClass.COMMON})
-    @ModuleAttributes(@Attributes={name=StabilityLevel.UNSTABLE})
-    public class MyProvider {
-        @FunctionName("main") void startProbe();
-    }
-
- *

- * @see Solaris Dynamic Tracing Guide, Chapter 34: Statically Defined Tracing for User Applications - * @see Solaris Dynamic Tracing Guide, Chapter 39: Stability - */ - -package com.sun.tracing.dtrace; diff --git a/jdk/src/jdk.runtime/share/classes/com/sun/tracing/package-info.java b/jdk/src/jdk.runtime/share/classes/com/sun/tracing/package-info.java deleted file mode 100644 index 44644ce813e..00000000000 --- a/jdk/src/jdk.runtime/share/classes/com/sun/tracing/package-info.java +++ /dev/null @@ -1,183 +0,0 @@ -/* - * Copyright (c) 2008, 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. Oracle designates this - * particular file as subject to the "Classpath" exception as provided - * by Oracle in the LICENSE file that accompanied this code. - * - * 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. - */ - -/** - * This package provides a mechanism for defining and - * inserting tracepoints into Java-technology based applications, which - * can then be monitored by the tracing tools available on the system. - *

- * To add tracepoints to a program, you must first decide where to place the - * tracepoints, what the logical names are for these points, what information - * will be available to the tracing mechanisms at each point, and decide upon - * any logical grouping. - *

- * You add instrumentation to a program in three steps: - *

    - *
  • First, declare tracepoints by creating interfaces to define - * them, and include these interfaces in the program definition. - * The declared interfaces are standard Java technology-based - * interfaces and are compiled with the program.
  • - *
  • Second, add code in the application to create an instance of the - * interface at some point during the initialization of the application, - * using a factory class provided by the system. The reference to the - * instance can be stored as a global static, or passed as context to all - * the places where it is needed.
  • - *
  • Finally, add the actual tracepoints to the desired locations in the - * application by inserting a call to one of the methods defined in the - * interface, via the factory-created reference.
  • - *
- *

- * The method calls representing the tracepoints have no logical - * impact on the program. The side effect of the call is that any - * activated tracing mechanisms will be notified that the tracepoint has - * been hit, and will take whatever actions are appropriate (for example, - * logging the tracepoint, or triggering a DTrace probe, etc.). In most - * cases, the impact on performance of adding tracepoints to the application - * will be minimal. - *

- * Each logical grouping of tracepoints should be defined in a common - * interface, called a provider. An application can have one or many - * providers. Each provider is independent and can be created whenever - * it is appropriate for that provider, for example, when a subsytem is - * initialized. Providers should be disposed of when they are no longer - * needed, to free up any associated system resources. Each tracepoint - * in a provider is represented by a method in that interface. These methods - * are referred to as probes. The method signature determines the probe - * parameters. A call to the method with the specified parameters triggers - * the probe and makes its parameter values visible to any associated tracing - * mechanism. - *

- * User-defined interfaces which represent providers must extend the - * {@code Provider} interface. To activate the system-defined - * tracing mechanisms, you must obtain an instance of the - * {@code ProviderFactory} class, and pass the class of the provider to - * the {@code createProvider()} method. The returned instance is then used to - * trigger the probes later in the application. - *

- * In addition to triggering the probes, the provider instance can be used - * to obtain direct references to the {@code Probe} objects, which can be used - * directly for triggering, or can be queried to determine whether the probe is - * currently being traced. The {@code Provider} interface also defines a - * {@code Provider.dispose()} method which is used to free up any resources - * that might be associated with that provider. - *

- * When a probe is triggered, any activated tracing system will be given - * the provider name, the probe name, and the values of the probe arguments. - * The tracing system is free to consume this data is whatever way is - * appropriate. - * By default, the provider name is the same as the class name of the interface - * that defines the provider. Similarly, the probe name is - * the name of the method that defines the probe. These default values - * can be over-ridden by annotations. The provider definition can be - * annotated with the {@code @ProviderName} annotation, whose value will - * indicate the provider name that the tracing system will use. Similarly, - * the {@code @ProbeName} annotation annotates a declared method and - * indicates the probe name that should be used in the place of the - * method name. These annotations can be used to define providers and - * probes with the same name, in cases where the semantics of the Java language - * may prevent this. - *

- * Here is a very small and simple usage example: - *

- * -

-   import com.sun.tracing.Provider;
-   import com.sun.tracing.ProviderFactory;
-
-   interface MyProvider extends Provider {
-       void startProbe();
-       void finishProbe(int value);
-   }
-
-   public class MyApplication {
-       public static void main(String argv[]) {
-           ProviderFactory factory = ProviderFactory.getDefaultFactory();
-           MyProvider trace = factory.createProvider(MyProvider.class);
-
-           trace.startProbe();
-           int result = foo();
-           trace.finishProbe(result);
-
-           trace.dispose();
-       }
-   }
-
- *

- * The Java Development Kit (JDK) currently only includes one system-defined - * tracing framework: DTrace. DTrace is enabled automatically whenever an - * application is run on a system and a JDK release that supports it. When - * DTrace is enabled, probes are made available for listing and matching by - * DTrace scripts as soon as the provider is created. At the tracepoint, an - * associated DTrace script is informed of the creation of the provider, and - * it takes whatever action it is designed to take. Tracepoints in the - * program have the following DTrace probe names:
- * {@code :::} - * Where: - *

    - *
  • {@code } the provider name as specified by the application
  • - *
  • {@code } the operating system process ID
  • - *
  • {@code } undefined, unless specified by the application
  • - *
  • {@code } undefined, unless specified by the application
  • - *
  • {@code } the probe name as specified by the application
  • - *
- *

- * The {@code com.sun.tracing.dtrace} package contains additional - * annotations that can be used to control the names used for the - * module and function fields, as well as annotations - * that can be added to the provider to control probe stability and dependency - * attributes. - *

- * Integer, float and string probe parameters are made available to DTrace - * using - * the built-in argument variables, {@code arg0 ... arg_n}. Integer-types - * are passed by value (boxed values are unboxed), floating-point types are - * passed as encoded integer - * arguments, and {@code java.lang.String} objects are converted - * to UTF8 strings, so they can be read into the DTrace script using the - * {@code copyinstr()} intrinsic. Non-string and non-boxed primitive - * reference arguments are only - * placeholders and have no value. - *

- * Using the example above, with a theoretical process ID of 123, these are - * the probes that can be traced from DTrace: -

-    MyProvider123:::startProbe
-    MyProvider123:::finishProbe
-
- * When {@code finishProbe} executes, {@code arg0} will contain the - * value of {@code result}. - *

- * The DTrace tracing mechanism is enabled for all providers, apart from in the - * following circumstances: - *

    - *
  • DTrace is not supported on the underlying system.
  • - *
  • The property {@code com.sun.tracing.dtrace} is set to "disable".
  • - *
  • The RuntimePermission {@code com.sun.tracing.dtrace.createProvider} - * is denied to the process.
  • - *
- *

- */ - -package com.sun.tracing; diff --git a/jdk/src/jdk.runtime/share/classes/sun/tracing/MultiplexProviderFactory.java b/jdk/src/jdk.runtime/share/classes/sun/tracing/MultiplexProviderFactory.java deleted file mode 100644 index 7391c60a2dd..00000000000 --- a/jdk/src/jdk.runtime/share/classes/sun/tracing/MultiplexProviderFactory.java +++ /dev/null @@ -1,137 +0,0 @@ -/* - * Copyright (c) 2008, 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. Oracle designates this - * particular file as subject to the "Classpath" exception as provided - * by Oracle in the LICENSE file that accompanied this code. - * - * 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. - */ - -package sun.tracing; - -import java.lang.reflect.Method; -import java.lang.reflect.InvocationTargetException; -import java.util.HashMap; -import java.util.HashSet; -import java.util.Set; - -import com.sun.tracing.ProviderFactory; -import com.sun.tracing.Provider; -import com.sun.tracing.Probe; - -/** - * Factory class to create tracing Providers. - * - * This factory creates a "multiplex provider", which is a provider that - * encapsulates a list of providers and whose probes trigger a corresponding - * trigger in each of the encapsulated providers' probes. - * - * This is used when there are multiple tracing frameworks activated at once. - * A user-defined provider gets implementation for each of the activated - * frameworks and this multiplex framework is what is ultimately passed - * back to the user. All probe triggers are multiplexed to each - * active framework. - * - * @since 1.7 - */ -public class MultiplexProviderFactory extends ProviderFactory { - - private Set factories; - - public MultiplexProviderFactory(Set factories) { - this.factories = factories; - } - - public T createProvider(Class cls) { - HashSet providers = new HashSet(); - for (ProviderFactory factory : factories) { - providers.add(factory.createProvider(cls)); - } - MultiplexProvider provider = new MultiplexProvider(cls, providers); - provider.init(); - return provider.newProxyInstance(); - } -} - -class MultiplexProvider extends ProviderSkeleton { - - private Set providers; - - protected ProbeSkeleton createProbe(Method m) { - return new MultiplexProbe(m, providers); - } - - MultiplexProvider(Class type, Set providers) { - super(type); - this.providers = providers; - } - - public void dispose() { - for (Provider p : providers) { - p.dispose(); - } - super.dispose(); - } -} - -class MultiplexProbe extends ProbeSkeleton { - - private Set probes; - - MultiplexProbe(Method m, Set providers) { - super(m.getParameterTypes()); - probes = new HashSet(); - for (Provider p : providers) { - Probe probe = p.getProbe(m); - if (probe != null) { - probes.add(probe); - } - } - } - - public boolean isEnabled() { - for (Probe p : probes) { - if (p.isEnabled()) { - return true; - } - } - return false; - } - - public void uncheckedTrigger(Object[] args) { - for (Probe p : probes) { - try { - // try the fast path - ProbeSkeleton ps = (ProbeSkeleton)p; - ps.uncheckedTrigger(args); - } catch (ClassCastException e) { - // Probe.trigger takes an "Object ..." varargs parameter, - // so we can't call it directly. - try { - Method m = Probe.class.getMethod( - "trigger", Class.forName("[java.lang.Object")); - m.invoke(p, args); - } catch (Exception e1) { - assert false; // This shouldn't happen - } - } - } - } -} - diff --git a/jdk/src/jdk.runtime/share/classes/sun/tracing/NullProviderFactory.java b/jdk/src/jdk.runtime/share/classes/sun/tracing/NullProviderFactory.java deleted file mode 100644 index e07082da4e3..00000000000 --- a/jdk/src/jdk.runtime/share/classes/sun/tracing/NullProviderFactory.java +++ /dev/null @@ -1,84 +0,0 @@ -/* - * Copyright (c) 2008, 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. Oracle designates this - * particular file as subject to the "Classpath" exception as provided - * by Oracle in the LICENSE file that accompanied this code. - * - * 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. - */ - -package sun.tracing; - -import java.lang.reflect.Method; - -import com.sun.tracing.ProviderFactory; -import com.sun.tracing.Provider; - -/** - * Factory class to create tracing Providers. - * - * This factory will create tracing instances that do nothing. - * It is used when no tracing is desired, but Provider instances still - * must be generated so that tracing calls in the application continue to - * run. - * - * @since 1.7 - */ -public class NullProviderFactory extends ProviderFactory { - - /** - * Creates and returns a Null provider. - * - * See comments at {@code ProviderSkeleton.createProvider()} for more - * details. - * - * @return a provider whose probe trigger are no-ops. - */ - public T createProvider(Class cls) { - NullProvider provider = new NullProvider(cls); - provider.init(); - return provider.newProxyInstance(); - } -} - -class NullProvider extends ProviderSkeleton { - - NullProvider(Class type) { - super(type); - } - - protected ProbeSkeleton createProbe(Method m) { - return new NullProbe(m.getParameterTypes()); - } -} - -class NullProbe extends ProbeSkeleton { - - public NullProbe(Class[] parameters) { - super(parameters); - } - - public boolean isEnabled() { - return false; - } - - public void uncheckedTrigger(Object[] args) { - } -} - diff --git a/jdk/src/jdk.runtime/share/classes/sun/tracing/PrintStreamProviderFactory.java b/jdk/src/jdk.runtime/share/classes/sun/tracing/PrintStreamProviderFactory.java deleted file mode 100644 index fda63f5b194..00000000000 --- a/jdk/src/jdk.runtime/share/classes/sun/tracing/PrintStreamProviderFactory.java +++ /dev/null @@ -1,120 +0,0 @@ -/* - * Copyright (c) 2008, 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. Oracle designates this - * particular file as subject to the "Classpath" exception as provided - * by Oracle in the LICENSE file that accompanied this code. - * - * 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. - */ - -package sun.tracing; - -import java.lang.reflect.Method; -import java.io.PrintStream; -import java.util.HashMap; - -import com.sun.tracing.ProviderFactory; -import com.sun.tracing.Provider; -import com.sun.tracing.ProviderName; -import com.sun.tracing.Probe; -import com.sun.tracing.ProbeName; - -/** - * Factory class to create tracing Providers. - * - * This factory will create tracing instances that print to a PrintStream - * when activated. - * - * @since 1.7 - */ -public class PrintStreamProviderFactory extends ProviderFactory { - - private PrintStream stream; - - public PrintStreamProviderFactory(PrintStream stream) { - this.stream = stream; - } - - public T createProvider(Class cls) { - PrintStreamProvider provider = new PrintStreamProvider(cls, stream); - provider.init(); - return provider.newProxyInstance(); - } -} - -class PrintStreamProvider extends ProviderSkeleton { - - private PrintStream stream; - private String providerName; - - protected ProbeSkeleton createProbe(Method m) { - String probeName = getAnnotationString(m, ProbeName.class, m.getName()); - return new PrintStreamProbe(this, probeName, m.getParameterTypes()); - } - - PrintStreamProvider(Class type, PrintStream stream) { - super(type); - this.stream = stream; - this.providerName = getProviderName(); - } - - PrintStream getStream() { - return stream; - } - - String getName() { - return providerName; - } -} - -class PrintStreamProbe extends ProbeSkeleton { - - private PrintStreamProvider provider; - private String name; - - PrintStreamProbe(PrintStreamProvider p, String name, Class[] params) { - super(params); - this.provider = p; - this.name = name; - } - - public boolean isEnabled() { - return true; - } - - public void uncheckedTrigger(Object[] args) { - StringBuilder sb = new StringBuilder(); - sb.append(provider.getName()); - sb.append("."); - sb.append(name); - sb.append("("); - boolean first = true; - for (Object o : args) { - if (first == false) { - sb.append(","); - } else { - first = false; - } - sb.append(o.toString()); - } - sb.append(")"); - provider.getStream().println(sb.toString()); - } -} - diff --git a/jdk/src/jdk.runtime/share/classes/sun/tracing/ProbeSkeleton.java b/jdk/src/jdk.runtime/share/classes/sun/tracing/ProbeSkeleton.java deleted file mode 100644 index 30f2aeda6df..00000000000 --- a/jdk/src/jdk.runtime/share/classes/sun/tracing/ProbeSkeleton.java +++ /dev/null @@ -1,90 +0,0 @@ -/* - * Copyright (c) 2008, 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. Oracle designates this - * particular file as subject to the "Classpath" exception as provided - * by Oracle in the LICENSE file that accompanied this code. - * - * 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. - */ - -package sun.tracing; - -import java.lang.reflect.Method; -import java.lang.reflect.Field; -import com.sun.tracing.Probe; - -/** - * Provides common code for implementation of {@code Probe} classes. - * - * @since 1.7 - */ -public abstract class ProbeSkeleton implements Probe { - - protected Class[] parameters; - - protected ProbeSkeleton(Class[] parameters) { - this.parameters = parameters; - } - - public abstract boolean isEnabled(); // framework-dependent - - /** - * Triggers the probe with verified arguments. - * - * The caller of this method must have already determined that the - * arity and types of the arguments match what the probe was - * declared with. - */ - public abstract void uncheckedTrigger(Object[] args); // framework-dependent - - private static boolean isAssignable(Object o, Class formal) { - if (o != null) { - if ( !formal.isInstance(o) ) { - if ( formal.isPrimitive() ) { // o might be a boxed primitive - try { - // Yuck. There must be a better way of doing this - Field f = o.getClass().getField("TYPE"); - return formal.isAssignableFrom((Class)f.get(null)); - } catch (Exception e) { - /* fall-through. */ - } - } - return false; - } - } - return true; - } - - /** - * Performs a type-check of the parameters before triggering the probe. - */ - public void trigger(Object ... args) { - if (args.length != parameters.length) { - throw new IllegalArgumentException("Wrong number of arguments"); - } else { - for (int i = 0; i < parameters.length; ++i) { - if ( !isAssignable(args[i], parameters[i]) ) { - throw new IllegalArgumentException( - "Wrong type of argument at position " + i); - } - } - uncheckedTrigger(args); - } - } -} diff --git a/jdk/src/jdk.runtime/share/classes/sun/tracing/ProviderSkeleton.java b/jdk/src/jdk.runtime/share/classes/sun/tracing/ProviderSkeleton.java deleted file mode 100644 index 5594e4c08be..00000000000 --- a/jdk/src/jdk.runtime/share/classes/sun/tracing/ProviderSkeleton.java +++ /dev/null @@ -1,273 +0,0 @@ -/* - * Copyright (c) 2008, 2014, 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. Oracle designates this - * particular file as subject to the "Classpath" exception as provided - * by Oracle in the LICENSE file that accompanied this code. - * - * 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. - */ - -package sun.tracing; - -import java.lang.reflect.InvocationHandler; -import java.lang.reflect.Method; -import java.lang.reflect.Proxy; -import java.lang.reflect.InvocationTargetException; -import java.lang.reflect.AnnotatedElement; -import java.lang.annotation.Annotation; -import java.util.HashMap; -import java.security.AccessController; -import java.security.PrivilegedAction; - -import com.sun.tracing.Provider; -import com.sun.tracing.Probe; -import com.sun.tracing.ProviderName; - -/** - * Provides a common code for implementation of {@code Provider} classes. - * - * Each tracing subsystem needs to provide three classes, a factory - * (derived from {@code ProviderFactory}, a provider (a subclass of - * {@code Provider}, and a probe type (subclass of {@code ProbeSkeleton}). - * - * The factory object takes a user-defined interface and provides an - * implementation of it whose method calls will trigger probes in the - * tracing framework. - * - * The framework's provider class, and its instances, are not seen by the - * user at all -- they usually sit in the background and receive and dispatch - * the calls to the user's provider interface. The {@code ProviderSkeleton} - * class provides almost all of the implementation needed by a framework - * provider. Framework providers must only provide a constructor and - * disposal method, and implement the {@code createProbe} method to create - * an appropriate {@code ProbeSkeleton} subclass. - * - * The framework's probe class provides the implementation of the two - * probe methods, {@code isEnabled()} and {@code uncheckedTrigger()}. Both are - * framework-dependent implementations. - * - * @since 1.7 - */ - -public abstract class ProviderSkeleton implements InvocationHandler, Provider { - - protected boolean active; // set to false after dispose() is called - protected Class providerType; // user's interface - protected HashMap probes; // methods to probes - - - /** - * Creates a framework-specific probe subtype. - * - * This method is implemented by the framework's provider and returns - * framework-specific probes for a method. - * - * @param method A method in the user's interface - * @return a subclass of ProbeSkeleton for the particular framework. - */ - protected abstract ProbeSkeleton createProbe(Method method); - - /** - * Initializes the provider. - * - * @param type the user's interface - */ - protected ProviderSkeleton(Class type) { - this.active = false; // in case of some error during initialization - this.providerType = type; - this.probes = new HashMap(); - } - - /** - * Post-constructor initialization routine. - * - * Subclass instances must be initialized before they can create probes. - * It is up to the factory implementations to call this after construction. - */ - public void init() { - Method[] methods = AccessController.doPrivileged(new PrivilegedAction() { - public Method[] run() { - return providerType.getDeclaredMethods(); - } - }); - - for (Method m : methods) { - if ( m.getReturnType() != Void.TYPE ) { - throw new IllegalArgumentException( - "Return value of method is not void"); - } else { - probes.put(m, createProbe(m)); - } - } - this.active = true; - } - - /** - * Magic routine which creates an implementation of the user's interface. - * - * This method creates the instance of the user's interface which is - * passed back to the user. Every call upon that interface will be - * redirected to the {@code invoke()} method of this class (until - * overridden by the VM). - * - * @return an implementation of the user's interface - */ - @SuppressWarnings("unchecked") - public T newProxyInstance() { - final InvocationHandler ih = this; - return AccessController.doPrivileged(new PrivilegedAction() { - public T run() { - return (T)Proxy.newProxyInstance(providerType.getClassLoader(), - new Class[] { providerType }, ih); - }}); - } - - /** - * Triggers a framework probe when a user interface method is called. - * - * This method dispatches a user interface method call to the appropriate - * probe associated with this framework. - * - * If the invoked method is not a user-defined member of the interface, - * then it is a member of {@code Provider} or {@code Object} and we - * invoke the method directly. - * - * @param proxy the instance whose method was invoked - * @param method the method that was called - * @param args the arguments passed in the call. - * @return always null, if the method is a user-defined probe - */ - public Object invoke(Object proxy, Method method, Object[] args) { - Class declaringClass = method.getDeclaringClass(); - // not a provider subtype's own method - if (declaringClass != providerType) { - try { - // delegate only to methods declared by - // com.sun.tracing.Provider or java.lang.Object - if (declaringClass == Provider.class || - declaringClass == Object.class) { - return method.invoke(this, args); - } else { - // assert false : "this should never happen" - // reaching here would indicate a breach - // in security in the higher layers - throw new SecurityException(); - } - } catch (IllegalAccessException e) { - assert false; - } catch (InvocationTargetException e) { - assert false; - } - } else { - triggerProbe(method, args); - } - return null; - } - - /** - * Direct accessor for {@code Probe} objects. - * - * @param m the method corresponding to a probe - * @return the method associated probe object, or null - */ - public Probe getProbe(Method m) { - return active ? probes.get(m) : null; - } - - /** - * Default provider disposal method. - * - * This is overridden in subclasses as needed. - */ - public void dispose() { - active = false; - probes.clear(); - } - - /** - * Gets the user-specified provider name for the user's interface. - * - * If the user's interface has a {@ProviderName} annotation, that value - * is used. Otherwise we use the simple name of the user interface's class. - * @return the provider name - */ - protected String getProviderName() { - return getAnnotationString( - providerType, ProviderName.class, providerType.getSimpleName()); - } - - /** - * Utility method for getting a string value from an annotation. - * - * Used for getting a string value from an annotation with a 'value' method. - * - * @param element the element that was annotated, either a class or method - * @param annotation the class of the annotation we're interested in - * @param defaultValue the value to return if the annotation doesn't - * exist, doesn't have a "value", or the value is empty. - */ - protected static String getAnnotationString( - AnnotatedElement element, Class annotation, - String defaultValue) { - String ret = (String)getAnnotationValue( - element, annotation, "value", defaultValue); - return ret.isEmpty() ? defaultValue : ret; - } - - /** - * Utility method for calling an arbitrary method in an annotation. - * - * @param element the element that was annotated, either a class or method - * @param annotation the class of the annotation we're interested in - * @param methodName the name of the method in the annotation we wish - * to call. - * @param defaultValue the value to return if the annotation doesn't - * exist, or we couldn't invoke the method for some reason. - * @return the result of calling the annotation method, or the default. - */ - protected static Object getAnnotationValue( - AnnotatedElement element, Class annotation, - String methodName, Object defaultValue) { - Object ret = defaultValue; - try { - Method m = annotation.getMethod(methodName); - Annotation a = element.getAnnotation(annotation); - ret = m.invoke(a); - } catch (NoSuchMethodException e) { - assert false; - } catch (IllegalAccessException e) { - assert false; - } catch (InvocationTargetException e) { - assert false; - } catch (NullPointerException e) { - assert false; - } - return ret; - } - - protected void triggerProbe(Method method, Object[] args) { - if (active) { - ProbeSkeleton p = probes.get(method); - if (p != null) { - // Skips argument check -- already done by javac - p.uncheckedTrigger(args); - } - } - } -} diff --git a/jdk/src/jdk.runtime/share/classes/sun/tracing/dtrace/Activation.java b/jdk/src/jdk.runtime/share/classes/sun/tracing/dtrace/Activation.java deleted file mode 100644 index 316ce323423..00000000000 --- a/jdk/src/jdk.runtime/share/classes/sun/tracing/dtrace/Activation.java +++ /dev/null @@ -1,107 +0,0 @@ -/* - * Copyright (c) 2008, 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. Oracle designates this - * particular file as subject to the "Classpath" exception as provided - * by Oracle in the LICENSE file that accompanied this code. - * - * 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. - */ - -package sun.tracing.dtrace; - -import java.lang.ref.WeakReference; -import java.lang.ref.ReferenceQueue; -import java.security.Permission; -import java.util.HashSet; - -class Activation { - private SystemResource resource; - private int referenceCount; - - Activation(String moduleName, DTraceProvider[] providers) { - SecurityManager security = System.getSecurityManager(); - if (security != null) { - Permission perm = - new RuntimePermission("com.sun.tracing.dtrace.createProvider"); - security.checkPermission(perm); - } - referenceCount = providers.length; - for (DTraceProvider p : providers) { - p.setActivation(this); - } - resource = new SystemResource( - this, JVM.activate(moduleName, providers)); - } - - void disposeProvider(DTraceProvider p) { - if (--referenceCount == 0) { - resource.dispose(); - } - } -} - -/** - * The native resource part of an Activation. - * - * This holds the native handle. - * - * If the user loses a reference to a set of Providers without disposing them, - * and GC determines the Activation is unreachable, then the next - * activation or flush call will automatically dispose the unreachable objects - * - * The SystemResource instances are creating during activation, and - * unattached during disposal. When created, they always have a - * strong reference to them via the {@code resources} static member. Explicit - * {@code dispose} calls will unregister the native resource and remove - * references to the SystemResource object. Absent an explicit dispose, - * when their associated Activation object becomes garbage, the SystemResource - * object will be enqueued on the reference queue and disposed at the - * next call to {@code flush}. - */ -class SystemResource extends WeakReference { - - private long handle; - - private static ReferenceQueue referenceQueue = - referenceQueue = new ReferenceQueue(); - static HashSet resources = new HashSet(); - - SystemResource(Activation activation, long handle) { - super(activation, referenceQueue); - this.handle = handle; - flush(); - resources.add(this); - } - - void dispose() { - JVM.dispose(handle); - resources.remove(this); - handle = 0; - } - - static void flush() { - SystemResource resource = null; - while ((resource = (SystemResource)referenceQueue.poll()) != null) { - if (resource.handle != 0) { - resource.dispose(); - } - } - } -} - diff --git a/jdk/src/jdk.runtime/share/classes/sun/tracing/dtrace/DTraceProbe.java b/jdk/src/jdk.runtime/share/classes/sun/tracing/dtrace/DTraceProbe.java deleted file mode 100644 index eedd5d44f54..00000000000 --- a/jdk/src/jdk.runtime/share/classes/sun/tracing/dtrace/DTraceProbe.java +++ /dev/null @@ -1,82 +0,0 @@ -/* - * Copyright (c) 2008, 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. Oracle designates this - * particular file as subject to the "Classpath" exception as provided - * by Oracle in the LICENSE file that accompanied this code. - * - * 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. - */ - -package sun.tracing.dtrace; - -import java.lang.reflect.Method; -import java.lang.reflect.InvocationTargetException; - -import sun.tracing.ProbeSkeleton; - -class DTraceProbe extends ProbeSkeleton { - private Object proxy; - private Method declared_method; - private Method implementing_method; - - DTraceProbe(Object proxy, Method m) { - super(m.getParameterTypes()); - this.proxy = proxy; - this.declared_method = m; - try { - // The JVM will override the proxy method's implementation with - // a version that will invoke the probe. - this.implementing_method = proxy.getClass().getMethod( - m.getName(), m.getParameterTypes()); - } catch (NoSuchMethodException e) { - throw new RuntimeException("Internal error, wrong proxy class"); - } - } - - public boolean isEnabled() { - return JVM.isEnabled(implementing_method); - } - - public void uncheckedTrigger(Object[] args) { - try { - implementing_method.invoke(proxy, args); - } catch (IllegalAccessException e) { - assert false; - } catch (InvocationTargetException e) { - assert false; - } - } - - String getProbeName() { - return DTraceProvider.getProbeName(declared_method); - } - - String getFunctionName() { - return DTraceProvider.getFunctionName(declared_method); - } - - Method getMethod() { - return implementing_method; - } - - Class[] getParameterTypes() { - return this.parameters; - } -} - diff --git a/jdk/src/jdk.runtime/share/classes/sun/tracing/dtrace/DTraceProvider.java b/jdk/src/jdk.runtime/share/classes/sun/tracing/dtrace/DTraceProvider.java deleted file mode 100644 index d03625d45b7..00000000000 --- a/jdk/src/jdk.runtime/share/classes/sun/tracing/dtrace/DTraceProvider.java +++ /dev/null @@ -1,210 +0,0 @@ -/* - * Copyright (c) 2008, 2014, 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. Oracle designates this - * particular file as subject to the "Classpath" exception as provided - * by Oracle in the LICENSE file that accompanied this code. - * - * 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. - */ - -package sun.tracing.dtrace; - -import java.lang.reflect.Method; -import java.lang.reflect.Modifier; -import java.lang.reflect.Constructor; -import java.lang.reflect.InvocationHandler; -import java.lang.reflect.InvocationTargetException; -import java.lang.annotation.Annotation; - -import sun.tracing.ProviderSkeleton; -import sun.tracing.ProbeSkeleton; -import com.sun.tracing.Provider; -import com.sun.tracing.ProbeName; -import com.sun.tracing.dtrace.Attributes; -import com.sun.tracing.dtrace.ModuleName; -import com.sun.tracing.dtrace.FunctionName; -import com.sun.tracing.dtrace.StabilityLevel; -import com.sun.tracing.dtrace.DependencyClass; - -import sun.misc.ProxyGenerator; - -class DTraceProvider extends ProviderSkeleton { - - private Activation activation; - private Object proxy; - - // For proxy generation - private final static Class[] constructorParams = { InvocationHandler.class }; - private final String proxyClassNamePrefix = "$DTraceTracingProxy"; - - static final String DEFAULT_MODULE = "java_tracing"; - static final String DEFAULT_FUNCTION = "unspecified"; - - private static long nextUniqueNumber = 0; - private static synchronized long getUniqueNumber() { - return nextUniqueNumber++; - } - - protected ProbeSkeleton createProbe(Method m) { - return new DTraceProbe(proxy, m); - } - - DTraceProvider(Class type) { - super(type); - } - - void setProxy(Object p) { - proxy = p; - } - - void setActivation(Activation a) { - this.activation = a; - } - - public void dispose() { - if (activation != null) { - activation.disposeProvider(this); - activation = null; - } - super.dispose(); - } - - /** - * Magic routine which creates an implementation of the user's interface. - * - * This method uses the ProxyGenerator directly to bypass the - * java.lang.reflect.proxy cache so that we get a unique class each - * time it's called and can't accidently reuse a $Proxy class. - * - * @return an implementation of the user's interface - */ - @SuppressWarnings("unchecked") - public T newProxyInstance() { - /* - * Choose a name for the proxy class to generate. - */ - long num = getUniqueNumber(); - - String proxyPkg = ""; - if (!Modifier.isPublic(providerType.getModifiers())) { - String name = providerType.getName(); - int n = name.lastIndexOf('.'); - proxyPkg = ((n == -1) ? "" : name.substring(0, n + 1)); - } - - String proxyName = proxyPkg + proxyClassNamePrefix + num; - - /* - * Generate the specified proxy class. - */ - Class proxyClass = null; - byte[] proxyClassFile = ProxyGenerator.generateProxyClass( - proxyName, new Class[] { providerType }); - try { - proxyClass = JVM.defineClass( - providerType.getClassLoader(), proxyName, - proxyClassFile, 0, proxyClassFile.length); - } catch (ClassFormatError e) { - /* - * A ClassFormatError here means that (barring bugs in the - * proxy class generation code) there was some other - * invalid aspect of the arguments supplied to the proxy - * class creation (such as virtual machine limitations - * exceeded). - */ - throw new IllegalArgumentException(e.toString()); - } - - /* - * Invoke its constructor with the designated invocation handler. - */ - try { - Constructor cons = proxyClass.getConstructor(constructorParams); - return (T)cons.newInstance(new Object[] { this }); - } catch (ReflectiveOperationException e) { - throw new InternalError(e.toString(), e); - } - } - - // In the normal case, the proxy object's method implementations will call - // this method (it usually calls the ProviderSkeleton's version). That - // method uses the passed 'method' object to lookup the associated - // 'ProbeSkeleton' and calls uncheckedTrigger() on that probe to cause the - // probe to fire. DTrace probes are different in that the proxy class's - // methods are immediately overridden with native code to fire the probe - // directly. So this method should never get invoked. We also wire up the - // DTraceProbe.uncheckedTrigger() method to call the proxy method instead - // of doing the work itself. - protected void triggerProbe(Method method, Object[] args) { - assert false : "This method should have been overridden by the JVM"; - } - - public String getProviderName() { - return super.getProviderName(); - } - - String getModuleName() { - return getAnnotationString( - providerType, ModuleName.class, DEFAULT_MODULE); - } - - static String getProbeName(Method method) { - return getAnnotationString( - method, ProbeName.class, method.getName()); - } - - static String getFunctionName(Method method) { - return getAnnotationString( - method, FunctionName.class, DEFAULT_FUNCTION); - } - - DTraceProbe[] getProbes() { - return probes.values().toArray(new DTraceProbe[0]); - } - - StabilityLevel getNameStabilityFor(Class type) { - Attributes attrs = (Attributes)getAnnotationValue( - providerType, type, "value", null); - if (attrs == null) { - return StabilityLevel.PRIVATE; - } else { - return attrs.name(); - } - } - - StabilityLevel getDataStabilityFor(Class type) { - Attributes attrs = (Attributes)getAnnotationValue( - providerType, type, "value", null); - if (attrs == null) { - return StabilityLevel.PRIVATE; - } else { - return attrs.data(); - } - } - - DependencyClass getDependencyClassFor(Class type) { - Attributes attrs = (Attributes)getAnnotationValue( - providerType, type, "value", null); - if (attrs == null) { - return DependencyClass.UNKNOWN; - } else { - return attrs.dependency(); - } - } -} diff --git a/jdk/src/jdk.runtime/share/classes/sun/tracing/dtrace/DTraceProviderFactory.java b/jdk/src/jdk.runtime/share/classes/sun/tracing/dtrace/DTraceProviderFactory.java deleted file mode 100644 index 84ea8cee131..00000000000 --- a/jdk/src/jdk.runtime/share/classes/sun/tracing/dtrace/DTraceProviderFactory.java +++ /dev/null @@ -1,156 +0,0 @@ -/* - * Copyright (c) 2008, 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. Oracle designates this - * particular file as subject to the "Classpath" exception as provided - * by Oracle in the LICENSE file that accompanied this code. - * - * 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. - */ - -package sun.tracing.dtrace; - -import java.util.Map; -import java.util.Set; -import java.util.HashMap; -import java.util.HashSet; -import java.security.Permission; - -import com.sun.tracing.ProviderFactory; -import com.sun.tracing.Provider; - -/** - * Factory class to create JSDT Providers. - * - * This class contains methods to create an instance of a Provider - * interface which can be used to place tracepoints in an application. - * Method calls upon that instance trigger DTrace probes that - * are visible from DTrace scripts. Such calls have no other - * side effects in the application. - *

- * The DTrace script mechanisms for listing and matching probes will not see - * nor match any probes until the provider they reside in is created by a - * call to {@code createProvider()} (or {@code createProviders()}). - *

- * Providers that are created should be disposed of when they are no longer - * needed to free up system resources, at which point the associated - * DTrace probes will no longer be available to DTrace. One disposes a - * provider by calling - * {@link com.sun.tracing.Provider#dispose Provider.dispose()} on a - * created provider instance. - * - * @since 1.7 - */ -public final class DTraceProviderFactory extends ProviderFactory { - /** - * Creates an instance of a provider which can then be used to trigger - * DTrace probes. - * - * The provider specification, provided as an argument, should only - * contain methods which have a 'void' return type and String or - * integer-based typed arguments (long, int, short, char, byte, or boolean). - * - * @param cls A user-defined interface which extends {@code Provider}. - * @return An instance of the interface which is used to trigger - * the DTrace probes. - * @throws java.lang.SecurityException if a security manager has been - * installed and it denies - * RuntimePermission("com.sun.dtrace.jsdt.createProvider") - * @throws java.lang.IllegalArgumentException if the interface contains - * methods that do not return null, or that contain arguments that are - * not String or integer types. - */ - public T createProvider(Class cls) { - DTraceProvider jsdt = new DTraceProvider(cls); - T proxy = jsdt.newProxyInstance(); - jsdt.setProxy(proxy); - jsdt.init(); - new Activation(jsdt.getModuleName(), new DTraceProvider[] { jsdt }); - return proxy; - } - - /** - * Creates multiple providers at once. - * - * This method batches together a number of provider instantiations. - * It works similarly - * to {@code createProvider}, but operates on a set of providers instead - * of one at a time. This method is in place since some DTrace - * implementations limit the number of times that providers can be - * created. When numerous providers can be created at once with this - * method, it will count only as a single creation point to DTrace, thus - * it uses less system resources. - *

- * All of the probes in the providers will be visible to DTrace after - * this call and all will remain visible until all of the providers - * are disposed. - *

- * The {@code moduleName} parameter will override any {@code ModuleName} - * annotation associated with any of the providers in the set. - * All of the probes created by this call will share the same - * module name. - *

- * @param providers a set of provider specification interfaces - * @param moduleName the module name to associate with all probes - * @return A map which maps the provider interface specification to an - * implementing instance. - * @throws java.lang.SecurityException if a security manager has been - * installed and it denies - * RuntimePermission("com.sun.dtrace.jsdt.createProvider") - * @throws java.lang.IllegalArgumentException if any of the interface - * contains methods that do not return null, or that contain arguments - * that are not String or integer types. - */ - public Map,Provider> createProviders( - Set> providers, String moduleName) { - HashMap,Provider> map = - new HashMap,Provider>(); - HashSet jsdts = new HashSet(); - for (Class cls : providers) { - DTraceProvider jsdt = new DTraceProvider(cls); - jsdts.add(jsdt); - map.put(cls, jsdt.newProxyInstance()); - } - new Activation(moduleName, jsdts.toArray(new DTraceProvider[0])); - return map; - } - - /** - * Used to check the status of DTrace support in the underlying JVM and - * operating system. - * - * This is an informative method only - the Java-level effects of - * creating providers and triggering probes will not change whether or - * not DTrace is supported by the underlying systems. - * - * @return true if DTrace is supported - */ - public static boolean isSupported() { - try { - SecurityManager security = System.getSecurityManager(); - if (security != null) { - Permission perm = new RuntimePermission( - "com.sun.tracing.dtrace.createProvider"); - security.checkPermission(perm); - } - return JVM.isSupported(); - } catch (SecurityException e) { - return false; - } - } -} diff --git a/jdk/src/jdk.runtime/share/classes/sun/tracing/dtrace/JVM.java b/jdk/src/jdk.runtime/share/classes/sun/tracing/dtrace/JVM.java deleted file mode 100644 index a3fb5e1838d..00000000000 --- a/jdk/src/jdk.runtime/share/classes/sun/tracing/dtrace/JVM.java +++ /dev/null @@ -1,75 +0,0 @@ -/* - * Copyright (c) 2008, 2012, 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. Oracle designates this - * particular file as subject to the "Classpath" exception as provided - * by Oracle in the LICENSE file that accompanied this code. - * - * 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. - */ - -package sun.tracing.dtrace; - -import java.lang.reflect.Method; - -/** - * Container class for JVM interface native methods - * - * @since 1.7 - */ -class JVM { - - static { - java.security.AccessController.doPrivileged( - new java.security.PrivilegedAction() { - public Void run() { - System.loadLibrary("jsdt"); - return null; - } - }); - } - - static long activate(String moduleName, DTraceProvider[] providers) { - return activate0(moduleName, providers); - } - - static void dispose(long handle) { - dispose0(handle); - } - - static boolean isEnabled(Method m) { - return isEnabled0(m); - } - - static boolean isSupported() { - return isSupported0(); - } - - static Class defineClass( - ClassLoader loader, String name, byte[] b, int off, int len) { - return defineClass0(loader, name, b, off, len); - } - - private static native long activate0( - String moduleName, DTraceProvider[] providers); - private static native void dispose0(long activation_handle); - private static native boolean isEnabled0(Method m); - private static native boolean isSupported0(); - private static native Class defineClass0( - ClassLoader loader, String name, byte[] b, int off, int len); -} diff --git a/jdk/src/jdk.runtime/share/classes/sun/tracing/package-info.java b/jdk/src/jdk.runtime/share/classes/sun/tracing/package-info.java deleted file mode 100644 index 533eb7af048..00000000000 --- a/jdk/src/jdk.runtime/share/classes/sun/tracing/package-info.java +++ /dev/null @@ -1,57 +0,0 @@ -/* - * Copyright (c) 2008, 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. Oracle designates this - * particular file as subject to the "Classpath" exception as provided - * by Oracle in the LICENSE file that accompanied this code. - * - * 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. - */ - -/** - * This package contains internal common code for implementing tracing - * frameworks, and defined a number of existing frameworks. - *

- * There are four tracing frameworks currently defined. The "Null" and - * "Multiplex" frameworks are used internally as part of the implementation. - * The "DTrace" framework is the prime consumer framework at the moment, - * while the "PrintStream" framework is a functional, but hidden, framework - * which can be used to track probe firings. All but the "DTrace" framework - * are defined in this package. The "DTrace" framework is implemented in the - * {@code sun.tracing.dtrace} package. - *

- * This package also contains the {@code ProviderSkeleton} class, which - * holds most of the common code needed for implementing frameworks. - *

- * The "Null" framework is used when there are no other active frameworks. - * It accomplishes absolutely nothing and is merely a placeholder so that - * the application can call the tracing routines without error. - *

- * The "Multiplex" framework is used when there are multiple active frameworks. - * It is initialized with the framework factories and create providers and - * probes that dispatch to each active framework in turn. - *

- * The "PrintStream" framework is currently a debugging framework which - * dispatches trace calls to a user-defined PrintStream class, defined by - * a property. It may some day be opened up to general use. - *

- * See the {@code sun.tracing.dtrace} and {@code com.sun.tracing.dtrace} - * packages for information on the "DTrace" framework. - */ - -package sun.tracing; diff --git a/jdk/src/jdk.runtime/share/native/libjsdt/JVM.c b/jdk/src/jdk.runtime/share/native/libjsdt/JVM.c deleted file mode 100644 index e81eb3d7064..00000000000 --- a/jdk/src/jdk.runtime/share/native/libjsdt/JVM.c +++ /dev/null @@ -1,334 +0,0 @@ -/* - * Copyright (c) 2008, 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. Oracle designates this - * particular file as subject to the "Classpath" exception as provided - * by Oracle in the LICENSE file that accompanied this code. - * - * 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. - */ - -#include - -#include "jvm.h" -#include "jni.h" -#include "jni_util.h" - -#include "jvm_symbols.h" -#include "sun_tracing_dtrace_JVM.h" - -#ifdef __cplusplus -extern "C" { -#endif - -static JvmSymbols* jvm_symbols = NULL; - -static void initialize() { - static int initialized = 0; - if (initialized == 0) { - jvm_symbols = lookupJvmSymbols(); - initialized = 1; - } -} - -/* - * Class: sun_tracing_dtrace_JVM - * Method: isSupported0 - * Signature: ()I - */ -JNIEXPORT jboolean JNICALL Java_sun_tracing_dtrace_JVM_isSupported0( - JNIEnv* env, jclass cls) { - initialize(); - if (jvm_symbols != NULL) { - return jvm_symbols->IsSupported(env) ? JNI_TRUE : JNI_FALSE; - } else { - return JNI_FALSE; - } -} - -// Macros that cause an immediate return if we detect an exception -#define CHECK if ((*env)->ExceptionOccurred(env)) { return; } -#define CHECK_(x) if ((*env)->ExceptionOccurred(env)) { return x; } - -static void readProbeData ( - JNIEnv* env, jobject probe, JVM_DTraceProbe* jvm_probe) { - jclass clazz; - jmethodID mid; - jobject method; - - if (jvm_probe == NULL) { - return; // just in case - } - - clazz = (*env)->GetObjectClass(env, probe); CHECK - - mid = (*env)->GetMethodID( - env, clazz, "getFunctionName", "()Ljava/lang/String;"); CHECK - jvm_probe->function = (jstring)(*env)->CallObjectMethod( - env, probe, mid); CHECK - - mid = (*env)->GetMethodID( - env, clazz, "getProbeName", "()Ljava/lang/String;"); CHECK - jvm_probe->name = (jstring)(*env)->CallObjectMethod(env, probe, mid); CHECK - - mid = (*env)->GetMethodID( - env, clazz, "getMethod", "()Ljava/lang/reflect/Method;"); CHECK - method = (*env)->CallObjectMethod(env, probe, mid); CHECK - jvm_probe->method = (*env)->FromReflectedMethod(env, method); CHECK -} - -static void readFieldInterfaceAttributes( - char* annotationName, JNIEnv* env, jobject provider, - JVM_DTraceInterfaceAttributes* attrs) { - jobject result; - jobject result_clazz; - jclass provider_clazz; - jclass annotation_clazz; - jmethodID get; - jmethodID enc; - - provider_clazz = (*env)->GetObjectClass(env, provider); CHECK - annotation_clazz = (*env)->FindClass(env, annotationName); CHECK - - get = (*env)->GetMethodID(env, provider_clazz, "getNameStabilityFor", - "(Ljava/lang/Class;)Lcom/sun/tracing/dtrace/StabilityLevel;"); CHECK - result = (*env)->CallObjectMethod( - env, provider, get, annotation_clazz); CHECK - result_clazz = (*env)->GetObjectClass(env, result); CHECK - enc = (*env)->GetMethodID(env, result_clazz, "getEncoding", "()I"); CHECK - attrs->nameStability = (*env)->CallIntMethod(env, result, enc); CHECK - - get = (*env)->GetMethodID(env, provider_clazz, "getDataStabilityFor", - "(Ljava/lang/Class;)Lcom/sun/tracing/dtrace/StabilityLevel;"); CHECK - result = (*env)->CallObjectMethod( - env, provider, get, annotation_clazz); CHECK - result_clazz = (*env)->GetObjectClass(env, result); CHECK - enc = (*env)->GetMethodID(env, result_clazz, "getEncoding", "()I"); CHECK - attrs->dataStability = (*env)->CallIntMethod(env, result, enc); CHECK - - get = (*env)->GetMethodID(env, provider_clazz, "getDependencyClassFor", - "(Ljava/lang/Class;)Lcom/sun/tracing/dtrace/DependencyClass;"); CHECK - result = (*env)->CallObjectMethod( - env, provider, get, annotation_clazz); CHECK - result_clazz = (*env)->GetObjectClass(env, result); CHECK - enc = (*env)->GetMethodID(env, result_clazz, "getEncoding", "()I"); CHECK - attrs->dependencyClass = (*env)->CallIntMethod(env, result, enc); CHECK -} - -static void readInterfaceAttributes( - JNIEnv* env, jobject provider, JVM_DTraceProvider* jvm_provider) { - readFieldInterfaceAttributes("com/sun/tracing/dtrace/ProviderAttributes", - env, provider, &(jvm_provider->providerAttributes)); - readFieldInterfaceAttributes("com/sun/tracing/dtrace/ModuleAttributes", - env, provider, &(jvm_provider->moduleAttributes)); - readFieldInterfaceAttributes("com/sun/tracing/dtrace/FunctionAttributes", - env, provider, &(jvm_provider->functionAttributes)); - readFieldInterfaceAttributes("com/sun/tracing/dtrace/NameAttributes", - env, provider, &(jvm_provider->nameAttributes)); - readFieldInterfaceAttributes("com/sun/tracing/dtrace/ArgsAttributes", - env, provider, &(jvm_provider->argsAttributes)); -} - -static int readProviderData( - JNIEnv* env, jobject provider, JVM_DTraceProvider* jvm_provider) { - jmethodID mid; - jobjectArray probes; - jsize i; - jclass clazz = (*env)->GetObjectClass(env, provider); CHECK_(0) - mid = (*env)->GetMethodID( - env, clazz, "getProbes", "()[Lsun/tracing/dtrace/DTraceProbe;"); CHECK_(0) - probes = (jobjectArray)(*env)->CallObjectMethod( - env, provider, mid); CHECK_(0) - - // Fill JVM structure, describing provider - jvm_provider->probe_count = (*env)->GetArrayLength(env, probes); CHECK_(0) - jvm_provider->probes = (JVM_DTraceProbe*)calloc( - jvm_provider->probe_count, sizeof(*jvm_provider->probes)); - mid = (*env)->GetMethodID( - env, clazz, "getProviderName", "()Ljava/lang/String;"); CHECK_(0) - jvm_provider->name = (jstring)(*env)->CallObjectMethod( - env, provider, mid); CHECK_(0) - - readInterfaceAttributes(env, provider, jvm_provider); CHECK_(0) - - for (i = 0; i < jvm_provider->probe_count; ++i) { - jobject probe = (*env)->GetObjectArrayElement(env, probes, i); CHECK_(0) - readProbeData(env, probe, &jvm_provider->probes[i]); CHECK_(0) - } - - return 1; -} - -/* - * Class: sun_tracing_dtrace_JVM - * Method: activate0 - * Signature: ()J - */ -JNIEXPORT jlong JNICALL Java_sun_tracing_dtrace_JVM_activate0( - JNIEnv* env, jclass cls, jstring moduleName, jobjectArray providers) { - jlong handle = 0; - jsize num_providers; - jsize i; - jsize count = 0; - JVM_DTraceProvider* jvm_providers; - - initialize(); - - if (jvm_symbols == NULL) { - return 0; - } - - num_providers = (*env)->GetArrayLength(env, providers); CHECK_(0L) - - jvm_providers = (JVM_DTraceProvider*)calloc( - num_providers, sizeof(*jvm_providers)); - - for (; count < num_providers; ++count) { - JVM_DTraceProvider* p = &(jvm_providers[count]); - jobject provider = (*env)->GetObjectArrayElement( - env, providers, count); - if ((*env)->ExceptionOccurred(env) || - ! readProviderData(env, provider, p)) { - // got an error, bail out! - break; - } - } - - if (count == num_providers) { - // all providers successfully loaded - get the handle - handle = jvm_symbols->Activate( - env, JVM_TRACING_DTRACE_VERSION, moduleName, - num_providers, jvm_providers); - } - - for (i = 0; i < num_providers; ++i) { - JVM_DTraceProvider* p = &(jvm_providers[i]); - free(p->probes); - } - free(jvm_providers); - - return handle; -} - -/* - * Class: sun_tracing_dtrace_JVM - * Method: dispose0 - * Signature: (J)V - */ -JNIEXPORT void JNICALL Java_sun_tracing_dtrace_JVM_dispose0( - JNIEnv* env, jclass cls, jlong handle) { - if (jvm_symbols != NULL && handle != 0) { - jvm_symbols->Dispose(env, handle); - } -} - -/* - * Class: sun_tracing_dtrace_JVM - * Method: isEnabled0 - * Signature: (Ljava/lang/String;Ljava/lang/String;)Z - */ -JNIEXPORT jboolean JNICALL Java_sun_tracing_dtrace_JVM_isEnabled0( - JNIEnv* env, jclass cls, jobject method) { - jmethodID mid; - if (jvm_symbols != NULL && method != NULL) { - mid = (*env)->FromReflectedMethod(env, method); - return jvm_symbols->IsProbeEnabled(env, mid); - } - return JNI_FALSE; -} - -/* - * Class: sun_tracing_dtrace_JVM - * Method: defineClass0 - * Signature: (Ljava/lang/ClassLoader;Ljava/lang/String;[BII)Ljava/lang/Class; - * - * The implementation of this native static method is a copy of that of - * the native instance method Java_java_lang_ClassLoader_defineClass0() - * with the implicit "this" parameter becoming the "loader" parameter. - * - * This code was cloned and modified from java_lang_reflect_Proxy - */ -JNIEXPORT jclass JNICALL -Java_sun_tracing_dtrace_JVM_defineClass0( - JNIEnv *env, jclass ignore, jobject loader, jstring name, jbyteArray data, - jint offset, jint length) -{ - jbyte *body; - char *utfName; - jclass result = 0; - char buf[128]; - - if (data == NULL) { - return 0; - } - - /* Work around 4153825. malloc crashes on Solaris when passed a - * negative size. - */ - if (length < 0) { - return 0; - } - - body = (jbyte *)malloc(length); - - if (body == 0) { - return 0; - } - - (*env)->GetByteArrayRegion(env, data, offset, length, body); - - if ((*env)->ExceptionOccurred(env)) - goto free_body; - - if (name != NULL) { - int i; - jsize len = (*env)->GetStringUTFLength(env, name); - int unicode_len = (*env)->GetStringLength(env, name); - if (len >= (jsize)sizeof(buf)) { - utfName = malloc(len + 1); - if (utfName == NULL) { - goto free_body; - } - } else { - utfName = buf; - } - (*env)->GetStringUTFRegion(env, name, 0, unicode_len, utfName); - - // Convert '.' to '/' in the package name - for (i = 0; i < unicode_len; ++i) { - if (utfName[i] == '.') { - utfName[i] = '/'; - } - } - } else { - utfName = NULL; - } - - result = (*env)->DefineClass(env, utfName, loader, body, length); - - if (utfName && utfName != buf) - free(utfName); - - free_body: - free(body); - return result; -} - -#ifdef __cplusplus -} -#endif diff --git a/jdk/src/jdk.runtime/share/native/libjsdt/jvm_symbols.h b/jdk/src/jdk.runtime/share/native/libjsdt/jvm_symbols.h deleted file mode 100644 index adbcaec96ba..00000000000 --- a/jdk/src/jdk.runtime/share/native/libjsdt/jvm_symbols.h +++ /dev/null @@ -1,50 +0,0 @@ -/* - * Copyright (c) 2008, 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. Oracle designates this - * particular file as subject to the "Classpath" exception as provided - * by Oracle in the LICENSE file that accompanied this code. - * - * 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. - */ - -#ifndef _JVM_SYMBOLS_H -#define _JVM_SYMBOLS_H - -#include "jvm.h" - -typedef jint (JNICALL* GetVersion_t)(JNIEnv*); -typedef jboolean (JNICALL *IsSupported_t)(JNIEnv*); -typedef jlong (JNICALL* Activate_t)( - JNIEnv*, jint, jstring, jint, JVM_DTraceProvider*); -typedef void (JNICALL *Dispose_t)(JNIEnv*, jlong); -typedef jboolean (JNICALL *IsProbeEnabled_t)(JNIEnv*, jmethodID); - -typedef struct { - GetVersion_t GetVersion; - IsSupported_t IsSupported; - Activate_t Activate; - Dispose_t Dispose; - IsProbeEnabled_t IsProbeEnabled; -} JvmSymbols; - -// Platform-dependent implementation. -// Returns NULL if the symbols are not found -extern JvmSymbols* lookupJvmSymbols(); - -#endif // def _JVM_SYMBOLS_H diff --git a/jdk/src/jdk.runtime/unix/native/libjsdt/jvm_symbols_md.c b/jdk/src/jdk.runtime/unix/native/libjsdt/jvm_symbols_md.c deleted file mode 100644 index 37f7849934e..00000000000 --- a/jdk/src/jdk.runtime/unix/native/libjsdt/jvm_symbols_md.c +++ /dev/null @@ -1,55 +0,0 @@ -/* - * Copyright (c) 2008, 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. Oracle designates this - * particular file as subject to the "Classpath" exception as provided - * by Oracle in the LICENSE file that accompanied this code. - * - * 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. - */ - -#include -#include - -#include - -#include "jvm_symbols.h" - -JvmSymbols* lookupJvmSymbols() { - JvmSymbols* syms = (JvmSymbols*)malloc(sizeof(JvmSymbols)); - if (syms != NULL) { - syms->GetVersion = (GetVersion_t) - dlsym(RTLD_DEFAULT, "JVM_DTraceGetVersion"); - syms->IsSupported = (IsSupported_t) - dlsym(RTLD_DEFAULT, "JVM_DTraceIsSupported"); - syms->Activate = (Activate_t) - dlsym(RTLD_DEFAULT, "JVM_DTraceActivate"); - syms->Dispose = (Dispose_t) - dlsym(RTLD_DEFAULT, "JVM_DTraceDispose"); - syms->IsProbeEnabled = (IsProbeEnabled_t) - dlsym(RTLD_DEFAULT, "JVM_DTraceIsProbeEnabled"); - - if ( syms->GetVersion == NULL || syms->Activate == NULL || - syms->IsProbeEnabled == NULL || syms->Dispose == NULL || - syms->IsSupported == NULL) { - free(syms); - syms = NULL; - } - } - return syms; -} diff --git a/jdk/src/jdk.runtime/windows/native/libjsdt/jvm_symbols_md.c b/jdk/src/jdk.runtime/windows/native/libjsdt/jvm_symbols_md.c deleted file mode 100644 index adca9ecb0e3..00000000000 --- a/jdk/src/jdk.runtime/windows/native/libjsdt/jvm_symbols_md.c +++ /dev/null @@ -1,64 +0,0 @@ -/* - * Copyright (c) 2008, 2011, 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. Oracle designates this - * particular file as subject to the "Classpath" exception as provided - * by Oracle in the LICENSE file that accompanied this code. - * - * 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. - */ - -#include -#include -#include -#include - -#include - -#include "jvm_symbols.h" - -JvmSymbols* lookupJvmSymbols() { - JvmSymbols* syms = (JvmSymbols*)malloc(sizeof(JvmSymbols)); - if (syms != NULL) { - HINSTANCE jvm = GetModuleHandle("jvm.dll"); - if (jvm == NULL) { - free(syms); - return NULL; - } - syms->GetVersion = (GetVersion_t) - GetProcAddress(jvm, "JVM_DTraceGetVersion"); - syms->IsSupported = (IsSupported_t) - GetProcAddress(jvm, "JVM_DTraceIsSupported"); - syms->Activate = (Activate_t) - GetProcAddress(jvm, "JVM_DTraceActivate"); - syms->Dispose = (Dispose_t) - GetProcAddress(jvm, "JVM_DTraceDispose"); - syms->IsProbeEnabled = (IsProbeEnabled_t) - GetProcAddress(jvm, "JVM_DTraceIsProbeEnabled"); - - (void)FreeLibrary(jvm); - if ( syms->GetVersion == NULL || syms->IsSupported == NULL || - syms->Activate == NULL || syms->Dispose == NULL || - syms->IsProbeEnabled == NULL) { - free(syms); - syms = NULL; - } - - } - return syms; -} diff --git a/jdk/test/ProblemList.txt b/jdk/test/ProblemList.txt index 378ba4d69c1..d08f31d740f 100644 --- a/jdk/test/ProblemList.txt +++ b/jdk/test/ProblemList.txt @@ -343,7 +343,4 @@ sun/jvmstat/monitor/MonitoredVm/MonitorVmStartTerminate.java generic-all # 8064572 8060736 8062938 sun/jvmstat/monitor/MonitoredVm/CR6672135.java generic-all -# 8060088 -com/sun/tracing/BasicWithSecurityMgr.java generic-all - ############################################################################ diff --git a/jdk/test/TEST.groups b/jdk/test/TEST.groups index 7acb6ab9147..ed17842d220 100644 --- a/jdk/test/TEST.groups +++ b/jdk/test/TEST.groups @@ -190,7 +190,6 @@ core_tools = \ svc_tools = \ com/sun/tools/attach \ - com/sun/tracing \ sun/tools \ -sun/tools/java \ -sun/tools/native2ascii \ @@ -562,7 +561,6 @@ needs_compact3 = \ com/sun/security/auth \ com/sun/security/sasl \ com/sun/security/jgss \ - com/sun/tracing \ java/util/prefs \ javax/naming \ javax/security \ diff --git a/jdk/test/com/sun/tracing/BasicFunctionality.java b/jdk/test/com/sun/tracing/BasicFunctionality.java deleted file mode 100644 index b8fc98a0728..00000000000 --- a/jdk/test/com/sun/tracing/BasicFunctionality.java +++ /dev/null @@ -1,147 +0,0 @@ -/* - * Copyright (c) 2008, 2010, 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. - */ - -/** - * @test - * @bug 6537506 - * @ignore 6962535 - * @summary Basic unit test for tracing framework - */ - -import com.sun.tracing.*; -import java.lang.reflect.Method; - -@ProviderName("NamedProvider") -interface BasicProvider extends Provider { - void plainProbe(); - void probeWithArgs(int a, float f, String s, Long l); - @ProbeName("namedProbe") void probeWithName(); - void overloadedProbe(); - void overloadedProbe(int i); -} - -interface InvalidProvider extends Provider { - int nonVoidProbe(); -} - -public class BasicFunctionality { - - public static ProviderFactory factory; - public static BasicProvider bp; - - public static void main(String[] args) throws Exception { - - factory = ProviderFactory.getDefaultFactory(); - if (factory != null) { - bp = factory.createProvider(BasicProvider.class); - } - - testProviderFactory(); - testProbe(); - testProvider(); - } - - static void fail(String s) throws Exception { - throw new Exception(s); - } - - static void testProviderFactory() throws Exception { - if (factory == null) { - fail("ProviderFactory.getDefaultFactory: Did not create factory"); - } - if (bp == null) { - fail("ProviderFactory.createProvider: Did not create provider"); - } - try { - factory.createProvider(null); - fail("ProviderFactory.createProvider: Did not throw NPE for null"); - } catch (NullPointerException e) {} - - try { - factory.createProvider(InvalidProvider.class); - fail("Factory.createProvider: Should error with non-void probes"); - } catch (IllegalArgumentException e) {} - } - - public static void testProvider() throws Exception { - - // These just shouldn't throw any exeptions: - bp.plainProbe(); - bp.probeWithArgs(42, (float)3.14, "spam", new Long(2L)); - bp.probeWithArgs(42, (float)3.14, null, null); - bp.probeWithName(); - bp.overloadedProbe(); - bp.overloadedProbe(42); - - Method m = BasicProvider.class.getMethod("plainProbe"); - Probe p = bp.getProbe(m); - if (p == null) { - fail("Provider.getProbe: Did not return probe"); - } - - Method m2 = BasicFunctionality.class.getMethod("testProvider"); - p = bp.getProbe(m2); - if (p != null) { - fail("Provider.getProbe: Got probe with invalid spec"); - } - - bp.dispose(); - // These just shouldn't throw any exeptions: - bp.plainProbe(); - bp.probeWithArgs(42, (float)3.14, "spam", new Long(2L)); - bp.probeWithArgs(42, (float)3.14, null, null); - bp.probeWithName(); - bp.overloadedProbe(); - bp.overloadedProbe(42); - - if (bp.getProbe(m) != null) { - fail("Provider.getProbe: Should return null after dispose()"); - } - - bp.dispose(); // just to make sure nothing bad happens - } - - static void testProbe() throws Exception { - Method m = BasicProvider.class.getMethod("plainProbe"); - Probe p = bp.getProbe(m); - p.isEnabled(); // just make sure it doesn't do anything bad - p.trigger(); - - try { - p.trigger(0); - fail("Probe.trigger: too many arguments not caught"); - } catch (IllegalArgumentException e) {} - - p = bp.getProbe(BasicProvider.class.getMethod( - "probeWithArgs", int.class, float.class, String.class, Long.class)); - try { - p.trigger(); - fail("Probe.trigger: too few arguments not caught"); - } catch (IllegalArgumentException e) {} - - try { - p.trigger((float)3.14, (float)3.14, "", new Long(0L)); - fail("Probe.trigger: wrong type primitive arguments not caught"); - } catch (IllegalArgumentException e) {} - } -} diff --git a/jdk/test/com/sun/tracing/BasicWithSecurityMgr.java b/jdk/test/com/sun/tracing/BasicWithSecurityMgr.java deleted file mode 100644 index 12e5c258571..00000000000 --- a/jdk/test/com/sun/tracing/BasicWithSecurityMgr.java +++ /dev/null @@ -1,149 +0,0 @@ -/* - * Copyright (c) 2008, 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. - */ - -/** - * @test - * @bug 6899605 - * @summary Basic unit test for tracing framework with security manager - * enabled - */ - -import com.sun.tracing.*; -import java.lang.reflect.Method; - -@ProviderName("NamedProvider") -interface BasicProvider extends Provider { - void plainProbe(); - void probeWithArgs(int a, float f, String s, Long l); - @ProbeName("namedProbe") void probeWithName(); - void overloadedProbe(); - void overloadedProbe(int i); -} - -interface InvalidProvider extends Provider { - int nonVoidProbe(); -} - -public class BasicWithSecurityMgr { - - public static ProviderFactory factory; - public static BasicProvider bp; - - public static void main(String[] args) throws Exception { - // enable security manager - System.setSecurityManager(new SecurityManager()); - - factory = ProviderFactory.getDefaultFactory(); - if (factory != null) { - bp = factory.createProvider(BasicProvider.class); - } - - testProviderFactory(); - testProbe(); - testProvider(); - } - - static void fail(String s) throws Exception { - throw new Exception(s); - } - - static void testProviderFactory() throws Exception { - if (factory == null) { - fail("ProviderFactory.getDefaultFactory: Did not create factory"); - } - if (bp == null) { - fail("ProviderFactory.createProvider: Did not create provider"); - } - try { - factory.createProvider(null); - fail("ProviderFactory.createProvider: Did not throw NPE for null"); - } catch (NullPointerException e) {} - - try { - factory.createProvider(InvalidProvider.class); - fail("Factory.createProvider: Should error with non-void probes"); - } catch (IllegalArgumentException e) {} - } - - public static void testProvider() throws Exception { - - // These just shouldn't throw any exeptions: - bp.plainProbe(); - bp.probeWithArgs(42, (float)3.14, "spam", new Long(2L)); - bp.probeWithArgs(42, (float)3.14, null, null); - bp.probeWithName(); - bp.overloadedProbe(); - bp.overloadedProbe(42); - - Method m = BasicProvider.class.getMethod("plainProbe"); - Probe p = bp.getProbe(m); - if (p == null) { - fail("Provider.getProbe: Did not return probe"); - } - - Method m2 = BasicWithSecurityMgr.class.getMethod("testProvider"); - p = bp.getProbe(m2); - if (p != null) { - fail("Provider.getProbe: Got probe with invalid spec"); - } - - bp.dispose(); - // These just shouldn't throw any exeptions: - bp.plainProbe(); - bp.probeWithArgs(42, (float)3.14, "spam", new Long(2L)); - bp.probeWithArgs(42, (float)3.14, null, null); - bp.probeWithName(); - bp.overloadedProbe(); - bp.overloadedProbe(42); - - if (bp.getProbe(m) != null) { - fail("Provider.getProbe: Should return null after dispose()"); - } - - bp.dispose(); // just to make sure nothing bad happens - } - - static void testProbe() throws Exception { - Method m = BasicProvider.class.getMethod("plainProbe"); - Probe p = bp.getProbe(m); - p.isEnabled(); // just make sure it doesn't do anything bad - p.trigger(); - - try { - p.trigger(0); - fail("Probe.trigger: too many arguments not caught"); - } catch (IllegalArgumentException e) {} - - p = bp.getProbe(BasicProvider.class.getMethod( - "probeWithArgs", int.class, float.class, String.class, Long.class)); - try { - p.trigger(); - fail("Probe.trigger: too few arguments not caught"); - } catch (IllegalArgumentException e) {} - - try { - p.trigger((float)3.14, (float)3.14, "", new Long(0L)); - fail("Probe.trigger: wrong type primitive arguments not caught"); - } catch (IllegalArgumentException e) {} - } -} From 1409c46772b02ec91ec81456a42b605beefef769 Mon Sep 17 00:00:00 2001 From: Alexander Scherbatiy Date: Wed, 17 Dec 2014 14:58:58 +0300 Subject: [PATCH 009/116] 6219960: null reference in ToolTipManager Reviewed-by: serb, azvegint --- .../classes/javax/swing/ToolTipManager.java | 5 +- .../swing/JToolTip/6219960/bug6219960.java | 210 ++++++++++++++++++ 2 files changed, 213 insertions(+), 2 deletions(-) create mode 100644 jdk/test/javax/swing/JToolTip/6219960/bug6219960.java diff --git a/jdk/src/java.desktop/share/classes/javax/swing/ToolTipManager.java b/jdk/src/java.desktop/share/classes/javax/swing/ToolTipManager.java index b127284be09..9bb7f00f14b 100644 --- a/jdk/src/java.desktop/share/classes/javax/swing/ToolTipManager.java +++ b/jdk/src/java.desktop/share/classes/javax/swing/ToolTipManager.java @@ -28,6 +28,7 @@ package javax.swing; import java.awt.event.*; import java.awt.*; +import java.util.Objects; /** * Manages all the ToolTips in the system. @@ -476,8 +477,8 @@ public class ToolTipManager extends MouseAdapter implements MouseMotionListener preferredLocation.equals(newPreferredLocation) : (newPreferredLocation == null); - if (!sameComponent || !toolTipText.equals(newToolTipText) || - !sameLoc) { + if (!sameComponent || !Objects.equals(toolTipText, newToolTipText) + || !sameLoc) { toolTipText = newToolTipText; preferredLocation = newPreferredLocation; showTipWindow(); diff --git a/jdk/test/javax/swing/JToolTip/6219960/bug6219960.java b/jdk/test/javax/swing/JToolTip/6219960/bug6219960.java new file mode 100644 index 00000000000..c23fa2c8472 --- /dev/null +++ b/jdk/test/javax/swing/JToolTip/6219960/bug6219960.java @@ -0,0 +1,210 @@ +/* + * Copyright (c) 2014, 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.awt.Component; +import java.awt.Container; +import java.awt.GridLayout; +import java.awt.Point; +import java.awt.Rectangle; +import java.awt.Robot; +import java.awt.AWTException; +import java.awt.IllegalComponentStateException; +import java.awt.event.InputEvent; +import javax.swing.JButton; +import javax.swing.JDesktopPane; +import javax.swing.JFrame; +import javax.swing.JInternalFrame; +import javax.swing.JOptionPane; +import javax.swing.JPanel; +import javax.swing.JScrollPane; +import javax.swing.JTable; +import javax.swing.SwingUtilities; +import javax.swing.ToolTipManager; +import javax.swing.table.DefaultTableModel; + +/** + * @test + * @bug 6219960 + * @summary null reference in ToolTipManager + * @run main bug6219960 + */ +public class bug6219960 { + + private static final String QUESTION = "Question"; + + static volatile JFrame frame; + static JTable table; + + public static void main(String[] args) throws Exception { + Robot robot = new Robot(); + SwingUtilities.invokeAndWait(bug6219960::createAndShowGUI); + robot.waitForIdle(); + showModal("The tooltip should be showing. Press ok with mouse. And don't move it."); + robot.waitForIdle(); + showModal("Now press ok and move the mouse inside the table (don't leave it)."); + robot.waitForIdle(); + } + + private static void createAndShowGUI() { + ToolTipManager.sharedInstance().setDismissDelay(10 * 60 * 1000); + frame = new JFrame(); + frame.setLocation(20, 20); + frame.setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE); + JDesktopPane desk = new JDesktopPane(); + JInternalFrame iframe = new JInternalFrame(); + iframe.setDefaultCloseOperation(JInternalFrame.DISPOSE_ON_CLOSE); + desk.add(iframe); + JButton save = new JButton(); + save.setToolTipText("Wait for dialog to show."); + save.setText("Wait for the tooltip to show."); + JPanel panel = new JPanel(new GridLayout(1, 2)); + panel.add(save); + table = createTable(); + panel.add(new JScrollPane(table)); + iframe.setContentPane(panel); + frame.getContentPane().add(desk); + frame.setSize(800, 600); + iframe.setSize(640, 480); + iframe.validate(); + iframe.setVisible(true); + frame.validate(); + frame.setVisible(true); + try { + iframe.setSelected(true); + } catch (Exception e) { + throw new AssertionError(e); + } + + try { + Robot robot = new Robot(); + Rectangle bounds = frame.getBounds(); + int centerX = (int) (bounds.getX() + bounds.getWidth() / 6); + int centerY = (int) (bounds.getY() + bounds.getHeight() / 6); + robot.mouseMove(centerX, centerY); + } catch (AWTException e) { + throw new RuntimeException(e); + } + } + + private static void showModal(final String msg) throws Exception { + + new Thread(() -> { + + int timeout = 3000; + long endTime = System.currentTimeMillis() + timeout; + + while (System.currentTimeMillis() <= endTime) { + if (pressOK(frame)) { + return; + } + } + throw new RuntimeException("Internal frame has not been found!"); + }).start(); + + Thread.sleep(900); + + SwingUtilities.invokeAndWait(() -> { + JOptionPane.showInternalMessageDialog(table, msg, + QUESTION, + JOptionPane.PLAIN_MESSAGE); + }); + } + + private static JTable createTable() { + DefaultTableModel model = new DefaultTableModel(); + JTable table = new JTable(model); + table.setFillsViewportHeight(true); + return table; + } + + private static boolean pressOK(Component comp) { + + JInternalFrame internalFrame + = findModalInternalFrame(comp, QUESTION); + + if (internalFrame == null) { + return false; + } + + JButton button = (JButton) findButton(internalFrame); + + if (button == null) { + return false; + } + + try { + Robot robot = new Robot(); + Point location = button.getLocationOnScreen(); + Rectangle bounds = button.getBounds(); + int centerX = (int) (location.getX() + bounds.getWidth() / 2); + int centerY = (int) (location.getY() + bounds.getHeight() / 2); + robot.mouseMove(centerX, centerY); + robot.mousePress(InputEvent.BUTTON1_MASK); + robot.mouseRelease(InputEvent.BUTTON1_MASK); + } catch (IllegalComponentStateException ignore) { + return false; + } catch (AWTException e) { + throw new RuntimeException(e); + } + return true; + } + + private static JInternalFrame findModalInternalFrame(Component comp, String title) { + + if (comp instanceof JInternalFrame) { + JInternalFrame internalFrame = (JInternalFrame) comp; + if (internalFrame.getTitle().equals(title)) { + return (JInternalFrame) comp; + } + } + + if (comp instanceof Container) { + Container cont = (Container) comp; + for (int i = 0; i < cont.getComponentCount(); i++) { + JInternalFrame result = findModalInternalFrame(cont.getComponent(i), title); + if (result != null) { + return result; + } + } + } + return null; + } + + private static JButton findButton(Component comp) { + + if (comp instanceof JButton) { + return (JButton) comp; + } + + if (comp instanceof Container) { + Container cont = (Container) comp; + for (int i = 0; i < cont.getComponentCount(); i++) { + JButton result = findButton(cont.getComponent(i)); + if (result != null) { + return result; + } + } + } + return null; + } +} From e047f11b3bbc6ce2ccef964adb3ca30c75691d63 Mon Sep 17 00:00:00 2001 From: Alexander Scherbatiy Date: Wed, 17 Dec 2014 17:56:11 +0300 Subject: [PATCH 010/116] 4796987: XP Only JButton.setBorderPainted() does not work with XP L&F Reviewed-by: serb --- .../swing/plaf/windows/WindowsButtonUI.java | 3 +- .../swing/JButton/4796987/bug4796987.java | 102 ++++++++++++++++++ 2 files changed, 104 insertions(+), 1 deletion(-) create mode 100644 jdk/test/javax/swing/JButton/4796987/bug4796987.java diff --git a/jdk/src/java.desktop/share/classes/com/sun/java/swing/plaf/windows/WindowsButtonUI.java b/jdk/src/java.desktop/share/classes/com/sun/java/swing/plaf/windows/WindowsButtonUI.java index 0ea400d53da..89a2a18e115 100644 --- a/jdk/src/java.desktop/share/classes/com/sun/java/swing/plaf/windows/WindowsButtonUI.java +++ b/jdk/src/java.desktop/share/classes/com/sun/java/swing/plaf/windows/WindowsButtonUI.java @@ -248,7 +248,8 @@ public class WindowsButtonUI extends BasicButtonUI Part part = getXPButtonType(b); - if (b.isContentAreaFilled() && xp != null) { + if (b.isContentAreaFilled() && b.getBorder() != null + && b.isBorderPainted() && xp != null) { Skin skin = xp.getSkin(b, part); diff --git a/jdk/test/javax/swing/JButton/4796987/bug4796987.java b/jdk/test/javax/swing/JButton/4796987/bug4796987.java new file mode 100644 index 00000000000..ac41799da61 --- /dev/null +++ b/jdk/test/javax/swing/JButton/4796987/bug4796987.java @@ -0,0 +1,102 @@ +/* + * Copyright (c) 2013, 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. + */ + +/* + * @test + * @bug 4796987 + * @summary XP Only: JButton.setBorderPainted() does not work with XP L&F + * @author Alexander Scherbatiy + * @library ../../regtesthelpers + * @build Util + * @run main bug4796987 + */ + +import java.awt.*; +import javax.swing.*; +import sun.awt.OSInfo; +import sun.awt.SunToolkit; +import com.sun.java.swing.plaf.windows.WindowsLookAndFeel; + +public class bug4796987 { + + private static JButton button1; + private static JButton button2; + + public static void main(String[] args) throws Exception { + if (OSInfo.getOSType() == OSInfo.OSType.WINDOWS + && OSInfo.getWindowsVersion() == OSInfo.WINDOWS_XP) { + UIManager.setLookAndFeel(new WindowsLookAndFeel()); + testButtonBorder(); + } + } + + private static void testButtonBorder() throws Exception { + SunToolkit toolkit = (SunToolkit) Toolkit.getDefaultToolkit(); + Robot robot = new Robot(); + robot.setAutoDelay(50); + + SwingUtilities.invokeAndWait(new Runnable() { + + public void run() { + createAndShowGUI(); + } + }); + + toolkit.realSync(); + Thread.sleep(500); + + Point p1 = Util.getCenterPoint(button1); + Point p2 = Util.getCenterPoint(button2); + + Color color = robot.getPixelColor(p1.x, p2.x); + for (int dx = p1.x; dx < p2.x - p1.x; dx++) { + robot.mouseMove(p1.x + dx, p1.y); + if (!color.equals(robot.getPixelColor(p1.x + dx, p1.y))) { + throw new RuntimeException("Button has border and background!"); + } + } + } + + private static JButton getButton() { + JButton button = new JButton(); + button.setBorderPainted(false); + button.setFocusable(false); + return button; + } + + private static void createAndShowGUI() { + JFrame frame = new JFrame("Test"); + frame.setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE); + frame.setSize(200, 200); + + JButton button = new JButton(); + button.setBorder(null); + + JPanel panel = new JPanel(new BorderLayout(50, 50)); + panel.add(getButton(), BorderLayout.CENTER); + panel.add(button1 = getButton(), BorderLayout.WEST); + panel.add(button2 = getButton(), BorderLayout.EAST); + frame.getContentPane().add(panel); + frame.setVisible(true); + } +} From d5a220d6737bbd0a3cc22e15b5fe19ea8e974f94 Mon Sep 17 00:00:00 2001 From: Sergey Bylokhov Date: Thu, 25 Dec 2014 14:43:49 +0300 Subject: [PATCH 011/116] 7180976: Pending String deadlocks UIDefaults Reviewed-by: azvegint, alexsch --- .../share/classes/javax/swing/UIDefaults.java | 6 +-- .../swing/plaf/synth/DefaultSynthStyle.java | 4 +- .../swing/UIDefaults/7180976/Pending.java | 50 +++++++++++++++++++ 3 files changed, 54 insertions(+), 6 deletions(-) create mode 100644 jdk/test/javax/swing/UIDefaults/7180976/Pending.java diff --git a/jdk/src/java.desktop/share/classes/javax/swing/UIDefaults.java b/jdk/src/java.desktop/share/classes/javax/swing/UIDefaults.java index 82e4e2e5103..95cdb149aa9 100644 --- a/jdk/src/java.desktop/share/classes/javax/swing/UIDefaults.java +++ b/jdk/src/java.desktop/share/classes/javax/swing/UIDefaults.java @@ -44,9 +44,7 @@ import java.awt.Font; import java.awt.Color; import java.awt.Insets; import java.awt.Dimension; -import java.lang.reflect.Method; import java.beans.PropertyChangeListener; -import java.beans.PropertyChangeEvent; import java.security.AccessController; import java.security.AccessControlContext; import java.security.PrivilegedAction; @@ -76,7 +74,7 @@ import sun.util.CoreResourceBundleControl; @SuppressWarnings("serial") // Same-version serialization only public class UIDefaults extends Hashtable { - private static final Object PENDING = "Pending"; + private static final Object PENDING = new Object(); private SwingPropertyChangeSupport changeSupport; @@ -170,7 +168,7 @@ public class UIDefaults extends Hashtable * Looks up the given key in our Hashtable and resolves LazyValues * or ActiveValues. */ - private Object getFromHashtable(Object key) { + private Object getFromHashtable(final Object key) { /* Quickly handle the common case, without grabbing * a lock. */ diff --git a/jdk/src/java.desktop/share/classes/sun/swing/plaf/synth/DefaultSynthStyle.java b/jdk/src/java.desktop/share/classes/sun/swing/plaf/synth/DefaultSynthStyle.java index 4906d6ba14c..8829f369460 100644 --- a/jdk/src/java.desktop/share/classes/sun/swing/plaf/synth/DefaultSynthStyle.java +++ b/jdk/src/java.desktop/share/classes/sun/swing/plaf/synth/DefaultSynthStyle.java @@ -28,7 +28,6 @@ import javax.swing.plaf.synth.*; import java.awt.*; import java.util.*; import javax.swing.*; -import javax.swing.border.Border; import javax.swing.plaf.*; /** @@ -44,7 +43,8 @@ import javax.swing.plaf.*; * @author Scott Violet */ public class DefaultSynthStyle extends SynthStyle implements Cloneable { - private static final String PENDING = "Pending"; + + private static final Object PENDING = new Object(); /** * Should the component be opaque? diff --git a/jdk/test/javax/swing/UIDefaults/7180976/Pending.java b/jdk/test/javax/swing/UIDefaults/7180976/Pending.java new file mode 100644 index 00000000000..23ece57ebb0 --- /dev/null +++ b/jdk/test/javax/swing/UIDefaults/7180976/Pending.java @@ -0,0 +1,50 @@ +/* + * Copyright (c) 2014, 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 javax.swing.SwingUtilities; +import javax.swing.UIManager; + +/** + * @test + * @bug 7180976 + * @author Sergey Bylokhov + */ +public final class Pending implements Runnable { + + private static volatile boolean passed; + + public static void main(final String[] args) throws Exception { + SwingUtilities.invokeLater(new Pending()); + Thread.sleep(10000); + if (!passed) { + throw new RuntimeException("Test failed"); + } + } + + @Override + public void run() { + UIManager.put("foobar", "Pending"); + UIManager.get("foobar"); + passed = true; + } +} \ No newline at end of file From 6a1f047a778c22f187d609ba16b7945d2f076e54 Mon Sep 17 00:00:00 2001 From: Sergey Bylokhov Date: Thu, 25 Dec 2014 14:54:32 +0300 Subject: [PATCH 012/116] 8067657: Dead/outdated links in Javadoc of package java.beans Reviewed-by: azvegint, prr --- jdk/src/java.desktop/share/classes/java/beans/package.html | 6 +++--- 1 file changed, 3 insertions(+), 3 deletions(-) diff --git a/jdk/src/java.desktop/share/classes/java/beans/package.html b/jdk/src/java.desktop/share/classes/java/beans/package.html index 2b68012cee5..81a9cdafd7b 100644 --- a/jdk/src/java.desktop/share/classes/java/beans/package.html +++ b/jdk/src/java.desktop/share/classes/java/beans/package.html @@ -1,5 +1,5 @@ don't test defines max and min in + // terms of preferred + runTest(new JScrollPane()); + runTest(new JViewport()); + runTest(new JSplitPane()); + runTest(new JTabbedPane()); + runTest(new JToolBar()); + runTest(new JSeparator()); + runTest(new JProgressBar()); + if (!failures.isEmpty()) { + System.out.println("These classes failed"); + for (final Component failure : failures) { + System.out.println(failure.getClass()); + } + throw new RuntimeException("Test failed"); + } + } + + public void runTest(final Component c) { + try { + test(c); + c.setMinimumSize(new Dimension(100, 10)); + c.setMaximumSize(new Dimension(200, 20)); + c.setPreferredSize(new Dimension(300, 30)); + test(c); + } catch (final Throwable ignored) { + failures.add(c); + } + } + + public void test(final Component component) { + final Dimension psize = component.getPreferredSize(); + psize.width += 200; + if (Objects.equals(psize, component.getPreferredSize())) { + throw new RuntimeException("PreferredSize is wrong"); + } + final Dimension msize = component.getMaximumSize(); + msize.width += 200; + if (Objects.equals(msize, component.getMaximumSize())) { + throw new RuntimeException("MaximumSize is wrong"); + } + final Dimension misize = component.getMinimumSize(); + misize.width += 200; + if (Objects.equals(misize, component.getMinimumSize())) { + throw new RuntimeException("MinimumSize is wrong"); + } + } + + private static void setLookAndFeel(final LookAndFeelInfo laf) { + try { + UIManager.setLookAndFeel(laf.getClassName()); + System.out.println("LookAndFeel: " + laf.getClassName()); + } catch (ClassNotFoundException | InstantiationException | + UnsupportedLookAndFeelException | IllegalAccessException e) { + throw new RuntimeException(e); + } + } +} \ No newline at end of file From c604e674ee9baa0fdc921590735513a63b783edd Mon Sep 17 00:00:00 2001 From: Sergey Bylokhov Date: Wed, 21 Jan 2015 18:04:49 +0300 Subject: [PATCH 036/116] 7056797: The test failed automatically,because throw a ArrayIndexOutOfBoundsException Reviewed-by: azvegint, alexsch --- .../swing/JTabbedPane/4209065/bug4209065.html | 35 ++++++++++++ .../swing/JTabbedPane/4209065/bug4209065.java | 57 +++++++++++++++++++ 2 files changed, 92 insertions(+) create mode 100644 jdk/test/javax/swing/JTabbedPane/4209065/bug4209065.html create mode 100644 jdk/test/javax/swing/JTabbedPane/4209065/bug4209065.java diff --git a/jdk/test/javax/swing/JTabbedPane/4209065/bug4209065.html b/jdk/test/javax/swing/JTabbedPane/4209065/bug4209065.html new file mode 100644 index 00000000000..5737912f130 --- /dev/null +++ b/jdk/test/javax/swing/JTabbedPane/4209065/bug4209065.html @@ -0,0 +1,35 @@ + + + + + + + + diff --git a/jdk/test/javax/swing/JTabbedPane/4209065/bug4209065.java b/jdk/test/javax/swing/JTabbedPane/4209065/bug4209065.java new file mode 100644 index 00000000000..c2e2c14d7d8 --- /dev/null +++ b/jdk/test/javax/swing/JTabbedPane/4209065/bug4209065.java @@ -0,0 +1,57 @@ +/* + * Copyright (c) 1999, 2015, 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.awt.EventQueue; +import java.lang.reflect.InvocationTargetException; + +import javax.swing.JApplet; +import javax.swing.JLabel; +import javax.swing.JTabbedPane; + +/** + * @test + * @bug 4209065 + * @author Georges Saab + * @run applet/manual=yesno bug4209065.html + */ +public final class bug4209065 extends JApplet { + + @Override + public void init() { + try { + EventQueue.invokeAndWait(this::createTabbedPane); + } catch (InterruptedException | InvocationTargetException e) { + throw new RuntimeException(e); + } + } + + private void createTabbedPane() { + JTabbedPane tp = new JTabbedPane(); + getContentPane().add(tp); + String text = "

If the style of the text on the tabs matches" + + "
the descriptions, press PASS
"; + tp.addTab("
big
", new JLabel(text)); + tp.addTab("
red
", new JLabel(text)); + tp.addTab("
Bold Italic!
", new JLabel(text)); + } +} From 00949632cd5242ab947ca3b483da0c0a892ae1ba Mon Sep 17 00:00:00 2001 From: Mikhail Cherkasov Date: Thu, 22 Jan 2015 17:42:17 +0400 Subject: [PATCH 037/116] 8065709: Deadlock in awt/logging apparently introduced by 8019623 Reviewed-by: ant, serb --- .../share/classes/java/awt/EventQueue.java | 29 ++++++++++++------- 1 file changed, 18 insertions(+), 11 deletions(-) diff --git a/jdk/src/java.desktop/share/classes/java/awt/EventQueue.java b/jdk/src/java.desktop/share/classes/java/awt/EventQueue.java index c398db77fdc..620c3c4ece8 100644 --- a/jdk/src/java.desktop/share/classes/java/awt/EventQueue.java +++ b/jdk/src/java.desktop/share/classes/java/awt/EventQueue.java @@ -182,7 +182,14 @@ public class EventQueue { private FwDispatcher fwDispatcher; - private static final PlatformLogger eventLog = PlatformLogger.getLogger("java.awt.event.EventQueue"); + private static volatile PlatformLogger eventLog; + + private static final PlatformLogger getEventLog() { + if(eventLog == null) { + eventLog = PlatformLogger.getLogger("java.awt.event.EventQueue"); + } + return eventLog; + } static { AWTAccessor.setEventQueueAccessor( @@ -762,8 +769,8 @@ public class EventQueue { dispatchThread.stopDispatching(); } } else { - if (eventLog.isLoggable(PlatformLogger.Level.FINE)) { - eventLog.fine("Unable to dispatch event: " + event); + if (getEventLog().isLoggable(PlatformLogger.Level.FINE)) { + getEventLog().fine("Unable to dispatch event: " + event); } } } @@ -860,8 +867,8 @@ public class EventQueue { * @since 1.2 */ public void push(EventQueue newEventQueue) { - if (eventLog.isLoggable(PlatformLogger.Level.FINE)) { - eventLog.fine("EventQueue.push(" + newEventQueue + ")"); + if (getEventLog().isLoggable(PlatformLogger.Level.FINE)) { + getEventLog().fine("EventQueue.push(" + newEventQueue + ")"); } pushPopLock.lock(); @@ -886,8 +893,8 @@ public class EventQueue { // Use getNextEventPrivate() as it doesn't call flushPendingEvents() newEventQueue.postEventPrivate(topQueue.getNextEventPrivate()); } catch (InterruptedException ie) { - if (eventLog.isLoggable(PlatformLogger.Level.FINE)) { - eventLog.fine("Interrupted push", ie); + if (getEventLog().isLoggable(PlatformLogger.Level.FINE)) { + getEventLog().fine("Interrupted push", ie); } } } @@ -925,8 +932,8 @@ public class EventQueue { * @since 1.2 */ protected void pop() throws EmptyStackException { - if (eventLog.isLoggable(PlatformLogger.Level.FINE)) { - eventLog.fine("EventQueue.pop(" + this + ")"); + if (getEventLog().isLoggable(PlatformLogger.Level.FINE)) { + getEventLog().fine("EventQueue.pop(" + this + ")"); } pushPopLock.lock(); @@ -948,8 +955,8 @@ public class EventQueue { try { prevQueue.postEventPrivate(topQueue.getNextEventPrivate()); } catch (InterruptedException ie) { - if (eventLog.isLoggable(PlatformLogger.Level.FINE)) { - eventLog.fine("Interrupted pop", ie); + if (getEventLog().isLoggable(PlatformLogger.Level.FINE)) { + getEventLog().fine("Interrupted pop", ie); } } } From d34b9b430ca28e1dc0fc4eb1c283c084d47b2468 Mon Sep 17 00:00:00 2001 From: Sergey Bylokhov Date: Fri, 23 Jan 2015 13:47:46 +0300 Subject: [PATCH 038/116] 7185221: [macosx] Regtest should not throw exception if a suitable display mode found Reviewed-by: azvegint, ant --- .../NonExistentDisplayModeTest.java | 152 ++++++++++++++++++ 1 file changed, 152 insertions(+) create mode 100644 jdk/test/java/awt/FullScreen/NonExistentDisplayModeTest/NonExistentDisplayModeTest.java diff --git a/jdk/test/java/awt/FullScreen/NonExistentDisplayModeTest/NonExistentDisplayModeTest.java b/jdk/test/java/awt/FullScreen/NonExistentDisplayModeTest/NonExistentDisplayModeTest.java new file mode 100644 index 00000000000..5387391f5e6 --- /dev/null +++ b/jdk/test/java/awt/FullScreen/NonExistentDisplayModeTest/NonExistentDisplayModeTest.java @@ -0,0 +1,152 @@ +/* + * Copyright (c) 2006, 2015, 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.awt.DisplayMode; +import java.awt.Frame; +import java.awt.GraphicsDevice; +import java.util.ArrayList; +import java.util.Random; + +import static java.awt.DisplayMode.REFRESH_RATE_UNKNOWN; + +/** + * @test + * @bug 6430607 + * @summary Test that we throw an exception for incorrect display modes + * @author Dmitri.Trembovetski@Sun.COM area=FullScreen + * @run main/othervm NonExistentDisplayModeTest + * @run main/othervm -Dsun.java2d.noddraw=true NonExistentDisplayModeTest + * @run main/othervm -Dsun.java2d.opengl=true NonExistentDisplayModeTest + */ +public class NonExistentDisplayModeTest { + + public static void main(String[] args) { + new NonExistentDisplayModeTest().start(); + } + + private void start() { + Frame f = new Frame("Testing, please wait.."); + f.pack(); + GraphicsDevice gd = f.getGraphicsConfiguration().getDevice(); + if (!gd.isFullScreenSupported()) { + System.out.println("Exclusive FS mode not supported, test passed."); + f.dispose(); + return; + } + + gd.setFullScreenWindow(f); + if (!gd.isDisplayChangeSupported()) { + System.out.println("DisplayMode change not supported, test passed."); + f.dispose(); + return; + } + + DisplayMode dms[] = gd.getDisplayModes(); + ArrayList dmList = new ArrayList(dms.length); + for (DisplayMode dm : dms) { + dmList.add(dm); + } + + ArrayList nonExistentDms = createNonExistentDMList(dmList); + + for (DisplayMode dm : nonExistentDms) { + boolean exThrown = false; + try { + System.out.printf("Testing mode: (%4dx%4d) depth=%3d rate=%d\n", + dm.getWidth(), dm.getHeight(), + dm.getBitDepth(), dm.getRefreshRate()); + gd.setDisplayMode(dm); + } catch (IllegalArgumentException e) { + exThrown = true; + } + if (!exThrown) { + gd.setFullScreenWindow(null); + f.dispose(); + throw new + RuntimeException("Failed: No exception thrown for dm "+dm); + } + } + gd.setFullScreenWindow(null); + f.dispose(); + System.out.println("Test passed."); + } + + private static final Random rnd = new Random(); + private ArrayList + createNonExistentDMList(ArrayList dmList) + { + ArrayList newList = + new ArrayList(dmList.size()); + // vary one parameter at a time + int param = 0; + for (DisplayMode dm : dmList) { + param = ++param % 3; + switch (param) { + case 0: { + DisplayMode newDM = deriveSize(dm); + if (!dmList.contains(newDM)) { + newList.add(newDM); + } + break; + } + case 1: { + DisplayMode newDM = deriveDepth(dm); + if (!dmList.contains(newDM)) { + newList.add(newDM); + } + break; + } + case 2: { + if (dm.getRefreshRate() != REFRESH_RATE_UNKNOWN) { + DisplayMode newDM = deriveRR(dm); + if (!dmList.contains(newDM)) { + newList.add(newDM); + } + } + break; + } + } + } + return newList; + } + + private static DisplayMode deriveSize(DisplayMode dm) { + int w = dm.getWidth() / 7; + int h = dm.getHeight() / 3; + return new DisplayMode(w, h, dm.getBitDepth(), dm.getRefreshRate()); + } + private static DisplayMode deriveRR(DisplayMode dm) { + return new DisplayMode(dm.getWidth(), dm.getHeight(), + dm.getBitDepth(), 777); + } + private static DisplayMode deriveDepth(DisplayMode dm) { + int depth; + if (dm.getBitDepth() == DisplayMode.BIT_DEPTH_MULTI) { + depth = 77; + } else { + depth = DisplayMode.BIT_DEPTH_MULTI; + } + return new DisplayMode(dm.getWidth(), dm.getHeight(), + depth, dm.getRefreshRate()); + } +} From fda56d3c54b1b130620d98f4da96f2af884641b7 Mon Sep 17 00:00:00 2001 From: Phil Race Date: Sun, 25 Jan 2015 15:53:46 -0800 Subject: [PATCH 039/116] 8064833: [macosx] Native font lookup uses family+style, not full name/postscript name Reviewed-by: bae, serb --- .../macosx/classes/sun/font/CFont.java | 68 ++++++- .../macosx/classes/sun/font/CFontManager.java | 39 +++- .../macosx/native/libawt_lwawt/font/AWTFont.m | 60 +++++-- .../share/classes/sun/font/Font2D.java | 15 ++ .../share/classes/sun/font/FontFamily.java | 113 +++++++++++- .../share/classes/sun/font/TrueTypeFont.java | 21 ++- .../java/awt/FontClass/HelvLtOblTest.java | 166 ++++++++++++++++++ 7 files changed, 460 insertions(+), 22 deletions(-) create mode 100644 jdk/test/java/awt/FontClass/HelvLtOblTest.java diff --git a/jdk/src/java.desktop/macosx/classes/sun/font/CFont.java b/jdk/src/java.desktop/macosx/classes/sun/font/CFont.java index 0173bfc9d23..c88e53c0663 100644 --- a/jdk/src/java.desktop/macosx/classes/sun/font/CFont.java +++ b/jdk/src/java.desktop/macosx/classes/sun/font/CFont.java @@ -77,14 +77,72 @@ public final class CFont extends PhysicalFont { } private static native long createNativeFont(final String nativeFontName, - final int style, - final boolean isFakeItalic); + final int style); private static native void disposeNativeFont(final long nativeFontPtr); private boolean isFakeItalic; private String nativeFontName; private long nativeFontPtr; + private native float getWidthNative(final long nativeFontPtr); + private native float getWeightNative(final long nativeFontPtr); + + private int fontWidth = -1; + private int fontWeight = -1; + + @Override + public int getWidth() { + if (fontWidth == -1) { + // Apple use a range of -1 -> +1, where 0.0 is normal + // OpenType uses a % range from 50% -> 200% where 100% is normal + // and maps these onto the integer values 1->9. + // Since that is what Font2D.getWidth() expects, remap to that. + float fw = getWidthNative(getNativeFontPtr()); + if (fw == 0.0) { // short cut the common case + fontWidth = Font2D.FWIDTH_NORMAL; + return fontWidth; + } + fw += 1.0; fw *= 100.0; + if (fw <= 50.0) { + fontWidth = 1; + } else if (fw <= 62.5) { + fontWidth = 2; + } else if (fw <= 75.0) { + fontWidth = 3; + } else if (fw <= 87.5) { + fontWidth = 4; + } else if (fw <= 100.0) { + fontWidth = 5; + } else if (fw <= 112.5) { + fontWidth = 6; + } else if (fw <= 125.0) { + fontWidth = 7; + } else if (fw <= 150.0) { + fontWidth = 8; + } else { + fontWidth = 9; + } + } + return fontWidth; + } + + @Override + public int getWeight() { + if (fontWeight == -1) { + // Apple use a range of -1 -> +1, where 0 is medium/regular + // Map this on to the OpenType range of 100->900 where + // 500 is medium/regular. + // We'll actually map to 0->1000 but that's close enough. + float fw = getWeightNative(getNativeFontPtr()); + if (fw == 0) { + return Font2D.FWEIGHT_NORMAL; + } + fw += 1.0; fw *= 500; + fontWeight = (int)fw; + } + return fontWeight; + } + // this constructor is called from CFontWrapper.m public CFont(String name) { this(name, name); @@ -94,10 +152,11 @@ public final class CFont extends PhysicalFont { handle = new Font2DHandle(this); fullName = name; familyName = inFamilyName; - nativeFontName = inFamilyName; + nativeFontName = fullName; setStyle(); } + /* Called from CFontManager too */ public CFont(CFont other, String logicalFamilyName) { handle = new Font2DHandle(this); fullName = logicalFamilyName; @@ -109,6 +168,7 @@ public final class CFont extends PhysicalFont { public CFont createItalicVariant() { CFont font = new CFont(this, familyName); + font.nativeFontName = fullName; font.fullName = fullName + (style == Font.BOLD ? "" : "-") + "Italic-Derived"; font.style |= Font.ITALIC; @@ -118,7 +178,7 @@ public final class CFont extends PhysicalFont { protected synchronized long getNativeFontPtr() { if (nativeFontPtr == 0L) { - nativeFontPtr = createNativeFont(nativeFontName, style, isFakeItalic); + nativeFontPtr = createNativeFont(nativeFontName, style); } return nativeFontPtr; } diff --git a/jdk/src/java.desktop/macosx/classes/sun/font/CFontManager.java b/jdk/src/java.desktop/macosx/classes/sun/font/CFontManager.java index 28c59712fe7..e37e9e449ea 100644 --- a/jdk/src/java.desktop/macosx/classes/sun/font/CFontManager.java +++ b/jdk/src/java.desktop/macosx/classes/sun/font/CFontManager.java @@ -252,13 +252,42 @@ public final class CFontManager extends SunFontManager { final CFont font = new CFont(fontName, fontFamilyName); registerGenericFont(font); + } - if ((font.getStyle() & Font.ITALIC) == 0) { - registerGenericFont(font.createItalicVariant(), true); + void registerItalicDerived() { + FontFamily[] famArr = FontFamily.getAllFontFamilies(); + for (int i=0; i() { public Object run() { - loadNativeFonts(); + if (!loadedAllFonts) { + loadNativeFonts(); + registerItalicDerived(); + loadedAllFonts = true; + } return null; } } diff --git a/jdk/src/java.desktop/macosx/native/libawt_lwawt/font/AWTFont.m b/jdk/src/java.desktop/macosx/native/libawt_lwawt/font/AWTFont.m index 0adeff0de06..bfb90ec6a59 100644 --- a/jdk/src/java.desktop/macosx/native/libawt_lwawt/font/AWTFont.m +++ b/jdk/src/java.desktop/macosx/native/libawt_lwawt/font/AWTFont.m @@ -35,15 +35,11 @@ #import "AWTStrike.h" #import "CoreTextSupport.h" - -#define DEBUG - @implementation AWTFont -- (id) initWithFont:(NSFont *)font isFakeItalic:(BOOL)isFakeItalic { +- (id) initWithFont:(NSFont *)font { self = [super init]; if (self) { - fIsFakeItalic = isFakeItalic; fFont = [font retain]; fNativeCGFont = CTFontCopyGraphicsFont((CTFontRef)font, NULL); } @@ -72,7 +68,6 @@ + (AWTFont *) awtFontForName:(NSString *)name style:(int)style - isFakeItalic:(BOOL)isFakeItalic { // create font with family & size NSFont *nsFont = [NSFont fontWithName:name size:1.0]; @@ -95,7 +90,7 @@ nsFont = [[NSFontManager sharedFontManager] convertFont:nsFont toHaveTrait:NSBoldFontMask]; } - return [[[AWTFont alloc] initWithFont:nsFont isFakeItalic:isFakeItalic] autorelease]; + return [[[AWTFont alloc] initWithFont:nsFont] autorelease]; } + (NSFont *) nsFontForJavaFont:(jobject)javaFont env:(JNIEnv *)env { @@ -354,7 +349,7 @@ JNF_COCOA_EXIT(env); JNIEXPORT jlong JNICALL Java_sun_font_CFont_createNativeFont (JNIEnv *env, jclass clazz, - jstring nativeFontName, jint style, jboolean isFakeItalic) + jstring nativeFontName, jint style) { AWTFont *awtFont = nil; @@ -362,8 +357,7 @@ JNF_COCOA_ENTER(env); awtFont = [AWTFont awtFontForName:JNFJavaToNSString(env, nativeFontName) - style:style - isFakeItalic:isFakeItalic]; // autoreleased + style:style]; // autoreleased if (awtFont) { CFRetain(awtFont); // GC @@ -374,6 +368,52 @@ JNF_COCOA_EXIT(env); return ptr_to_jlong(awtFont); } +/* + * Class: sun_font_CFont + * Method: getWidthNative + * Signature: (J)F + */ +JNIEXPORT jfloat JNICALL +Java_sun_font_CFont_getWidthNative + (JNIEnv *env, jobject cfont, jlong awtFontPtr) +{ + float widthVal; +JNF_COCOA_ENTER(env); + + AWTFont *awtFont = (AWTFont *)jlong_to_ptr(awtFontPtr); + NSFont* nsFont = awtFont->fFont; + NSFontDescriptor *fontDescriptor = nsFont.fontDescriptor; + NSDictionary *fontTraits = [fontDescriptor objectForKey : NSFontTraitsAttribute]; + NSNumber *width = [fontTraits objectForKey : NSFontWidthTrait]; + widthVal = (float)[width floatValue]; + +JNF_COCOA_EXIT(env); + return (jfloat)widthVal; +} + +/* + * Class: sun_font_CFont + * Method: getWeightNative + * Signature: (J)F + */ +JNIEXPORT jfloat JNICALL +Java_sun_font_CFont_getWeightNative + (JNIEnv *env, jobject cfont, jlong awtFontPtr) +{ + float weightVal; +JNF_COCOA_ENTER(env); + + AWTFont *awtFont = (AWTFont *)jlong_to_ptr(awtFontPtr); + NSFont* nsFont = awtFont->fFont; + NSFontDescriptor *fontDescriptor = nsFont.fontDescriptor; + NSDictionary *fontTraits = [fontDescriptor objectForKey : NSFontTraitsAttribute]; + NSNumber *weight = [fontTraits objectForKey : NSFontWeightTrait]; + weightVal = (float)[weight floatValue]; + +JNF_COCOA_EXIT(env); + return (jfloat)weightVal; +} + /* * Class: sun_font_CFont * Method: disposeNativeFont diff --git a/jdk/src/java.desktop/share/classes/sun/font/Font2D.java b/jdk/src/java.desktop/share/classes/sun/font/Font2D.java index 6fa3ca45e92..e1c7c912e3d 100644 --- a/jdk/src/java.desktop/share/classes/sun/font/Font2D.java +++ b/jdk/src/java.desktop/share/classes/sun/font/Font2D.java @@ -157,6 +157,21 @@ public abstract class Font2D { } } + public static final int FWIDTH_NORMAL = 5; // OS/2 usWidthClass + public static final int FWEIGHT_NORMAL = 400; // OS/2 usWeightClass + public static final int FWEIGHT_BOLD = 700; // OS/2 usWeightClass + + public int getWidth() { + return FWIDTH_NORMAL; + } + + public int getWeight() { + if ((style & Font.BOLD) !=0) { + return FWEIGHT_BOLD; + } else { + return FWEIGHT_NORMAL; + } + } int getRank() { return fontRank; diff --git a/jdk/src/java.desktop/share/classes/sun/font/FontFamily.java b/jdk/src/java.desktop/share/classes/sun/font/FontFamily.java index 6a4cd2552f9..b450f86930b 100644 --- a/jdk/src/java.desktop/share/classes/sun/font/FontFamily.java +++ b/jdk/src/java.desktop/share/classes/sun/font/FontFamily.java @@ -27,6 +27,7 @@ package sun.font; import java.io.File; import java.awt.Font; +import java.util.Collection; import java.util.HashMap; import java.util.concurrent.ConcurrentHashMap; import java.util.Locale; @@ -134,7 +135,98 @@ public class FontFamily { return java.util.Objects.equals(newDir, existDir); } + /* + * We want a family to be of the same width and prefer medium/normal width. + * Once we find a particular width we accept more of the same width + * until we find one closer to normal when we 'evict' all existing fonts. + * So once we see a 'normal' width font we evict all members that are not + * normal width and then accept only new ones that are normal width. + * + * Once a font passes the width test we subject it to the weight test. + * For Plain we target the weight the closest that is <= NORMAL (400) + * For Bold we target the weight that is closest to BOLD (700). + * + * In the future, rather than discarding these fonts, we should + * extend the family to include these so lookups on these properties + * can locate them, as presently they will only be located by full name + * based lookup. + */ + + private int familyWidth = 0; + private boolean preferredWidth(Font2D font) { + + int newWidth = font.getWidth(); + + if (familyWidth == 0) { + familyWidth = newWidth; + return true; + } + + if (newWidth == familyWidth) { + return true; + } + + if (Math.abs(Font2D.FWIDTH_NORMAL - newWidth) < + Math.abs(Font2D.FWIDTH_NORMAL - familyWidth)) + { + if (FontUtilities.debugFonts()) { + FontUtilities.getLogger().info( + "Found more preferred width. New width = " + newWidth + + " Old width = " + familyWidth + " in font " + font + + " nulling out fonts plain: " + plain + " bold: " + bold + + " italic: " + italic + " bolditalic: " + bolditalic); + } + familyWidth = newWidth; + plain = bold = italic = bolditalic = null; + return true; + } else if (FontUtilities.debugFonts()) { + FontUtilities.getLogger().info( + "Family rejecting font " + font + + " of less preferred width " + newWidth); + } + return false; + } + + private boolean closerWeight(Font2D currFont, Font2D font, int style) { + if (familyWidth != font.getWidth()) { + return false; + } + + if (currFont == null) { + return true; + } + + if (FontUtilities.debugFonts()) { + FontUtilities.getLogger().info( + "New weight for style " + style + ". Curr.font=" + currFont + + " New font="+font+" Curr.weight="+ + currFont.getWeight()+ + " New weight="+font.getWeight()); + } + + int newWeight = font.getWeight(); + switch (style) { + case Font.PLAIN: + case Font.ITALIC: + return (newWeight <= Font2D.FWEIGHT_NORMAL && + newWeight > currFont.getWeight()); + + case Font.BOLD: + case Font.BOLD|Font.ITALIC: + return (Math.abs(newWeight - Font2D.FWEIGHT_BOLD) < + Math.abs(currFont.getWeight() - Font2D.FWEIGHT_BOLD)); + + default: + return false; + } + } + public void setFont(Font2D font, int style) { + + if (FontUtilities.isLogging()) { + FontUtilities.getLogger().info( + "Request to add " + font + " with style " + style + + " to family " + this); + } /* Allow a lower-rank font only if its a file font * from the exact same source as any previous font. */ @@ -152,19 +244,27 @@ public class FontFamily { switch (style) { case Font.PLAIN: - plain = font; + if (preferredWidth(font) && closerWeight(plain, font, style)) { + plain = font; + } break; case Font.BOLD: - bold = font; + if (preferredWidth(font) && closerWeight(bold, font, style)) { + bold = font; + } break; case Font.ITALIC: - italic = font; + if (preferredWidth(font) && closerWeight(italic, font, style)) { + italic = font; + } break; case Font.BOLD|Font.ITALIC: - bolditalic = font; + if (preferredWidth(font) && closerWeight(bolditalic, font, style)) { + bolditalic = font; + } break; default: @@ -316,6 +416,11 @@ public class FontFamily { return allLocaleNames.get(name.toLowerCase()); } + public static FontFamily[] getAllFontFamilies() { + Collection families = familyNameMap.values(); + return families.toArray(new FontFamily[0]); + } + public String toString() { return "Font family: " + familyName + diff --git a/jdk/src/java.desktop/share/classes/sun/font/TrueTypeFont.java b/jdk/src/java.desktop/share/classes/sun/font/TrueTypeFont.java index 047a9309095..0e8647cc734 100644 --- a/jdk/src/java.desktop/share/classes/sun/font/TrueTypeFont.java +++ b/jdk/src/java.desktop/share/classes/sun/font/TrueTypeFont.java @@ -963,6 +963,18 @@ public class TrueTypeFont extends FileFont { setStyle(getTableBuffer(os_2Tag)); } + private int fontWidth = 0; + @Override + public int getWidth() { + return (fontWidth > 0) ? fontWidth : super.getWidth(); + } + + private int fontWeight = 0; + @Override + public int getWeight() { + return (fontWeight > 0) ? fontWeight : super.getWeight(); + } + /* TrueTypeFont can use the fsSelection fields of OS/2 table * to determine the style. In the unlikely case that doesn't exist, * can use macStyle in the 'head' table but simpler to @@ -978,8 +990,15 @@ public class TrueTypeFont extends FileFont { private static final int fsSelectionBoldBit = 0x00020; private static final int fsSelectionRegularBit = 0x00040; private void setStyle(ByteBuffer os_2Table) { + if (os_2Table == null) { + return; + } + if (os_2Table.capacity() >= 8) { + fontWeight = os_2Table.getChar(4) & 0xffff; + fontWidth = os_2Table.getChar(6) & 0xffff; + } /* fsSelection is unsigned short at buffer offset 62 */ - if (os_2Table == null || os_2Table.capacity() < 64) { + if (os_2Table.capacity() < 64) { super.setStyle(); return; } diff --git a/jdk/test/java/awt/FontClass/HelvLtOblTest.java b/jdk/test/java/awt/FontClass/HelvLtOblTest.java new file mode 100644 index 00000000000..bc88d381f9e --- /dev/null +++ b/jdk/test/java/awt/FontClass/HelvLtOblTest.java @@ -0,0 +1,166 @@ +/* + * Copyright (c) 2015, 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. + */ + +/* + * @test + * @bug 8064833 + * @summary Test correct font is obtained via famil+style + * @run main HelvLtOblTest + */ + +import javax.swing.JComponent; +import javax.swing.JFrame; +import javax.swing.SwingUtilities; +import java.awt.Color; +import java.awt.Dimension; +import java.awt.Font; +import java.awt.Graphics; +import java.awt.Graphics2D; +import java.awt.GraphicsEnvironment; +import java.awt.RenderingHints; +import java.awt.font.FontRenderContext; +import java.awt.font.GlyphVector; +import java.awt.image.BufferedImage; + +public class HelvLtOblTest extends JComponent { + + static Font helvFont = null; + + static int[] codes = { 0x23, 0x4a, 0x48, 0x3, 0x4a, 0x55, 0x42, 0x4d, + 0x4a, 0x44, 0x3, + 0x53, 0x46, 0x45, 0x3, 0x55, 0x46, 0x59, 0x55, }; + + static String str = "Big italic red text"; + + public static void main(String[] args) throws Exception { + String os = System.getProperty("os.name"); + if (!os.startsWith("Mac")) { + return; + } + GraphicsEnvironment ge = GraphicsEnvironment.getLocalGraphicsEnvironment(); + Font[] fonts = ge.getAllFonts(); + for (int i=0; i { + JFrame f = new JFrame(); + f.setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE); + f.add("Center", test); + f.pack(); + f.setVisible(true); + }); + test.compareImages(); + } + + public Dimension getPreferredSize() { + return new Dimension(400,400); + } + + public void paintComponent(Graphics g) { + super.paintComponent(g); + Graphics2D g2 = (Graphics2D)g; + FontRenderContext frc = new FontRenderContext(null, true, true); + Font f = helvFont.deriveFont(Font.PLAIN, 40); + System.out.println("font = " +f.getFontName()); + GlyphVector gv = f.createGlyphVector(frc, codes); + g.setFont(f); + g.setColor(Color.white); + g.fillRect(0,0,400,400); + g.setColor(Color.black); + g2.drawGlyphVector(gv, 5,200); + g2.setRenderingHint(RenderingHints.KEY_TEXT_ANTIALIASING, + RenderingHints.VALUE_TEXT_ANTIALIAS_ON); + g2.setRenderingHint(RenderingHints.KEY_FRACTIONALMETRICS, + RenderingHints.VALUE_FRACTIONALMETRICS_ON); + g2.drawString(str, 5, 250); + } + + void compareImages() { + BufferedImage bi0 = drawText(false); + BufferedImage bi1 = drawText(true); + compare(bi0, bi1); + } + + BufferedImage drawText(boolean doGV) { + int w = 400; + int h = 50; + BufferedImage bi = new BufferedImage(w, h, BufferedImage.TYPE_INT_RGB); + Graphics2D g = bi.createGraphics(); + g.setColor(Color.white); + g.fillRect(0,0,w,h); + g.setColor(Color.black); + Font f = helvFont.deriveFont(Font.PLAIN, 40); + g.setFont(f); + int x = 5; + int y = h - 10; + if (doGV) { + FontRenderContext frc = new FontRenderContext(null, true, true); + GlyphVector gv = f.createGlyphVector(frc, codes); + g.drawGlyphVector(gv, 5, y); + } else { + g.setRenderingHint(RenderingHints.KEY_TEXT_ANTIALIASING, + RenderingHints.VALUE_TEXT_ANTIALIAS_ON); + g.setRenderingHint(RenderingHints.KEY_FRACTIONALMETRICS, + RenderingHints.VALUE_FRACTIONALMETRICS_ON); + g.drawString(str, x, y); + } + return bi; + } + + // Need to allow for minimal rounding error, so allow each component + // to differ by 1. + void compare(BufferedImage bi0, BufferedImage bi1) { + int wid = bi0.getWidth(); + int hgt = bi0.getHeight(); + for (int x=0; x> 16; + int r1 = (rgb1 & 0xff0000) >> 16; + int rdiff = r0-r1; if (rdiff<0) rdiff = -rdiff; + int g0 = (rgb0 & 0x00ff00) >> 8; + int g1 = (rgb1 & 0x00ff00) >> 8; + int gdiff = g0-g1; if (gdiff<0) gdiff = -gdiff; + int b0 = (rgb0 & 0x0000ff); + int b1 = (rgb1 & 0x0000ff); + int bdiff = b0-b1; if (bdiff<0) bdiff = -bdiff; + if (rdiff > 1 || gdiff > 1 || bdiff > 1) { + throw new RuntimeException( + "Images differ at x=" + x + " y="+ y + " " + + Integer.toHexString(rgb0) + " vs " + + Integer.toHexString(rgb1)); + } + } + } + } + +} From cfe8daa596d70a43a2f0a463a74348450d9c9313 Mon Sep 17 00:00:00 2001 From: Alexander Zvegintsev Date: Mon, 26 Jan 2015 12:37:20 +0300 Subject: [PATCH 040/116] 8071483: Possible case-folding collision for color/Color subdirectories of jdk/test/java/awt/ Reviewed-by: rriggs, serb --- jdk/test/java/awt/{color => Color}/LoadProfileWithSM.java | 0 jdk/test/java/awt/{color => Color}/LoadStandardProfilesTest.java | 0 2 files changed, 0 insertions(+), 0 deletions(-) rename jdk/test/java/awt/{color => Color}/LoadProfileWithSM.java (100%) rename jdk/test/java/awt/{color => Color}/LoadStandardProfilesTest.java (100%) diff --git a/jdk/test/java/awt/color/LoadProfileWithSM.java b/jdk/test/java/awt/Color/LoadProfileWithSM.java similarity index 100% rename from jdk/test/java/awt/color/LoadProfileWithSM.java rename to jdk/test/java/awt/Color/LoadProfileWithSM.java diff --git a/jdk/test/java/awt/color/LoadStandardProfilesTest.java b/jdk/test/java/awt/Color/LoadStandardProfilesTest.java similarity index 100% rename from jdk/test/java/awt/color/LoadStandardProfilesTest.java rename to jdk/test/java/awt/Color/LoadStandardProfilesTest.java From deeb4faa8024b875c85c7f2b9277b84b2d00250e Mon Sep 17 00:00:00 2001 From: Sergey Bylokhov Date: Mon, 26 Jan 2015 16:32:47 +0300 Subject: [PATCH 041/116] 8069015: Re-examine Solaris/Linux java.desktop dependency on java.logging Reviewed-by: azvegint, ant --- .../classes/sun/awt/X11/XAWTFormatter.java | 150 ------------------ .../classes/sun/awt/X11/XEmbeddedFrame.java | 12 +- 2 files changed, 7 insertions(+), 155 deletions(-) delete mode 100644 jdk/src/java.desktop/unix/classes/sun/awt/X11/XAWTFormatter.java diff --git a/jdk/src/java.desktop/unix/classes/sun/awt/X11/XAWTFormatter.java b/jdk/src/java.desktop/unix/classes/sun/awt/X11/XAWTFormatter.java deleted file mode 100644 index 198d7a79508..00000000000 --- a/jdk/src/java.desktop/unix/classes/sun/awt/X11/XAWTFormatter.java +++ /dev/null @@ -1,150 +0,0 @@ -/* - * Copyright (c) 2003, 2014, 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. Oracle designates this - * particular file as subject to the "Classpath" exception as provided - * by Oracle in the LICENSE file that accompanied this code. - * - * 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. - */ - -package sun.awt.X11; - -import java.util.logging.*; -import java.text.*; -import java.util.*; -import java.io.*; - -/** - * Formatter class providing ANSI output. Based on java.util.logging.SimpleFormatter sources. - */ - -public class XAWTFormatter extends java.util.logging.Formatter { - Date dat = new Date(); - private final static String format = "{0,date} {0,time}"; - private MessageFormat formatter; - - private Object args[] = new Object[1]; - - // Line separator string. This is the value of the line.separator - // property at the moment that the SimpleFormatter was created. - private String lineSeparator = System.lineSeparator(); - - boolean displayFullRecord = false; - boolean useANSI = false; - boolean showDate = true; - boolean showLevel = true; - boolean swapMethodClass = false; - public XAWTFormatter() { - displayFullRecord = "true".equals(LogManager.getLogManager().getProperty("XAWTFormatter.displayFullRecord")); - useANSI = "true".equals(LogManager.getLogManager().getProperty("XAWTFormatter.useANSI")); - showDate = !"false".equals(LogManager.getLogManager().getProperty("XAWTFormatter.showDate")); - showLevel = !"false".equals(LogManager.getLogManager().getProperty("XAWTFormatter.showLevel")); - swapMethodClass = "true".equals(LogManager.getLogManager().getProperty("XAWTFormatter.swapMethodClass")); - } - - /** - * Format the given LogRecord. - * @param record the log record to be formatted. - * @return a formatted log record - */ - public synchronized String format(LogRecord record) { - StringBuffer sb = new StringBuffer(); - if (useANSI) { - Level lev = record.getLevel(); - if (Level.FINEST.equals(lev)) { - sb.append(""); - } else if (Level.FINER.equals(lev)) { - sb.append(""); - } else if (Level.FINE.equals(lev)) { - sb.append(""); - } - } - if (displayFullRecord) { - if (showDate) { - // Minimize memory allocations here. - dat.setTime(record.getMillis()); - args[0] = dat; - StringBuffer text = new StringBuffer(); - if (formatter == null) { - formatter = new MessageFormat(format); - } - formatter.format(args, text, null); - sb.append(text); - sb.append(" "); - } else { - sb.append(" "); - } - if (swapMethodClass) { - if (record.getSourceMethodName() != null) { - sb.append(" "); - sb.append(record.getSourceMethodName()); - sb.append(" "); - } - if (record.getSourceClassName() != null) { - sb.append(record.getSourceClassName()); - } else { - sb.append(record.getLoggerName()); - } - } else { - if (record.getSourceClassName() != null) { - sb.append(record.getSourceClassName()); - } else { - sb.append(record.getLoggerName()); - } - if (record.getSourceMethodName() != null) { - sb.append(" "); - sb.append(record.getSourceMethodName()); - sb.append(""); - } - } - sb.append(lineSeparator); - } - if (useANSI) { - Level lev = record.getLevel(); - if (Level.FINEST.equals(lev)) { - sb.append(""); - } else if (Level.FINER.equals(lev)) { - sb.append(""); - } else if (Level.FINE.equals(lev)) { - sb.append(""); - } - } - if (showLevel) { - sb.append(record.getLevel().getLocalizedName()); - sb.append(": "); - } - String message = formatMessage(record); - sb.append(message); - sb.append(lineSeparator); - if (record.getThrown() != null) { - try { - StringWriter sw = new StringWriter(); - PrintWriter pw = new PrintWriter(sw); - record.getThrown().printStackTrace(pw); - pw.close(); - sb.append(sw.toString()); - } catch (Exception ex) { - } - } - if (useANSI) { - sb.append(""); - } - return sb.toString(); - } -} diff --git a/jdk/src/java.desktop/unix/classes/sun/awt/X11/XEmbeddedFrame.java b/jdk/src/java.desktop/unix/classes/sun/awt/X11/XEmbeddedFrame.java index 489558b18bd..9b9431893cb 100644 --- a/jdk/src/java.desktop/unix/classes/sun/awt/X11/XEmbeddedFrame.java +++ b/jdk/src/java.desktop/unix/classes/sun/awt/X11/XEmbeddedFrame.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2002, 2014, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2002, 2015, 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 @@ -25,15 +25,17 @@ package sun.awt.X11; -import sun.awt.EmbeddedFrame; -import java.awt.*; import java.awt.AWTKeyStroke; -import java.util.logging.Logger; +import java.awt.Toolkit; + +import sun.awt.EmbeddedFrame; +import sun.util.logging.PlatformLogger; @SuppressWarnings("serial") // JDK-implementation class public class XEmbeddedFrame extends EmbeddedFrame { - private static final Logger log = Logger.getLogger(XEmbeddedFrame.class.getName()); + private static final PlatformLogger log = + PlatformLogger.getLogger(XEmbeddedFrame.class.getName()); long handle; public XEmbeddedFrame() { From 8dd67e74592ebd16ca1c660e3f3f16d69d3a9514 Mon Sep 17 00:00:00 2001 From: Shobhit Gupta Date: Thu, 29 Jan 2015 14:03:23 +0300 Subject: [PATCH 042/116] 8068292: [TEST_BUG] Test javax/swing/JLayer/6824395/bug6824395.java fails with -Dswing.defaultlaf=com.sun.java.swing.plaf.gtk.GTKLookAndFeel Reviewed-by: alexsch, azvegint --- jdk/test/javax/swing/JLayer/6824395/bug6824395.java | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/jdk/test/javax/swing/JLayer/6824395/bug6824395.java b/jdk/test/javax/swing/JLayer/6824395/bug6824395.java index f2040f4b327..fd35608d478 100644 --- a/jdk/test/javax/swing/JLayer/6824395/bug6824395.java +++ b/jdk/test/javax/swing/JLayer/6824395/bug6824395.java @@ -59,7 +59,7 @@ public class bug6824395 { editorPaneLayer.setUI(layerUI); scrollPane = new JScrollPane(editorPaneLayer); - + scrollPane.setViewportBorder(null); scrollPane.setPreferredSize(new Dimension(200, 250)); frame.add(scrollPane); From 8717474863e78daeb8e212d74c9e624bbd3b2721 Mon Sep 17 00:00:00 2001 From: Phil Race Date: Thu, 29 Jan 2015 09:34:05 -0800 Subject: [PATCH 043/116] 8071710: [solaris] libfontmanager should be linked against headless awt library Reviewed-by: ihse, erikj --- jdk/make/lib/Awt2dLibraries.gmk | 11 +++-------- 1 file changed, 3 insertions(+), 8 deletions(-) diff --git a/jdk/make/lib/Awt2dLibraries.gmk b/jdk/make/lib/Awt2dLibraries.gmk index fca33420271..a20b85b59c1 100644 --- a/jdk/make/lib/Awt2dLibraries.gmk +++ b/jdk/make/lib/Awt2dLibraries.gmk @@ -562,10 +562,6 @@ ifeq ($(OPENJDK_TARGET_OS), linux) BUILD_LIBFONTMANAGER_ExtensionSubtables.cpp_CXXFLAGS := -fno-strict-aliasing endif -# Libfontmanager doesn't actually need X_LIBS to link, but if building -# on a Solaris machine without X installed, using a devkit, linking -# to libawt_xawt will fail without the -L parameters from X_LIBS. Filter -# out the -R parameters since they aren't needed. $(eval $(call SetupNativeCompilation,BUILD_LIBFONTMANAGER, \ LIBRARY := fontmanager, \ OUTPUT_DIR := $(INSTALL_LIBRARIES_HERE), \ @@ -583,9 +579,8 @@ $(eval $(call SetupNativeCompilation,BUILD_LIBFONTMANAGER, \ LDFLAGS_unix := -L$(INSTALL_LIBRARIES_HERE), \ LDFLAGS_SUFFIX := $(BUILD_LIBFONTMANAGER_FONTLIB), \ LDFLAGS_SUFFIX_linux := -lawt $(LIBM) $(LIBCXX) -ljava -ljvm -lc, \ - LDFLAGS_SUFFIX_solaris := $(filter-out -R%, $(X_LIBS)) \ - -lawt -lawt_xawt -lc $(LIBM) $(LIBCXX) -ljava -ljvm, \ - LDFLAGS_SUFFIX_aix := -lawt -lawt_xawt $(LIBM) $(LIBCXX) -ljava -ljvm,\ + LDFLAGS_SUFFIX_solaris := -lawt -lawt_headless -lc $(LIBM) $(LIBCXX) -ljava -ljvm, \ + LDFLAGS_SUFFIX_aix := -lawt -lawt_headless $(LIBM) $(LIBCXX) -ljava -ljvm,\ LDFLAGS_SUFFIX_macosx := -lawt $(LIBM) $(LIBCXX) -undefined dynamic_lookup \ -ljava -ljvm, \ LDFLAGS_SUFFIX_windows := $(WIN_JAVA_LIB) advapi32.lib user32.lib gdi32.lib \ @@ -601,7 +596,7 @@ $(eval $(call SetupNativeCompilation,BUILD_LIBFONTMANAGER, \ $(BUILD_LIBFONTMANAGER): $(BUILD_LIBAWT) ifneq (, $(findstring $(OPENJDK_TARGET_OS), solaris aix)) - $(BUILD_LIBFONTMANAGER): $(BUILD_LIBAWT_XAWT) + $(BUILD_LIBFONTMANAGER): $(BUILD_LIBAWT_HEADLESS) endif TARGETS += $(BUILD_LIBFONTMANAGER) From 49282c3927982f97b348dfeb4ce3aa8e99f5b718 Mon Sep 17 00:00:00 2001 From: Zoltan Majo Date: Thu, 29 Jan 2015 19:16:47 +0100 Subject: [PATCH 044/116] 8071654: disassembler handles embedded OOPs not uniformly Remove (currently dead) code that prints oops within disassembled instructions. Reviewed-by: kvn, thartmann, roland --- hotspot/src/share/vm/code/nmethod.cpp | 11 ----------- hotspot/src/share/vm/code/nmethod.hpp | 5 ----- hotspot/src/share/vm/compiler/disassembler.cpp | 15 --------------- 3 files changed, 31 deletions(-) diff --git a/hotspot/src/share/vm/code/nmethod.cpp b/hotspot/src/share/vm/code/nmethod.cpp index 835b3dc831d..0e60a131ae8 100644 --- a/hotspot/src/share/vm/code/nmethod.cpp +++ b/hotspot/src/share/vm/code/nmethod.cpp @@ -2310,17 +2310,6 @@ void nmethod::preserve_callee_argument_oops(frame fr, const RegisterMap *reg_map #endif // !SHARK } - -oop nmethod::embeddedOop_at(u_char* p) { - RelocIterator iter(this, p, p + 1); - while (iter.next()) - if (iter.type() == relocInfo::oop_type) { - return iter.oop_reloc()->oop_value(); - } - return NULL; -} - - inline bool includes(void* p, void* from, void* to) { return from <= p && p < to; } diff --git a/hotspot/src/share/vm/code/nmethod.hpp b/hotspot/src/share/vm/code/nmethod.hpp index c95679649fd..5d4173738d9 100644 --- a/hotspot/src/share/vm/code/nmethod.hpp +++ b/hotspot/src/share/vm/code/nmethod.hpp @@ -730,11 +730,6 @@ public: int compile_id() const { return _compile_id; } const char* compile_kind() const; - // For debugging - // CompiledIC* IC_at(char* p) const; - // PrimitiveIC* primitiveIC_at(char* p) const; - oop embeddedOop_at(address p); - // tells if any of this method's dependencies have been invalidated // (this is expensive!) static void check_all_dependencies(DepChange& changes); diff --git a/hotspot/src/share/vm/compiler/disassembler.cpp b/hotspot/src/share/vm/compiler/disassembler.cpp index e4f6d3f5040..eb99f050f87 100644 --- a/hotspot/src/share/vm/compiler/disassembler.cpp +++ b/hotspot/src/share/vm/compiler/disassembler.cpp @@ -345,21 +345,6 @@ void decode_env::print_address(address adr) { if (WizardMode) st->print(" " INTPTR_FORMAT, (intptr_t)adr); return; } - - oop obj; - if (_nm != NULL - && (obj = _nm->embeddedOop_at(cur_insn())) != NULL - && (address) obj == adr - && Universe::heap()->is_in(obj) - && Universe::heap()->is_in(obj->klass())) { - julong c = st->count(); - obj->print_value_on(st); - if (st->count() == c) { - // No output. (Can happen in product builds.) - st->print("(a %s)", obj->klass()->external_name()); - } - return; - } } // Fall through to a simple (hexadecimal) numeral. From 7227e9ba536035ee1139311494adff703c697728 Mon Sep 17 00:00:00 2001 From: Vladimir Ivanov Date: Thu, 29 Jan 2015 10:25:59 -0800 Subject: [PATCH 045/116] 8063137: Never-taken branches should be pruned when GWT LambdaForms are shared Reviewed-by: jrose, kvn --- hotspot/src/share/vm/ci/ciMethod.cpp | 6 +- hotspot/src/share/vm/ci/ciMethod.hpp | 4 ++ hotspot/src/share/vm/classfile/vmSymbols.hpp | 10 ++- hotspot/src/share/vm/opto/classes.hpp | 1 + hotspot/src/share/vm/opto/compile.cpp | 7 ++ hotspot/src/share/vm/opto/graphKit.hpp | 9 +++ hotspot/src/share/vm/opto/library_call.cpp | 50 ++++++++++++++ hotspot/src/share/vm/opto/opaquenode.cpp | 23 ++++++ hotspot/src/share/vm/opto/opaquenode.hpp | 26 +++++++ hotspot/src/share/vm/opto/parse.hpp | 4 +- hotspot/src/share/vm/opto/parse2.cpp | 73 ++++++++++++++------ 11 files changed, 185 insertions(+), 28 deletions(-) diff --git a/hotspot/src/share/vm/ci/ciMethod.cpp b/hotspot/src/share/vm/ci/ciMethod.cpp index d32df16bcbb..4769254e9b6 100644 --- a/hotspot/src/share/vm/ci/ciMethod.cpp +++ b/hotspot/src/share/vm/ci/ciMethod.cpp @@ -70,7 +70,8 @@ // Loaded method. ciMethod::ciMethod(methodHandle h_m, ciInstanceKlass* holder) : ciMetadata(h_m()), - _holder(holder) + _holder(holder), + _has_injected_profile(false) { assert(h_m() != NULL, "no null method"); @@ -168,7 +169,8 @@ ciMethod::ciMethod(ciInstanceKlass* holder, _liveness( NULL), _can_be_statically_bound(false), _method_blocks( NULL), - _method_data( NULL) + _method_data( NULL), + _has_injected_profile( false) #if defined(COMPILER2) || defined(SHARK) , _flow( NULL), diff --git a/hotspot/src/share/vm/ci/ciMethod.hpp b/hotspot/src/share/vm/ci/ciMethod.hpp index 5a46fc483c9..76662089bd8 100644 --- a/hotspot/src/share/vm/ci/ciMethod.hpp +++ b/hotspot/src/share/vm/ci/ciMethod.hpp @@ -79,6 +79,7 @@ class ciMethod : public ciMetadata { bool _is_c1_compilable; bool _is_c2_compilable; bool _can_be_statically_bound; + bool _has_injected_profile; // Lazy fields, filled in on demand address _code; @@ -286,6 +287,9 @@ class ciMethod : public ciMetadata { int instructions_size(); int scale_count(int count, float prof_factor = 1.); // make MDO count commensurate with IIC + bool has_injected_profile() const { return _has_injected_profile; } + void set_injected_profile(bool x) { _has_injected_profile = x; } + // Stack walking support bool is_ignored_by_security_stack_walk() const; diff --git a/hotspot/src/share/vm/classfile/vmSymbols.hpp b/hotspot/src/share/vm/classfile/vmSymbols.hpp index 6a5f1508076..94150a96cea 100644 --- a/hotspot/src/share/vm/classfile/vmSymbols.hpp +++ b/hotspot/src/share/vm/classfile/vmSymbols.hpp @@ -243,7 +243,6 @@ template(returnType_name, "returnType") \ template(signature_name, "signature") \ template(slot_name, "slot") \ - template(selectAlternative_name, "selectAlternative") \ \ /* Support for annotations (JDK 1.5 and above) */ \ \ @@ -295,8 +294,7 @@ template(setTarget_signature, "(Ljava/lang/invoke/MethodHandle;)V") \ NOT_LP64( do_alias(intptr_signature, int_signature) ) \ LP64_ONLY( do_alias(intptr_signature, long_signature) ) \ - template(selectAlternative_signature, "(ZLjava/lang/invoke/MethodHandle;Ljava/lang/invoke/MethodHandle;)Ljava/lang/invoke/MethodHandle;") \ - \ + \ /* common method and field names */ \ template(object_initializer_name, "") \ template(class_initializer_name, "") \ @@ -868,6 +866,12 @@ do_name( fullFence_name, "fullFence") \ do_alias( fullFence_signature, void_method_signature) \ \ + /* Custom branch frequencies profiling support for JSR292 */ \ + do_class(java_lang_invoke_MethodHandleImpl, "java/lang/invoke/MethodHandleImpl") \ + do_intrinsic(_profileBoolean, java_lang_invoke_MethodHandleImpl, profileBoolean_name, profileBoolean_signature, F_S) \ + do_name( profileBoolean_name, "profileBoolean") \ + do_signature(profileBoolean_signature, "(Z[I)Z") \ + \ /* unsafe memory references (there are a lot of them...) */ \ do_signature(getObject_signature, "(Ljava/lang/Object;J)Ljava/lang/Object;") \ do_signature(putObject_signature, "(Ljava/lang/Object;JLjava/lang/Object;)V") \ diff --git a/hotspot/src/share/vm/opto/classes.hpp b/hotspot/src/share/vm/opto/classes.hpp index 238e3491862..0638cdee3bb 100644 --- a/hotspot/src/share/vm/opto/classes.hpp +++ b/hotspot/src/share/vm/opto/classes.hpp @@ -200,6 +200,7 @@ macro(NeverBranch) macro(Opaque1) macro(Opaque2) macro(Opaque3) +macro(ProfileBoolean) macro(OrI) macro(OrL) macro(OverflowAddI) diff --git a/hotspot/src/share/vm/opto/compile.cpp b/hotspot/src/share/vm/opto/compile.cpp index 23253651dca..b2a29982e0f 100644 --- a/hotspot/src/share/vm/opto/compile.cpp +++ b/hotspot/src/share/vm/opto/compile.cpp @@ -3105,6 +3105,7 @@ void Compile::final_graph_reshaping_impl( Node *n, Final_Reshape_Counts &frc) { default: assert( !n->is_Call(), "" ); assert( !n->is_Mem(), "" ); + assert( nop != Op_ProfileBoolean, "should be eliminated during IGVN"); break; } @@ -3321,6 +3322,9 @@ bool Compile::final_graph_reshaping() { bool Compile::too_many_traps(ciMethod* method, int bci, Deoptimization::DeoptReason reason) { + if (method->has_injected_profile()) { + return false; + } ciMethodData* md = method->method_data(); if (md->is_empty()) { // Assume the trap has not occurred, or that it occurred only @@ -3370,6 +3374,9 @@ bool Compile::too_many_traps(Deoptimization::DeoptReason reason, bool Compile::too_many_recompiles(ciMethod* method, int bci, Deoptimization::DeoptReason reason) { + if (method->has_injected_profile()) { + return false; + } ciMethodData* md = method->method_data(); if (md->is_empty()) { // Assume the trap has not occurred, or that it occurred only diff --git a/hotspot/src/share/vm/opto/graphKit.hpp b/hotspot/src/share/vm/opto/graphKit.hpp index 22699420cbb..d608537f90c 100644 --- a/hotspot/src/share/vm/opto/graphKit.hpp +++ b/hotspot/src/share/vm/opto/graphKit.hpp @@ -714,6 +714,15 @@ class GraphKit : public Phase { klass, reason_string, must_throw, keep_exact_action); } + // Bail out to the interpreter and keep exact action (avoid switching to Action_none). + void uncommon_trap_exact(Deoptimization::DeoptReason reason, + Deoptimization::DeoptAction action, + ciKlass* klass = NULL, const char* reason_string = NULL, + bool must_throw = false) { + uncommon_trap(Deoptimization::make_trap_request(reason, action), + klass, reason_string, must_throw, /*keep_exact_action=*/true); + } + // SP when bytecode needs to be reexecuted. virtual int reexecute_sp() { return sp(); } diff --git a/hotspot/src/share/vm/opto/library_call.cpp b/hotspot/src/share/vm/opto/library_call.cpp index 45eeb9672ff..384f8b491c2 100644 --- a/hotspot/src/share/vm/opto/library_call.cpp +++ b/hotspot/src/share/vm/opto/library_call.cpp @@ -41,6 +41,7 @@ #include "opto/movenode.hpp" #include "opto/mulnode.hpp" #include "opto/narrowptrnode.hpp" +#include "opto/opaquenode.hpp" #include "opto/parse.hpp" #include "opto/runtime.hpp" #include "opto/subnode.hpp" @@ -287,6 +288,8 @@ class LibraryCallKit : public GraphKit { bool inline_updateBytesCRC32(); bool inline_updateByteBufferCRC32(); bool inline_multiplyToLen(); + + bool inline_profileBoolean(); }; @@ -900,6 +903,9 @@ bool LibraryCallKit::try_to_inline(int predicate) { case vmIntrinsics::_updateByteBufferCRC32: return inline_updateByteBufferCRC32(); + case vmIntrinsics::_profileBoolean: + return inline_profileBoolean(); + default: // If you get here, it may be that someone has added a new intrinsic // to the list in vmSymbols.hpp without implementing it here. @@ -5867,3 +5873,47 @@ Node* LibraryCallKit::inline_digestBase_implCompressMB_predicate(int predicate) return instof_false; // even if it is NULL } + +bool LibraryCallKit::inline_profileBoolean() { + Node* counts = argument(1); + const TypeAryPtr* ary = NULL; + ciArray* aobj = NULL; + if (counts->is_Con() + && (ary = counts->bottom_type()->isa_aryptr()) != NULL + && (aobj = ary->const_oop()->as_array()) != NULL + && (aobj->length() == 2)) { + // Profile is int[2] where [0] and [1] correspond to false and true value occurrences respectively. + jint false_cnt = aobj->element_value(0).as_int(); + jint true_cnt = aobj->element_value(1).as_int(); + + method()->set_injected_profile(true); + + if (C->log() != NULL) { + C->log()->elem("observe source='profileBoolean' false='%d' true='%d'", + false_cnt, true_cnt); + } + + if (false_cnt + true_cnt == 0) { + // According to profile, never executed. + uncommon_trap_exact(Deoptimization::Reason_intrinsic, + Deoptimization::Action_reinterpret); + return true; + } + // Stop profiling. + // MethodHandleImpl::profileBoolean() has profiling logic in it's bytecode. + // By replacing method's body with profile data (represented as ProfileBooleanNode + // on IR level) we effectively disable profiling. + // It enables full speed execution once optimized code is generated. + Node* profile = _gvn.transform(new ProfileBooleanNode(argument(0), false_cnt, true_cnt)); + C->record_for_igvn(profile); + set_result(profile); + return true; + } else { + // Continue profiling. + // Profile data isn't available at the moment. So, execute method's bytecode version. + // Usually, when GWT LambdaForms are profiled it means that a stand-alone nmethod + // is compiled and counters aren't available since corresponding MethodHandle + // isn't a compile-time constant. + return false; + } +} diff --git a/hotspot/src/share/vm/opto/opaquenode.cpp b/hotspot/src/share/vm/opto/opaquenode.cpp index b2cd073b131..cc0bdebc79e 100644 --- a/hotspot/src/share/vm/opto/opaquenode.cpp +++ b/hotspot/src/share/vm/opto/opaquenode.cpp @@ -60,4 +60,27 @@ uint Opaque2Node::cmp( const Node &n ) const { return (&n == this); // Always fail except on self } +//============================================================================= +uint ProfileBooleanNode::hash() const { return NO_HASH; } +uint ProfileBooleanNode::cmp( const Node &n ) const { + return (&n == this); +} + +Node *ProfileBooleanNode::Ideal(PhaseGVN *phase, bool can_reshape) { + if (can_reshape && _delay_removal) { + _delay_removal = false; + return this; + } else { + return NULL; + } +} + +Node *ProfileBooleanNode::Identity( PhaseTransform *phase ) { + if (_delay_removal) { + return this; + } else { + assert(_consumed, "profile should be consumed before elimination"); + return in(1); + } +} diff --git a/hotspot/src/share/vm/opto/opaquenode.hpp b/hotspot/src/share/vm/opto/opaquenode.hpp index 2f92a4a37aa..ba298864486 100644 --- a/hotspot/src/share/vm/opto/opaquenode.hpp +++ b/hotspot/src/share/vm/opto/opaquenode.hpp @@ -87,5 +87,31 @@ class Opaque3Node : public Opaque2Node { bool rtm_opt() const { return (_opt == RTM_OPT); } }; +//------------------------------ProfileBooleanNode------------------------------- +// A node represents value profile for a boolean during parsing. +// Once parsing is over, the node goes away (during IGVN). +// It is used to override branch frequencies from MDO (see has_injected_profile in parse2.cpp). +class ProfileBooleanNode : public Node { + uint _false_cnt; + uint _true_cnt; + bool _consumed; + bool _delay_removal; + virtual uint hash() const ; // { return NO_HASH; } + virtual uint cmp( const Node &n ) const; + public: + ProfileBooleanNode(Node *n, uint false_cnt, uint true_cnt) : Node(0, n), + _false_cnt(false_cnt), _true_cnt(true_cnt), _delay_removal(true), _consumed(false) {} + + uint false_count() const { return _false_cnt; } + uint true_count() const { return _true_cnt; } + + void consume() { _consumed = true; } + + virtual int Opcode() const; + virtual Node *Ideal(PhaseGVN *phase, bool can_reshape); + virtual Node *Identity(PhaseTransform *phase); + virtual const Type *bottom_type() const { return TypeInt::BOOL; } +}; + #endif // SHARE_VM_OPTO_OPAQUENODE_HPP diff --git a/hotspot/src/share/vm/opto/parse.hpp b/hotspot/src/share/vm/opto/parse.hpp index ab05a633ae1..97bfac6d169 100644 --- a/hotspot/src/share/vm/opto/parse.hpp +++ b/hotspot/src/share/vm/opto/parse.hpp @@ -555,8 +555,8 @@ class Parse : public GraphKit { void do_jsr(); void do_ret(); - float dynamic_branch_prediction(float &cnt); - float branch_prediction(float &cnt, BoolTest::mask btest, int target_bci); + float dynamic_branch_prediction(float &cnt, BoolTest::mask btest, Node* test); + float branch_prediction(float &cnt, BoolTest::mask btest, int target_bci, Node* test); bool seems_never_taken(float prob) const; bool path_is_suitable_for_uncommon_trap(float prob) const; bool seems_stable_comparison() const; diff --git a/hotspot/src/share/vm/opto/parse2.cpp b/hotspot/src/share/vm/opto/parse2.cpp index c99ac9659d1..237bf7625ad 100644 --- a/hotspot/src/share/vm/opto/parse2.cpp +++ b/hotspot/src/share/vm/opto/parse2.cpp @@ -37,6 +37,7 @@ #include "opto/matcher.hpp" #include "opto/memnode.hpp" #include "opto/mulnode.hpp" +#include "opto/opaquenode.hpp" #include "opto/parse.hpp" #include "opto/runtime.hpp" #include "runtime/deoptimization.hpp" @@ -763,35 +764,64 @@ void Parse::do_ret() { merge_common(target, pnum); } +static bool has_injected_profile(BoolTest::mask btest, Node* test, int& taken, int& not_taken) { + if (btest != BoolTest::eq && btest != BoolTest::ne) { + // Only ::eq and ::ne are supported for profile injection. + return false; + } + if (test->is_Cmp() && + test->in(1)->Opcode() == Op_ProfileBoolean) { + ProfileBooleanNode* profile = (ProfileBooleanNode*)test->in(1); + int false_cnt = profile->false_count(); + int true_cnt = profile->true_count(); + + // Counts matching depends on the actual test operation (::eq or ::ne). + // No need to scale the counts because profile injection was designed + // to feed exact counts into VM. + taken = (btest == BoolTest::eq) ? false_cnt : true_cnt; + not_taken = (btest == BoolTest::eq) ? true_cnt : false_cnt; + + profile->consume(); + return true; + } + return false; +} //--------------------------dynamic_branch_prediction-------------------------- // Try to gather dynamic branch prediction behavior. Return a probability // of the branch being taken and set the "cnt" field. Returns a -1.0 // if we need to use static prediction for some reason. -float Parse::dynamic_branch_prediction(float &cnt) { +float Parse::dynamic_branch_prediction(float &cnt, BoolTest::mask btest, Node* test) { ResourceMark rm; cnt = COUNT_UNKNOWN; - // Use MethodData information if it is available - // FIXME: free the ProfileData structure - ciMethodData* methodData = method()->method_data(); - if (!methodData->is_mature()) return PROB_UNKNOWN; - ciProfileData* data = methodData->bci_to_data(bci()); - if (!data->is_JumpData()) return PROB_UNKNOWN; - - // get taken and not taken values - int taken = data->as_JumpData()->taken(); + int taken = 0; int not_taken = 0; - if (data->is_BranchData()) { - not_taken = data->as_BranchData()->not_taken(); + + bool use_mdo = !has_injected_profile(btest, test, taken, not_taken); + + if (use_mdo) { + // Use MethodData information if it is available + // FIXME: free the ProfileData structure + ciMethodData* methodData = method()->method_data(); + if (!methodData->is_mature()) return PROB_UNKNOWN; + ciProfileData* data = methodData->bci_to_data(bci()); + if (!data->is_JumpData()) return PROB_UNKNOWN; + + // get taken and not taken values + taken = data->as_JumpData()->taken(); + not_taken = 0; + if (data->is_BranchData()) { + not_taken = data->as_BranchData()->not_taken(); + } + + // scale the counts to be commensurate with invocation counts: + taken = method()->scale_count(taken); + not_taken = method()->scale_count(not_taken); } - // scale the counts to be commensurate with invocation counts: - taken = method()->scale_count(taken); - not_taken = method()->scale_count(not_taken); - // Give up if too few (or too many, in which case the sum will overflow) counts to be meaningful. - // We also check that individual counters are positive first, overwise the sum can become positive. + // We also check that individual counters are positive first, otherwise the sum can become positive. if (taken < 0 || not_taken < 0 || taken + not_taken < 40) { if (C->log() != NULL) { C->log()->elem("branch target_bci='%d' taken='%d' not_taken='%d'", iter().get_dest(), taken, not_taken); @@ -841,8 +871,9 @@ float Parse::dynamic_branch_prediction(float &cnt) { //-----------------------------branch_prediction------------------------------- float Parse::branch_prediction(float& cnt, BoolTest::mask btest, - int target_bci) { - float prob = dynamic_branch_prediction(cnt); + int target_bci, + Node* test) { + float prob = dynamic_branch_prediction(cnt, btest, test); // If prob is unknown, switch to static prediction if (prob != PROB_UNKNOWN) return prob; @@ -932,7 +963,7 @@ void Parse::do_ifnull(BoolTest::mask btest, Node *c) { Block* next_block = successor_for_bci(iter().next_bci()); float cnt; - float prob = branch_prediction(cnt, btest, target_bci); + float prob = branch_prediction(cnt, btest, target_bci, c); if (prob == PROB_UNKNOWN) { // (An earlier version of do_ifnull omitted this trap for OSR methods.) #ifndef PRODUCT @@ -1013,7 +1044,7 @@ void Parse::do_if(BoolTest::mask btest, Node* c) { Block* next_block = successor_for_bci(iter().next_bci()); float cnt; - float prob = branch_prediction(cnt, btest, target_bci); + float prob = branch_prediction(cnt, btest, target_bci, c); float untaken_prob = 1.0 - prob; if (prob == PROB_UNKNOWN) { From efd80ec6afc432e445e32b467ad999779b6e41ef Mon Sep 17 00:00:00 2001 From: Vladimir Ivanov Date: Thu, 29 Jan 2015 10:26:02 -0800 Subject: [PATCH 046/116] 8068915: uncommon trap w/ Reason_speculate_class_check causes performance regression due to continuous deoptimizations Reviewed-by: kvn, roland, jrose --- hotspot/src/share/vm/opto/graphKit.cpp | 23 +++++++++++++---------- 1 file changed, 13 insertions(+), 10 deletions(-) diff --git a/hotspot/src/share/vm/opto/graphKit.cpp b/hotspot/src/share/vm/opto/graphKit.cpp index 20932a5bd51..ccde0152a87 100644 --- a/hotspot/src/share/vm/opto/graphKit.cpp +++ b/hotspot/src/share/vm/opto/graphKit.cpp @@ -1989,6 +1989,11 @@ void GraphKit::uncommon_trap(int trap_request, Deoptimization::trap_request_index(trap_request) < 0 && too_many_recompiles(reason)) { // This BCI is causing too many recompilations. + if (C->log() != NULL) { + C->log()->elem("observe that='trap_action_change' reason='%s' from='%s' to='none'", + Deoptimization::trap_reason_name(reason), + Deoptimization::trap_action_name(action)); + } action = Deoptimization::Action_none; trap_request = Deoptimization::make_trap_request(reason, action); } else { @@ -2763,7 +2768,7 @@ Node* GraphKit::maybe_cast_profiled_receiver(Node* not_null_obj, Deoptimization::DeoptReason reason = Deoptimization::reason_class_check(spec_klass != NULL); // Make sure we haven't already deoptimized from this tactic. - if (too_many_traps(reason)) + if (too_many_traps(reason) || too_many_recompiles(reason)) return NULL; // (No, this isn't a call, but it's enough like a virtual call @@ -2785,8 +2790,7 @@ Node* GraphKit::maybe_cast_profiled_receiver(Node* not_null_obj, &exact_obj); { PreserveJVMState pjvms(this); set_control(slow_ctl); - uncommon_trap(reason, - Deoptimization::Action_maybe_recompile); + uncommon_trap_exact(reason, Deoptimization::Action_maybe_recompile); } if (safe_for_replace) { replace_in_map(not_null_obj, exact_obj); @@ -2815,8 +2819,8 @@ Node* GraphKit::maybe_cast_profiled_obj(Node* obj, if (type != NULL) { Deoptimization::DeoptReason class_reason = Deoptimization::Reason_speculate_class_check; Deoptimization::DeoptReason null_reason = Deoptimization::Reason_speculate_null_check; - if (!too_many_traps(null_reason) && - !too_many_traps(class_reason)) { + if (!too_many_traps(null_reason) && !too_many_recompiles(null_reason) && + !too_many_traps(class_reason) && !too_many_recompiles(class_reason)) { Node* not_null_obj = NULL; // not_null is true if we know the object is not null and // there's no need for a null check @@ -2836,19 +2840,18 @@ Node* GraphKit::maybe_cast_profiled_obj(Node* obj, GraphKit kit(sfpt->jvms()); PreserveJVMState pjvms(&kit); kit.set_control(slow_ctl); - kit.uncommon_trap(class_reason, - Deoptimization::Action_maybe_recompile); + kit.uncommon_trap_exact(class_reason, Deoptimization::Action_maybe_recompile); } else { PreserveJVMState pjvms(this); set_control(slow_ctl); - uncommon_trap(class_reason, - Deoptimization::Action_maybe_recompile); + uncommon_trap_exact(class_reason, Deoptimization::Action_maybe_recompile); } replace_in_map(not_null_obj, exact_obj); obj = exact_obj; } } else { - if (!too_many_traps(Deoptimization::Reason_null_assert)) { + if (!too_many_traps(Deoptimization::Reason_null_assert) && + !too_many_recompiles(Deoptimization::Reason_null_assert)) { Node* exact_obj = null_assert(obj); replace_in_map(obj, exact_obj); obj = exact_obj; From 06305c456b9d1802ff391056e46a36362a829fad Mon Sep 17 00:00:00 2001 From: Vladimir Ivanov Date: Thu, 29 Jan 2015 10:27:30 -0800 Subject: [PATCH 047/116] 8063137: Never-taken branches should be pruned when GWT LambdaForms are shared Reviewed-by: jrose, kvn --- .../lang/invoke/InvokerBytecodeGenerator.java | 1 - .../classes/java/lang/invoke/LambdaForm.java | 12 ++-- .../java/lang/invoke/MethodHandleImpl.java | 59 +++++++++++++++---- .../java/lang/invoke/MethodHandleStatics.java | 5 +- 4 files changed, 56 insertions(+), 21 deletions(-) diff --git a/jdk/src/java.base/share/classes/java/lang/invoke/InvokerBytecodeGenerator.java b/jdk/src/java.base/share/classes/java/lang/invoke/InvokerBytecodeGenerator.java index acb5aa91623..6a4b2995058 100644 --- a/jdk/src/java.base/share/classes/java/lang/invoke/InvokerBytecodeGenerator.java +++ b/jdk/src/java.base/share/classes/java/lang/invoke/InvokerBytecodeGenerator.java @@ -635,7 +635,6 @@ class InvokerBytecodeGenerator { mv.visitAnnotation("Ljava/lang/invoke/DontInline;", true); } - // iterate over the form's names, generating bytecode instructions for each // start iterating at the first name following the arguments Name onStack = null; diff --git a/jdk/src/java.base/share/classes/java/lang/invoke/LambdaForm.java b/jdk/src/java.base/share/classes/java/lang/invoke/LambdaForm.java index 2129f8618bd..7533d83bb25 100644 --- a/jdk/src/java.base/share/classes/java/lang/invoke/LambdaForm.java +++ b/jdk/src/java.base/share/classes/java/lang/invoke/LambdaForm.java @@ -244,7 +244,7 @@ class LambdaForm { LambdaForm(String debugName, int arity, Name[] names, int result) { - this(debugName, arity, names, result, true); + this(debugName, arity, names, result, /*forceInline=*/true); } LambdaForm(String debugName, int arity, Name[] names, int result, boolean forceInline) { @@ -263,7 +263,7 @@ class LambdaForm { } LambdaForm(String debugName, int arity, Name[] names) { - this(debugName, arity, names, LAST_RESULT, true); + this(debugName, arity, names, LAST_RESULT, /*forceInline=*/true); } LambdaForm(String debugName, int arity, Name[] names, boolean forceInline) { @@ -272,7 +272,7 @@ class LambdaForm { LambdaForm(String debugName, Name[] formals, Name[] temps, Name result) { this(debugName, - formals.length, buildNames(formals, temps, result), LAST_RESULT, true); + formals.length, buildNames(formals, temps, result), LAST_RESULT, /*forceInline=*/true); } LambdaForm(String debugName, Name[] formals, Name[] temps, Name result, boolean forceInline) { @@ -291,10 +291,6 @@ class LambdaForm { } private LambdaForm(String sig) { - this(sig, true); - } - - private LambdaForm(String sig, boolean forceInline) { // Make a blank lambda form, which returns a constant zero or null. // It is used as a template for managing the invocation of similar forms that are non-empty. // Called only from getPreparedForm. @@ -303,7 +299,7 @@ class LambdaForm { this.result = (signatureReturn(sig) == V_TYPE ? -1 : arity); this.names = buildEmptyNames(arity, sig); this.debugName = "LF.zero"; - this.forceInline = forceInline; + this.forceInline = true; assert(nameRefsAreLegal()); assert(isEmpty()); assert(sig.equals(basicTypeSignature())) : sig + " != " + basicTypeSignature(); diff --git a/jdk/src/java.base/share/classes/java/lang/invoke/MethodHandleImpl.java b/jdk/src/java.base/share/classes/java/lang/invoke/MethodHandleImpl.java index 7d8c63490d5..1a78502ebe5 100644 --- a/jdk/src/java.base/share/classes/java/lang/invoke/MethodHandleImpl.java +++ b/jdk/src/java.base/share/classes/java/lang/invoke/MethodHandleImpl.java @@ -597,6 +597,7 @@ import static java.lang.invoke.MethodHandles.Lookup.IMPL_LOOKUP; static final NamedFunction NF_checkSpreadArgument; static final NamedFunction NF_guardWithCatch; static final NamedFunction NF_throwException; + static final NamedFunction NF_profileBoolean; static final MethodHandle MH_castReference; static final MethodHandle MH_selectAlternative; @@ -614,10 +615,12 @@ import static java.lang.invoke.MethodHandles.Lookup.IMPL_LOOKUP; NF_guardWithCatch = new NamedFunction(MHI.getDeclaredMethod("guardWithCatch", MethodHandle.class, Class.class, MethodHandle.class, Object[].class)); NF_throwException = new NamedFunction(MHI.getDeclaredMethod("throwException", Throwable.class)); + NF_profileBoolean = new NamedFunction(MHI.getDeclaredMethod("profileBoolean", boolean.class, int[].class)); NF_checkSpreadArgument.resolve(); NF_guardWithCatch.resolve(); NF_throwException.resolve(); + NF_profileBoolean.resolve(); MH_castReference = IMPL_LOOKUP.findStatic(MHI, "castReference", MethodType.methodType(Object.class, Class.class, Object.class)); @@ -697,7 +700,26 @@ import static java.lang.invoke.MethodHandles.Lookup.IMPL_LOOKUP; @LambdaForm.Hidden static MethodHandle selectAlternative(boolean testResult, MethodHandle target, MethodHandle fallback) { - return testResult ? target : fallback; + if (testResult) { + return target; + } else { + return fallback; + } + } + + // Intrinsified by C2. Counters are used during parsing to calculate branch frequencies. + @LambdaForm.Hidden + static + boolean profileBoolean(boolean result, int[] counters) { + // Profile is int[2] where [0] and [1] correspond to false and true occurrences respectively. + int idx = result ? 1 : 0; + try { + counters[idx] = Math.addExact(counters[idx], 1); + } catch (ArithmeticException e) { + // Avoid continuous overflow by halving the problematic count. + counters[idx] = counters[idx] / 2; + } + return result; } static @@ -708,13 +730,18 @@ import static java.lang.invoke.MethodHandles.Lookup.IMPL_LOOKUP; assert(test.type().equals(type.changeReturnType(boolean.class)) && fallback.type().equals(type)); MethodType basicType = type.basicType(); LambdaForm form = makeGuardWithTestForm(basicType); - BoundMethodHandle.SpeciesData data = BoundMethodHandle.speciesData_LLL(); BoundMethodHandle mh; - try { - mh = (BoundMethodHandle) - data.constructor().invokeBasic(type, form, - (Object) test, (Object) profile(target), (Object) profile(fallback)); + if (PROFILE_GWT) { + int[] counts = new int[2]; + mh = (BoundMethodHandle) + BoundMethodHandle.speciesData_LLLL().constructor().invokeBasic(type, form, + (Object) test, (Object) profile(target), (Object) profile(fallback), counts); + } else { + mh = (BoundMethodHandle) + BoundMethodHandle.speciesData_LLL().constructor().invokeBasic(type, form, + (Object) test, (Object) profile(target), (Object) profile(fallback)); + } } catch (Throwable ex) { throw uncaughtException(ex); } @@ -856,7 +883,10 @@ import static java.lang.invoke.MethodHandles.Lookup.IMPL_LOOKUP; final int GET_TEST = nameCursor++; final int GET_TARGET = nameCursor++; final int GET_FALLBACK = nameCursor++; + final int GET_COUNTERS = PROFILE_GWT ? nameCursor++ : -1; final int CALL_TEST = nameCursor++; + final int PROFILE = (GET_COUNTERS != -1) ? nameCursor++ : -1; + final int TEST = nameCursor-1; // previous statement: either PROFILE or CALL_TEST final int SELECT_ALT = nameCursor++; final int CALL_TARGET = nameCursor++; assert(CALL_TARGET == SELECT_ALT+1); // must be true to trigger IBG.emitSelectAlternative @@ -864,12 +894,16 @@ import static java.lang.invoke.MethodHandles.Lookup.IMPL_LOOKUP; MethodType lambdaType = basicType.invokerType(); Name[] names = arguments(nameCursor - ARG_LIMIT, lambdaType); - BoundMethodHandle.SpeciesData data = BoundMethodHandle.speciesData_LLL(); + BoundMethodHandle.SpeciesData data = + (GET_COUNTERS != -1) ? BoundMethodHandle.speciesData_LLLL() + : BoundMethodHandle.speciesData_LLL(); names[THIS_MH] = names[THIS_MH].withConstraint(data); names[GET_TEST] = new Name(data.getterFunction(0), names[THIS_MH]); names[GET_TARGET] = new Name(data.getterFunction(1), names[THIS_MH]); names[GET_FALLBACK] = new Name(data.getterFunction(2), names[THIS_MH]); - + if (GET_COUNTERS != -1) { + names[GET_COUNTERS] = new Name(data.getterFunction(3), names[THIS_MH]); + } Object[] invokeArgs = Arrays.copyOfRange(names, 0, ARG_LIMIT, Object[].class); // call test @@ -877,15 +911,18 @@ import static java.lang.invoke.MethodHandles.Lookup.IMPL_LOOKUP; invokeArgs[0] = names[GET_TEST]; names[CALL_TEST] = new Name(testType, invokeArgs); + // profile branch + if (PROFILE != -1) { + names[PROFILE] = new Name(Lazy.NF_profileBoolean, names[CALL_TEST], names[GET_COUNTERS]); + } // call selectAlternative - names[SELECT_ALT] = new Name(Lazy.MH_selectAlternative, names[CALL_TEST], - names[GET_TARGET], names[GET_FALLBACK]); + names[SELECT_ALT] = new Name(Lazy.MH_selectAlternative, names[TEST], names[GET_TARGET], names[GET_FALLBACK]); // call target or fallback invokeArgs[0] = names[SELECT_ALT]; names[CALL_TARGET] = new Name(basicType, invokeArgs); - lform = new LambdaForm("guard", lambdaType.parameterCount(), names); + lform = new LambdaForm("guard", lambdaType.parameterCount(), names, /*forceInline=*/true); return basicType.form().setCachedLambdaForm(MethodTypeForm.LF_GWT, lform); } diff --git a/jdk/src/java.base/share/classes/java/lang/invoke/MethodHandleStatics.java b/jdk/src/java.base/share/classes/java/lang/invoke/MethodHandleStatics.java index 335a32289a7..40b4397c178 100644 --- a/jdk/src/java.base/share/classes/java/lang/invoke/MethodHandleStatics.java +++ b/jdk/src/java.base/share/classes/java/lang/invoke/MethodHandleStatics.java @@ -48,9 +48,10 @@ import sun.misc.Unsafe; static final int COMPILE_THRESHOLD; static final int DONT_INLINE_THRESHOLD; static final int PROFILE_LEVEL; + static final boolean PROFILE_GWT; static { - final Object[] values = new Object[7]; + final Object[] values = new Object[8]; AccessController.doPrivileged(new PrivilegedAction() { public Void run() { values[0] = Boolean.getBoolean("java.lang.invoke.MethodHandle.DEBUG_NAMES"); @@ -60,6 +61,7 @@ import sun.misc.Unsafe; values[4] = Integer.getInteger("java.lang.invoke.MethodHandle.COMPILE_THRESHOLD", 0); values[5] = Integer.getInteger("java.lang.invoke.MethodHandle.DONT_INLINE_THRESHOLD", 30); values[6] = Integer.getInteger("java.lang.invoke.MethodHandle.PROFILE_LEVEL", 0); + values[7] = Boolean.parseBoolean(System.getProperty("java.lang.invoke.MethodHandle.PROFILE_GWT", "true")); return null; } }); @@ -70,6 +72,7 @@ import sun.misc.Unsafe; COMPILE_THRESHOLD = (Integer) values[4]; DONT_INLINE_THRESHOLD = (Integer) values[5]; PROFILE_LEVEL = (Integer) values[6]; + PROFILE_GWT = (Boolean) values[7]; } /** Tell if any of the debugging switches are turned on. From bfc5193fe73ebe691941e9ce56218e28d41ef35b Mon Sep 17 00:00:00 2001 From: Vladimir Ivanov Date: Thu, 29 Jan 2015 10:27:30 -0800 Subject: [PATCH 048/116] 8069591: Customize LambdaForms which are invoked using MH.invoke/invokeExact Reviewed-by: jrose, plevart, forax --- .../java/lang/invoke/DirectMethodHandle.java | 7 ++- .../lang/invoke/InvokerBytecodeGenerator.java | 22 +++++++++ .../classes/java/lang/invoke/Invokers.java | 31 ++++++++++++- .../classes/java/lang/invoke/LambdaForm.java | 45 +++++++++++++++---- .../java/lang/invoke/LambdaFormEditor.java | 5 ++- .../java/lang/invoke/MethodHandle.java | 18 +++++++- .../java/lang/invoke/MethodHandleImpl.java | 9 ++++ .../java/lang/invoke/MethodHandleStatics.java | 9 +++- 8 files changed, 131 insertions(+), 15 deletions(-) diff --git a/jdk/src/java.base/share/classes/java/lang/invoke/DirectMethodHandle.java b/jdk/src/java.base/share/classes/java/lang/invoke/DirectMethodHandle.java index e9d2526cd8d..fe54fd21492 100644 --- a/jdk/src/java.base/share/classes/java/lang/invoke/DirectMethodHandle.java +++ b/jdk/src/java.base/share/classes/java/lang/invoke/DirectMethodHandle.java @@ -31,7 +31,6 @@ import java.util.Arrays; import sun.invoke.util.VerifyAccess; import static java.lang.invoke.MethodHandleNatives.Constants.*; import static java.lang.invoke.LambdaForm.*; -import static java.lang.invoke.LambdaForm.BasicType.*; import static java.lang.invoke.MethodTypeForm.*; import static java.lang.invoke.MethodHandleStatics.*; import java.lang.ref.WeakReference; @@ -693,4 +692,10 @@ class DirectMethodHandle extends MethodHandle { } } } + + @Override + void customize() { + assert(form.customized == null); + // No need to customize DMHs. + } } diff --git a/jdk/src/java.base/share/classes/java/lang/invoke/InvokerBytecodeGenerator.java b/jdk/src/java.base/share/classes/java/lang/invoke/InvokerBytecodeGenerator.java index 6a4b2995058..a29eed9417a 100644 --- a/jdk/src/java.base/share/classes/java/lang/invoke/InvokerBytecodeGenerator.java +++ b/jdk/src/java.base/share/classes/java/lang/invoke/InvokerBytecodeGenerator.java @@ -56,9 +56,11 @@ class InvokerBytecodeGenerator { private static final String OBJ = "java/lang/Object"; private static final String OBJARY = "[Ljava/lang/Object;"; + private static final String MH_SIG = "L" + MH + ";"; private static final String LF_SIG = "L" + LF + ";"; private static final String LFN_SIG = "L" + LFN + ";"; private static final String LL_SIG = "(L" + OBJ + ";)L" + OBJ + ";"; + private static final String LLV_SIG = "(L" + OBJ + ";L" + OBJ + ";)V"; private static final String CLL_SIG = "(L" + CLS + ";L" + OBJ + ";)L" + OBJ + ";"; /** Name of its super class*/ @@ -616,6 +618,15 @@ class InvokerBytecodeGenerator { return g.loadMethod(g.generateCustomizedCodeBytes()); } + /** Generates code to check that actual receiver and LambdaForm matches */ + private boolean checkActualReceiver() { + // Expects MethodHandle on the stack and actual receiver MethodHandle in slot #0 + mv.visitInsn(Opcodes.DUP); + mv.visitVarInsn(Opcodes.ALOAD, localsMap[0]); + mv.visitMethodInsn(Opcodes.INVOKESTATIC, MHI, "assertSame", LLV_SIG, false); + return true; + } + /** * Generate an invoker method for the passed {@link LambdaForm}. */ @@ -635,6 +646,17 @@ class InvokerBytecodeGenerator { mv.visitAnnotation("Ljava/lang/invoke/DontInline;", true); } + if (lambdaForm.customized != null) { + // Since LambdaForm is customized for a particular MethodHandle, it's safe to substitute + // receiver MethodHandle (at slot #0) with an embedded constant and use it instead. + // It enables more efficient code generation in some situations, since embedded constants + // are compile-time constants for JIT compiler. + mv.visitLdcInsn(constantPlaceholder(lambdaForm.customized)); + mv.visitTypeInsn(Opcodes.CHECKCAST, MH); + assert(checkActualReceiver()); // expects MethodHandle on top of the stack + mv.visitVarInsn(Opcodes.ASTORE, localsMap[0]); + } + // iterate over the form's names, generating bytecode instructions for each // start iterating at the first name following the arguments Name onStack = null; diff --git a/jdk/src/java.base/share/classes/java/lang/invoke/Invokers.java b/jdk/src/java.base/share/classes/java/lang/invoke/Invokers.java index 12a118a7576..43cf38f12bd 100644 --- a/jdk/src/java.base/share/classes/java/lang/invoke/Invokers.java +++ b/jdk/src/java.base/share/classes/java/lang/invoke/Invokers.java @@ -247,6 +247,7 @@ class Invokers { int nameCursor = OUTARG_LIMIT; final int MTYPE_ARG = customized ? -1 : nameCursor++; // might be last in-argument final int CHECK_TYPE = nameCursor++; + final int CHECK_CUSTOM = (CUSTOMIZE_THRESHOLD >= 0) ? nameCursor++ : -1; final int LINKER_CALL = nameCursor++; MethodType invokerFormType = mtype.invokerType(); if (isLinker) { @@ -279,6 +280,9 @@ class Invokers { // mh.invokeGeneric(a*):R => checkGenericType(mh, TYPEOF(a*:R)).invokeBasic(a*) outArgs[0] = names[CHECK_TYPE]; } + if (CHECK_CUSTOM != -1) { + names[CHECK_CUSTOM] = new Name(NF_checkCustomized, names[CALL_MH]); + } names[LINKER_CALL] = new Name(outCallType, outArgs); lform = new LambdaForm(debugName, INARG_LIMIT, names); if (isLinker) @@ -386,11 +390,32 @@ class Invokers { return ((CallSite)site).getTarget(); } + /*non-public*/ static + @ForceInline + void checkCustomized(Object o) { + MethodHandle mh = (MethodHandle)o; + if (mh.form.customized == null) { + maybeCustomize(mh); + } + } + + /*non-public*/ static + @DontInline + void maybeCustomize(MethodHandle mh) { + byte count = mh.customizationCount; + if (count >= CUSTOMIZE_THRESHOLD) { + mh.customize(); + } else { + mh.customizationCount = (byte)(count+1); + } + } + // Local constant functions: private static final NamedFunction NF_checkExactType, NF_checkGenericType, - NF_getCallSiteTarget; + NF_getCallSiteTarget, + NF_checkCustomized; static { try { NamedFunction nfs[] = { @@ -399,7 +424,9 @@ class Invokers { NF_checkGenericType = new NamedFunction(Invokers.class .getDeclaredMethod("checkGenericType", Object.class, Object.class)), NF_getCallSiteTarget = new NamedFunction(Invokers.class - .getDeclaredMethod("getCallSiteTarget", Object.class)) + .getDeclaredMethod("getCallSiteTarget", Object.class)), + NF_checkCustomized = new NamedFunction(Invokers.class + .getDeclaredMethod("checkCustomized", Object.class)) }; for (NamedFunction nf : nfs) { // Each nf must be statically invocable or we get tied up in our bootstraps. diff --git a/jdk/src/java.base/share/classes/java/lang/invoke/LambdaForm.java b/jdk/src/java.base/share/classes/java/lang/invoke/LambdaForm.java index 7533d83bb25..5c441071b92 100644 --- a/jdk/src/java.base/share/classes/java/lang/invoke/LambdaForm.java +++ b/jdk/src/java.base/share/classes/java/lang/invoke/LambdaForm.java @@ -120,12 +120,14 @@ class LambdaForm { final int arity; final int result; final boolean forceInline; + final MethodHandle customized; @Stable final Name[] names; final String debugName; MemberName vmentry; // low-level behavior, or null if not yet prepared private boolean isCompiled; - volatile Object transformCache; // managed by LambdaFormEditor + // Either a LambdaForm cache (managed by LambdaFormEditor) or a link to uncustomized version (for customized LF) + volatile Object transformCache; public static final int VOID_RESULT = -1, LAST_RESULT = -2; @@ -244,16 +246,17 @@ class LambdaForm { LambdaForm(String debugName, int arity, Name[] names, int result) { - this(debugName, arity, names, result, /*forceInline=*/true); + this(debugName, arity, names, result, /*forceInline=*/true, /*customized=*/null); } LambdaForm(String debugName, - int arity, Name[] names, int result, boolean forceInline) { + int arity, Name[] names, int result, boolean forceInline, MethodHandle customized) { assert(namesOK(arity, names)); this.arity = arity; this.result = fixResult(result, names); this.names = names.clone(); this.debugName = fixDebugName(debugName); this.forceInline = forceInline; + this.customized = customized; int maxOutArity = normalize(); if (maxOutArity > MethodType.MAX_MH_INVOKER_ARITY) { // Cannot use LF interpreter on very high arity expressions. @@ -263,21 +266,21 @@ class LambdaForm { } LambdaForm(String debugName, int arity, Name[] names) { - this(debugName, arity, names, LAST_RESULT, /*forceInline=*/true); + this(debugName, arity, names, LAST_RESULT, /*forceInline=*/true, /*customized=*/null); } LambdaForm(String debugName, int arity, Name[] names, boolean forceInline) { - this(debugName, arity, names, LAST_RESULT, forceInline); + this(debugName, arity, names, LAST_RESULT, forceInline, /*customized=*/null); } LambdaForm(String debugName, Name[] formals, Name[] temps, Name result) { this(debugName, - formals.length, buildNames(formals, temps, result), LAST_RESULT, /*forceInline=*/true); + formals.length, buildNames(formals, temps, result), LAST_RESULT, /*forceInline=*/true, /*customized=*/null); } LambdaForm(String debugName, Name[] formals, Name[] temps, Name result, boolean forceInline) { this(debugName, - formals.length, buildNames(formals, temps, result), LAST_RESULT, forceInline); + formals.length, buildNames(formals, temps, result), LAST_RESULT, forceInline, /*customized=*/null); } private static Name[] buildNames(Name[] formals, Name[] temps, Name result) { @@ -300,6 +303,7 @@ class LambdaForm { this.names = buildEmptyNames(arity, sig); this.debugName = "LF.zero"; this.forceInline = true; + this.customized = null; assert(nameRefsAreLegal()); assert(isEmpty()); assert(sig.equals(basicTypeSignature())) : sig + " != " + basicTypeSignature(); @@ -371,6 +375,31 @@ class LambdaForm { return true; } + /** Customize LambdaForm for a particular MethodHandle */ + LambdaForm customize(MethodHandle mh) { + LambdaForm customForm = new LambdaForm(debugName, arity, names, result, forceInline, mh); + if (COMPILE_THRESHOLD > 0 && isCompiled) { + // If shared LambdaForm has been compiled, compile customized version as well. + customForm.compileToBytecode(); + } + customForm.transformCache = this; // LambdaFormEditor should always use uncustomized form. + return customForm; + } + + /** Get uncustomized flavor of the LambdaForm */ + LambdaForm uncustomize() { + if (customized == null) { + return this; + } + assert(transformCache != null); // Customized LambdaForm should always has a link to uncustomized version. + LambdaForm uncustomizedForm = (LambdaForm)transformCache; + if (COMPILE_THRESHOLD > 0 && isCompiled) { + // If customized LambdaForm has been compiled, compile uncustomized version as well. + uncustomizedForm.compileToBytecode(); + } + return uncustomizedForm; + } + /** Renumber and/or replace params so that they are interned and canonically numbered. * @return maximum argument list length among the names (since we have to pass over them anyway) */ @@ -413,8 +442,8 @@ class LambdaForm { for (int i = arity; i < names.length; i++) { names[i].internArguments(); } - assert(nameRefsAreLegal()); } + assert(nameRefsAreLegal()); return maxOutArity; } diff --git a/jdk/src/java.base/share/classes/java/lang/invoke/LambdaFormEditor.java b/jdk/src/java.base/share/classes/java/lang/invoke/LambdaFormEditor.java index 1c23e94995a..7bc2dfbebad 100644 --- a/jdk/src/java.base/share/classes/java/lang/invoke/LambdaFormEditor.java +++ b/jdk/src/java.base/share/classes/java/lang/invoke/LambdaFormEditor.java @@ -51,7 +51,10 @@ class LambdaFormEditor { static LambdaFormEditor lambdaFormEditor(LambdaForm lambdaForm) { // TO DO: Consider placing intern logic here, to cut down on duplication. // lambdaForm = findPreexistingEquivalent(lambdaForm) - return new LambdaFormEditor(lambdaForm); + + // Always use uncustomized version for editing. + // It helps caching and customized LambdaForms reuse transformCache field to keep a link to uncustomized version. + return new LambdaFormEditor(lambdaForm.uncustomize()); } /** A description of a cached transform, possibly associated with the result of the transform. diff --git a/jdk/src/java.base/share/classes/java/lang/invoke/MethodHandle.java b/jdk/src/java.base/share/classes/java/lang/invoke/MethodHandle.java index 0a45d2707e9..61c114e54b1 100644 --- a/jdk/src/java.base/share/classes/java/lang/invoke/MethodHandle.java +++ b/jdk/src/java.base/share/classes/java/lang/invoke/MethodHandle.java @@ -434,6 +434,8 @@ public abstract class MethodHandle { // form is not private so that invokers can easily fetch it /*private*/ MethodHandle asTypeCache; // asTypeCache is not private so that invokers can easily fetch it + /*non-public*/ byte customizationCount; + // customizationCount should be accessible from invokers /** * Reports the type of this method handle. @@ -454,9 +456,9 @@ public abstract class MethodHandle { type.getClass(); // explicit NPE form.getClass(); // explicit NPE this.type = type; - this.form = form; + this.form = form.uncustomize(); - form.prepare(); // TO DO: Try to delay this step until just before invocation. + this.form.prepare(); // TO DO: Try to delay this step until just before invocation. } /** @@ -1425,12 +1427,24 @@ assertEquals("[three, thee, tee]", asListFix.invoke((Object)argv).toString()); */ /*non-public*/ void updateForm(LambdaForm newForm) { + assert(newForm.customized == null || newForm.customized == this); if (form == newForm) return; newForm.prepare(); // as in MethodHandle. UNSAFE.putObject(this, FORM_OFFSET, newForm); UNSAFE.fullFence(); } + /** Craft a LambdaForm customized for this particular MethodHandle */ + /*non-public*/ + void customize() { + if (form.customized == null) { + LambdaForm newForm = form.customize(this); + updateForm(newForm); + } else { + assert(form.customized == this); + } + } + private static final long FORM_OFFSET; static { try { diff --git a/jdk/src/java.base/share/classes/java/lang/invoke/MethodHandleImpl.java b/jdk/src/java.base/share/classes/java/lang/invoke/MethodHandleImpl.java index 1a78502ebe5..e1cfb7303e6 100644 --- a/jdk/src/java.base/share/classes/java/lang/invoke/MethodHandleImpl.java +++ b/jdk/src/java.base/share/classes/java/lang/invoke/MethodHandleImpl.java @@ -1666,4 +1666,13 @@ import static java.lang.invoke.MethodHandles.Lookup.IMPL_LOOKUP; assert(elemType.isPrimitive()); return Lazy.MH_copyAsPrimitiveArray.bindTo(Wrapper.forPrimitiveType(elemType)); } + + /*non-public*/ static void assertSame(Object mh1, Object mh2) { + if (mh1 != mh2) { + String msg = String.format("mh1 != mh2: mh1 = %s (form: %s); mh2 = %s (form: %s)", + mh1, ((MethodHandle)mh1).form, + mh2, ((MethodHandle)mh2).form); + throw newInternalError(msg); + } + } } diff --git a/jdk/src/java.base/share/classes/java/lang/invoke/MethodHandleStatics.java b/jdk/src/java.base/share/classes/java/lang/invoke/MethodHandleStatics.java index 40b4397c178..144de11094f 100644 --- a/jdk/src/java.base/share/classes/java/lang/invoke/MethodHandleStatics.java +++ b/jdk/src/java.base/share/classes/java/lang/invoke/MethodHandleStatics.java @@ -49,9 +49,10 @@ import sun.misc.Unsafe; static final int DONT_INLINE_THRESHOLD; static final int PROFILE_LEVEL; static final boolean PROFILE_GWT; + static final int CUSTOMIZE_THRESHOLD; static { - final Object[] values = new Object[8]; + final Object[] values = new Object[9]; AccessController.doPrivileged(new PrivilegedAction() { public Void run() { values[0] = Boolean.getBoolean("java.lang.invoke.MethodHandle.DEBUG_NAMES"); @@ -62,6 +63,7 @@ import sun.misc.Unsafe; values[5] = Integer.getInteger("java.lang.invoke.MethodHandle.DONT_INLINE_THRESHOLD", 30); values[6] = Integer.getInteger("java.lang.invoke.MethodHandle.PROFILE_LEVEL", 0); values[7] = Boolean.parseBoolean(System.getProperty("java.lang.invoke.MethodHandle.PROFILE_GWT", "true")); + values[8] = Integer.getInteger("java.lang.invoke.MethodHandle.CUSTOMIZE_THRESHOLD", 127); return null; } }); @@ -73,6 +75,11 @@ import sun.misc.Unsafe; DONT_INLINE_THRESHOLD = (Integer) values[5]; PROFILE_LEVEL = (Integer) values[6]; PROFILE_GWT = (Boolean) values[7]; + CUSTOMIZE_THRESHOLD = (Integer) values[8]; + + if (CUSTOMIZE_THRESHOLD < -1 || CUSTOMIZE_THRESHOLD > 127) { + throw newInternalError("CUSTOMIZE_THRESHOLD should be in [-1...127] range"); + } } /** Tell if any of the debugging switches are turned on. From 676ea8324097b693fef3969f8b26c8be74170194 Mon Sep 17 00:00:00 2001 From: Vladimir Ivanov Date: Thu, 29 Jan 2015 10:29:43 -0800 Subject: [PATCH 049/116] 8071787: Don't block inlining when DONT_INLINE_THRESHOLD=0 Reviewed-by: jrose --- .../java/lang/invoke/MethodHandleImpl.java | 16 +++++++++++----- 1 file changed, 11 insertions(+), 5 deletions(-) diff --git a/jdk/src/java.base/share/classes/java/lang/invoke/MethodHandleImpl.java b/jdk/src/java.base/share/classes/java/lang/invoke/MethodHandleImpl.java index e1cfb7303e6..6f13ce30766 100644 --- a/jdk/src/java.base/share/classes/java/lang/invoke/MethodHandleImpl.java +++ b/jdk/src/java.base/share/classes/java/lang/invoke/MethodHandleImpl.java @@ -753,7 +753,7 @@ import static java.lang.invoke.MethodHandles.Lookup.IMPL_LOOKUP; static MethodHandle profile(MethodHandle target) { if (DONT_INLINE_THRESHOLD >= 0) { - return makeBlockInlningWrapper(target); + return makeBlockInliningWrapper(target); } else { return target; } @@ -764,8 +764,13 @@ import static java.lang.invoke.MethodHandles.Lookup.IMPL_LOOKUP; * Corresponding LambdaForm has @DontInline when compiled into bytecode. */ static - MethodHandle makeBlockInlningWrapper(MethodHandle target) { - LambdaForm lform = PRODUCE_BLOCK_INLINING_FORM.apply(target); + MethodHandle makeBlockInliningWrapper(MethodHandle target) { + LambdaForm lform; + if (DONT_INLINE_THRESHOLD > 0) { + lform = PRODUCE_BLOCK_INLINING_FORM.apply(target); + } else { + lform = PRODUCE_REINVOKER_FORM.apply(target); + } return new CountingWrapper(target, lform, PRODUCE_BLOCK_INLINING_FORM, PRODUCE_REINVOKER_FORM, DONT_INLINE_THRESHOLD); @@ -836,7 +841,8 @@ import static java.lang.invoke.MethodHandles.Lookup.IMPL_LOOKUP; } boolean countDown() { - if (count <= 0) { + int c = count; + if (c <= 1) { // Try to limit number of updates. MethodHandle.updateForm() doesn't guarantee LF update visibility. if (isCounting) { isCounting = false; @@ -845,7 +851,7 @@ import static java.lang.invoke.MethodHandles.Lookup.IMPL_LOOKUP; return false; } } else { - --count; + count = c - 1; return false; } } From 55d14bca62ed5bc05f0420a4611a9faca8bebd19 Mon Sep 17 00:00:00 2001 From: Vladimir Ivanov Date: Thu, 29 Jan 2015 10:29:49 -0800 Subject: [PATCH 050/116] 8071788: BlockInliningWrapper.asType() is broken Reviewed-by: jrose --- .../share/classes/java/lang/invoke/MethodHandleImpl.java | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/jdk/src/java.base/share/classes/java/lang/invoke/MethodHandleImpl.java b/jdk/src/java.base/share/classes/java/lang/invoke/MethodHandleImpl.java index 6f13ce30766..57568ece696 100644 --- a/jdk/src/java.base/share/classes/java/lang/invoke/MethodHandleImpl.java +++ b/jdk/src/java.base/share/classes/java/lang/invoke/MethodHandleImpl.java @@ -832,7 +832,7 @@ import static java.lang.invoke.MethodHandles.Lookup.IMPL_LOOKUP; MethodHandle wrapper; if (isCounting) { LambdaForm lform; - lform = countingFormProducer.apply(target); + lform = countingFormProducer.apply(newTarget); wrapper = new CountingWrapper(newTarget, lform, countingFormProducer, nonCountingFormProducer, DONT_INLINE_THRESHOLD); } else { wrapper = newTarget; // no need for a counting wrapper anymore From 883d349e17554bd0576eb2c6cbe58b9f27831bf0 Mon Sep 17 00:00:00 2001 From: Zoltan Majo Date: Fri, 30 Jan 2015 10:40:08 +0100 Subject: [PATCH 051/116] 8071818: Incorrect addressing mode used for ldf in SPARC assembler Update MacroAssembler::ldf to select addressing mode depending on Address parameter. Reviewed-by: kvn, dlong --- hotspot/src/cpu/sparc/vm/macroAssembler_sparc.inline.hpp | 7 ++++++- 1 file changed, 6 insertions(+), 1 deletion(-) diff --git a/hotspot/src/cpu/sparc/vm/macroAssembler_sparc.inline.hpp b/hotspot/src/cpu/sparc/vm/macroAssembler_sparc.inline.hpp index 7e3804fd379..3518d0b6336 100644 --- a/hotspot/src/cpu/sparc/vm/macroAssembler_sparc.inline.hpp +++ b/hotspot/src/cpu/sparc/vm/macroAssembler_sparc.inline.hpp @@ -630,7 +630,12 @@ inline void MacroAssembler::ldf(FloatRegisterImpl::Width w, Register s1, Registe inline void MacroAssembler::ldf(FloatRegisterImpl::Width w, const Address& a, FloatRegister d, int offset) { relocate(a.rspec(offset)); - ldf(w, a.base(), a.disp() + offset, d); + if (a.has_index()) { + assert(offset == 0, ""); + ldf(w, a.base(), a.index(), d); + } else { + ldf(w, a.base(), a.disp() + offset, d); + } } // returns if membar generates anything, obviously this code should mirror From 7c658a76106f0ff5ca203128236e134a473fd23b Mon Sep 17 00:00:00 2001 From: Shobhit Gupta Date: Fri, 30 Jan 2015 13:27:33 +0300 Subject: [PATCH 052/116] 8068301: [TEST_BUG] Test javax/swing/JColorChooser/Test4177735.java fails with ArrayIndexOutOfBoundsException with GTKL&F Reviewed-by: alexsch, azvegint --- jdk/test/javax/swing/JColorChooser/Test4177735.java | 13 ++++++++++++- 1 file changed, 12 insertions(+), 1 deletion(-) diff --git a/jdk/test/javax/swing/JColorChooser/Test4177735.java b/jdk/test/javax/swing/JColorChooser/Test4177735.java index 84e77300571..338bf99bf25 100644 --- a/jdk/test/javax/swing/JColorChooser/Test4177735.java +++ b/jdk/test/javax/swing/JColorChooser/Test4177735.java @@ -38,9 +38,20 @@ public class Test4177735 implements Runnable { private static final long DELAY = 1000L; public static void main(String[] args) throws Exception { + int hsvIndex = 0; + int panelsLength; + int finalIndex; JColorChooser chooser = new JColorChooser(); AbstractColorChooserPanel[] panels = chooser.getChooserPanels(); - chooser.setChooserPanels(new AbstractColorChooserPanel[] { panels[1] }); + panelsLength = panels.length; + + for(int i = 0; i < panelsLength; i++) { + if(panels[i].getDisplayName().equals("HSV")) { + hsvIndex = i; + } + } + finalIndex = Math.min(hsvIndex, panelsLength - 1); + chooser.setChooserPanels(new AbstractColorChooserPanel[] { panels[finalIndex] }); JDialog dialog = show(chooser); pause(DELAY); From a32f9adb0fc785781c6b4c1f439b9ea59b193810 Mon Sep 17 00:00:00 2001 From: Albert Noll Date: Fri, 30 Jan 2015 15:20:45 +0100 Subject: [PATCH 053/116] 8071906: Quarantine OverloadCompileQueueTest until the reason for timeout is known Quarantine OverloadCompileQueueTest until the reason for timeout is known Reviewed-by: kvn --- .../test/compiler/codecache/stress/OverloadCompileQueueTest.java | 1 + 1 file changed, 1 insertion(+) diff --git a/hotspot/test/compiler/codecache/stress/OverloadCompileQueueTest.java b/hotspot/test/compiler/codecache/stress/OverloadCompileQueueTest.java index e759d499468..ec29cf5d729 100644 --- a/hotspot/test/compiler/codecache/stress/OverloadCompileQueueTest.java +++ b/hotspot/test/compiler/codecache/stress/OverloadCompileQueueTest.java @@ -30,6 +30,7 @@ import com.oracle.java.testlibrary.Platform; /* * @test OverloadCompileQueueTest * @library /testlibrary /../../test/lib + * @ignore 8071905 * @build OverloadCompileQueueTest * @run main ClassFileInstaller sun.hotspot.WhiteBox * sun.hotspot.WhiteBox$WhiteBoxPermission From 1e85e321f986cc6533e65920d2bdc0be8c98859e Mon Sep 17 00:00:00 2001 From: Vladimir Kozlov Date: Fri, 30 Jan 2015 10:27:50 -0800 Subject: [PATCH 054/116] 8071534: assert(!failing()) failed: Must not have pending failure. Reason is: out of memory Add missing C->failing() check after Connection graph construction. Reviewed-by: iveresov --- hotspot/src/share/vm/opto/escape.cpp | 5 +++++ 1 file changed, 5 insertions(+) diff --git a/hotspot/src/share/vm/opto/escape.cpp b/hotspot/src/share/vm/opto/escape.cpp index 42ba1262000..efc795b03f0 100644 --- a/hotspot/src/share/vm/opto/escape.cpp +++ b/hotspot/src/share/vm/opto/escape.cpp @@ -206,6 +206,11 @@ bool ConnectionGraph::compute_escape() { _verify = false; } #endif + // Bytecode analyzer BCEscapeAnalyzer, used for Call nodes + // processing, calls to CI to resolve symbols (types, fields, methods) + // referenced in bytecode. During symbol resolution VM may throw + // an exception which CI cleans and converts to compilation failure. + if (C->failing()) return false; // 2. Finish Graph construction by propagating references to all // java objects through graph. From 87ac24f1e229b33585c56ba55a4766b16bb6a998 Mon Sep 17 00:00:00 2001 From: Tobias Hartmann Date: Mon, 2 Feb 2015 15:19:24 +0100 Subject: [PATCH 055/116] 8071995: compiler/codecache/jmx/InitialAndMaxUsageTest.java fails with large pages Disable large page usage for test. Reviewed-by: kvn --- hotspot/test/compiler/codecache/jmx/InitialAndMaxUsageTest.java | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/hotspot/test/compiler/codecache/jmx/InitialAndMaxUsageTest.java b/hotspot/test/compiler/codecache/jmx/InitialAndMaxUsageTest.java index e18be5cab98..eaf137b9e4c 100644 --- a/hotspot/test/compiler/codecache/jmx/InitialAndMaxUsageTest.java +++ b/hotspot/test/compiler/codecache/jmx/InitialAndMaxUsageTest.java @@ -36,7 +36,7 @@ import sun.hotspot.code.BlobType; * @run main/othervm -Xbootclasspath/a:. -XX:-UseCodeCacheFlushing * -XX:-MethodFlushing -XX:+UnlockDiagnosticVMOptions -XX:+WhiteBoxAPI * -XX:+SegmentedCodeCache -XX:CompileCommand=compileonly,null::* - * InitialAndMaxUsageTest + * -XX:-UseLargePages InitialAndMaxUsageTest * @summary testing of initial and max usage */ public class InitialAndMaxUsageTest { From 0682d29b8f5ab5c9befdac2ed93d77f8d618723f Mon Sep 17 00:00:00 2001 From: Dean Long Date: Mon, 2 Feb 2015 23:26:33 -0500 Subject: [PATCH 056/116] 8069030: support new PTRACE_GETREGSET Use PTRACE_GETREGSET if other options are not available Reviewed-by: sla, dholmes --- hotspot/agent/src/os/linux/ps_proc.c | 11 +++++++++++ 1 file changed, 11 insertions(+) diff --git a/hotspot/agent/src/os/linux/ps_proc.c b/hotspot/agent/src/os/linux/ps_proc.c index a3c18c9e0de..7d9d2611c3b 100644 --- a/hotspot/agent/src/os/linux/ps_proc.c +++ b/hotspot/agent/src/os/linux/ps_proc.c @@ -27,9 +27,11 @@ #include #include #include +#include #include #include #include +#include #include "libproc_impl.h" #if defined(x86_64) && !defined(amd64) @@ -138,6 +140,15 @@ static bool process_get_lwp_regs(struct ps_prochandle* ph, pid_t pid, struct use return false; } return true; +#elif defined(PTRACE_GETREGSET) + struct iovec iov; + iov.iov_base = user; + iov.iov_len = sizeof(*user); + if (ptrace(PTRACE_GETREGSET, pid, NT_PRSTATUS, (void*) &iov) < 0) { + print_debug("ptrace(PTRACE_GETREGSET, ...) failed for lwp %d\n", pid); + return false; + } + return true; #else print_debug("ptrace(PTRACE_GETREGS, ...) not supported\n"); return false; From c5bb133c686252da194fa01514a3c6fcb8fdccab Mon Sep 17 00:00:00 2001 From: Albert Noll Date: Tue, 3 Feb 2015 10:30:16 +0100 Subject: [PATCH 057/116] 8068440: Test6857159.java times out Replace shell script with Java-only code Reviewed-by: kvn, iignatyev --- .../test/compiler/c2/6857159/Test6857159.java | 33 +++++++++++-------- 1 file changed, 19 insertions(+), 14 deletions(-) diff --git a/hotspot/test/compiler/c2/6857159/Test6857159.java b/hotspot/test/compiler/c2/6857159/Test6857159.java index 58efa373e68..c0a0349f952 100644 --- a/hotspot/test/compiler/c2/6857159/Test6857159.java +++ b/hotspot/test/compiler/c2/6857159/Test6857159.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2009, 2010, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2009, 2015, 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 @@ -26,15 +26,24 @@ * @test * @bug 6857159 * @summary local schedule failed with checkcast of Thread.currentThread() - * - * @run shell Test6857159.sh + * @library /testlibrary */ -public class Test6857159 extends Thread { - static class ct0 extends Test6857159 { - public void message() { - // System.out.println("message"); - } +import com.oracle.java.testlibrary.*; + +public class Test6857159 { + public static void main(String[] args) throws Exception { + ProcessBuilder pb = ProcessTools.createJavaProcessBuilder("-Xbatch", "-XX:+PrintCompilation", + "-XX:CompileOnly=Test$ct.run", "Test"); + OutputAnalyzer analyzer = new OutputAnalyzer(pb.start()); + analyzer.shouldNotContain("COMPILE SKIPPED"); + analyzer.shouldContain("Test$ct0::run (16 bytes)"); + } +} + +class Test extends Thread { + static class ct0 extends Test { + public void message() { } public void run() { message(); @@ -43,14 +52,10 @@ public class Test6857159 extends Thread { } } static class ct1 extends ct0 { - public void message() { - // System.out.println("message"); - } + public void message() { } } static class ct2 extends ct0 { - public void message() { - // System.out.println("message"); - } + public void message() { } } public static void main(String[] args) throws Exception { From d4d8ef4585c1c6192fe35524faa6c6961d1e7a64 Mon Sep 17 00:00:00 2001 From: Goetz Lindenmaier Date: Fri, 30 Jan 2015 12:53:56 +0100 Subject: [PATCH 058/116] 8071996: split_if accesses NULL region of ConstraintCast Reviewed-by: kvn --- hotspot/src/share/vm/opto/ifnode.cpp | 16 ++++++++++++---- 1 file changed, 12 insertions(+), 4 deletions(-) diff --git a/hotspot/src/share/vm/opto/ifnode.cpp b/hotspot/src/share/vm/opto/ifnode.cpp index 493d4a021b8..0b5b261e577 100644 --- a/hotspot/src/share/vm/opto/ifnode.cpp +++ b/hotspot/src/share/vm/opto/ifnode.cpp @@ -145,10 +145,18 @@ static Node* split_if(IfNode *iff, PhaseIterGVN *igvn) { Node* v = u->fast_out(k); // User of the phi // CNC - Allow only really simple patterns. // In particular I disallow AddP of the Phi, a fairly common pattern - if( v == cmp ) continue; // The compare is OK - if( (v->is_ConstraintCast()) && - v->in(0)->in(0) == iff ) - continue; // CastPP/II of the IfNode is OK + if (v == cmp) continue; // The compare is OK + if (v->is_ConstraintCast()) { + // If the cast is derived from data flow edges, it may not have a control edge. + // If so, it should be safe to split. But follow-up code can not deal with + // this (l. 359). So skip. + if (v->in(0) == NULL) { + return NULL; + } + if (v->in(0)->in(0) == iff) { + continue; // CastPP/II of the IfNode is OK + } + } // Disabled following code because I cannot tell if exactly one // path dominates without a real dominator check. CNC 9/9/1999 //uint vop = v->Opcode(); From a25fe37e171c1c1e66de9f3e1d5f95fcb504ce07 Mon Sep 17 00:00:00 2001 From: Zoltan Majo Date: Fri, 6 Feb 2015 18:16:55 +0100 Subject: [PATCH 059/116] 8072398: assert fails in L1RGenerator::increment_event_counter_impl Change scaling code to allow scaling with 0.0; change set_tiered_flags() to treat CompileThresholdScaling==0.0 in a special way. Reviewed-by: kvn, iveresov --- hotspot/src/share/vm/runtime/arguments.cpp | 33 +++++++++++-------- hotspot/src/share/vm/runtime/globals.hpp | 2 +- .../CheckCompileThresholdScaling.java | 2 +- 3 files changed, 22 insertions(+), 15 deletions(-) diff --git a/hotspot/src/share/vm/runtime/arguments.cpp b/hotspot/src/share/vm/runtime/arguments.cpp index 6096c98b29f..1fa921b896b 100644 --- a/hotspot/src/share/vm/runtime/arguments.cpp +++ b/hotspot/src/share/vm/runtime/arguments.cpp @@ -1126,34 +1126,39 @@ static void no_shared_spaces(const char* message) { } #endif +// Returns threshold scaled with the value of scale. +// If scale < 0.0, threshold is returned without scaling. intx Arguments::scaled_compile_threshold(intx threshold, double scale) { - if (scale == 1.0 || scale <= 0.0) { + if (scale == 1.0 || scale < 0.0) { return threshold; } else { return (intx)(threshold * scale); } } -// Returns freq_log scaled with CompileThresholdScaling +// Returns freq_log scaled with the value of scale. +// Returned values are in the range of [0, InvocationCounter::number_of_count_bits + 1]. +// If scale < 0.0, freq_log is returned without scaling. intx Arguments::scaled_freq_log(intx freq_log, double scale) { - // Check if scaling is necessary or negative value was specified. + // Check if scaling is necessary or if negative value was specified. if (scale == 1.0 || scale < 0.0) { return freq_log; } - - // Check value to avoid calculating log2 of 0. - if (scale == 0.0) { - return freq_log; + // Check values to avoid calculating log2 of 0. + if (scale == 0.0 || freq_log == 0) { + return 0; } - - intx scaled_freq = scaled_compile_threshold((intx)1 << freq_log, scale); // Determine the maximum notification frequency value currently supported. // The largest mask value that the interpreter/C1 can handle is // of length InvocationCounter::number_of_count_bits. Mask values are always // one bit shorter then the value of the notification frequency. Set // max_freq_bits accordingly. intx max_freq_bits = InvocationCounter::number_of_count_bits + 1; - if (scaled_freq > nth_bit(max_freq_bits)) { + intx scaled_freq = scaled_compile_threshold((intx)1 << freq_log, scale); + if (scaled_freq == 0) { + // Return 0 right away to avoid calculating log2 of 0. + return 0; + } else if (scaled_freq > nth_bit(max_freq_bits)) { return max_freq_bits; } else { return log2_intptr(scaled_freq); @@ -1204,8 +1209,9 @@ void Arguments::set_tiered_flags() { vm_exit_during_initialization("Negative value specified for CompileThresholdScaling", NULL); } - // Scale tiered compilation thresholds - if (!FLAG_IS_DEFAULT(CompileThresholdScaling)) { + // Scale tiered compilation thresholds. + // CompileThresholdScaling == 0.0 is equivalent to -Xint and leaves compilation thresholds unchanged. + if (!FLAG_IS_DEFAULT(CompileThresholdScaling) && CompileThresholdScaling > 0.0) { FLAG_SET_ERGO(intx, Tier0InvokeNotifyFreqLog, scaled_freq_log(Tier0InvokeNotifyFreqLog)); FLAG_SET_ERGO(intx, Tier0BackedgeNotifyFreqLog, scaled_freq_log(Tier0BackedgeNotifyFreqLog)); @@ -3921,7 +3927,8 @@ jint Arguments::apply_ergo() { "Incompatible compilation policy selected", NULL); } // Scale CompileThreshold - if (!FLAG_IS_DEFAULT(CompileThresholdScaling)) { + // CompileThresholdScaling == 0.0 is equivalent to -Xint and leaves CompileThreshold unchanged. + if (!FLAG_IS_DEFAULT(CompileThresholdScaling) && CompileThresholdScaling > 0.0) { FLAG_SET_ERGO(intx, CompileThreshold, scaled_compile_threshold(CompileThreshold)); } } diff --git a/hotspot/src/share/vm/runtime/globals.hpp b/hotspot/src/share/vm/runtime/globals.hpp index dd014368f69..189fbe1c4bc 100644 --- a/hotspot/src/share/vm/runtime/globals.hpp +++ b/hotspot/src/share/vm/runtime/globals.hpp @@ -3531,7 +3531,7 @@ class CommandLineFlags { "(both with and without tiered compilation): " \ "values greater than 1.0 delay counter overflow, " \ "values between 0 and 1.0 rush counter overflow, " \ - "value of 1.0 leave compilation thresholds unchanged " \ + "value of 1.0 leaves compilation thresholds unchanged " \ "value of 0.0 is equivalent to -Xint. " \ "" \ "Flag can be set as per-method option. " \ diff --git a/hotspot/test/compiler/arguments/CheckCompileThresholdScaling.java b/hotspot/test/compiler/arguments/CheckCompileThresholdScaling.java index 257e70a5bcc..9c9b94f8c24 100644 --- a/hotspot/test/compiler/arguments/CheckCompileThresholdScaling.java +++ b/hotspot/test/compiler/arguments/CheckCompileThresholdScaling.java @@ -26,7 +26,7 @@ import com.oracle.java.testlibrary.*; /* * @test CheckCompileThresholdScaling * @bug 8059604 - * @summary "Add CompileThresholdScalingPercentage flag to control when methods are first compiled (with +/-TieredCompilation)" + * @summary "Add CompileThresholdScaling flag to control when methods are first compiled (with +/-TieredCompilation)" * @library /testlibrary * @run main CheckCompileThresholdScaling */ From fb0bdf6a4b345d76f1e2ddc3517a2a847b474e79 Mon Sep 17 00:00:00 2001 From: Pavel Chistyakov Date: Fri, 30 Jan 2015 20:45:18 +0300 Subject: [PATCH 060/116] 8068003: compiler/whitebox/DeoptimizeFramesTest.java fails: compilation 48 can't be available Disabled DeoptimizeALot for test runs Reviewed-by: kvn --- hotspot/test/compiler/whitebox/DeoptimizeFramesTest.java | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/hotspot/test/compiler/whitebox/DeoptimizeFramesTest.java b/hotspot/test/compiler/whitebox/DeoptimizeFramesTest.java index 16a291562fc..d5268dfe5b6 100644 --- a/hotspot/test/compiler/whitebox/DeoptimizeFramesTest.java +++ b/hotspot/test/compiler/whitebox/DeoptimizeFramesTest.java @@ -31,11 +31,11 @@ * @run main/othervm -Xbootclasspath/a:. -XX:+UnlockDiagnosticVMOptions * -XX:+WhiteBoxAPI -Xmixed * -XX:CompileCommand=compileonly,DeoptimizeFramesTest$TestCaseImpl::method - * -XX:-DeoptimizeRandom DeoptimizeFramesTest true + * -XX:-DeoptimizeRandom -XX:-DeoptimizeALot DeoptimizeFramesTest true * @run main/othervm -Xbootclasspath/a:. -XX:+UnlockDiagnosticVMOptions * -XX:+WhiteBoxAPI -Xmixed * -XX:CompileCommand=compileonly,DeoptimizeFramesTest$TestCaseImpl::method - * -XX:-DeoptimizeRandom DeoptimizeFramesTest false + * -XX:-DeoptimizeRandom -XX:-DeoptimizeALot DeoptimizeFramesTest false * @summary testing of WB::deoptimizeFrames() */ import java.lang.reflect.Executable; From 43bcdf401719190da7613b8664cb7b51e85ae512 Mon Sep 17 00:00:00 2001 From: Roland Westrelin Date: Fri, 30 Jan 2015 15:23:41 +0100 Subject: [PATCH 061/116] 8071533: assert(n0->is_Call()) failed: expect a call here Remove_dead_region() call missing from ArrayCopyNode::Ideal() Reviewed-by: kvn, vlivanov --- hotspot/src/share/vm/opto/callnode.cpp | 1 + 1 file changed, 1 insertion(+) diff --git a/hotspot/src/share/vm/opto/callnode.cpp b/hotspot/src/share/vm/opto/callnode.cpp index f6a32496054..9749bd210ee 100644 --- a/hotspot/src/share/vm/opto/callnode.cpp +++ b/hotspot/src/share/vm/opto/callnode.cpp @@ -1982,6 +1982,7 @@ bool ArrayCopyNode::finish_transform(PhaseGVN *phase, bool can_reshape, Node *ArrayCopyNode::Ideal(PhaseGVN *phase, bool can_reshape) { + if (remove_dead_region(phase, can_reshape)) return this; if (StressArrayCopyMacroNode && !can_reshape) return NULL; From afa1e6d6706d74251ec0ad8ab35139fb57b0299b Mon Sep 17 00:00:00 2001 From: Sergey Bylokhov Date: Mon, 2 Feb 2015 18:21:24 +0300 Subject: [PATCH 062/116] 8015085: [macosx] Label shortening via " ... " broken when String contains combining diaeresis Reviewed-by: alexsch, azvegint --- .../classes/sun/swing/SwingUtilities2.java | 12 +-- .../TestBadBreak/TestBadBreak.java | 92 +++++++++++++++++++ 2 files changed, 98 insertions(+), 6 deletions(-) create mode 100644 jdk/test/javax/swing/SwingUtilities/TestBadBreak/TestBadBreak.java diff --git a/jdk/src/java.desktop/share/classes/sun/swing/SwingUtilities2.java b/jdk/src/java.desktop/share/classes/sun/swing/SwingUtilities2.java index 10e4e3bfa7f..3953297184c 100644 --- a/jdk/src/java.desktop/share/classes/sun/swing/SwingUtilities2.java +++ b/jdk/src/java.desktop/share/classes/sun/swing/SwingUtilities2.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2002, 2014, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2002, 2015, 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 @@ -31,6 +31,7 @@ import static java.awt.RenderingHints.*; import java.awt.event.*; import java.awt.font.*; import java.awt.print.PrinterGraphics; +import java.text.BreakIterator; import java.text.CharacterIterator; import java.text.AttributedCharacterIterator; import java.text.AttributedString; @@ -461,16 +462,15 @@ public class SwingUtilities2 { } } if (needsTextLayout) { - FontRenderContext frc = getFontRenderContext(c, fm); AttributedString aString = new AttributedString(string); if (c != null) { aString.addAttribute(TextAttribute.NUMERIC_SHAPING, c.getClientProperty(TextAttribute.NUMERIC_SHAPING)); } - LineBreakMeasurer measurer = - new LineBreakMeasurer(aString.getIterator(), frc); - int nChars = measurer.nextOffset(availTextWidth); - string = string.substring(0, nChars); + LineBreakMeasurer measurer = new LineBreakMeasurer( + aString.getIterator(), BreakIterator.getCharacterInstance(), + getFontRenderContext(c, fm)); + string = string.substring(0, measurer.nextOffset(availTextWidth)); } return string + clipString; diff --git a/jdk/test/javax/swing/SwingUtilities/TestBadBreak/TestBadBreak.java b/jdk/test/javax/swing/SwingUtilities/TestBadBreak/TestBadBreak.java new file mode 100644 index 00000000000..59806a33a0a --- /dev/null +++ b/jdk/test/javax/swing/SwingUtilities/TestBadBreak/TestBadBreak.java @@ -0,0 +1,92 @@ +/* + * Copyright (c) 2015, 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.awt.Graphics; +import java.awt.Graphics2D; +import java.awt.Robot; +import java.awt.image.BufferedImage; +import java.io.File; + +import javax.imageio.ImageIO; +import javax.swing.JFrame; +import javax.swing.JLabel; +import javax.swing.SwingUtilities; + +import static java.awt.image.BufferedImage.TYPE_INT_ARGB; + +/** + * @test + * @bug 8015085 + * @summary Shortening via " ... " is broken for Strings containing a combining + * diaeresis. + * @author Sergey Bylokhov + */ +public class TestBadBreak { + + static JFrame frame; + static Robot robot; + static final String withCombiningDiaeresis = "123p://.aaaaaaaaaaaaaaaaaaaaaa.123/a\u0308" ; + static final String withoutCombiningDiaeresis = "123p://.aaaaaaaaaaaaaaaaaaaaaa.123/\u00E4" ; + + public static void main(final String[] args) throws Exception { + robot = new Robot(); + final BufferedImage bi1 = new BufferedImage(200, 90, TYPE_INT_ARGB); + final BufferedImage bi2 = new BufferedImage(200, 90, TYPE_INT_ARGB); + test(withCombiningDiaeresis, bi1); + test(withoutCombiningDiaeresis, bi2); + for (int x = 0; x < bi1.getWidth(); ++x) { + for (int y = 0; y < bi1.getHeight(); ++y) { + if (bi1.getRGB(x, y) != bi2.getRGB(x, y)) { + ImageIO.write(bi1, "png", new File("image1.png")); + ImageIO.write(bi2, "png", new File("image2.png")); + throw new RuntimeException("Wrong color"); + } + } + } + } + + private static void test(final String text, final BufferedImage i1) + throws Exception { + SwingUtilities.invokeAndWait(new Runnable() { + @Override + public void run() { + frame = new JFrame(); + final JLabel label = new JLabel(text) { + @Override + protected void paintComponent(Graphics g) { + Graphics2D g2d = i1.createGraphics(); + super.paintComponent(g2d); + g2d.dispose(); + } + }; + frame.getContentPane().add(label); + frame.setBounds(200, 200, 200, 90); + } + }); + robot.waitForIdle(); + SwingUtilities.invokeAndWait(() -> frame.setVisible(true)); + robot.waitForIdle(); + SwingUtilities.invokeAndWait(frame::dispose); + robot.waitForIdle(); + } +} From 5a65a2cc13965dd52b1409936ed31a20fa0cc03f Mon Sep 17 00:00:00 2001 From: Dmitry Markov Date: Tue, 3 Feb 2015 11:51:30 +0400 Subject: [PATCH 063/116] 8064934: Incorrect Exception message from java.awt.Desktop.open() Reviewed-by: azvegint, serb --- .../native/libawt/windows/awt_Desktop.cpp | 3 +- .../java/awt/Desktop/8064934/bug8064934.java | 83 +++++++++++++++++++ 2 files changed, 85 insertions(+), 1 deletion(-) create mode 100644 jdk/test/java/awt/Desktop/8064934/bug8064934.java diff --git a/jdk/src/java.desktop/windows/native/libawt/windows/awt_Desktop.cpp b/jdk/src/java.desktop/windows/native/libawt/windows/awt_Desktop.cpp index 828818bad4a..36b54670642 100644 --- a/jdk/src/java.desktop/windows/native/libawt/windows/awt_Desktop.cpp +++ b/jdk/src/java.desktop/windows/native/libawt/windows/awt_Desktop.cpp @@ -52,6 +52,7 @@ JNIEXPORT jstring JNICALL Java_sun_awt_windows_WDesktopPeer_ShellExecute // 6457572: ShellExecute possibly changes FPU control word - saving it here unsigned oldcontrol87 = _control87(0, 0); HINSTANCE retval = ::ShellExecute(NULL, verb_c, fileOrUri_c, NULL, NULL, SW_SHOWNORMAL); + DWORD error = ::GetLastError(); _control87(oldcontrol87, 0xffffffff); JNU_ReleaseStringPlatformChars(env, fileOrUri_j, fileOrUri_c); @@ -65,7 +66,7 @@ JNIEXPORT jstring JNICALL Java_sun_awt_windows_WDesktopPeer_ShellExecute FORMAT_MESSAGE_FROM_SYSTEM | FORMAT_MESSAGE_IGNORE_INSERTS, NULL, - (int)retval, + error, MAKELANGID(LANG_NEUTRAL, SUBLANG_DEFAULT), // Default language (LPTSTR)&buffer, 0, diff --git a/jdk/test/java/awt/Desktop/8064934/bug8064934.java b/jdk/test/java/awt/Desktop/8064934/bug8064934.java new file mode 100644 index 00000000000..8824f883cf5 --- /dev/null +++ b/jdk/test/java/awt/Desktop/8064934/bug8064934.java @@ -0,0 +1,83 @@ +/* + * Copyright (c) 2015, 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. + */ + +/* @test + * @bug 8064934 + * @summary Incorrect Exception message from java.awt.Desktop.open() + * @author Dmitry Markov + * @run main bug8064934 + */ +import sun.awt.OSInfo; + +import java.awt.*; +import java.io.File; +import java.io.IOException; +import java.security.AccessController; + +public class bug8064934 { + private static final String NO_ASSOCIATION_ERROR_MESSAGE = "Error message: No application is associated with" + + " the specified file for this operation."; + + public static void main(String[] args) { + // This test is intended only for Windows + if (AccessController.doPrivileged(OSInfo.getOSTypeAction()) != OSInfo.OSType.WINDOWS) { + System.out.println("The test is for Windows platform only"); + return; + } + + // Test whether Desktop is supported of not + if (!Desktop.isDesktopSupported()) { + System.out.println("Desktop is not supported"); + return; + } + + Desktop desktop = Desktop.getDesktop(); + // Test whether open action is supported or not + if (!desktop.isSupported(Desktop.Action.OPEN)) { + System.out.println("Desktop.Action.OPEN is not supported"); + return; + } + + File file = null; + try { + file = File.createTempFile("test", ".foo"); + if (!file.exists()) { + throw new RuntimeException("Can not create temp file"); + } + desktop.open(file); + } catch (IOException ioe) { + String errorMessage = ioe.getMessage().trim(); + if (errorMessage != null && !errorMessage.endsWith(NO_ASSOCIATION_ERROR_MESSAGE)) { + throw new RuntimeException("Test FAILED! Wrong Error message: \n" + + "Actual " + errorMessage.substring(errorMessage.indexOf("Error message:")) + "\n" + + "Expected " + NO_ASSOCIATION_ERROR_MESSAGE); + } + } finally { + if (file != null) { + file.delete(); + } + } + + System.out.println("Test PASSED!"); + } +} From cec84ed1f2b5d2c20b1ce0d7805b5e169859ab75 Mon Sep 17 00:00:00 2001 From: Phil Race Date: Tue, 3 Feb 2015 09:28:21 -0800 Subject: [PATCH 064/116] 8072116: [Solaris] : Fix for 8071710 needs to be updated for build dependency checking Reviewed-by: ihse --- jdk/make/lib/Awt2dLibraries.gmk | 142 ++++++++++++++++---------------- 1 file changed, 71 insertions(+), 71 deletions(-) diff --git a/jdk/make/lib/Awt2dLibraries.gmk b/jdk/make/lib/Awt2dLibraries.gmk index a20b85b59c1..d7e50779625 100644 --- a/jdk/make/lib/Awt2dLibraries.gmk +++ b/jdk/make/lib/Awt2dLibraries.gmk @@ -515,6 +515,77 @@ TARGETS += $(BUILD_LIBJAVAJPEG) ################################################################################ +ifeq ($(BUILD_HEADLESS), true) + # Mac and Windows only use the native AWT lib, do not build libawt_headless + ifeq ($(findstring $(OPENJDK_TARGET_OS), windows macosx),) + + LIBAWT_HEADLESS_DIRS := $(JDK_TOPDIR)/src/java.desktop/unix/native/libawt_headless/awt \ + $(JDK_TOPDIR)/src/java.desktop/$(OPENJDK_TARGET_OS_TYPE)/native/common/awt \ + $(JDK_TOPDIR)/src/java.desktop/$(OPENJDK_TARGET_OS_TYPE)/native/common/java2d/opengl \ + $(JDK_TOPDIR)/src/java.desktop/$(OPENJDK_TARGET_OS_TYPE)/native/common/java2d/x11 \ + $(JDK_TOPDIR)/src/java.desktop/share/native/common/java2d/opengl \ + $(JDK_TOPDIR)/src/java.desktop/share/native/common/font \ + # + + LIBAWT_HEADLESS_EXCLUDES := medialib + LIBAWT_HEADLESS_CFLAGS := -I$(SUPPORT_OUTPUTDIR)/headers/java.desktop \ + $(addprefix -I, $(LIBAWT_HEADLESS_DIRS)) \ + -I$(JDK_TOPDIR)/src/java.desktop/share/native/libawt/java2d \ + -I$(JDK_TOPDIR)/src/java.desktop/share/native/libawt/java2d/loops \ + -I$(JDK_TOPDIR)/src/java.desktop/share/native/libawt/awt/image/cvutils \ + -I$(JDK_TOPDIR)/src/java.desktop/share/native/libawt/java2d/pipe \ + -I$(JDK_TOPDIR)/src/java.desktop/share/native/libawt/awt/image \ + -I$(JDK_TOPDIR)/src/java.desktop/$(OPENJDK_TARGET_OS_TYPE)/native/libawt/java2d \ + -I$(JDK_TOPDIR)/src/java.desktop/share/native/common/font \ + -I$(JDK_TOPDIR)/src/java.desktop/share/native/common/awt/debug \ + -I$(JDK_TOPDIR)/src/java.desktop/$(OPENJDK_TARGET_OS_TYPE)/native/common/font \ + -I$(JDK_TOPDIR)/src/java.desktop/$(OPENJDK_TARGET_OS_TYPE)/native/libsunwjdga/ \ + $(LIBJAVA_HEADER_FLAGS) \ + # + + LIBAWT_HEADLESS_REORDER := + ifeq ($(OPENJDK_TARGET_OS), solaris) + ifneq ($(OPENJDK_TARGET_CPU), x86_64) + LIBAWT_HEADLESS_REORDER := $(JDK_TOPDIR)/make/mapfiles/libawt_headless/reorder-$(OPENJDK_TARGET_CPU) + endif + endif + + $(eval $(call SetupNativeCompilation,BUILD_LIBAWT_HEADLESS, \ + LIBRARY := awt_headless, \ + OUTPUT_DIR := $(INSTALL_LIBRARIES_HERE), \ + SRC := $(LIBAWT_HEADLESS_DIRS), \ + EXCLUDES := $(LIBAWT_HEADLESS_EXCLUDES), \ + LANG := C, \ + OPTIMIZATION := LOW, \ + CFLAGS := $(CFLAGS_JDKLIB) \ + -DHEADLESS=true \ + -DPACKAGE_PATH=\"$(PACKAGE_PATH)\" \ + $(CUPS_CFLAGS) \ + $(X_CFLAGS) \ + $(LIBAWT_HEADLESS_CFLAGS), \ + MAPFILE := $(JDK_TOPDIR)/make/mapfiles/libawt_headless/mapfile-vers, \ + LDFLAGS := $(LDFLAGS_JDKLIB) \ + $(call SET_SHARED_LIBRARY_ORIGIN), \ + LDFLAGS_unix := -L$(INSTALL_LIBRARIES_HERE), \ + LDFLAGS_linux := $(call SET_SHARED_LIBRARY_ORIGIN,/..), \ + LDFLAGS_solaris := $(call SET_SHARED_LIBRARY_ORIGIN,/..), \ + LDFLAGS_macosx := $(call SET_SHARED_LIBRARY_ORIGIN)., \ + REORDER := $(LIBAWT_HEADLESS_REORDER), \ + LDFLAGS_SUFFIX_linux := -ljvm -lawt -lm $(LIBDL) -ljava, \ + LDFLAGS_SUFFIX_aix := -ljvm -lawt -ljava,\ + LDFLAGS_SUFFIX_solaris := $(LIBDL) -ljvm -lawt -lm -ljava $(LIBCXX) -lc, \ + OBJECT_DIR := $(SUPPORT_OUTPUTDIR)/native/$(MODULE)/libawt_headless, \ + DEBUG_SYMBOLS := $(DEBUG_ALL_BINARIES))) + + $(BUILD_LIBAWT_HEADLESS): $(BUILD_LIBAWT) + + TARGETS += $(BUILD_LIBAWT_HEADLESS) + + endif +endif + +################################################################################ + LIBFONTMANAGER_SRC := $(JDK_TOPDIR)/src/java.desktop/share/native/libfontmanager \ $(JDK_TOPDIR)/src/java.desktop/$(OPENJDK_TARGET_OS_TYPE)/native/libfontmanager LIBFONTMANAGER_CFLAGS := \ @@ -718,77 +789,6 @@ TARGETS += $(BUILD_LIBJAWT) ################################################################################ -ifeq ($(BUILD_HEADLESS), true) - # Mac and Windows only use the native AWT lib, do not build libawt_headless - ifeq ($(findstring $(OPENJDK_TARGET_OS), windows macosx),) - - LIBAWT_HEADLESS_DIRS := $(JDK_TOPDIR)/src/java.desktop/unix/native/libawt_headless/awt \ - $(JDK_TOPDIR)/src/java.desktop/$(OPENJDK_TARGET_OS_TYPE)/native/common/awt \ - $(JDK_TOPDIR)/src/java.desktop/$(OPENJDK_TARGET_OS_TYPE)/native/common/java2d/opengl \ - $(JDK_TOPDIR)/src/java.desktop/$(OPENJDK_TARGET_OS_TYPE)/native/common/java2d/x11 \ - $(JDK_TOPDIR)/src/java.desktop/share/native/common/java2d/opengl \ - $(JDK_TOPDIR)/src/java.desktop/share/native/common/font \ - # - - LIBAWT_HEADLESS_EXCLUDES := medialib - LIBAWT_HEADLESS_CFLAGS := -I$(SUPPORT_OUTPUTDIR)/headers/java.desktop \ - $(addprefix -I, $(LIBAWT_HEADLESS_DIRS)) \ - -I$(JDK_TOPDIR)/src/java.desktop/share/native/libawt/java2d \ - -I$(JDK_TOPDIR)/src/java.desktop/share/native/libawt/java2d/loops \ - -I$(JDK_TOPDIR)/src/java.desktop/share/native/libawt/awt/image/cvutils \ - -I$(JDK_TOPDIR)/src/java.desktop/share/native/libawt/java2d/pipe \ - -I$(JDK_TOPDIR)/src/java.desktop/share/native/libawt/awt/image \ - -I$(JDK_TOPDIR)/src/java.desktop/$(OPENJDK_TARGET_OS_TYPE)/native/libawt/java2d \ - -I$(JDK_TOPDIR)/src/java.desktop/share/native/common/font \ - -I$(JDK_TOPDIR)/src/java.desktop/share/native/common/awt/debug \ - -I$(JDK_TOPDIR)/src/java.desktop/$(OPENJDK_TARGET_OS_TYPE)/native/common/font \ - -I$(JDK_TOPDIR)/src/java.desktop/$(OPENJDK_TARGET_OS_TYPE)/native/libsunwjdga/ \ - $(LIBJAVA_HEADER_FLAGS) \ - # - - LIBAWT_HEADLESS_REORDER := - ifeq ($(OPENJDK_TARGET_OS), solaris) - ifneq ($(OPENJDK_TARGET_CPU), x86_64) - LIBAWT_HEADLESS_REORDER := $(JDK_TOPDIR)/make/mapfiles/libawt_headless/reorder-$(OPENJDK_TARGET_CPU) - endif - endif - - $(eval $(call SetupNativeCompilation,BUILD_LIBAWT_HEADLESS, \ - LIBRARY := awt_headless, \ - OUTPUT_DIR := $(INSTALL_LIBRARIES_HERE), \ - SRC := $(LIBAWT_HEADLESS_DIRS), \ - EXCLUDES := $(LIBAWT_HEADLESS_EXCLUDES), \ - LANG := C, \ - OPTIMIZATION := LOW, \ - CFLAGS := $(CFLAGS_JDKLIB) \ - -DHEADLESS=true \ - -DPACKAGE_PATH=\"$(PACKAGE_PATH)\" \ - $(CUPS_CFLAGS) \ - $(X_CFLAGS) \ - $(LIBAWT_HEADLESS_CFLAGS), \ - MAPFILE := $(JDK_TOPDIR)/make/mapfiles/libawt_headless/mapfile-vers, \ - LDFLAGS := $(LDFLAGS_JDKLIB) \ - $(call SET_SHARED_LIBRARY_ORIGIN), \ - LDFLAGS_unix := -L$(INSTALL_LIBRARIES_HERE), \ - LDFLAGS_linux := $(call SET_SHARED_LIBRARY_ORIGIN,/..), \ - LDFLAGS_solaris := $(call SET_SHARED_LIBRARY_ORIGIN,/..), \ - LDFLAGS_macosx := $(call SET_SHARED_LIBRARY_ORIGIN)., \ - REORDER := $(LIBAWT_HEADLESS_REORDER), \ - LDFLAGS_SUFFIX_linux := -ljvm -lawt -lm $(LIBDL) -ljava, \ - LDFLAGS_SUFFIX_aix := -ljvm -lawt -ljava,\ - LDFLAGS_SUFFIX_solaris := $(LIBDL) -ljvm -lawt -lm -ljava $(LIBCXX) -lc, \ - OBJECT_DIR := $(SUPPORT_OUTPUTDIR)/native/$(MODULE)/libawt_headless, \ - DEBUG_SYMBOLS := $(DEBUG_ALL_BINARIES))) - - $(BUILD_LIBAWT_HEADLESS): $(BUILD_LIBAWT) - - TARGETS += $(BUILD_LIBAWT_HEADLESS) - - endif -endif - -################################################################################ - ifndef BUILD_HEADLESS_ONLY LIBSPLASHSCREEN_DIRS := \ From a75613049be8177abfaad709f1e9ddfe2d2647c4 Mon Sep 17 00:00:00 2001 From: Phil Race Date: Wed, 4 Feb 2015 10:28:40 -0800 Subject: [PATCH 065/116] 6243376: JPEGImageWriter corrupts color for non-JFIF images with differing sample factor Reviewed-by: bae, serb --- .../imageio/plugins/jpeg/JPEGImageWriter.java | 2 +- .../imageio/plugins/jpeg/MagentaEXIFTest.java | 205 ++++++++++++++++++ 2 files changed, 206 insertions(+), 1 deletion(-) create mode 100644 jdk/test/javax/imageio/plugins/jpeg/MagentaEXIFTest.java diff --git a/jdk/src/java.desktop/share/classes/com/sun/imageio/plugins/jpeg/JPEGImageWriter.java b/jdk/src/java.desktop/share/classes/com/sun/imageio/plugins/jpeg/JPEGImageWriter.java index 477e6738b5f..b71c73fd54d 100644 --- a/jdk/src/java.desktop/share/classes/com/sun/imageio/plugins/jpeg/JPEGImageWriter.java +++ b/jdk/src/java.desktop/share/classes/com/sun/imageio/plugins/jpeg/JPEGImageWriter.java @@ -1652,7 +1652,7 @@ public class JPEGImageWriter extends ImageWriter { int vsamp0 = specs[0].VsamplingFactor; for (int i = 1; i < specs.length; i++) { if ((specs[i].HsamplingFactor != hsamp0) || - (specs[i].HsamplingFactor != hsamp0)) + (specs[i].VsamplingFactor != vsamp0)) return true; } return false; diff --git a/jdk/test/javax/imageio/plugins/jpeg/MagentaEXIFTest.java b/jdk/test/javax/imageio/plugins/jpeg/MagentaEXIFTest.java new file mode 100644 index 00000000000..8f3cfcf7929 --- /dev/null +++ b/jdk/test/javax/imageio/plugins/jpeg/MagentaEXIFTest.java @@ -0,0 +1,205 @@ +/* + * Copyright (c) 2015, 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. + */ + +/** + * @test + * @bug 8071707 6243376 + * @summary Test verifies that EXIF images with differing sampling factors + * are written correctly + * + * @run main MagentaEXIFTest + */ + +import java.awt.Color; +import java.awt.Graphics2D; +import java.awt.image.BufferedImage; + +import java.io.ByteArrayInputStream; +import java.io.ByteArrayOutputStream; + +import javax.imageio.IIOImage; +import javax.imageio.ImageIO; +import javax.imageio.ImageReader; +import javax.imageio.ImageTypeSpecifier; +import javax.imageio.ImageWriteParam; +import javax.imageio.ImageWriter; +import javax.imageio.metadata.IIOInvalidTreeException; +import javax.imageio.metadata.IIOMetadata; +import javax.imageio.metadata.IIOMetadataNode; +import javax.imageio.stream.ImageInputStream; +import javax.imageio.stream.ImageOutputStream; + +import org.w3c.dom.Attr; +import org.w3c.dom.NamedNodeMap; +import org.w3c.dom.Node; +import org.w3c.dom.NodeList; + + +public class MagentaEXIFTest { + + public static void main(final String[] argv) throws Exception { + + IIOMetadata jpegmetadata = null; + ImageWriter jpgWriter = ImageIO.getImageWritersByFormatName("jpg").next(); + try { + jpegmetadata = createJPEGMetadata(jpgWriter); + } catch (Exception e) { + throw new RuntimeException(e); + } + + ByteArrayOutputStream baos = new ByteArrayOutputStream(); + ImageOutputStream output = ImageIO.createImageOutputStream(baos); + jpgWriter.setOutput(output); + int w=100, h=100; + BufferedImage bi = new BufferedImage(100, 100, BufferedImage.TYPE_INT_RGB); + Graphics2D g2d = bi.createGraphics(); + g2d.setColor(Color.white); + g2d.fillRect(0, 0, w, h); + IIOImage image = new IIOImage(bi, null, jpegmetadata); + jpgWriter.write(null, image, null); + jpgWriter.dispose(); + + baos.flush(); + ByteArrayInputStream bais = new ByteArrayInputStream(baos.toByteArray()); + ImageInputStream iis = ImageIO.createImageInputStream(bais); + bi = ImageIO.read(iis); + for (int i=0; i"); // close current tag + while (child != null) { // emit child tags recursively + displayMetadata(child, level + 1); + child = child.getNextSibling(); + } + for (int i = 0; i < level; i++) System.out.print(" "); + System.out.println(""); + } else { + System.out.println("/>"); + } + } + + /* + * Construct a JPEG IIOMetadata that has had the JFIF marker removed and + * an APP1 EXIF marker added, and further massaged so that we have differing + * horizontal and vertical sampling factors for one channel. + */ + static IIOMetadata createJPEGMetadata(ImageWriter iw) throws IIOInvalidTreeException { + String jpegMDName = "javax_imageio_jpeg_image_1.0"; + ImageWriter imgWriter = ImageIO.getImageWritersByFormatName("jpg").next(); + BufferedImage bi = new BufferedImage(1, 1, BufferedImage.TYPE_INT_RGB); + ImageTypeSpecifier ist = new ImageTypeSpecifier(bi); + IIOMetadata metadata = imgWriter.getDefaultImageMetadata(ist, null); + + IIOMetadataNode root = new IIOMetadataNode(jpegMDName); + IIOMetadataNode header = new IIOMetadataNode("JPEGvariety"); + IIOMetadataNode sequence = new IIOMetadataNode("markerSequence"); + + root.appendChild(header); + root.appendChild(sequence); + + IIOMetadataNode app1 = new IIOMetadataNode("unknown"); + app1.setUserObject(new byte[255]); + app1.setAttribute("MarkerTag", "255"); + sequence.appendChild(app1); + + IIOMetadataNode sof = new IIOMetadataNode("sof"); + sof.setAttribute("process", "0"); + sof.setAttribute("samplePrecision", "8"); + sof.setAttribute("numLines", "100"); + sof.setAttribute("samplesPerLine", "100"); + sof.setAttribute("numFrameComponents", "3"); + IIOMetadataNode c1 = new IIOMetadataNode("componentSpec"); + c1.setAttribute("componentId", "1"); + c1.setAttribute("HsamplingFactor", "1"); + c1.setAttribute("VsamplingFactor", "2"); + c1.setAttribute("QtableSelector", "1"); + sof.appendChild(c1); + IIOMetadataNode c2 = new IIOMetadataNode("componentSpec"); + c2.setAttribute("componentId", "2"); + c2.setAttribute("HsamplingFactor", "1"); + c2.setAttribute("VsamplingFactor", "1"); + c2.setAttribute("QtableSelector", "1"); + sof.appendChild(c2); + IIOMetadataNode c3 = new IIOMetadataNode("componentSpec"); + c3.setAttribute("componentId", "3"); + c3.setAttribute("HsamplingFactor", "1"); + c3.setAttribute("VsamplingFactor", "1"); + c3.setAttribute("QtableSelector", "1"); + sof.appendChild(c3); + sequence.appendChild(sof); + metadata.setFromTree(jpegMDName, root); + IIOMetadata def = imgWriter.getDefaultImageMetadata(ist, null); + metadata.mergeTree(jpegMDName, def.getAsTree(jpegMDName)); + Node tree = metadata.getAsTree(jpegMDName); + Node variety = tree.getFirstChild(); + Node jfif = variety.getFirstChild(); + variety.removeChild(jfif); + sequence = (IIOMetadataNode)tree.getLastChild(); + NodeList markers = sequence.getChildNodes(); + IIOMetadataNode n, sofNode=null; + for (int i=0;i Date: Wed, 4 Feb 2015 10:29:51 -0800 Subject: [PATCH 066/116] 8072433: copy/paste duplicated tests in some condition statements Reviewed-by: bae, serb --- jdk/src/java.desktop/share/classes/sun/font/FontFamily.java | 2 +- jdk/src/java.desktop/share/classes/sun/print/ServiceDialog.java | 2 +- 2 files changed, 2 insertions(+), 2 deletions(-) diff --git a/jdk/src/java.desktop/share/classes/sun/font/FontFamily.java b/jdk/src/java.desktop/share/classes/sun/font/FontFamily.java index b450f86930b..2b67e5122f6 100644 --- a/jdk/src/java.desktop/share/classes/sun/font/FontFamily.java +++ b/jdk/src/java.desktop/share/classes/sun/font/FontFamily.java @@ -78,7 +78,7 @@ public class FontFamily { family.bolditalic = null; } if (family.plain == null && family.bold == null && - family.plain == null && family.bold == null) { + family.italic == null && family.bolditalic == null) { familyNameMap.remove(name); } } diff --git a/jdk/src/java.desktop/share/classes/sun/print/ServiceDialog.java b/jdk/src/java.desktop/share/classes/sun/print/ServiceDialog.java index dd99535251f..ece4f48ef97 100644 --- a/jdk/src/java.desktop/share/classes/sun/print/ServiceDialog.java +++ b/jdk/src/java.desktop/share/classes/sun/print/ServiceDialog.java @@ -1564,7 +1564,7 @@ public class ServiceDialog extends JDialog implements ActionListener { bmObj = bmTmpObj; } else { if (lmObj == null || rmObj == null || - tmObj == null || rmObj == null) { + tmObj == null || bmObj == null) { return; } else { leftMargin.setValue(lmObj); From d32000a7105450439c5b86f949b2e90cb5acb2e4 Mon Sep 17 00:00:00 2001 From: Sergey Bylokhov Date: Thu, 5 Feb 2015 14:20:05 +0300 Subject: [PATCH 067/116] 4952954: abort flag is not cleared for every write operation for JPEG ImageWriter Reviewed-by: bae, prr --- .../imageio/plugins/jpeg/JPEGImageWriter.java | 29 ++- .../plugins/shared/WriteAfterAbort.java | 212 ++++++++++++++++++ 2 files changed, 237 insertions(+), 4 deletions(-) create mode 100644 jdk/test/javax/imageio/plugins/shared/WriteAfterAbort.java diff --git a/jdk/src/java.desktop/share/classes/com/sun/imageio/plugins/jpeg/JPEGImageWriter.java b/jdk/src/java.desktop/share/classes/com/sun/imageio/plugins/jpeg/JPEGImageWriter.java index b71c73fd54d..0daa7d38b79 100644 --- a/jdk/src/java.desktop/share/classes/com/sun/imageio/plugins/jpeg/JPEGImageWriter.java +++ b/jdk/src/java.desktop/share/classes/com/sun/imageio/plugins/jpeg/JPEGImageWriter.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2000, 2014, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2000, 2015, 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 @@ -43,8 +43,6 @@ import org.w3c.dom.Node; import java.awt.image.Raster; import java.awt.image.WritableRaster; -import java.awt.image.SampleModel; -import java.awt.image.DataBuffer; import java.awt.image.DataBufferByte; import java.awt.image.ColorModel; import java.awt.image.IndexColorModel; @@ -1048,7 +1046,13 @@ public class JPEGImageWriter extends ImageWriter { // Call the writer, who will call back for every scanline - processImageStarted(currentImage); + clearAbortRequest(); + cbLock.lock(); + try { + processImageStarted(currentImage); + } finally { + cbLock.unlock(); + } boolean aborted = false; @@ -1225,6 +1229,23 @@ public class JPEGImageWriter extends ImageWriter { } } + @Override + protected synchronized void clearAbortRequest() { + setThreadLock(); + try { + cbLock.check(); + if (abortRequested()) { + super.clearAbortRequest(); + // reset C structures + resetWriter(structPointer); + // reset the native destination + setDest(structPointer); + } + } finally { + clearThreadLock(); + } + } + private void resetInternalState() { // reset C structures resetWriter(structPointer); diff --git a/jdk/test/javax/imageio/plugins/shared/WriteAfterAbort.java b/jdk/test/javax/imageio/plugins/shared/WriteAfterAbort.java new file mode 100644 index 00000000000..4b503d2fe6f --- /dev/null +++ b/jdk/test/javax/imageio/plugins/shared/WriteAfterAbort.java @@ -0,0 +1,212 @@ +/* + * Copyright (c) 2015, 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.awt.Color; +import java.awt.Graphics2D; +import java.awt.image.BufferedImage; +import java.io.File; +import java.io.FileNotFoundException; +import java.io.FileOutputStream; +import java.io.IOException; +import java.util.Iterator; + +import javax.imageio.ImageIO; +import javax.imageio.ImageWriter; +import javax.imageio.event.IIOWriteProgressListener; +import javax.imageio.spi.IIORegistry; +import javax.imageio.spi.ImageWriterSpi; +import javax.imageio.stream.ImageOutputStream; + +import static java.awt.image.BufferedImage.TYPE_BYTE_BINARY; + +/** + * @test + * @bug 4952954 + * @summary abortFlag must be cleared for every ImageWriter.write operation + * @author Sergey Bylokhov + */ +public final class WriteAfterAbort implements IIOWriteProgressListener { + + private volatile boolean abortFlag = true; + private volatile boolean isAbortCalled; + private volatile boolean isCompleteCalled; + private volatile boolean isProgressCalled; + private volatile boolean isStartedCalled; + private static final int WIDTH = 100; + private static final int HEIGHT = 100; + + private void test(final ImageWriter writer) throws IOException { + // Image initialization + final BufferedImage imageWrite = new BufferedImage(WIDTH, HEIGHT, + TYPE_BYTE_BINARY); + final Graphics2D g = imageWrite.createGraphics(); + g.setColor(Color.WHITE); + g.fillRect(0, 0, WIDTH, HEIGHT); + g.dispose(); + + // File initialization + final File file = File.createTempFile("temp", ".img"); + file.deleteOnExit(); + final FileOutputStream fos = new SkipWriteOnAbortOutputStream(file); + final ImageOutputStream ios = ImageIO.createImageOutputStream(fos); + writer.setOutput(ios); + writer.addIIOWriteProgressListener(this); + + // This write will be aborted, and file will not be touched + writer.write(imageWrite); + if (!isStartedCalled) { + throw new RuntimeException("Started should be called"); + } + if (!isProgressCalled) { + throw new RuntimeException("Progress should be called"); + } + if (!isAbortCalled) { + throw new RuntimeException("Abort should be called"); + } + if (isCompleteCalled) { + throw new RuntimeException("Complete should not be called"); + } + // Flush aborted data + ios.flush(); + + // This write should be completed successfully and the file should + // contain correct image data. + abortFlag = false; + isAbortCalled = false; + isCompleteCalled = false; + isProgressCalled = false; + isStartedCalled = false; + writer.write(imageWrite); + + if (!isStartedCalled) { + throw new RuntimeException("Started should be called"); + } + if (!isProgressCalled) { + throw new RuntimeException("Progress should be called"); + } + if (isAbortCalled) { + throw new RuntimeException("Abort should not be called"); + } + if (!isCompleteCalled) { + throw new RuntimeException("Complete should be called"); + } + writer.dispose(); + ios.close(); + + // Validates content of the file. + final BufferedImage imageRead = ImageIO.read(file); + for (int x = 0; x < WIDTH; ++x) { + for (int y = 0; y < HEIGHT; ++y) { + if (imageRead.getRGB(x, y) != imageWrite.getRGB(x, y)) { + throw new RuntimeException("Test failed."); + } + } + } + } + + public static void main(final String[] args) throws IOException { + final IIORegistry registry = IIORegistry.getDefaultInstance(); + final Iterator iter = registry.getServiceProviders( + ImageWriterSpi.class, provider -> true, true); + + // Validates all supported ImageWriters + while (iter.hasNext()) { + final WriteAfterAbort writeAfterAbort = new WriteAfterAbort(); + final ImageWriter writer = iter.next().createWriterInstance(); + System.out.println("ImageWriter = " + writer); + writeAfterAbort.test(writer); + } + System.out.println("Test passed"); + } + + // Callbacks + + @Override + public void imageComplete(ImageWriter source) { + isCompleteCalled = true; + } + + @Override + public void imageProgress(ImageWriter source, float percentageDone) { + isProgressCalled = true; + if (percentageDone > 50 && abortFlag) { + source.abort(); + } + } + + @Override + public void imageStarted(ImageWriter source, int imageIndex) { + isStartedCalled = true; + } + + @Override + public void writeAborted(final ImageWriter source) { + isAbortCalled = true; + } + + @Override + public void thumbnailComplete(ImageWriter source) { + } + + @Override + public void thumbnailProgress(ImageWriter source, float percentageDone) { + } + + @Override + public void thumbnailStarted(ImageWriter source, int imageIndex, + int thumbnailIndex) { + } + + /** + * We need to skip writes on abort, because content of the file after abort + * is undefined. + */ + private class SkipWriteOnAbortOutputStream extends FileOutputStream { + + SkipWriteOnAbortOutputStream(File file) throws FileNotFoundException { + super(file); + } + + @Override + public void write(int b) throws IOException { + if (!abortFlag) { + super.write(b); + } + } + + @Override + public void write(byte[] b) throws IOException { + if (!abortFlag) { + super.write(b); + } + } + + @Override + public void write(byte[] b, int off, int len) throws IOException { + if (!abortFlag) { + super.write(b, off, len); + } + } + } +} + From 3cd8a07dc75753b00f85d56baf25c9f5ac636a72 Mon Sep 17 00:00:00 2001 From: Sergey Bylokhov Date: Thu, 5 Feb 2015 16:16:46 +0300 Subject: [PATCH 068/116] 8062738: Test java/awt/datatransfer/MissedHtmlAndRtfBug/MissedHtmlAndRtfBug fails in Windows Reviewed-by: azvegint, ant --- .../share/classes/java/awt/datatransfer/SystemFlavorMap.java | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/jdk/src/java.datatransfer/share/classes/java/awt/datatransfer/SystemFlavorMap.java b/jdk/src/java.datatransfer/share/classes/java/awt/datatransfer/SystemFlavorMap.java index 3dc096d235a..e6462146274 100644 --- a/jdk/src/java.datatransfer/share/classes/java/awt/datatransfer/SystemFlavorMap.java +++ b/jdk/src/java.datatransfer/share/classes/java/awt/datatransfer/SystemFlavorMap.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 1997, 2014, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 1997, 2015, 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 @@ -215,7 +215,7 @@ public final class SystemFlavorMap implements FlavorMap, FlavorTable { line = line.substring(0, line.length() - 1) + reader.readLine().trim(); } int delimiterPosition = line.indexOf('='); - String key = line.substring(0, delimiterPosition).replaceAll("\\ ", " "); + String key = line.substring(0, delimiterPosition).replace("\\ ", " "); String[] values = line.substring(delimiterPosition + 1, line.length()).split(","); for (String value : values) { try { From 47d0ae0d368fa0ed6d66478d5f2a3092026ff584 Mon Sep 17 00:00:00 2001 From: Alexander Zvegintsev Date: Mon, 2 Feb 2015 21:38:19 +0300 Subject: [PATCH 069/116] 8072088: [PIT] NPE in DnD tests apparently because of the fix to JDK-8061636 Reviewed-by: ant, prr, serb --- jdk/src/java.desktop/share/classes/java/awt/Container.java | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/jdk/src/java.desktop/share/classes/java/awt/Container.java b/jdk/src/java.desktop/share/classes/java/awt/Container.java index dbf60f849fc..86607534163 100644 --- a/jdk/src/java.desktop/share/classes/java/awt/Container.java +++ b/jdk/src/java.desktop/share/classes/java/awt/Container.java @@ -4636,7 +4636,7 @@ class LightweightDispatcher implements java.io.Serializable, AWTEventListener { // drag has an associated drop target. MOUSE_ENTERED comes when the // mouse is in the native container already. To propagate this event // properly we should null out targetLastEntered. - targetLastEnteredDT = null; + targetLastEnteredDT.clear(); } else if (id == MouseEvent.MOUSE_ENTERED) { isMouseDTInNativeContainer = true; } else if (id == MouseEvent.MOUSE_EXITED) { From b81e35ebffafdfb1424af49c10c9c1282fe47261 Mon Sep 17 00:00:00 2001 From: Erik Joelsson Date: Thu, 5 Feb 2015 14:55:30 +0100 Subject: [PATCH 070/116] 8072107: New dependency introduced by deploy.dll and awt.dll (msvcp100.dll) Reviewed-by: ihse --- common/autoconf/flags.m4 | 2 +- common/autoconf/generated-configure.sh | 4 ++-- 2 files changed, 3 insertions(+), 3 deletions(-) diff --git a/common/autoconf/flags.m4 b/common/autoconf/flags.m4 index 1dd8470cdb5..aa1bc2b849f 100644 --- a/common/autoconf/flags.m4 +++ b/common/autoconf/flags.m4 @@ -572,7 +572,7 @@ AC_DEFUN_ONCE([FLAGS_SETUP_COMPILER_FLAGS_FOR_JDK], # avoid bundling msvcpNNN.dll. Doesn't work with newer versions of visual # studio. if test "x$TOOLCHAIN_VERSION" = "x2010"; then - COMMON_CXXFLAGS_JDK="$COMMON_CXXFLAGS_JDK \ + COMMON_CCXXFLAGS_JDK="$COMMON_CCXXFLAGS_JDK \ -D_STATIC_CPPLIB -D_DISABLE_DEPRECATE_STATIC_CPPLIB" fi fi diff --git a/common/autoconf/generated-configure.sh b/common/autoconf/generated-configure.sh index 6bee7555004..e71993e1f27 100644 --- a/common/autoconf/generated-configure.sh +++ b/common/autoconf/generated-configure.sh @@ -4391,7 +4391,7 @@ VS_SDK_PLATFORM_NAME_2013= #CUSTOM_AUTOCONF_INCLUDE # Do not change or remove the following line, it is needed for consistency checks: -DATE_WHEN_GENERATED=1422461639 +DATE_WHEN_GENERATED=1423144508 ############################################################################### # @@ -42468,7 +42468,7 @@ fi # avoid bundling msvcpNNN.dll. Doesn't work with newer versions of visual # studio. if test "x$TOOLCHAIN_VERSION" = "x2010"; then - COMMON_CXXFLAGS_JDK="$COMMON_CXXFLAGS_JDK \ + COMMON_CCXXFLAGS_JDK="$COMMON_CCXXFLAGS_JDK \ -D_STATIC_CPPLIB -D_DISABLE_DEPRECATE_STATIC_CPPLIB" fi fi From a967f754a2aed02553096a4d26f0eddadaeb5212 Mon Sep 17 00:00:00 2001 From: Roland Westrelin Date: Fri, 6 Feb 2015 13:50:44 +0100 Subject: [PATCH 071/116] 8071999: SA's buildreplayjars fail with exception Support default methods when dumping classes in SA Reviewed-by: vlivanov, kvn, dsamersoff --- .../sun/jvm/hotspot/tools/jcore/ClassWriter.java | 14 ++++++++++++-- 1 file changed, 12 insertions(+), 2 deletions(-) diff --git a/hotspot/agent/src/share/classes/sun/jvm/hotspot/tools/jcore/ClassWriter.java b/hotspot/agent/src/share/classes/sun/jvm/hotspot/tools/jcore/ClassWriter.java index 954052703c8..771f95377ca 100644 --- a/hotspot/agent/src/share/classes/sun/jvm/hotspot/tools/jcore/ClassWriter.java +++ b/hotspot/agent/src/share/classes/sun/jvm/hotspot/tools/jcore/ClassWriter.java @@ -423,12 +423,22 @@ public class ClassWriter implements /* imports */ ClassConstants protected void writeMethods() throws IOException { MethodArray methods = klass.getMethods(); - final int len = methods.length(); + ArrayList valid_methods = new ArrayList(); + for (int i = 0; i < methods.length(); i++) { + Method m = methods.at(i); + long accessFlags = m.getAccessFlags(); + // overpass method + if (accessFlags == (JVM_ACC_PUBLIC | JVM_ACC_SYNTHETIC | JVM_ACC_BRIDGE)) { + continue; + } + valid_methods.add(m); + } + final int len = valid_methods.size(); // write number of methods dos.writeShort((short) len); if (DEBUG) debugMessage("number of methods = " + len); for (int m = 0; m < len; m++) { - writeMethod(methods.at(m)); + writeMethod(valid_methods.get(m)); } } From 685f6eb32e6382cb2711b50b1390fc7385a50c3b Mon Sep 17 00:00:00 2001 From: Mikael Gerdin Date: Fri, 6 Feb 2015 16:24:25 +0100 Subject: [PATCH 072/116] 8072693: [BACKOUT] GCCause should distinguish jcmd GC.run from System.gc() Reviewed-by: jwilhelm, tschatzl --- hotspot/src/share/vm/gc_interface/gcCause.cpp | 3 --- hotspot/src/share/vm/gc_interface/gcCause.hpp | 3 --- hotspot/src/share/vm/services/diagnosticCommand.cpp | 2 +- 3 files changed, 1 insertion(+), 7 deletions(-) diff --git a/hotspot/src/share/vm/gc_interface/gcCause.cpp b/hotspot/src/share/vm/gc_interface/gcCause.cpp index 3e0b9dd750d..a364214bdd2 100644 --- a/hotspot/src/share/vm/gc_interface/gcCause.cpp +++ b/hotspot/src/share/vm/gc_interface/gcCause.cpp @@ -103,9 +103,6 @@ const char* GCCause::to_string(GCCause::Cause cause) { case _last_ditch_collection: return "Last ditch collection"; - case _dcmd_gc_run: - return "Diagnostic Command"; - case _last_gc_cause: return "ILLEGAL VALUE - last gc cause - ILLEGAL VALUE"; diff --git a/hotspot/src/share/vm/gc_interface/gcCause.hpp b/hotspot/src/share/vm/gc_interface/gcCause.hpp index df4a212213f..cb304294639 100644 --- a/hotspot/src/share/vm/gc_interface/gcCause.hpp +++ b/hotspot/src/share/vm/gc_interface/gcCause.hpp @@ -74,9 +74,6 @@ class GCCause : public AllStatic { _g1_humongous_allocation, _last_ditch_collection, - - _dcmd_gc_run, - _last_gc_cause }; diff --git a/hotspot/src/share/vm/services/diagnosticCommand.cpp b/hotspot/src/share/vm/services/diagnosticCommand.cpp index d5abd05afa6..a1853ea2464 100644 --- a/hotspot/src/share/vm/services/diagnosticCommand.cpp +++ b/hotspot/src/share/vm/services/diagnosticCommand.cpp @@ -267,7 +267,7 @@ int VMUptimeDCmd::num_arguments() { void SystemGCDCmd::execute(DCmdSource source, TRAPS) { if (!DisableExplicitGC) { - Universe::heap()->collect(GCCause::_dcmd_gc_run); + Universe::heap()->collect(GCCause::_java_lang_system_gc); } else { output()->print_cr("Explicit GC is disabled, no GC has been performed."); } From 67c555e0533ddb1caad85e6b5674138675611327 Mon Sep 17 00:00:00 2001 From: Sergey Bylokhov Date: Fri, 6 Feb 2015 19:49:20 +0300 Subject: [PATCH 073/116] 8063066: Some look and feels ignores the JSlider.PaintTrack property Reviewed-by: ant, azvegint, alexsch --- .../java.desktop/share/classes/javax/swing/JSlider.java | 8 ++++---- 1 file changed, 4 insertions(+), 4 deletions(-) diff --git a/jdk/src/java.desktop/share/classes/javax/swing/JSlider.java b/jdk/src/java.desktop/share/classes/javax/swing/JSlider.java index 956c57a166c..5475d51ffc4 100644 --- a/jdk/src/java.desktop/share/classes/javax/swing/JSlider.java +++ b/jdk/src/java.desktop/share/classes/javax/swing/JSlider.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 1997, 2014, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 1997, 2015, 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 @@ -1287,10 +1287,10 @@ public class JSlider extends JComponent implements SwingConstants, Accessible { return paintTrack; } - /** - * Determines whether the track is painted on the slider. - * By default, this property is {@code true}. + * Determines whether the track is painted on the slider. By default, this + * property is {@code true}. It is up to the look and feel to honor this + * property, some may choose to ignore it. * * @param b whether or not to paint the slider track * @see #getPaintTrack From f387f55093eca75aadf2f407845d6c6d112911fd Mon Sep 17 00:00:00 2001 From: Sergei Kovalev Date: Mon, 9 Feb 2015 09:51:12 +0300 Subject: [PATCH 074/116] 8071811: gc/arguments/TestG1ConcRefinementThreads.java failed on Exception: java.lang.RuntimeException: Actual G1ConcRefinementThreads(0) is not equal to expected value(23) Reviewed-by: jwilhelm, iignatyev --- hotspot/test/TEST.groups | 3 ++- 1 file changed, 2 insertions(+), 1 deletion(-) diff --git a/hotspot/test/TEST.groups b/hotspot/test/TEST.groups index 6a58000bd30..109866e0b06 100644 --- a/hotspot/test/TEST.groups +++ b/hotspot/test/TEST.groups @@ -235,7 +235,8 @@ needs_g1gc = \ gc/metaspace/G1AddMetaspaceDependency.java \ gc/metaspace/TestMetaspacePerfCounters.java \ gc/startup_warnings/TestG1.java \ - gc/whitebox/TestConcMarkCycleWB.java + gc/whitebox/TestConcMarkCycleWB.java \ + gc/arguments/TestG1ConcRefinementThreads.java # All tests that explicitly set the serial GC # From e6ac3ca09ec7a984c45b37652c5eeff2d9b1c570 Mon Sep 17 00:00:00 2001 From: Roland Westrelin Date: Mon, 9 Feb 2015 15:10:58 +0100 Subject: [PATCH 075/116] 8072016: Array copy may cause infinite cycle of deoptimization/compilation Infinite deoptimization/recompilation cycles in case of arraycopy with tightly coupled allocation Reviewed-by: kvn, vlivanov --- hotspot/src/share/vm/opto/graphKit.cpp | 6 +- hotspot/src/share/vm/opto/library_call.cpp | 7 +- .../arraycopy/TestArrayCopyNoInit.java | 4 +- .../arraycopy/TestArrayCopyNoInitDeopt.java | 158 ++++++++++++++++++ 4 files changed, 170 insertions(+), 5 deletions(-) create mode 100644 hotspot/test/compiler/arraycopy/TestArrayCopyNoInitDeopt.java diff --git a/hotspot/src/share/vm/opto/graphKit.cpp b/hotspot/src/share/vm/opto/graphKit.cpp index ccde0152a87..c0845c3f271 100644 --- a/hotspot/src/share/vm/opto/graphKit.cpp +++ b/hotspot/src/share/vm/opto/graphKit.cpp @@ -2819,8 +2819,12 @@ Node* GraphKit::maybe_cast_profiled_obj(Node* obj, if (type != NULL) { Deoptimization::DeoptReason class_reason = Deoptimization::Reason_speculate_class_check; Deoptimization::DeoptReason null_reason = Deoptimization::Reason_speculate_null_check; + ciMethod* trap_method = (sfpt == NULL) ? method() : sfpt->jvms()->method(); + int trap_bci = (sfpt == NULL) ? bci() : sfpt->jvms()->bci(); + if (!too_many_traps(null_reason) && !too_many_recompiles(null_reason) && - !too_many_traps(class_reason) && !too_many_recompiles(class_reason)) { + !C->too_many_traps(trap_method, trap_bci, class_reason) && + !C->too_many_recompiles(trap_method, trap_bci, class_reason)) { Node* not_null_obj = NULL; // not_null is true if we know the object is not null and // there's no need for a null check diff --git a/hotspot/src/share/vm/opto/library_call.cpp b/hotspot/src/share/vm/opto/library_call.cpp index 384f8b491c2..9cd1f9463a9 100644 --- a/hotspot/src/share/vm/opto/library_call.cpp +++ b/hotspot/src/share/vm/opto/library_call.cpp @@ -4740,6 +4740,8 @@ bool LibraryCallKit::inline_arraycopy() { // tightly_coupled_allocation() AllocateArrayNode* alloc = tightly_coupled_allocation(dest, NULL); + ciMethod* trap_method = method(); + int trap_bci = bci(); SafePointNode* sfpt = NULL; if (alloc != NULL) { // The JVM state for uncommon traps between the allocation and @@ -4764,6 +4766,9 @@ bool LibraryCallKit::inline_arraycopy() { sfpt->set_i_o(map()->i_o()); sfpt->set_memory(map()->memory()); + + trap_method = jvms->method(); + trap_bci = jvms->bci(); } bool validated = false; @@ -4868,7 +4873,7 @@ bool LibraryCallKit::inline_arraycopy() { } } - if (!too_many_traps(Deoptimization::Reason_intrinsic) && !src->is_top() && !dest->is_top()) { + if (!C->too_many_traps(trap_method, trap_bci, Deoptimization::Reason_intrinsic) && !src->is_top() && !dest->is_top()) { // validate arguments: enables transformation the ArrayCopyNode validated = true; diff --git a/hotspot/test/compiler/arraycopy/TestArrayCopyNoInit.java b/hotspot/test/compiler/arraycopy/TestArrayCopyNoInit.java index d820eb7fc67..4583e5a366f 100644 --- a/hotspot/test/compiler/arraycopy/TestArrayCopyNoInit.java +++ b/hotspot/test/compiler/arraycopy/TestArrayCopyNoInit.java @@ -29,8 +29,6 @@ * */ -import java.lang.invoke.*; - public class TestArrayCopyNoInit { static int[] m1(int[] src) { @@ -134,7 +132,7 @@ public class TestArrayCopyNoInit { return dest; } - static public void main(String[] args) throws Throwable { + static public void main(String[] args) { boolean success = true; int[] src = new int[10]; TestArrayCopyNoInit[] src2 = new TestArrayCopyNoInit[10]; diff --git a/hotspot/test/compiler/arraycopy/TestArrayCopyNoInitDeopt.java b/hotspot/test/compiler/arraycopy/TestArrayCopyNoInitDeopt.java new file mode 100644 index 00000000000..26ebd39a0a9 --- /dev/null +++ b/hotspot/test/compiler/arraycopy/TestArrayCopyNoInitDeopt.java @@ -0,0 +1,158 @@ +/* + * Copyright (c) 2015, 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. + */ + +/* + * @test + * @bug 8072016 + * @summary Infinite deoptimization/recompilation cycles in case of arraycopy with tightly coupled allocation + * @library /testlibrary /../../test/lib /compiler/whitebox + * @build TestArrayCopyNoInitDeopt + * @run main ClassFileInstaller sun.hotspot.WhiteBox + * @run main ClassFileInstaller com.oracle.java.testlibrary.Platform + * @run main/othervm -Xmixed -Xbootclasspath/a:. -XX:+UnlockDiagnosticVMOptions -XX:+WhiteBoxAPI + * -XX:-BackgroundCompilation -XX:-UseOnStackReplacement -XX:TypeProfileLevel=020 + * TestArrayCopyNoInitDeopt + * + */ + + +import sun.hotspot.WhiteBox; +import sun.hotspot.code.NMethod; +import com.oracle.java.testlibrary.Platform; +import java.lang.reflect.*; + +public class TestArrayCopyNoInitDeopt { + + public static int[] m1(Object src) { + if (src == null) return null; + int[] dest = new int[10]; + try { + System.arraycopy(src, 0, dest, 0, 10); + } catch (ArrayStoreException npe) { + } + return dest; + } + + static Object m2_src(Object src) { + return src; + } + + public static int[] m2(Object src) { + if (src == null) return null; + src = m2_src(src); + int[] dest = new int[10]; + try { + System.arraycopy(src, 0, dest, 0, 10); + } catch (ArrayStoreException npe) { + } + return dest; + } + + private static final WhiteBox WHITE_BOX = WhiteBox.getWhiteBox(); + + static boolean deoptimize(Method method, Object src_obj) throws Exception { + for (int i = 0; i < 10; i++) { + method.invoke(null, src_obj); + if (!WHITE_BOX.isMethodCompiled(method)) { + return true; + } + } + return false; + } + + static public void main(String[] args) throws Exception { + if (Platform.isServer()) { + int[] src = new int[10]; + Object src_obj = new Object(); + Method method_m1 = TestArrayCopyNoInitDeopt.class.getMethod("m1", Object.class); + Method method_m2 = TestArrayCopyNoInitDeopt.class.getMethod("m2", Object.class); + + // Warm up + for (int i = 0; i < 20000; i++) { + m1(src); + } + + // And make sure m1 is compiled by C2 + WHITE_BOX.enqueueMethodForCompilation(method_m1, CompilerWhiteBoxTest.COMP_LEVEL_FULL_OPTIMIZATION); + + if (!WHITE_BOX.isMethodCompiled(method_m1)) { + throw new RuntimeException("m1 not compiled"); + } + + // should deoptimize for type check + if (!deoptimize(method_m1, src_obj)) { + throw new RuntimeException("m1 not deoptimized"); + } + + WHITE_BOX.enqueueMethodForCompilation(method_m1, CompilerWhiteBoxTest.COMP_LEVEL_FULL_OPTIMIZATION); + + if (!WHITE_BOX.isMethodCompiled(method_m1)) { + throw new RuntimeException("m1 not recompiled"); + } + + if (deoptimize(method_m1, src_obj)) { + throw new RuntimeException("m1 deoptimized again"); + } + + // Same test as above but with speculative types + + // Warm up & make sure we collect type profiling + for (int i = 0; i < 20000; i++) { + m2(src); + } + + // And make sure m2 is compiled by C2 + WHITE_BOX.enqueueMethodForCompilation(method_m2, CompilerWhiteBoxTest.COMP_LEVEL_FULL_OPTIMIZATION); + + if (!WHITE_BOX.isMethodCompiled(method_m2)) { + throw new RuntimeException("m2 not compiled"); + } + + // should deoptimize for speculative type check + if (!deoptimize(method_m2, src_obj)) { + throw new RuntimeException("m2 not deoptimized"); + } + + WHITE_BOX.enqueueMethodForCompilation(method_m2, CompilerWhiteBoxTest.COMP_LEVEL_FULL_OPTIMIZATION); + + if (!WHITE_BOX.isMethodCompiled(method_m2)) { + throw new RuntimeException("m2 not recompiled"); + } + + // should deoptimize for actual type check + if (!deoptimize(method_m2, src_obj)) { + throw new RuntimeException("m2 not deoptimized"); + } + + WHITE_BOX.enqueueMethodForCompilation(method_m2, CompilerWhiteBoxTest.COMP_LEVEL_FULL_OPTIMIZATION); + + if (!WHITE_BOX.isMethodCompiled(method_m2)) { + throw new RuntimeException("m2 not recompiled"); + } + + if (deoptimize(method_m2, src_obj)) { + throw new RuntimeException("m2 deoptimized again"); + } + } + } +} From 01716f18f32b1ade0ddef1b164a6f83aae6e9730 Mon Sep 17 00:00:00 2001 From: Roland Westrelin Date: Mon, 9 Feb 2015 13:45:59 +0100 Subject: [PATCH 076/116] 8071821: Assert failed in UnexpectedDeoptimizationTest.java Assert fires in case of concurrent initialization of ciInstanceKlass::_has_injected_fields Reviewed-by: kvn --- hotspot/src/share/vm/ci/ciInstanceKlass.cpp | 33 ++++++++++----------- hotspot/src/share/vm/ci/ciInstanceKlass.hpp | 6 ++-- 2 files changed, 19 insertions(+), 20 deletions(-) diff --git a/hotspot/src/share/vm/ci/ciInstanceKlass.cpp b/hotspot/src/share/vm/ci/ciInstanceKlass.cpp index 43691b907d7..b81206a1616 100644 --- a/hotspot/src/share/vm/ci/ciInstanceKlass.cpp +++ b/hotspot/src/share/vm/ci/ciInstanceKlass.cpp @@ -501,32 +501,31 @@ ciInstanceKlass::compute_nonstatic_fields_impl(GrowableArray* return fields; } -void ciInstanceKlass::compute_injected_fields_helper() { +bool ciInstanceKlass::compute_injected_fields_helper() { ASSERT_IN_VM; InstanceKlass* k = get_instanceKlass(); for (InternalFieldStream fs(k); !fs.done(); fs.next()) { if (fs.access_flags().is_static()) continue; - _has_injected_fields++; - break; - } -} - -bool ciInstanceKlass::compute_injected_fields() { - assert(_has_injected_fields == -1, "shouldn't be initialized yet"); - assert(is_loaded(), "must be loaded"); - - if (super() != NULL && super()->has_injected_fields()) { - _has_injected_fields = 1; return true; } + return false; +} - _has_injected_fields = 0; - GUARDED_VM_ENTRY({ - compute_injected_fields_helper(); - }); +void ciInstanceKlass::compute_injected_fields() { + assert(is_loaded(), "must be loaded"); - return _has_injected_fields > 0 ? true : false; + int has_injected_fields = 0; + if (super() != NULL && super()->has_injected_fields()) { + has_injected_fields = 1; + } else { + GUARDED_VM_ENTRY({ + has_injected_fields = compute_injected_fields_helper() ? 1 : 0; + }); + } + // may be concurrently initialized for shared ciInstanceKlass objects + assert(_has_injected_fields == -1 || _has_injected_fields == has_injected_fields, "broken concurrent initialization"); + _has_injected_fields = has_injected_fields; } // ------------------------------------------------------------------ diff --git a/hotspot/src/share/vm/ci/ciInstanceKlass.hpp b/hotspot/src/share/vm/ci/ciInstanceKlass.hpp index 424b61a0a10..df9ed0f7fe9 100644 --- a/hotspot/src/share/vm/ci/ciInstanceKlass.hpp +++ b/hotspot/src/share/vm/ci/ciInstanceKlass.hpp @@ -72,8 +72,8 @@ private: // Itsef: more than one implementors. ciInstanceKlass* _implementor; - bool compute_injected_fields(); - void compute_injected_fields_helper(); + void compute_injected_fields(); + bool compute_injected_fields_helper(); protected: ciInstanceKlass(KlassHandle h_k); @@ -193,7 +193,7 @@ public: bool has_injected_fields() { if (_has_injected_fields == -1) { - return compute_injected_fields(); + compute_injected_fields(); } return _has_injected_fields > 0 ? true : false; } From 832b4db2151a575cd4d38e939580754215f7c3e9 Mon Sep 17 00:00:00 2001 From: Jesper Wilhelmsson Date: Mon, 9 Feb 2015 17:38:42 +0100 Subject: [PATCH 077/116] 8072688: Description of flag ExplicitGCInvokesConcurrent should mention G1 as well Changed to a more generic description. Reviewed-by: mgerdin, tschatzl --- hotspot/src/share/vm/runtime/globals.hpp | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/hotspot/src/share/vm/runtime/globals.hpp b/hotspot/src/share/vm/runtime/globals.hpp index dd014368f69..b161162729a 100644 --- a/hotspot/src/share/vm/runtime/globals.hpp +++ b/hotspot/src/share/vm/runtime/globals.hpp @@ -1501,7 +1501,7 @@ class CommandLineFlags { \ product(bool, ExplicitGCInvokesConcurrent, false, \ "A System.gc() request invokes a concurrent collection; " \ - "(effective only when UseConcMarkSweepGC)") \ + "(effective only when using concurrent collectors)") \ \ product(bool, ExplicitGCInvokesConcurrentAndUnloadsClasses, false, \ "A System.gc() request invokes a concurrent collection and " \ From 736e4a1146f817ede7e766ecf27ad20ae0a9d3ce Mon Sep 17 00:00:00 2001 From: Paul Sandoz Date: Tue, 10 Feb 2015 14:10:32 +0100 Subject: [PATCH 078/116] 8068975: Remove deprecated methods on sun.misc.Unsafe and clean up native implementation Reviewed-by: dholmes, kvn, vlivanov --- .../share/classes/sun/misc/Unsafe.java | 250 ++---------------- 1 file changed, 16 insertions(+), 234 deletions(-) diff --git a/jdk/src/java.base/share/classes/sun/misc/Unsafe.java b/jdk/src/java.base/share/classes/sun/misc/Unsafe.java index 46080c3bd22..15402d168cd 100644 --- a/jdk/src/java.base/share/classes/sun/misc/Unsafe.java +++ b/jdk/src/java.base/share/classes/sun/misc/Unsafe.java @@ -25,8 +25,8 @@ package sun.misc; -import java.security.*; -import java.lang.reflect.*; +import java.lang.reflect.Field; +import java.security.ProtectionDomain; import sun.reflect.CallerSensitive; import sun.reflect.Reflection; @@ -189,205 +189,39 @@ public final class Unsafe { * If the reference o is non-null, car marks or * other store barriers for that object (if the VM requires them) * are updated. - * @see #putInt(Object, int, int) + * @see #putInt(Object, long, int) */ public native void putObject(Object o, long offset, Object x); /** @see #getInt(Object, long) */ public native boolean getBoolean(Object o, long offset); - /** @see #putInt(Object, int, int) */ + /** @see #putInt(Object, long, int) */ public native void putBoolean(Object o, long offset, boolean x); /** @see #getInt(Object, long) */ public native byte getByte(Object o, long offset); - /** @see #putInt(Object, int, int) */ + /** @see #putInt(Object, long, int) */ public native void putByte(Object o, long offset, byte x); /** @see #getInt(Object, long) */ public native short getShort(Object o, long offset); - /** @see #putInt(Object, int, int) */ + /** @see #putInt(Object, long, int) */ public native void putShort(Object o, long offset, short x); /** @see #getInt(Object, long) */ public native char getChar(Object o, long offset); - /** @see #putInt(Object, int, int) */ + /** @see #putInt(Object, long, int) */ public native void putChar(Object o, long offset, char x); /** @see #getInt(Object, long) */ public native long getLong(Object o, long offset); - /** @see #putInt(Object, int, int) */ + /** @see #putInt(Object, long, int) */ public native void putLong(Object o, long offset, long x); /** @see #getInt(Object, long) */ public native float getFloat(Object o, long offset); - /** @see #putInt(Object, int, int) */ + /** @see #putInt(Object, long, int) */ public native void putFloat(Object o, long offset, float x); /** @see #getInt(Object, long) */ public native double getDouble(Object o, long offset); - /** @see #putInt(Object, int, int) */ + /** @see #putInt(Object, long, int) */ public native void putDouble(Object o, long offset, double x); - /** - * This method, like all others with 32-bit offsets, was native - * in a previous release but is now a wrapper which simply casts - * the offset to a long value. It provides backward compatibility - * with bytecodes compiled against 1.4. - * @deprecated As of 1.4.1, cast the 32-bit offset argument to a long. - * See {@link #staticFieldOffset}. - */ - @Deprecated - public int getInt(Object o, int offset) { - return getInt(o, (long)offset); - } - - /** - * @deprecated As of 1.4.1, cast the 32-bit offset argument to a long. - * See {@link #staticFieldOffset}. - */ - @Deprecated - public void putInt(Object o, int offset, int x) { - putInt(o, (long)offset, x); - } - - /** - * @deprecated As of 1.4.1, cast the 32-bit offset argument to a long. - * See {@link #staticFieldOffset}. - */ - @Deprecated - public Object getObject(Object o, int offset) { - return getObject(o, (long)offset); - } - - /** - * @deprecated As of 1.4.1, cast the 32-bit offset argument to a long. - * See {@link #staticFieldOffset}. - */ - @Deprecated - public void putObject(Object o, int offset, Object x) { - putObject(o, (long)offset, x); - } - - /** - * @deprecated As of 1.4.1, cast the 32-bit offset argument to a long. - * See {@link #staticFieldOffset}. - */ - @Deprecated - public boolean getBoolean(Object o, int offset) { - return getBoolean(o, (long)offset); - } - - /** - * @deprecated As of 1.4.1, cast the 32-bit offset argument to a long. - * See {@link #staticFieldOffset}. - */ - @Deprecated - public void putBoolean(Object o, int offset, boolean x) { - putBoolean(o, (long)offset, x); - } - - /** - * @deprecated As of 1.4.1, cast the 32-bit offset argument to a long. - * See {@link #staticFieldOffset}. - */ - @Deprecated - public byte getByte(Object o, int offset) { - return getByte(o, (long)offset); - } - - /** - * @deprecated As of 1.4.1, cast the 32-bit offset argument to a long. - * See {@link #staticFieldOffset}. - */ - @Deprecated - public void putByte(Object o, int offset, byte x) { - putByte(o, (long)offset, x); - } - - /** - * @deprecated As of 1.4.1, cast the 32-bit offset argument to a long. - * See {@link #staticFieldOffset}. - */ - @Deprecated - public short getShort(Object o, int offset) { - return getShort(o, (long)offset); - } - - /** - * @deprecated As of 1.4.1, cast the 32-bit offset argument to a long. - * See {@link #staticFieldOffset}. - */ - @Deprecated - public void putShort(Object o, int offset, short x) { - putShort(o, (long)offset, x); - } - - /** - * @deprecated As of 1.4.1, cast the 32-bit offset argument to a long. - * See {@link #staticFieldOffset}. - */ - @Deprecated - public char getChar(Object o, int offset) { - return getChar(o, (long)offset); - } - - /** - * @deprecated As of 1.4.1, cast the 32-bit offset argument to a long. - * See {@link #staticFieldOffset}. - */ - @Deprecated - public void putChar(Object o, int offset, char x) { - putChar(o, (long)offset, x); - } - - /** - * @deprecated As of 1.4.1, cast the 32-bit offset argument to a long. - * See {@link #staticFieldOffset}. - */ - @Deprecated - public long getLong(Object o, int offset) { - return getLong(o, (long)offset); - } - - /** - * @deprecated As of 1.4.1, cast the 32-bit offset argument to a long. - * See {@link #staticFieldOffset}. - */ - @Deprecated - public void putLong(Object o, int offset, long x) { - putLong(o, (long)offset, x); - } - - /** - * @deprecated As of 1.4.1, cast the 32-bit offset argument to a long. - * See {@link #staticFieldOffset}. - */ - @Deprecated - public float getFloat(Object o, int offset) { - return getFloat(o, (long)offset); - } - - /** - * @deprecated As of 1.4.1, cast the 32-bit offset argument to a long. - * See {@link #staticFieldOffset}. - */ - @Deprecated - public void putFloat(Object o, int offset, float x) { - putFloat(o, (long)offset, x); - } - - /** - * @deprecated As of 1.4.1, cast the 32-bit offset argument to a long. - * See {@link #staticFieldOffset}. - */ - @Deprecated - public double getDouble(Object o, int offset) { - return getDouble(o, (long)offset); - } - - /** - * @deprecated As of 1.4.1, cast the 32-bit offset argument to a long. - * See {@link #staticFieldOffset}. - */ - @Deprecated - public void putDouble(Object o, int offset, double x) { - putDouble(o, (long)offset, x); - } - // These work on values in the C heap. /** @@ -578,58 +412,6 @@ public final class Unsafe { */ public static final int INVALID_FIELD_OFFSET = -1; - /** - * Returns the offset of a field, truncated to 32 bits. - * This method is implemented as follows: - *
-     * public int fieldOffset(Field f) {
-     *     if (Modifier.isStatic(f.getModifiers()))
-     *         return (int) staticFieldOffset(f);
-     *     else
-     *         return (int) objectFieldOffset(f);
-     * }
-     * 
- * @deprecated As of 1.4.1, use {@link #staticFieldOffset} for static - * fields and {@link #objectFieldOffset} for non-static fields. - */ - @Deprecated - public int fieldOffset(Field f) { - if (Modifier.isStatic(f.getModifiers())) - return (int) staticFieldOffset(f); - else - return (int) objectFieldOffset(f); - } - - /** - * Returns the base address for accessing some static field - * in the given class. This method is implemented as follows: - *
-     * public Object staticFieldBase(Class c) {
-     *     Field[] fields = c.getDeclaredFields();
-     *     for (int i = 0; i < fields.length; i++) {
-     *         if (Modifier.isStatic(fields[i].getModifiers())) {
-     *             return staticFieldBase(fields[i]);
-     *         }
-     *     }
-     *     return null;
-     * }
-     * 
- * @deprecated As of 1.4.1, use {@link #staticFieldBase(Field)} - * to obtain the base pertaining to a specific {@link Field}. - * This method works only for JVMs which store all statics - * for a given class in one place. - */ - @Deprecated - public Object staticFieldBase(Class c) { - Field[] fields = c.getDeclaredFields(); - for (int i = 0; i < fields.length; i++) { - if (Modifier.isStatic(fields[i].getModifiers())) { - return staticFieldBase(fields[i]); - } - } - return null; - } - /** * Report the location of a given field in the storage allocation of its * class. Do not expect to perform any sort of arithmetic on this offset; @@ -648,7 +430,7 @@ public final class Unsafe { * must preserve all bits of static field offsets. * @see #getInt(Object, long) */ - public native long staticFieldOffset(Field f); + public native long objectFieldOffset(Field f); /** * Report the location of a given static field, in conjunction with {@link @@ -667,7 +449,7 @@ public final class Unsafe { * this method reports its result as a long value. * @see #getInt(Object, long) */ - public native long objectFieldOffset(Field f); + public native long staticFieldOffset(Field f); /** * Report the location of a given static field, in conjunction with {@link @@ -748,7 +530,7 @@ public final class Unsafe { * Report the scale factor for addressing elements in the storage * allocation of a given array class. However, arrays of "narrow" types * will generally not work properly with accessors like {@link - * #getByte(Object, int)}, so the scale factor for such classes is reported + * #getByte(Object, long)}, so the scale factor for such classes is reported * as zero. * * @see #arrayBaseOffset @@ -1136,11 +918,11 @@ public final class Unsafe { public native void fullFence(); /** - * Throws IllegalAccessError; for use by the VM. + * Throws IllegalAccessError; for use by the VM for access control + * error support. * @since 1.8 */ private static void throwIllegalAccessError() { - throw new IllegalAccessError(); + throw new IllegalAccessError(); } - } From a1d993e9ce2e2f9a3d17232014fb2875084e6712 Mon Sep 17 00:00:00 2001 From: Paul Sandoz Date: Tue, 10 Feb 2015 14:10:43 +0100 Subject: [PATCH 079/116] 8068975: Remove deprecated methods on sun.misc.Unsafe and clean up native implementation Reviewed-by: dholmes, kvn, vlivanov --- hotspot/src/share/vm/prims/unsafe.cpp | 441 ++---------------- hotspot/test/runtime/Unsafe/FieldOffset.java | 32 +- .../test/runtime/Unsafe/GetPutBoolean.java | 2 +- hotspot/test/runtime/Unsafe/GetPutByte.java | 2 +- hotspot/test/runtime/Unsafe/GetPutChar.java | 2 +- hotspot/test/runtime/Unsafe/GetPutDouble.java | 2 +- hotspot/test/runtime/Unsafe/GetPutFloat.java | 2 +- hotspot/test/runtime/Unsafe/GetPutInt.java | 2 +- hotspot/test/runtime/Unsafe/GetPutLong.java | 2 +- hotspot/test/runtime/Unsafe/GetPutObject.java | 2 +- hotspot/test/runtime/Unsafe/GetPutShort.java | 2 +- 11 files changed, 70 insertions(+), 421 deletions(-) diff --git a/hotspot/src/share/vm/prims/unsafe.cpp b/hotspot/src/share/vm/prims/unsafe.cpp index f681ccebd9d..09081999f7f 100644 --- a/hotspot/src/share/vm/prims/unsafe.cpp +++ b/hotspot/src/share/vm/prims/unsafe.cpp @@ -30,10 +30,8 @@ #include "runtime/atomic.inline.hpp" #include "runtime/globals.hpp" #include "runtime/interfaceSupport.hpp" -#include "runtime/prefetch.inline.hpp" #include "runtime/orderAccess.inline.hpp" #include "runtime/reflection.hpp" -#include "runtime/synchronizer.hpp" #include "runtime/vm_version.hpp" #include "services/threadService.hpp" #include "trace/tracing.hpp" @@ -596,17 +594,7 @@ UNSAFE_ENTRY(void, Unsafe_FreeMemory(JNIEnv *env, jobject unsafe, jlong addr)) os::free(p); UNSAFE_END -UNSAFE_ENTRY(void, Unsafe_SetMemory(JNIEnv *env, jobject unsafe, jlong addr, jlong size, jbyte value)) - UnsafeWrapper("Unsafe_SetMemory"); - size_t sz = (size_t)size; - if (sz != (julong)size || size < 0) { - THROW(vmSymbols::java_lang_IllegalArgumentException()); - } - char* p = (char*) addr_from_java(addr); - Copy::fill_to_memory_atomic(p, sz, value); -UNSAFE_END - -UNSAFE_ENTRY(void, Unsafe_SetMemory2(JNIEnv *env, jobject unsafe, jobject obj, jlong offset, jlong size, jbyte value)) +UNSAFE_ENTRY(void, Unsafe_SetMemory(JNIEnv *env, jobject unsafe, jobject obj, jlong offset, jlong size, jbyte value)) UnsafeWrapper("Unsafe_SetMemory"); size_t sz = (size_t)size; if (sz != (julong)size || size < 0) { @@ -617,21 +605,7 @@ UNSAFE_ENTRY(void, Unsafe_SetMemory2(JNIEnv *env, jobject unsafe, jobject obj, j Copy::fill_to_memory_atomic(p, sz, value); UNSAFE_END -UNSAFE_ENTRY(void, Unsafe_CopyMemory(JNIEnv *env, jobject unsafe, jlong srcAddr, jlong dstAddr, jlong size)) - UnsafeWrapper("Unsafe_CopyMemory"); - if (size == 0) { - return; - } - size_t sz = (size_t)size; - if (sz != (julong)size || size < 0) { - THROW(vmSymbols::java_lang_IllegalArgumentException()); - } - void* src = addr_from_java(srcAddr); - void* dst = addr_from_java(dstAddr); - Copy::conjoint_memory_atomic(src, dst, sz); -UNSAFE_END - -UNSAFE_ENTRY(void, Unsafe_CopyMemory2(JNIEnv *env, jobject unsafe, jobject srcObj, jlong srcOffset, jobject dstObj, jlong dstOffset, jlong size)) +UNSAFE_ENTRY(void, Unsafe_CopyMemory(JNIEnv *env, jobject unsafe, jobject srcObj, jlong srcOffset, jobject dstObj, jlong dstOffset, jlong size)) UnsafeWrapper("Unsafe_CopyMemory"); if (size == 0) { return; @@ -725,24 +699,6 @@ UNSAFE_ENTRY(jobject, Unsafe_StaticFieldBaseFromField(JNIEnv *env, jobject unsaf return JNIHandles::make_local(env, mirror); UNSAFE_END -//@deprecated -UNSAFE_ENTRY(jint, Unsafe_FieldOffset(JNIEnv *env, jobject unsafe, jobject field)) - UnsafeWrapper("Unsafe_FieldOffset"); - // tries (but fails) to be polymorphic between static and non-static: - jlong offset = find_field_offset(field, -1, THREAD); - guarantee(offset == (jint)offset, "offset fits in 32 bits"); - return (jint)offset; -UNSAFE_END - -//@deprecated -UNSAFE_ENTRY(jobject, Unsafe_StaticFieldBaseFromClass(JNIEnv *env, jobject unsafe, jobject clazz)) - UnsafeWrapper("Unsafe_StaticFieldBase"); - if (clazz == NULL) { - THROW_0(vmSymbols::java_lang_NullPointerException()); - } - return JNIHandles::make_local(env, JNIHandles::resolve_non_null(clazz)); -UNSAFE_END - UNSAFE_ENTRY(void, Unsafe_EnsureClassInitialized(JNIEnv *env, jobject unsafe, jobject clazz)) { UnsafeWrapper("Unsafe_EnsureClassInitialized"); if (clazz == NULL) { @@ -915,31 +871,7 @@ UNSAFE_ENTRY(jclass, Unsafe_DefineClass(JNIEnv *env, jobject unsafe, jstring nam } UNSAFE_END -static jobject get_class_loader(JNIEnv* env, jclass cls) { - if (java_lang_Class::is_primitive(JNIHandles::resolve_non_null(cls))) { - return NULL; - } - Klass* k = java_lang_Class::as_Klass(JNIHandles::resolve_non_null(cls)); - oop loader = k->class_loader(); - return JNIHandles::make_local(env, loader); -} -UNSAFE_ENTRY(jclass, Unsafe_DefineClass0(JNIEnv *env, jobject unsafe, jstring name, jbyteArray data, int offset, int length)) - UnsafeWrapper("Unsafe_DefineClass"); - { - ThreadToNativeFromVM ttnfv(thread); - - int depthFromDefineClass0 = 1; - jclass caller = JVM_GetCallerClass(env, depthFromDefineClass0); - jobject loader = (caller == NULL) ? NULL : get_class_loader(env, caller); - jobject pd = (caller == NULL) ? NULL : JVM_GetProtectionDomain(env, caller); - - return Unsafe_DefineClass_impl(env, name, data, offset, length, loader, pd); - } -UNSAFE_END - - -#define DAC_Args CLS"[B["OBJ // define a class but do not make it known to the class loader or system dictionary // - host_class: supplies context for linkage, access control, protection domain, and class loader // - data: bytes of a class file, a raw memory address (length gives the number of bytes) @@ -1233,20 +1165,6 @@ UNSAFE_ENTRY(jint, Unsafe_Loadavg(JNIEnv *env, jobject unsafe, jdoubleArray load return ret; UNSAFE_END -UNSAFE_ENTRY(void, Unsafe_PrefetchRead(JNIEnv* env, jclass ignored, jobject obj, jlong offset)) - UnsafeWrapper("Unsafe_PrefetchRead"); - oop p = JNIHandles::resolve(obj); - void* addr = index_oop_from_field_offset_long(p, 0); - Prefetch::read(addr, (intx)offset); -UNSAFE_END - -UNSAFE_ENTRY(void, Unsafe_PrefetchWrite(JNIEnv* env, jclass ignored, jobject obj, jlong offset)) - UnsafeWrapper("Unsafe_PrefetchWrite"); - oop p = JNIHandles::resolve(obj); - void* addr = index_oop_from_field_offset_long(p, 0); - Prefetch::write(addr, (intx)offset); -UNSAFE_END - /// JVM_RegisterUnsafeMethods @@ -1256,256 +1174,50 @@ UNSAFE_END #define OBJ LANG"Object;" #define CLS LANG"Class;" -#define CTR LANG"reflect/Constructor;" #define FLD LANG"reflect/Field;" -#define MTH LANG"reflect/Method;" #define THR LANG"Throwable;" -#define DC0_Args LANG"String;[BII" -#define DC_Args DC0_Args LANG"ClassLoader;" "Ljava/security/ProtectionDomain;" +#define DC_Args LANG"String;[BII" LANG"ClassLoader;" "Ljava/security/ProtectionDomain;" +#define DAC_Args CLS"[B["OBJ #define CC (char*) /*cast a literal from (const char*)*/ #define FN_PTR(f) CAST_FROM_FN_PTR(void*, &f) -// define deprecated accessors for compabitility with 1.4.0 -#define DECLARE_GETSETOOP_140(Boolean, Z) \ - {CC"get"#Boolean, CC"("OBJ"I)"#Z, FN_PTR(Unsafe_Get##Boolean##140)}, \ - {CC"put"#Boolean, CC"("OBJ"I"#Z")V", FN_PTR(Unsafe_Set##Boolean##140)} - -// Note: In 1.4.1, getObject and kin take both int and long offsets. -#define DECLARE_GETSETOOP_141(Boolean, Z) \ - {CC"get"#Boolean, CC"("OBJ"J)"#Z, FN_PTR(Unsafe_Get##Boolean)}, \ - {CC"put"#Boolean, CC"("OBJ"J"#Z")V", FN_PTR(Unsafe_Set##Boolean)} - -// Note: In 1.5.0, there are volatile versions too -#define DECLARE_GETSETOOP(Boolean, Z) \ +#define DECLARE_GETPUTOOP(Boolean, Z) \ {CC"get"#Boolean, CC"("OBJ"J)"#Z, FN_PTR(Unsafe_Get##Boolean)}, \ {CC"put"#Boolean, CC"("OBJ"J"#Z")V", FN_PTR(Unsafe_Set##Boolean)}, \ {CC"get"#Boolean"Volatile", CC"("OBJ"J)"#Z, FN_PTR(Unsafe_Get##Boolean##Volatile)}, \ {CC"put"#Boolean"Volatile", CC"("OBJ"J"#Z")V", FN_PTR(Unsafe_Set##Boolean##Volatile)} -#define DECLARE_GETSETNATIVE(Byte, B) \ +#define DECLARE_GETPUTNATIVE(Byte, B) \ {CC"get"#Byte, CC"("ADR")"#B, FN_PTR(Unsafe_GetNative##Byte)}, \ {CC"put"#Byte, CC"("ADR#B")V", FN_PTR(Unsafe_SetNative##Byte)} -// These are the methods for 1.4.0 -static JNINativeMethod methods_140[] = { - DECLARE_GETSETOOP_140(Boolean, Z), - DECLARE_GETSETOOP_140(Byte, B), - DECLARE_GETSETOOP_140(Short, S), - DECLARE_GETSETOOP_140(Char, C), - DECLARE_GETSETOOP_140(Int, I), - DECLARE_GETSETOOP_140(Long, J), - DECLARE_GETSETOOP_140(Float, F), - DECLARE_GETSETOOP_140(Double, D), - - DECLARE_GETSETNATIVE(Byte, B), - DECLARE_GETSETNATIVE(Short, S), - DECLARE_GETSETNATIVE(Char, C), - DECLARE_GETSETNATIVE(Int, I), - DECLARE_GETSETNATIVE(Long, J), - DECLARE_GETSETNATIVE(Float, F), - DECLARE_GETSETNATIVE(Double, D), - - {CC"getAddress", CC"("ADR")"ADR, FN_PTR(Unsafe_GetNativeAddress)}, - {CC"putAddress", CC"("ADR""ADR")V", FN_PTR(Unsafe_SetNativeAddress)}, - - {CC"allocateMemory", CC"(J)"ADR, FN_PTR(Unsafe_AllocateMemory)}, - {CC"reallocateMemory", CC"("ADR"J)"ADR, FN_PTR(Unsafe_ReallocateMemory)}, - {CC"freeMemory", CC"("ADR")V", FN_PTR(Unsafe_FreeMemory)}, - - {CC"fieldOffset", CC"("FLD")I", FN_PTR(Unsafe_FieldOffset)}, - {CC"staticFieldBase", CC"("CLS")"OBJ, FN_PTR(Unsafe_StaticFieldBaseFromClass)}, - {CC"ensureClassInitialized",CC"("CLS")V", FN_PTR(Unsafe_EnsureClassInitialized)}, - {CC"arrayBaseOffset", CC"("CLS")I", FN_PTR(Unsafe_ArrayBaseOffset)}, - {CC"arrayIndexScale", CC"("CLS")I", FN_PTR(Unsafe_ArrayIndexScale)}, - {CC"addressSize", CC"()I", FN_PTR(Unsafe_AddressSize)}, - {CC"pageSize", CC"()I", FN_PTR(Unsafe_PageSize)}, - - {CC"defineClass", CC"("DC0_Args")"CLS, FN_PTR(Unsafe_DefineClass0)}, - {CC"defineClass", CC"("DC_Args")"CLS, FN_PTR(Unsafe_DefineClass)}, - {CC"allocateInstance", CC"("CLS")"OBJ, FN_PTR(Unsafe_AllocateInstance)}, - {CC"throwException", CC"("THR")V", FN_PTR(Unsafe_ThrowException)} -}; - -// These are the methods prior to the JSR 166 changes in 1.5.0 -static JNINativeMethod methods_141[] = { - {CC"getObject", CC"("OBJ"J)"OBJ"", FN_PTR(Unsafe_GetObject)}, - {CC"putObject", CC"("OBJ"J"OBJ")V", FN_PTR(Unsafe_SetObject)}, - - DECLARE_GETSETOOP_141(Boolean, Z), - DECLARE_GETSETOOP_141(Byte, B), - DECLARE_GETSETOOP_141(Short, S), - DECLARE_GETSETOOP_141(Char, C), - DECLARE_GETSETOOP_141(Int, I), - DECLARE_GETSETOOP_141(Long, J), - DECLARE_GETSETOOP_141(Float, F), - DECLARE_GETSETOOP_141(Double, D), - - DECLARE_GETSETNATIVE(Byte, B), - DECLARE_GETSETNATIVE(Short, S), - DECLARE_GETSETNATIVE(Char, C), - DECLARE_GETSETNATIVE(Int, I), - DECLARE_GETSETNATIVE(Long, J), - DECLARE_GETSETNATIVE(Float, F), - DECLARE_GETSETNATIVE(Double, D), - - {CC"getAddress", CC"("ADR")"ADR, FN_PTR(Unsafe_GetNativeAddress)}, - {CC"putAddress", CC"("ADR""ADR")V", FN_PTR(Unsafe_SetNativeAddress)}, - - {CC"allocateMemory", CC"(J)"ADR, FN_PTR(Unsafe_AllocateMemory)}, - {CC"reallocateMemory", CC"("ADR"J)"ADR, FN_PTR(Unsafe_ReallocateMemory)}, - {CC"freeMemory", CC"("ADR")V", FN_PTR(Unsafe_FreeMemory)}, - - {CC"objectFieldOffset", CC"("FLD")J", FN_PTR(Unsafe_ObjectFieldOffset)}, - {CC"staticFieldOffset", CC"("FLD")J", FN_PTR(Unsafe_StaticFieldOffset)}, - {CC"staticFieldBase", CC"("FLD")"OBJ, FN_PTR(Unsafe_StaticFieldBaseFromField)}, - {CC"ensureClassInitialized",CC"("CLS")V", FN_PTR(Unsafe_EnsureClassInitialized)}, - {CC"arrayBaseOffset", CC"("CLS")I", FN_PTR(Unsafe_ArrayBaseOffset)}, - {CC"arrayIndexScale", CC"("CLS")I", FN_PTR(Unsafe_ArrayIndexScale)}, - {CC"addressSize", CC"()I", FN_PTR(Unsafe_AddressSize)}, - {CC"pageSize", CC"()I", FN_PTR(Unsafe_PageSize)}, - - {CC"defineClass", CC"("DC0_Args")"CLS, FN_PTR(Unsafe_DefineClass0)}, - {CC"defineClass", CC"("DC_Args")"CLS, FN_PTR(Unsafe_DefineClass)}, - {CC"allocateInstance", CC"("CLS")"OBJ, FN_PTR(Unsafe_AllocateInstance)}, - {CC"throwException", CC"("THR")V", FN_PTR(Unsafe_ThrowException)} - -}; - -// These are the methods prior to the JSR 166 changes in 1.6.0 -static JNINativeMethod methods_15[] = { +static JNINativeMethod methods[] = { {CC"getObject", CC"("OBJ"J)"OBJ"", FN_PTR(Unsafe_GetObject)}, {CC"putObject", CC"("OBJ"J"OBJ")V", FN_PTR(Unsafe_SetObject)}, {CC"getObjectVolatile",CC"("OBJ"J)"OBJ"", FN_PTR(Unsafe_GetObjectVolatile)}, {CC"putObjectVolatile",CC"("OBJ"J"OBJ")V", FN_PTR(Unsafe_SetObjectVolatile)}, + DECLARE_GETPUTOOP(Boolean, Z), + DECLARE_GETPUTOOP(Byte, B), + DECLARE_GETPUTOOP(Short, S), + DECLARE_GETPUTOOP(Char, C), + DECLARE_GETPUTOOP(Int, I), + DECLARE_GETPUTOOP(Long, J), + DECLARE_GETPUTOOP(Float, F), + DECLARE_GETPUTOOP(Double, D), - DECLARE_GETSETOOP(Boolean, Z), - DECLARE_GETSETOOP(Byte, B), - DECLARE_GETSETOOP(Short, S), - DECLARE_GETSETOOP(Char, C), - DECLARE_GETSETOOP(Int, I), - DECLARE_GETSETOOP(Long, J), - DECLARE_GETSETOOP(Float, F), - DECLARE_GETSETOOP(Double, D), - - DECLARE_GETSETNATIVE(Byte, B), - DECLARE_GETSETNATIVE(Short, S), - DECLARE_GETSETNATIVE(Char, C), - DECLARE_GETSETNATIVE(Int, I), - DECLARE_GETSETNATIVE(Long, J), - DECLARE_GETSETNATIVE(Float, F), - DECLARE_GETSETNATIVE(Double, D), - - {CC"getAddress", CC"("ADR")"ADR, FN_PTR(Unsafe_GetNativeAddress)}, - {CC"putAddress", CC"("ADR""ADR")V", FN_PTR(Unsafe_SetNativeAddress)}, - - {CC"allocateMemory", CC"(J)"ADR, FN_PTR(Unsafe_AllocateMemory)}, - {CC"reallocateMemory", CC"("ADR"J)"ADR, FN_PTR(Unsafe_ReallocateMemory)}, - {CC"freeMemory", CC"("ADR")V", FN_PTR(Unsafe_FreeMemory)}, - - {CC"objectFieldOffset", CC"("FLD")J", FN_PTR(Unsafe_ObjectFieldOffset)}, - {CC"staticFieldOffset", CC"("FLD")J", FN_PTR(Unsafe_StaticFieldOffset)}, - {CC"staticFieldBase", CC"("FLD")"OBJ, FN_PTR(Unsafe_StaticFieldBaseFromField)}, - {CC"ensureClassInitialized",CC"("CLS")V", FN_PTR(Unsafe_EnsureClassInitialized)}, - {CC"arrayBaseOffset", CC"("CLS")I", FN_PTR(Unsafe_ArrayBaseOffset)}, - {CC"arrayIndexScale", CC"("CLS")I", FN_PTR(Unsafe_ArrayIndexScale)}, - {CC"addressSize", CC"()I", FN_PTR(Unsafe_AddressSize)}, - {CC"pageSize", CC"()I", FN_PTR(Unsafe_PageSize)}, - - {CC"defineClass", CC"("DC0_Args")"CLS, FN_PTR(Unsafe_DefineClass0)}, - {CC"defineClass", CC"("DC_Args")"CLS, FN_PTR(Unsafe_DefineClass)}, - {CC"allocateInstance", CC"("CLS")"OBJ, FN_PTR(Unsafe_AllocateInstance)}, - {CC"throwException", CC"("THR")V", FN_PTR(Unsafe_ThrowException)}, - {CC"compareAndSwapObject", CC"("OBJ"J"OBJ""OBJ")Z", FN_PTR(Unsafe_CompareAndSwapObject)}, - {CC"compareAndSwapInt", CC"("OBJ"J""I""I"")Z", FN_PTR(Unsafe_CompareAndSwapInt)}, - {CC"compareAndSwapLong", CC"("OBJ"J""J""J"")Z", FN_PTR(Unsafe_CompareAndSwapLong)}, - {CC"park", CC"(ZJ)V", FN_PTR(Unsafe_Park)}, - {CC"unpark", CC"("OBJ")V", FN_PTR(Unsafe_Unpark)} - -}; - -// These are the methods for 1.6.0 and 1.7.0 -static JNINativeMethod methods_16[] = { - {CC"getObject", CC"("OBJ"J)"OBJ"", FN_PTR(Unsafe_GetObject)}, - {CC"putObject", CC"("OBJ"J"OBJ")V", FN_PTR(Unsafe_SetObject)}, - {CC"getObjectVolatile",CC"("OBJ"J)"OBJ"", FN_PTR(Unsafe_GetObjectVolatile)}, - {CC"putObjectVolatile",CC"("OBJ"J"OBJ")V", FN_PTR(Unsafe_SetObjectVolatile)}, - - DECLARE_GETSETOOP(Boolean, Z), - DECLARE_GETSETOOP(Byte, B), - DECLARE_GETSETOOP(Short, S), - DECLARE_GETSETOOP(Char, C), - DECLARE_GETSETOOP(Int, I), - DECLARE_GETSETOOP(Long, J), - DECLARE_GETSETOOP(Float, F), - DECLARE_GETSETOOP(Double, D), - - DECLARE_GETSETNATIVE(Byte, B), - DECLARE_GETSETNATIVE(Short, S), - DECLARE_GETSETNATIVE(Char, C), - DECLARE_GETSETNATIVE(Int, I), - DECLARE_GETSETNATIVE(Long, J), - DECLARE_GETSETNATIVE(Float, F), - DECLARE_GETSETNATIVE(Double, D), - - {CC"getAddress", CC"("ADR")"ADR, FN_PTR(Unsafe_GetNativeAddress)}, - {CC"putAddress", CC"("ADR""ADR")V", FN_PTR(Unsafe_SetNativeAddress)}, - - {CC"allocateMemory", CC"(J)"ADR, FN_PTR(Unsafe_AllocateMemory)}, - {CC"reallocateMemory", CC"("ADR"J)"ADR, FN_PTR(Unsafe_ReallocateMemory)}, - {CC"freeMemory", CC"("ADR")V", FN_PTR(Unsafe_FreeMemory)}, - - {CC"objectFieldOffset", CC"("FLD")J", FN_PTR(Unsafe_ObjectFieldOffset)}, - {CC"staticFieldOffset", CC"("FLD")J", FN_PTR(Unsafe_StaticFieldOffset)}, - {CC"staticFieldBase", CC"("FLD")"OBJ, FN_PTR(Unsafe_StaticFieldBaseFromField)}, - {CC"ensureClassInitialized",CC"("CLS")V", FN_PTR(Unsafe_EnsureClassInitialized)}, - {CC"arrayBaseOffset", CC"("CLS")I", FN_PTR(Unsafe_ArrayBaseOffset)}, - {CC"arrayIndexScale", CC"("CLS")I", FN_PTR(Unsafe_ArrayIndexScale)}, - {CC"addressSize", CC"()I", FN_PTR(Unsafe_AddressSize)}, - {CC"pageSize", CC"()I", FN_PTR(Unsafe_PageSize)}, - - {CC"defineClass", CC"("DC0_Args")"CLS, FN_PTR(Unsafe_DefineClass0)}, - {CC"defineClass", CC"("DC_Args")"CLS, FN_PTR(Unsafe_DefineClass)}, - {CC"allocateInstance", CC"("CLS")"OBJ, FN_PTR(Unsafe_AllocateInstance)}, - {CC"throwException", CC"("THR")V", FN_PTR(Unsafe_ThrowException)}, - {CC"compareAndSwapObject", CC"("OBJ"J"OBJ""OBJ")Z", FN_PTR(Unsafe_CompareAndSwapObject)}, - {CC"compareAndSwapInt", CC"("OBJ"J""I""I"")Z", FN_PTR(Unsafe_CompareAndSwapInt)}, - {CC"compareAndSwapLong", CC"("OBJ"J""J""J"")Z", FN_PTR(Unsafe_CompareAndSwapLong)}, - {CC"putOrderedObject", CC"("OBJ"J"OBJ")V", FN_PTR(Unsafe_SetOrderedObject)}, - {CC"putOrderedInt", CC"("OBJ"JI)V", FN_PTR(Unsafe_SetOrderedInt)}, - {CC"putOrderedLong", CC"("OBJ"JJ)V", FN_PTR(Unsafe_SetOrderedLong)}, - {CC"park", CC"(ZJ)V", FN_PTR(Unsafe_Park)}, - {CC"unpark", CC"("OBJ")V", FN_PTR(Unsafe_Unpark)} -}; - -// These are the methods for 1.8.0 -static JNINativeMethod methods_18[] = { - {CC"getObject", CC"("OBJ"J)"OBJ"", FN_PTR(Unsafe_GetObject)}, - {CC"putObject", CC"("OBJ"J"OBJ")V", FN_PTR(Unsafe_SetObject)}, - {CC"getObjectVolatile",CC"("OBJ"J)"OBJ"", FN_PTR(Unsafe_GetObjectVolatile)}, - {CC"putObjectVolatile",CC"("OBJ"J"OBJ")V", FN_PTR(Unsafe_SetObjectVolatile)}, - - DECLARE_GETSETOOP(Boolean, Z), - DECLARE_GETSETOOP(Byte, B), - DECLARE_GETSETOOP(Short, S), - DECLARE_GETSETOOP(Char, C), - DECLARE_GETSETOOP(Int, I), - DECLARE_GETSETOOP(Long, J), - DECLARE_GETSETOOP(Float, F), - DECLARE_GETSETOOP(Double, D), - - DECLARE_GETSETNATIVE(Byte, B), - DECLARE_GETSETNATIVE(Short, S), - DECLARE_GETSETNATIVE(Char, C), - DECLARE_GETSETNATIVE(Int, I), - DECLARE_GETSETNATIVE(Long, J), - DECLARE_GETSETNATIVE(Float, F), - DECLARE_GETSETNATIVE(Double, D), + DECLARE_GETPUTNATIVE(Byte, B), + DECLARE_GETPUTNATIVE(Short, S), + DECLARE_GETPUTNATIVE(Char, C), + DECLARE_GETPUTNATIVE(Int, I), + DECLARE_GETPUTNATIVE(Long, J), + DECLARE_GETPUTNATIVE(Float, F), + DECLARE_GETPUTNATIVE(Double, D), {CC"getAddress", CC"("ADR")"ADR, FN_PTR(Unsafe_GetNativeAddress)}, {CC"putAddress", CC"("ADR""ADR")V", FN_PTR(Unsafe_SetNativeAddress)}, @@ -1533,39 +1245,17 @@ static JNINativeMethod methods_18[] = { {CC"putOrderedInt", CC"("OBJ"JI)V", FN_PTR(Unsafe_SetOrderedInt)}, {CC"putOrderedLong", CC"("OBJ"JJ)V", FN_PTR(Unsafe_SetOrderedLong)}, {CC"park", CC"(ZJ)V", FN_PTR(Unsafe_Park)}, - {CC"unpark", CC"("OBJ")V", FN_PTR(Unsafe_Unpark)} -}; + {CC"unpark", CC"("OBJ")V", FN_PTR(Unsafe_Unpark)}, -JNINativeMethod loadavg_method[] = { - {CC"getLoadAverage", CC"([DI)I", FN_PTR(Unsafe_Loadavg)} -}; + {CC"getLoadAverage", CC"([DI)I", FN_PTR(Unsafe_Loadavg)}, -JNINativeMethod prefetch_methods[] = { - {CC"prefetchRead", CC"("OBJ"J)V", FN_PTR(Unsafe_PrefetchRead)}, - {CC"prefetchWrite", CC"("OBJ"J)V", FN_PTR(Unsafe_PrefetchWrite)}, - {CC"prefetchReadStatic", CC"("OBJ"J)V", FN_PTR(Unsafe_PrefetchRead)}, - {CC"prefetchWriteStatic",CC"("OBJ"J)V", FN_PTR(Unsafe_PrefetchWrite)} -}; + {CC"copyMemory", CC"("OBJ"J"OBJ"JJ)V", FN_PTR(Unsafe_CopyMemory)}, + {CC"setMemory", CC"("OBJ"JJB)V", FN_PTR(Unsafe_SetMemory)}, -JNINativeMethod memcopy_methods_17[] = { - {CC"copyMemory", CC"("OBJ"J"OBJ"JJ)V", FN_PTR(Unsafe_CopyMemory2)}, - {CC"setMemory", CC"("OBJ"JJB)V", FN_PTR(Unsafe_SetMemory2)} -}; - -JNINativeMethod memcopy_methods_15[] = { - {CC"setMemory", CC"("ADR"JB)V", FN_PTR(Unsafe_SetMemory)}, - {CC"copyMemory", CC"("ADR ADR"J)V", FN_PTR(Unsafe_CopyMemory)} -}; - -JNINativeMethod anonk_methods[] = { {CC"defineAnonymousClass", CC"("DAC_Args")"CLS, FN_PTR(Unsafe_DefineAnonymousClass)}, -}; -JNINativeMethod lform_methods[] = { {CC"shouldBeInitialized",CC"("CLS")Z", FN_PTR(Unsafe_ShouldBeInitialized)}, -}; -JNINativeMethod fence_methods[] = { {CC"loadFence", CC"()V", FN_PTR(Unsafe_LoadFence)}, {CC"storeFence", CC"()V", FN_PTR(Unsafe_StoreFence)}, {CC"fullFence", CC"()V", FN_PTR(Unsafe_FullFence)}, @@ -1578,35 +1268,13 @@ JNINativeMethod fence_methods[] = { #undef LANG #undef OBJ #undef CLS -#undef CTR #undef FLD -#undef MTH #undef THR -#undef DC0_Args #undef DC_Args +#undef DAC_Args -#undef DECLARE_GETSETOOP -#undef DECLARE_GETSETNATIVE - - -/** - * Helper method to register native methods. - */ -static bool register_natives(const char* message, JNIEnv* env, jclass clazz, const JNINativeMethod* methods, jint nMethods) { - int status = env->RegisterNatives(clazz, methods, nMethods); - if (status < 0 || env->ExceptionOccurred()) { - if (PrintMiscellaneous && (Verbose || WizardMode)) { - tty->print_cr("Unsafe: failed registering %s", message); - } - env->ExceptionClear(); - return false; - } else { - if (PrintMiscellaneous && (Verbose || WizardMode)) { - tty->print_cr("Unsafe: successfully registered %s", message); - } - return true; - } -} +#undef DECLARE_GETPUTOOP +#undef DECLARE_GETPUTNATIVE // This one function is exported, used by NativeLookup. @@ -1614,57 +1282,12 @@ static bool register_natives(const char* message, JNIEnv* env, jclass clazz, con // The optimizer looks at names and signatures to recognize // individual functions. -JVM_ENTRY(void, JVM_RegisterUnsafeMethods(JNIEnv *env, jclass unsafecls)) +JVM_ENTRY(void, JVM_RegisterUnsafeMethods(JNIEnv *env, jclass unsafeclass)) UnsafeWrapper("JVM_RegisterUnsafeMethods"); { ThreadToNativeFromVM ttnfv(thread); - // Unsafe methods - { - bool success = false; - // We need to register the 1.6 methods first because the 1.8 methods would register fine on 1.7 and 1.6 - if (!success) { - success = register_natives("1.6 methods", env, unsafecls, methods_16, sizeof(methods_16)/sizeof(JNINativeMethod)); - } - if (!success) { - success = register_natives("1.8 methods", env, unsafecls, methods_18, sizeof(methods_18)/sizeof(JNINativeMethod)); - } - if (!success) { - success = register_natives("1.5 methods", env, unsafecls, methods_15, sizeof(methods_15)/sizeof(JNINativeMethod)); - } - if (!success) { - success = register_natives("1.4.1 methods", env, unsafecls, methods_141, sizeof(methods_141)/sizeof(JNINativeMethod)); - } - if (!success) { - success = register_natives("1.4.0 methods", env, unsafecls, methods_140, sizeof(methods_140)/sizeof(JNINativeMethod)); - } - guarantee(success, "register unsafe natives"); - } - - // Unsafe.getLoadAverage - register_natives("1.6 loadavg method", env, unsafecls, loadavg_method, sizeof(loadavg_method)/sizeof(JNINativeMethod)); - - // Prefetch methods - register_natives("1.6 prefetch methods", env, unsafecls, prefetch_methods, sizeof(prefetch_methods)/sizeof(JNINativeMethod)); - - // Memory copy methods - { - bool success = false; - if (!success) { - success = register_natives("1.7 memory copy methods", env, unsafecls, memcopy_methods_17, sizeof(memcopy_methods_17)/sizeof(JNINativeMethod)); - } - if (!success) { - success = register_natives("1.5 memory copy methods", env, unsafecls, memcopy_methods_15, sizeof(memcopy_methods_15)/sizeof(JNINativeMethod)); - } - } - - // Unsafe.defineAnonymousClass - register_natives("1.7 define anonymous class method", env, unsafecls, anonk_methods, sizeof(anonk_methods)/sizeof(JNINativeMethod)); - - // Unsafe.shouldBeInitialized - register_natives("1.7 LambdaForm support", env, unsafecls, lform_methods, sizeof(lform_methods)/sizeof(JNINativeMethod)); - - // Fence methods - register_natives("1.8 fence methods", env, unsafecls, fence_methods, sizeof(fence_methods)/sizeof(JNINativeMethod)); + int ok = env->RegisterNatives(unsafeclass, methods, sizeof(methods)/sizeof(JNINativeMethod)); + guarantee(ok == 0, "register unsafe natives"); } JVM_END diff --git a/hotspot/test/runtime/Unsafe/FieldOffset.java b/hotspot/test/runtime/Unsafe/FieldOffset.java index 7eb609f8da2..72b168ddd7e 100644 --- a/hotspot/test/runtime/Unsafe/FieldOffset.java +++ b/hotspot/test/runtime/Unsafe/FieldOffset.java @@ -37,18 +37,31 @@ import static com.oracle.java.testlibrary.Asserts.*; public class FieldOffset { public static void main(String args[]) throws Exception { Unsafe unsafe = Utils.getUnsafe(); - Field fields[] = Test.class.getDeclaredFields(); + Field[] fields = Test.class.getDeclaredFields(); for (int i = 0; i < fields.length; i++) { - int offset = unsafe.fieldOffset(fields[i]); + long offset = unsafe.objectFieldOffset(fields[i]); // Ensure we got a valid offset value back assertNotEquals(offset, unsafe.INVALID_FIELD_OFFSET); // Make sure the field offset is unique for (int j = 0; j < i; j++) { - assertNotEquals(offset, unsafe.fieldOffset(fields[j])); + assertNotEquals(offset, unsafe.objectFieldOffset(fields[j])); } } + + fields = StaticTest.class.getDeclaredFields(); + for (int i = 0; i < fields.length; i++) { + long offset = unsafe.staticFieldOffset(fields[i]); + // Ensure we got a valid offset value back + assertNotEquals(offset, unsafe.INVALID_FIELD_OFFSET); + + // Make sure the field offset is unique + for (int j = 0; j < i; j++) { + assertNotEquals(offset, unsafe.staticFieldOffset(fields[j])); + } + } + } class Test { @@ -62,4 +75,17 @@ public class FieldOffset { Object objectField; short shortField; } + + static class StaticTest { + static boolean booleanField; + static byte byteField; + static char charField; + static double doubleField; + static float floatField; + static int intField; + static long longField; + static Object objectField; + static short shortField; + } + } diff --git a/hotspot/test/runtime/Unsafe/GetPutBoolean.java b/hotspot/test/runtime/Unsafe/GetPutBoolean.java index d7b64f83a31..93f0b3df053 100644 --- a/hotspot/test/runtime/Unsafe/GetPutBoolean.java +++ b/hotspot/test/runtime/Unsafe/GetPutBoolean.java @@ -39,7 +39,7 @@ public class GetPutBoolean { Test t = new Test(); Field field = Test.class.getField("b1"); - int offset = unsafe.fieldOffset(field); + long offset = unsafe.objectFieldOffset(field); assertEquals(false, unsafe.getBoolean(t, offset)); unsafe.putBoolean(t, offset, true); assertEquals(true, unsafe.getBoolean(t, offset)); diff --git a/hotspot/test/runtime/Unsafe/GetPutByte.java b/hotspot/test/runtime/Unsafe/GetPutByte.java index 016a2a94049..44546f91a27 100644 --- a/hotspot/test/runtime/Unsafe/GetPutByte.java +++ b/hotspot/test/runtime/Unsafe/GetPutByte.java @@ -39,7 +39,7 @@ public class GetPutByte { Test t = new Test(); Field field = Test.class.getField("b"); - int offset = unsafe.fieldOffset(field); + long offset = unsafe.objectFieldOffset(field); assertEquals((byte)0, unsafe.getByte(t, offset)); unsafe.putByte(t, offset, (byte)1); assertEquals((byte)1, unsafe.getByte(t, offset)); diff --git a/hotspot/test/runtime/Unsafe/GetPutChar.java b/hotspot/test/runtime/Unsafe/GetPutChar.java index 83dd737f218..a0c2a0e0310 100644 --- a/hotspot/test/runtime/Unsafe/GetPutChar.java +++ b/hotspot/test/runtime/Unsafe/GetPutChar.java @@ -39,7 +39,7 @@ public class GetPutChar { Test t = new Test(); Field field = Test.class.getField("c"); - int offset = unsafe.fieldOffset(field); + long offset = unsafe.objectFieldOffset(field); assertEquals('\u0000', unsafe.getChar(t, offset)); unsafe.putChar(t, offset, '\u0001'); assertEquals('\u0001', unsafe.getChar(t, offset)); diff --git a/hotspot/test/runtime/Unsafe/GetPutDouble.java b/hotspot/test/runtime/Unsafe/GetPutDouble.java index dca8d3038c9..17b2bdfe9e1 100644 --- a/hotspot/test/runtime/Unsafe/GetPutDouble.java +++ b/hotspot/test/runtime/Unsafe/GetPutDouble.java @@ -39,7 +39,7 @@ public class GetPutDouble { Test t = new Test(); Field field = Test.class.getField("d"); - int offset = unsafe.fieldOffset(field); + long offset = unsafe.objectFieldOffset(field); assertEquals(-1.0, unsafe.getDouble(t, offset)); unsafe.putDouble(t, offset, 0.0); assertEquals(0.0, unsafe.getDouble(t, offset)); diff --git a/hotspot/test/runtime/Unsafe/GetPutFloat.java b/hotspot/test/runtime/Unsafe/GetPutFloat.java index 64125671721..239bf1078f5 100644 --- a/hotspot/test/runtime/Unsafe/GetPutFloat.java +++ b/hotspot/test/runtime/Unsafe/GetPutFloat.java @@ -39,7 +39,7 @@ public class GetPutFloat { Test t = new Test(); Field field = Test.class.getField("f"); - int offset = unsafe.fieldOffset(field); + long offset = unsafe.objectFieldOffset(field); assertEquals(-1.0f, unsafe.getFloat(t, offset)); unsafe.putFloat(t, offset, 0.0f); assertEquals(0.0f, unsafe.getFloat(t, offset)); diff --git a/hotspot/test/runtime/Unsafe/GetPutInt.java b/hotspot/test/runtime/Unsafe/GetPutInt.java index 9239c073bff..e93aeb8b2ac 100644 --- a/hotspot/test/runtime/Unsafe/GetPutInt.java +++ b/hotspot/test/runtime/Unsafe/GetPutInt.java @@ -38,7 +38,7 @@ public class GetPutInt { Test t = new Test(); Field field = Test.class.getField("i"); - int offset = unsafe.fieldOffset(field); + long offset = unsafe.objectFieldOffset(field); assertEquals(-1, unsafe.getInt(t, offset)); unsafe.putInt(t, offset, 0); assertEquals(0, unsafe.getInt(t, offset)); diff --git a/hotspot/test/runtime/Unsafe/GetPutLong.java b/hotspot/test/runtime/Unsafe/GetPutLong.java index ae8fe5f3f4d..2ea4a196e4c 100644 --- a/hotspot/test/runtime/Unsafe/GetPutLong.java +++ b/hotspot/test/runtime/Unsafe/GetPutLong.java @@ -39,7 +39,7 @@ public class GetPutLong { Test t = new Test(); Field field = Test.class.getField("l"); - int offset = unsafe.fieldOffset(field); + long offset = unsafe.objectFieldOffset(field); assertEquals(-1L, unsafe.getLong(t, offset)); unsafe.putLong(t, offset, 0L); assertEquals(0L, unsafe.getLong(t, offset)); diff --git a/hotspot/test/runtime/Unsafe/GetPutObject.java b/hotspot/test/runtime/Unsafe/GetPutObject.java index 03813acf087..bd186bcf307 100644 --- a/hotspot/test/runtime/Unsafe/GetPutObject.java +++ b/hotspot/test/runtime/Unsafe/GetPutObject.java @@ -40,7 +40,7 @@ public class GetPutObject { Object o = new Object(); Field field = Test.class.getField("o"); - int offset = unsafe.fieldOffset(field); + long offset = unsafe.objectFieldOffset(field); assertEquals(t.o, unsafe.getObject(t, offset)); unsafe.putObject(t, offset, o); diff --git a/hotspot/test/runtime/Unsafe/GetPutShort.java b/hotspot/test/runtime/Unsafe/GetPutShort.java index 263cde28f3c..d89fcc26d42 100644 --- a/hotspot/test/runtime/Unsafe/GetPutShort.java +++ b/hotspot/test/runtime/Unsafe/GetPutShort.java @@ -39,7 +39,7 @@ public class GetPutShort { Test t = new Test(); Field field = Test.class.getField("s"); - int offset = unsafe.fieldOffset(field); + long offset = unsafe.objectFieldOffset(field); assertEquals((short)-1, unsafe.getShort(t, offset)); unsafe.putShort(t, offset, (short)0); assertEquals((short)0, unsafe.getShort(t, offset)); From 811df313ff13ba02eb43d077bb01c85cc7a91447 Mon Sep 17 00:00:00 2001 From: Harold Seigel Date: Tue, 10 Feb 2015 09:25:00 -0500 Subject: [PATCH 080/116] 8072694: Need errno info when CDS archive creation fails Add errno output to error message when CDS archive creation fails Reviewed-by: dholmes, lfoltan --- hotspot/src/share/vm/memory/filemap.cpp | 5 +++-- 1 file changed, 3 insertions(+), 2 deletions(-) diff --git a/hotspot/src/share/vm/memory/filemap.cpp b/hotspot/src/share/vm/memory/filemap.cpp index cbe369f327e..adba08d0cf6 100644 --- a/hotspot/src/share/vm/memory/filemap.cpp +++ b/hotspot/src/share/vm/memory/filemap.cpp @@ -1,5 +1,5 @@ /* - * Copyright (c) 2003, 2014, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2003, 2015, 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 @@ -388,7 +388,8 @@ void FileMapInfo::open_for_write() { remove(_full_path); int fd = open(_full_path, O_RDWR | O_CREAT | O_TRUNC | O_BINARY, 0444); if (fd < 0) { - fail_stop("Unable to create shared archive file %s.", _full_path); + fail_stop("Unable to create shared archive file %s: (%s).", _full_path, + strerror(errno)); } _fd = fd; _file_offset = 0; From 8df6ac1794db1de0c456866004704fb3a38afe04 Mon Sep 17 00:00:00 2001 From: Coleen Phillimore Date: Tue, 10 Feb 2015 15:10:47 -0500 Subject: [PATCH 081/116] 8068451: Kitchensink fails with assert(_size >= sz) failed: Negative size Need ThreadCritical lock around chunk pool cleaning and copying for snapshot Reviewed-by: lfoltan, gtriantafill, hseigel --- hotspot/src/share/vm/memory/allocation.cpp | 41 ++++++++++--------- .../src/share/vm/services/mallocSiteTable.cpp | 2 +- .../src/share/vm/services/mallocTracker.cpp | 2 +- .../src/share/vm/services/mallocTracker.hpp | 5 +++ hotspot/src/share/vm/services/nmtDCmd.cpp | 6 +-- 5 files changed, 31 insertions(+), 25 deletions(-) diff --git a/hotspot/src/share/vm/memory/allocation.cpp b/hotspot/src/share/vm/memory/allocation.cpp index be721091dd7..4e2056861f6 100644 --- a/hotspot/src/share/vm/memory/allocation.cpp +++ b/hotspot/src/share/vm/memory/allocation.cpp @@ -1,5 +1,5 @@ /* - * Copyright (c) 1997, 2014, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 1997, 2015, 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 @@ -275,31 +275,30 @@ class ChunkPool: public CHeapObj { Chunk* cur = NULL; Chunk* next; { - // if we have more than n chunks, free all of them - ThreadCritical tc; - if (_num_chunks > n) { - // free chunks at end of queue, for better locality + // if we have more than n chunks, free all of them + ThreadCritical tc; + if (_num_chunks > n) { + // free chunks at end of queue, for better locality cur = _first; - for (size_t i = 0; i < (n - 1) && cur != NULL; i++) cur = cur->next(); + for (size_t i = 0; i < (n - 1) && cur != NULL; i++) cur = cur->next(); - if (cur != NULL) { + if (cur != NULL) { next = cur->next(); - cur->set_next(NULL); - cur = next; + cur->set_next(NULL); + cur = next; - _num_chunks = n; + // Free all remaining chunks while in ThreadCritical lock + // so NMT adjustment is stable. + while(cur != NULL) { + next = cur->next(); + os::free(cur); + _num_chunks--; + cur = next; + } } } } - - // Free all remaining chunks, outside of ThreadCritical - // to avoid deadlock with NMT - while(cur != NULL) { - next = cur->next(); - os::free(cur); - cur = next; - } - } + } // Accessors to preallocated pool's static ChunkPool* large_pool() { assert(_large_pool != NULL, "must be initialized"); return _large_pool; } @@ -384,7 +383,9 @@ void Chunk::operator delete(void* p) { case Chunk::medium_size: ChunkPool::medium_pool()->free(c); break; case Chunk::init_size: ChunkPool::small_pool()->free(c); break; case Chunk::tiny_size: ChunkPool::tiny_pool()->free(c); break; - default: os::free(c); + default: + ThreadCritical tc; // Free chunks under TC lock so that NMT adjustment is stable. + os::free(c); } } diff --git a/hotspot/src/share/vm/services/mallocSiteTable.cpp b/hotspot/src/share/vm/services/mallocSiteTable.cpp index ec11cfabe69..59339a17750 100644 --- a/hotspot/src/share/vm/services/mallocSiteTable.cpp +++ b/hotspot/src/share/vm/services/mallocSiteTable.cpp @@ -136,7 +136,7 @@ bool MallocSiteTable::walk(MallocSiteWalker* walker) { MallocSite* MallocSiteTable::lookup_or_add(const NativeCallStack& key, size_t* bucket_idx, size_t* pos_idx) { int index = hash_to_index(key.hash()); - assert(index >= 0, "Negative index"); + assert(index >= 0, err_msg("Negative index %d", index)); *bucket_idx = (size_t)index; *pos_idx = 0; diff --git a/hotspot/src/share/vm/services/mallocTracker.cpp b/hotspot/src/share/vm/services/mallocTracker.cpp index dc4f08f94a6..ea399401115 100644 --- a/hotspot/src/share/vm/services/mallocTracker.cpp +++ b/hotspot/src/share/vm/services/mallocTracker.cpp @@ -52,7 +52,7 @@ size_t MallocMemorySnapshot::total_arena() const { } // Make adjustment by subtracting chunks used by arenas -// from total chunks to get total free chunck size +// from total chunks to get total free chunk size void MallocMemorySnapshot::make_adjustment() { size_t arena_size = total_arena(); int chunk_idx = NMTUtil::flag_to_index(mtChunk); diff --git a/hotspot/src/share/vm/services/mallocTracker.hpp b/hotspot/src/share/vm/services/mallocTracker.hpp index 3c61aa4327a..3020b3148fe 100644 --- a/hotspot/src/share/vm/services/mallocTracker.hpp +++ b/hotspot/src/share/vm/services/mallocTracker.hpp @@ -29,6 +29,7 @@ #include "memory/allocation.hpp" #include "runtime/atomic.hpp" +#include "runtime/threadCritical.hpp" #include "services/nmtCommon.hpp" #include "utilities/nativeCallStack.hpp" @@ -164,6 +165,10 @@ class MallocMemorySnapshot : public ResourceObj { } void copy_to(MallocMemorySnapshot* s) { + // Need to make sure that mtChunks don't get deallocated while the + // copy is going on, because their size is adjusted using this + // buffer in make_adjustment(). + ThreadCritical tc; s->_tracking_header = _tracking_header; for (int index = 0; index < mt_number_of_types; index ++) { s->_malloc[index] = _malloc[index]; diff --git a/hotspot/src/share/vm/services/nmtDCmd.cpp b/hotspot/src/share/vm/services/nmtDCmd.cpp index fcad784f586..3af8b51106d 100644 --- a/hotspot/src/share/vm/services/nmtDCmd.cpp +++ b/hotspot/src/share/vm/services/nmtDCmd.cpp @@ -1,5 +1,5 @@ /* - * Copyright (c) 2012, 2014, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2012, 2015, 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 @@ -137,8 +137,8 @@ void NMTDCmd::execute(DCmdSource source, TRAPS) { } } else if (_detail_diff.value()) { if (!check_detail_tracking_level(output())) { - return; - } + return; + } MemBaseline& baseline = MemTracker::get_baseline(); if (baseline.baseline_type() == MemBaseline::Detail_baselined) { report_diff(false, scale_unit); From c002e71565347f68c49dc76d4a41b3049ec9faea Mon Sep 17 00:00:00 2001 From: Paul Sandoz Date: Tue, 10 Feb 2015 21:32:05 +0100 Subject: [PATCH 082/116] 8068977: Remove unused sun.misc.Unsafe prefetch intrinsic support Reviewed-by: kvn, vlivanov --- hotspot/src/cpu/ppc/vm/ppc.ad | 52 ---------- .../cpu/sparc/vm/c1_LIRAssembler_sparc.cpp | 22 +---- hotspot/src/cpu/sparc/vm/sparc.ad | 28 +----- .../src/cpu/x86/vm/c1_LIRAssembler_x86.cpp | 46 +-------- hotspot/src/cpu/x86/vm/globals_x86.hpp | 5 +- hotspot/src/cpu/x86/vm/vm_version_x86.cpp | 8 +- hotspot/src/cpu/x86/vm/x86_32.ad | 98 +------------------ hotspot/src/cpu/x86/vm/x86_64.ad | 65 +----------- hotspot/src/share/vm/adlc/formssel.cpp | 6 +- hotspot/src/share/vm/c1/c1_Canonicalizer.cpp | 4 +- hotspot/src/share/vm/c1/c1_Canonicalizer.hpp | 4 +- hotspot/src/share/vm/c1/c1_GraphBuilder.cpp | 28 +----- hotspot/src/share/vm/c1/c1_GraphBuilder.hpp | 3 +- hotspot/src/share/vm/c1/c1_Instruction.hpp | 35 +------ .../src/share/vm/c1/c1_InstructionPrinter.cpp | 12 +-- .../src/share/vm/c1/c1_InstructionPrinter.hpp | 4 +- hotspot/src/share/vm/c1/c1_LIR.cpp | 9 -- hotspot/src/share/vm/c1/c1_LIR.hpp | 6 +- hotspot/src/share/vm/c1/c1_LIRAssembler.cpp | 8 -- hotspot/src/share/vm/c1/c1_LIRAssembler.hpp | 5 +- hotspot/src/share/vm/c1/c1_LIRGenerator.cpp | 31 +----- hotspot/src/share/vm/c1/c1_LIRGenerator.hpp | 6 +- hotspot/src/share/vm/c1/c1_Optimizer.cpp | 6 +- .../share/vm/c1/c1_RangeCheckElimination.hpp | 4 +- hotspot/src/share/vm/c1/c1_ValueMap.hpp | 4 +- hotspot/src/share/vm/classfile/vmSymbols.hpp | 16 +-- hotspot/src/share/vm/opto/classes.hpp | 4 +- hotspot/src/share/vm/opto/library_call.cpp | 75 +------------- hotspot/src/share/vm/opto/matcher.cpp | 4 +- hotspot/src/share/vm/opto/memnode.hpp | 22 +---- hotspot/src/share/vm/runtime/vmStructs.cpp | 2 - 31 files changed, 31 insertions(+), 591 deletions(-) diff --git a/hotspot/src/cpu/ppc/vm/ppc.ad b/hotspot/src/cpu/ppc/vm/ppc.ad index a9d576c5014..3808eabd27e 100644 --- a/hotspot/src/cpu/ppc/vm/ppc.ad +++ b/hotspot/src/cpu/ppc/vm/ppc.ad @@ -6365,58 +6365,6 @@ instruct loadConD_Ex(regD dst, immD src) %{ // Prefetch instructions. // Must be safe to execute with invalid address (cannot fault). -instruct prefetchr(indirectMemory mem, iRegLsrc src) %{ - match(PrefetchRead (AddP mem src)); - ins_cost(MEMORY_REF_COST); - - format %{ "PREFETCH $mem, 0, $src \t// Prefetch read-many" %} - size(4); - ins_encode %{ - // TODO: PPC port $archOpcode(ppc64Opcode_dcbt); - __ dcbt($src$$Register, $mem$$base$$Register); - %} - ins_pipe(pipe_class_memory); -%} - -instruct prefetchr_no_offset(indirectMemory mem) %{ - match(PrefetchRead mem); - ins_cost(MEMORY_REF_COST); - - format %{ "PREFETCH $mem" %} - size(4); - ins_encode %{ - // TODO: PPC port $archOpcode(ppc64Opcode_dcbt); - __ dcbt($mem$$base$$Register); - %} - ins_pipe(pipe_class_memory); -%} - -instruct prefetchw(indirectMemory mem, iRegLsrc src) %{ - match(PrefetchWrite (AddP mem src)); - ins_cost(MEMORY_REF_COST); - - format %{ "PREFETCH $mem, 2, $src \t// Prefetch write-many (and read)" %} - size(4); - ins_encode %{ - // TODO: PPC port $archOpcode(ppc64Opcode_dcbtst); - __ dcbtst($src$$Register, $mem$$base$$Register); - %} - ins_pipe(pipe_class_memory); -%} - -instruct prefetchw_no_offset(indirectMemory mem) %{ - match(PrefetchWrite mem); - ins_cost(MEMORY_REF_COST); - - format %{ "PREFETCH $mem" %} - size(4); - ins_encode %{ - // TODO: PPC port $archOpcode(ppc64Opcode_dcbtst); - __ dcbtst($mem$$base$$Register); - %} - ins_pipe(pipe_class_memory); -%} - // Special prefetch versions which use the dcbz instruction. instruct prefetch_alloc_zero(indirectMemory mem, iRegLsrc src) %{ match(PrefetchAllocation (AddP mem src)); diff --git a/hotspot/src/cpu/sparc/vm/c1_LIRAssembler_sparc.cpp b/hotspot/src/cpu/sparc/vm/c1_LIRAssembler_sparc.cpp index 0c733a7b1b9..69d5987a40d 100644 --- a/hotspot/src/cpu/sparc/vm/c1_LIRAssembler_sparc.cpp +++ b/hotspot/src/cpu/sparc/vm/c1_LIRAssembler_sparc.cpp @@ -1,5 +1,5 @@ /* - * Copyright (c) 2000, 2013, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2000, 2015, 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 @@ -1436,26 +1436,6 @@ void LIR_Assembler::mem2reg(LIR_Opr src_opr, LIR_Opr dest, BasicType type, } -void LIR_Assembler::prefetchr(LIR_Opr src) { - LIR_Address* addr = src->as_address_ptr(); - Address from_addr = as_Address(addr); - - if (VM_Version::has_v9()) { - __ prefetch(from_addr, Assembler::severalReads); - } -} - - -void LIR_Assembler::prefetchw(LIR_Opr src) { - LIR_Address* addr = src->as_address_ptr(); - Address from_addr = as_Address(addr); - - if (VM_Version::has_v9()) { - __ prefetch(from_addr, Assembler::severalWritesAndPossiblyReads); - } -} - - void LIR_Assembler::stack2reg(LIR_Opr src, LIR_Opr dest, BasicType type) { Address addr; if (src->is_single_word()) { diff --git a/hotspot/src/cpu/sparc/vm/sparc.ad b/hotspot/src/cpu/sparc/vm/sparc.ad index 739cc9612bd..c344c216b37 100644 --- a/hotspot/src/cpu/sparc/vm/sparc.ad +++ b/hotspot/src/cpu/sparc/vm/sparc.ad @@ -889,8 +889,6 @@ void emit_form3_mem_reg(CodeBuffer &cbuf, PhaseRegAlloc* ra, const MachNode* n, !(n->ideal_Opcode()==Op_LoadD_unaligned && ld_op==Op_LoadF) && !(n->ideal_Opcode()==Op_ConvI2F && ld_op==Op_LoadF) && !(n->ideal_Opcode()==Op_ConvI2D && ld_op==Op_LoadF) && - !(n->ideal_Opcode()==Op_PrefetchRead && ld_op==Op_LoadI) && - !(n->ideal_Opcode()==Op_PrefetchWrite && ld_op==Op_LoadI) && !(n->ideal_Opcode()==Op_PrefetchAllocation && ld_op==Op_LoadI) && !(n->ideal_Opcode()==Op_LoadVector && ld_op==Op_LoadD) && !(n->rule() == loadUB_rule)) { @@ -6316,32 +6314,8 @@ instruct loadConD(regD dst, immD con, o7RegI tmp) %{ ins_pipe(loadConFD); %} -// Prefetch instructions. -// Must be safe to execute with invalid address (cannot fault). - -instruct prefetchr( memory mem ) %{ - match( PrefetchRead mem ); - ins_cost(MEMORY_REF_COST); - size(4); - - format %{ "PREFETCH $mem,0\t! Prefetch read-many" %} - opcode(Assembler::prefetch_op3); - ins_encode( form3_mem_prefetch_read( mem ) ); - ins_pipe(iload_mem); -%} - -instruct prefetchw( memory mem ) %{ - match( PrefetchWrite mem ); - ins_cost(MEMORY_REF_COST); - size(4); - - format %{ "PREFETCH $mem,2\t! Prefetch write-many (and read)" %} - opcode(Assembler::prefetch_op3); - ins_encode( form3_mem_prefetch_write( mem ) ); - ins_pipe(iload_mem); -%} - // Prefetch instructions for allocation. +// Must be safe to execute with invalid address (cannot fault). instruct prefetchAlloc( memory mem ) %{ predicate(AllocatePrefetchInstr == 0); diff --git a/hotspot/src/cpu/x86/vm/c1_LIRAssembler_x86.cpp b/hotspot/src/cpu/x86/vm/c1_LIRAssembler_x86.cpp index 6235c90df13..7c90c1decda 100644 --- a/hotspot/src/cpu/x86/vm/c1_LIRAssembler_x86.cpp +++ b/hotspot/src/cpu/x86/vm/c1_LIRAssembler_x86.cpp @@ -1,5 +1,5 @@ /* - * Copyright (c) 2000, 2013, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2000, 2015, 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 @@ -1398,50 +1398,6 @@ void LIR_Assembler::mem2reg(LIR_Opr src, LIR_Opr dest, BasicType type, LIR_Patch } -void LIR_Assembler::prefetchr(LIR_Opr src) { - LIR_Address* addr = src->as_address_ptr(); - Address from_addr = as_Address(addr); - - if (VM_Version::supports_sse()) { - switch (ReadPrefetchInstr) { - case 0: - __ prefetchnta(from_addr); break; - case 1: - __ prefetcht0(from_addr); break; - case 2: - __ prefetcht2(from_addr); break; - default: - ShouldNotReachHere(); break; - } - } else if (VM_Version::supports_3dnow_prefetch()) { - __ prefetchr(from_addr); - } -} - - -void LIR_Assembler::prefetchw(LIR_Opr src) { - LIR_Address* addr = src->as_address_ptr(); - Address from_addr = as_Address(addr); - - if (VM_Version::supports_sse()) { - switch (AllocatePrefetchInstr) { - case 0: - __ prefetchnta(from_addr); break; - case 1: - __ prefetcht0(from_addr); break; - case 2: - __ prefetcht2(from_addr); break; - case 3: - __ prefetchw(from_addr); break; - default: - ShouldNotReachHere(); break; - } - } else if (VM_Version::supports_3dnow_prefetch()) { - __ prefetchw(from_addr); - } -} - - NEEDS_CLEANUP; // This could be static? Address::ScaleFactor LIR_Assembler::array_element_size(BasicType type) const { int elem_size = type2aelembytes(type); diff --git a/hotspot/src/cpu/x86/vm/globals_x86.hpp b/hotspot/src/cpu/x86/vm/globals_x86.hpp index 1401997b3a1..81b3b81a36c 100644 --- a/hotspot/src/cpu/x86/vm/globals_x86.hpp +++ b/hotspot/src/cpu/x86/vm/globals_x86.hpp @@ -1,5 +1,5 @@ /* - * Copyright (c) 2000, 2013, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2000, 2015, 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 @@ -90,9 +90,6 @@ define_pd_global(uintx, TypeProfileLevel, 111); product(intx, FenceInstruction, 0, \ "(Unsafe,Unstable) Experimental") \ \ - product(intx, ReadPrefetchInstr, 0, \ - "Prefetch instruction to prefetch ahead") \ - \ product(bool, UseStoreImmI16, true, \ "Use store immediate 16-bits value instruction on x86") \ \ diff --git a/hotspot/src/cpu/x86/vm/vm_version_x86.cpp b/hotspot/src/cpu/x86/vm/vm_version_x86.cpp index 8d575c2d4bd..e702cf8dd02 100644 --- a/hotspot/src/cpu/x86/vm/vm_version_x86.cpp +++ b/hotspot/src/cpu/x86/vm/vm_version_x86.cpp @@ -1,5 +1,5 @@ /* - * Copyright (c) 1997, 2014, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 1997, 2015, 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 @@ -924,15 +924,9 @@ void VM_Version::get_processor_features() { } #endif // COMPILER2 - assert(0 <= ReadPrefetchInstr && ReadPrefetchInstr <= 3, "invalid value"); assert(0 <= AllocatePrefetchInstr && AllocatePrefetchInstr <= 3, "invalid value"); // set valid Prefetch instruction - if( ReadPrefetchInstr < 0 ) ReadPrefetchInstr = 0; - if( ReadPrefetchInstr > 3 ) ReadPrefetchInstr = 3; - if( ReadPrefetchInstr == 3 && !supports_3dnow_prefetch() ) ReadPrefetchInstr = 0; - if( !supports_sse() && supports_3dnow_prefetch() ) ReadPrefetchInstr = 3; - if( AllocatePrefetchInstr < 0 ) AllocatePrefetchInstr = 0; if( AllocatePrefetchInstr > 3 ) AllocatePrefetchInstr = 3; if( AllocatePrefetchInstr == 3 && !supports_3dnow_prefetch() ) AllocatePrefetchInstr=0; diff --git a/hotspot/src/cpu/x86/vm/x86_32.ad b/hotspot/src/cpu/x86/vm/x86_32.ad index 940541b6c30..e8b54389258 100644 --- a/hotspot/src/cpu/x86/vm/x86_32.ad +++ b/hotspot/src/cpu/x86/vm/x86_32.ad @@ -1,5 +1,5 @@ // -// Copyright (c) 1997, 2013, Oracle and/or its affiliates. All rights reserved. +// Copyright (c) 1997, 2015, 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 @@ -6061,102 +6061,8 @@ instruct loadSSD(regDPR dst, stackSlotD src) %{ ins_pipe( fpu_reg_mem ); %} -// Prefetch instructions. -// Must be safe to execute with invalid address (cannot fault). - -instruct prefetchr0( memory mem ) %{ - predicate(UseSSE==0 && !VM_Version::supports_3dnow_prefetch()); - match(PrefetchRead mem); - ins_cost(0); - size(0); - format %{ "PREFETCHR (non-SSE is empty encoding)" %} - ins_encode(); - ins_pipe(empty); -%} - -instruct prefetchr( memory mem ) %{ - predicate(UseSSE==0 && VM_Version::supports_3dnow_prefetch() || ReadPrefetchInstr==3); - match(PrefetchRead mem); - ins_cost(100); - - format %{ "PREFETCHR $mem\t! Prefetch into level 1 cache for read" %} - ins_encode %{ - __ prefetchr($mem$$Address); - %} - ins_pipe(ialu_mem); -%} - -instruct prefetchrNTA( memory mem ) %{ - predicate(UseSSE>=1 && ReadPrefetchInstr==0); - match(PrefetchRead mem); - ins_cost(100); - - format %{ "PREFETCHNTA $mem\t! Prefetch into non-temporal cache for read" %} - ins_encode %{ - __ prefetchnta($mem$$Address); - %} - ins_pipe(ialu_mem); -%} - -instruct prefetchrT0( memory mem ) %{ - predicate(UseSSE>=1 && ReadPrefetchInstr==1); - match(PrefetchRead mem); - ins_cost(100); - - format %{ "PREFETCHT0 $mem\t! Prefetch into L1 and L2 caches for read" %} - ins_encode %{ - __ prefetcht0($mem$$Address); - %} - ins_pipe(ialu_mem); -%} - -instruct prefetchrT2( memory mem ) %{ - predicate(UseSSE>=1 && ReadPrefetchInstr==2); - match(PrefetchRead mem); - ins_cost(100); - - format %{ "PREFETCHT2 $mem\t! Prefetch into L2 cache for read" %} - ins_encode %{ - __ prefetcht2($mem$$Address); - %} - ins_pipe(ialu_mem); -%} - -instruct prefetchw0( memory mem ) %{ - predicate(UseSSE==0 && !VM_Version::supports_3dnow_prefetch()); - match(PrefetchWrite mem); - ins_cost(0); - size(0); - format %{ "Prefetch (non-SSE is empty encoding)" %} - ins_encode(); - ins_pipe(empty); -%} - -instruct prefetchw( memory mem ) %{ - predicate(UseSSE==0 && VM_Version::supports_3dnow_prefetch()); - match( PrefetchWrite mem ); - ins_cost(100); - - format %{ "PREFETCHW $mem\t! Prefetch into L1 cache and mark modified" %} - ins_encode %{ - __ prefetchw($mem$$Address); - %} - ins_pipe(ialu_mem); -%} - -instruct prefetchwNTA( memory mem ) %{ - predicate(UseSSE>=1); - match(PrefetchWrite mem); - ins_cost(100); - - format %{ "PREFETCHNTA $mem\t! Prefetch into non-temporal cache for write" %} - ins_encode %{ - __ prefetchnta($mem$$Address); - %} - ins_pipe(ialu_mem); -%} - // Prefetch instructions for allocation. +// Must be safe to execute with invalid address (cannot fault). instruct prefetchAlloc0( memory mem ) %{ predicate(UseSSE==0 && AllocatePrefetchInstr!=3); diff --git a/hotspot/src/cpu/x86/vm/x86_64.ad b/hotspot/src/cpu/x86/vm/x86_64.ad index 1233dbf775c..20569256102 100644 --- a/hotspot/src/cpu/x86/vm/x86_64.ad +++ b/hotspot/src/cpu/x86/vm/x86_64.ad @@ -1,5 +1,5 @@ // -// Copyright (c) 2003, 2013, Oracle and/or its affiliates. All rights reserved. +// Copyright (c) 2003, 2015, 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 @@ -5319,69 +5319,8 @@ instruct loadSSD(regD dst, stackSlotD src) ins_pipe(pipe_slow); // XXX %} -// Prefetch instructions. -// Must be safe to execute with invalid address (cannot fault). - -instruct prefetchr( memory mem ) %{ - predicate(ReadPrefetchInstr==3); - match(PrefetchRead mem); - ins_cost(125); - - format %{ "PREFETCHR $mem\t# Prefetch into level 1 cache" %} - ins_encode %{ - __ prefetchr($mem$$Address); - %} - ins_pipe(ialu_mem); -%} - -instruct prefetchrNTA( memory mem ) %{ - predicate(ReadPrefetchInstr==0); - match(PrefetchRead mem); - ins_cost(125); - - format %{ "PREFETCHNTA $mem\t# Prefetch into non-temporal cache for read" %} - ins_encode %{ - __ prefetchnta($mem$$Address); - %} - ins_pipe(ialu_mem); -%} - -instruct prefetchrT0( memory mem ) %{ - predicate(ReadPrefetchInstr==1); - match(PrefetchRead mem); - ins_cost(125); - - format %{ "PREFETCHT0 $mem\t# prefetch into L1 and L2 caches for read" %} - ins_encode %{ - __ prefetcht0($mem$$Address); - %} - ins_pipe(ialu_mem); -%} - -instruct prefetchrT2( memory mem ) %{ - predicate(ReadPrefetchInstr==2); - match(PrefetchRead mem); - ins_cost(125); - - format %{ "PREFETCHT2 $mem\t# prefetch into L2 caches for read" %} - ins_encode %{ - __ prefetcht2($mem$$Address); - %} - ins_pipe(ialu_mem); -%} - -instruct prefetchwNTA( memory mem ) %{ - match(PrefetchWrite mem); - ins_cost(125); - - format %{ "PREFETCHNTA $mem\t# Prefetch to non-temporal cache for write" %} - ins_encode %{ - __ prefetchnta($mem$$Address); - %} - ins_pipe(ialu_mem); -%} - // Prefetch instructions for allocation. +// Must be safe to execute with invalid address (cannot fault). instruct prefetchAlloc( memory mem ) %{ predicate(AllocatePrefetchInstr==3); diff --git a/hotspot/src/share/vm/adlc/formssel.cpp b/hotspot/src/share/vm/adlc/formssel.cpp index c5becc89b47..4a68da6cd1c 100644 --- a/hotspot/src/share/vm/adlc/formssel.cpp +++ b/hotspot/src/share/vm/adlc/formssel.cpp @@ -1,5 +1,5 @@ /* - * Copyright (c) 1998, 2014, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 1998, 2015, 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 @@ -3489,9 +3489,7 @@ int MatchNode::needs_ideal_memory_edge(FormDict &globals) const { "GetAndAddL", "GetAndSetL", "GetAndSetN", }; int cnt = sizeof(needs_ideal_memory_list)/sizeof(char*); - if( strcmp(_opType,"PrefetchRead")==0 || - strcmp(_opType,"PrefetchWrite")==0 || - strcmp(_opType,"PrefetchAllocation")==0 ) + if( strcmp(_opType,"PrefetchAllocation")==0 ) return 1; if( _lChild ) { const char *opType = _lChild->_opType; diff --git a/hotspot/src/share/vm/c1/c1_Canonicalizer.cpp b/hotspot/src/share/vm/c1/c1_Canonicalizer.cpp index bbc5f477783..26cee689ab0 100644 --- a/hotspot/src/share/vm/c1/c1_Canonicalizer.cpp +++ b/hotspot/src/share/vm/c1/c1_Canonicalizer.cpp @@ -1,5 +1,5 @@ /* - * Copyright (c) 1999, 2013, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 1999, 2015, 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 @@ -964,8 +964,6 @@ void Canonicalizer::do_UnsafePutRaw(UnsafePutRaw* x) { if (OptimizeUnsafes) do_U void Canonicalizer::do_UnsafeGetObject(UnsafeGetObject* x) {} void Canonicalizer::do_UnsafePutObject(UnsafePutObject* x) {} void Canonicalizer::do_UnsafeGetAndSetObject(UnsafeGetAndSetObject* x) {} -void Canonicalizer::do_UnsafePrefetchRead (UnsafePrefetchRead* x) {} -void Canonicalizer::do_UnsafePrefetchWrite(UnsafePrefetchWrite* x) {} void Canonicalizer::do_ProfileCall(ProfileCall* x) {} void Canonicalizer::do_ProfileReturnType(ProfileReturnType* x) {} void Canonicalizer::do_ProfileInvoke(ProfileInvoke* x) {} diff --git a/hotspot/src/share/vm/c1/c1_Canonicalizer.hpp b/hotspot/src/share/vm/c1/c1_Canonicalizer.hpp index c1191830ed0..e9ba74c1a48 100644 --- a/hotspot/src/share/vm/c1/c1_Canonicalizer.hpp +++ b/hotspot/src/share/vm/c1/c1_Canonicalizer.hpp @@ -1,5 +1,5 @@ /* - * Copyright (c) 1999, 2013, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 1999, 2015, 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 @@ -101,8 +101,6 @@ class Canonicalizer: InstructionVisitor { virtual void do_UnsafeGetObject(UnsafeGetObject* x); virtual void do_UnsafePutObject(UnsafePutObject* x); virtual void do_UnsafeGetAndSetObject(UnsafeGetAndSetObject* x); - virtual void do_UnsafePrefetchRead (UnsafePrefetchRead* x); - virtual void do_UnsafePrefetchWrite(UnsafePrefetchWrite* x); virtual void do_ProfileCall (ProfileCall* x); virtual void do_ProfileReturnType (ProfileReturnType* x); virtual void do_ProfileInvoke (ProfileInvoke* x); diff --git a/hotspot/src/share/vm/c1/c1_GraphBuilder.cpp b/hotspot/src/share/vm/c1/c1_GraphBuilder.cpp index 351e410aa15..7bf14b5386d 100644 --- a/hotspot/src/share/vm/c1/c1_GraphBuilder.cpp +++ b/hotspot/src/share/vm/c1/c1_GraphBuilder.cpp @@ -1,5 +1,5 @@ /* - * Copyright (c) 1999, 2014, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 1999, 2015, 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 @@ -3497,11 +3497,6 @@ bool GraphBuilder::try_inline_intrinsics(ciMethod* callee) { case vmIntrinsics::_putFloat_raw : return append_unsafe_put_raw(callee, T_FLOAT); case vmIntrinsics::_putDouble_raw : return append_unsafe_put_raw(callee, T_DOUBLE); - case vmIntrinsics::_prefetchRead : return append_unsafe_prefetch(callee, false, false); - case vmIntrinsics::_prefetchWrite : return append_unsafe_prefetch(callee, false, true); - case vmIntrinsics::_prefetchReadStatic : return append_unsafe_prefetch(callee, true, false); - case vmIntrinsics::_prefetchWriteStatic : return append_unsafe_prefetch(callee, true, true); - case vmIntrinsics::_checkIndex : if (!InlineNIOCheckIndex) return false; preserves_state = true; @@ -4258,27 +4253,6 @@ bool GraphBuilder::append_unsafe_put_raw(ciMethod* callee, BasicType t) { } -bool GraphBuilder::append_unsafe_prefetch(ciMethod* callee, bool is_static, bool is_store) { - if (InlineUnsafeOps) { - Values* args = state()->pop_arguments(callee->arg_size()); - int obj_arg_index = 1; // Assume non-static case - if (is_static) { - obj_arg_index = 0; - } else { - null_check(args->at(0)); - } - Instruction* offset = args->at(obj_arg_index + 1); -#ifndef _LP64 - offset = append(new Convert(Bytecodes::_l2i, offset, as_ValueType(T_INT))); -#endif - Instruction* op = is_store ? append(new UnsafePrefetchWrite(args->at(obj_arg_index), offset)) - : append(new UnsafePrefetchRead (args->at(obj_arg_index), offset)); - compilation()->set_has_unsafe_access(true); - } - return InlineUnsafeOps; -} - - void GraphBuilder::append_unsafe_CAS(ciMethod* callee) { ValueStack* state_before = copy_state_for_exception(); ValueType* result_type = as_ValueType(callee->return_type()); diff --git a/hotspot/src/share/vm/c1/c1_GraphBuilder.hpp b/hotspot/src/share/vm/c1/c1_GraphBuilder.hpp index 2caf6142e53..d53c1c04953 100644 --- a/hotspot/src/share/vm/c1/c1_GraphBuilder.hpp +++ b/hotspot/src/share/vm/c1/c1_GraphBuilder.hpp @@ -1,5 +1,5 @@ /* - * Copyright (c) 1999, 2013, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 1999, 2015, 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 @@ -368,7 +368,6 @@ class GraphBuilder VALUE_OBJ_CLASS_SPEC { bool append_unsafe_put_obj(ciMethod* callee, BasicType t, bool is_volatile); bool append_unsafe_get_raw(ciMethod* callee, BasicType t); bool append_unsafe_put_raw(ciMethod* callee, BasicType t); - bool append_unsafe_prefetch(ciMethod* callee, bool is_store, bool is_static); void append_unsafe_CAS(ciMethod* callee); bool append_unsafe_get_and_set_obj(ciMethod* callee, bool is_add); diff --git a/hotspot/src/share/vm/c1/c1_Instruction.hpp b/hotspot/src/share/vm/c1/c1_Instruction.hpp index 3121088c9e6..b61786c58c5 100644 --- a/hotspot/src/share/vm/c1/c1_Instruction.hpp +++ b/hotspot/src/share/vm/c1/c1_Instruction.hpp @@ -1,5 +1,5 @@ /* - * Copyright (c) 1999, 2013, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 1999, 2015, 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 @@ -103,9 +103,6 @@ class UnsafeObjectOp; class UnsafeGetObject; class UnsafePutObject; class UnsafeGetAndSetObject; -class UnsafePrefetch; -class UnsafePrefetchRead; -class UnsafePrefetchWrite; class ProfileCall; class ProfileReturnType; class ProfileInvoke; @@ -209,8 +206,6 @@ class InstructionVisitor: public StackObj { virtual void do_UnsafeGetObject(UnsafeGetObject* x) = 0; virtual void do_UnsafePutObject(UnsafePutObject* x) = 0; virtual void do_UnsafeGetAndSetObject(UnsafeGetAndSetObject* x) = 0; - virtual void do_UnsafePrefetchRead (UnsafePrefetchRead* x) = 0; - virtual void do_UnsafePrefetchWrite(UnsafePrefetchWrite* x) = 0; virtual void do_ProfileCall (ProfileCall* x) = 0; virtual void do_ProfileReturnType (ProfileReturnType* x) = 0; virtual void do_ProfileInvoke (ProfileInvoke* x) = 0; @@ -2442,34 +2437,6 @@ LEAF(UnsafeGetAndSetObject, UnsafeObjectOp) f->visit(&_value); } }; -BASE(UnsafePrefetch, UnsafeObjectOp) - public: - UnsafePrefetch(Value object, Value offset) - : UnsafeObjectOp(T_VOID, object, offset, false, false) - { - } -}; - - -LEAF(UnsafePrefetchRead, UnsafePrefetch) - public: - UnsafePrefetchRead(Value object, Value offset) - : UnsafePrefetch(object, offset) - { - ASSERT_VALUES - } -}; - - -LEAF(UnsafePrefetchWrite, UnsafePrefetch) - public: - UnsafePrefetchWrite(Value object, Value offset) - : UnsafePrefetch(object, offset) - { - ASSERT_VALUES - } -}; - LEAF(ProfileCall, Instruction) private: ciMethod* _method; diff --git a/hotspot/src/share/vm/c1/c1_InstructionPrinter.cpp b/hotspot/src/share/vm/c1/c1_InstructionPrinter.cpp index 842acec5be9..6b4e31b9a54 100644 --- a/hotspot/src/share/vm/c1/c1_InstructionPrinter.cpp +++ b/hotspot/src/share/vm/c1/c1_InstructionPrinter.cpp @@ -1,5 +1,5 @@ /* - * Copyright (c) 1999, 2014, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 1999, 2015, 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 @@ -853,11 +853,6 @@ void InstructionPrinter::do_UnsafeGetAndSetObject(UnsafeGetAndSetObject* x) { output()->put(')'); } -void InstructionPrinter::do_UnsafePrefetchRead(UnsafePrefetchRead* x) { - print_unsafe_object_op(x, "UnsafePrefetchRead"); - output()->put(')'); -} - void InstructionPrinter::do_RangeCheckPredicate(RangeCheckPredicate* x) { if (x->x() != NULL && x->y() != NULL) { @@ -880,11 +875,6 @@ void InstructionPrinter::do_Assert(Assert* x) { } #endif -void InstructionPrinter::do_UnsafePrefetchWrite(UnsafePrefetchWrite* x) { - print_unsafe_object_op(x, "UnsafePrefetchWrite"); - output()->put(')'); -} - void InstructionPrinter::do_ProfileCall(ProfileCall* x) { output()->print("profile "); print_value(x->recv()); diff --git a/hotspot/src/share/vm/c1/c1_InstructionPrinter.hpp b/hotspot/src/share/vm/c1/c1_InstructionPrinter.hpp index a3a91033d70..c2ef4b7b969 100644 --- a/hotspot/src/share/vm/c1/c1_InstructionPrinter.hpp +++ b/hotspot/src/share/vm/c1/c1_InstructionPrinter.hpp @@ -1,5 +1,5 @@ /* - * Copyright (c) 1999, 2013, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 1999, 2015, 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 @@ -129,8 +129,6 @@ class InstructionPrinter: public InstructionVisitor { virtual void do_UnsafeGetObject(UnsafeGetObject* x); virtual void do_UnsafePutObject(UnsafePutObject* x); virtual void do_UnsafeGetAndSetObject(UnsafeGetAndSetObject* x); - virtual void do_UnsafePrefetchRead (UnsafePrefetchRead* x); - virtual void do_UnsafePrefetchWrite(UnsafePrefetchWrite* x); virtual void do_ProfileCall (ProfileCall* x); virtual void do_ProfileReturnType (ProfileReturnType* x); virtual void do_ProfileInvoke (ProfileInvoke* x); diff --git a/hotspot/src/share/vm/c1/c1_LIR.cpp b/hotspot/src/share/vm/c1/c1_LIR.cpp index f60190ae6c3..0494b28ff98 100644 --- a/hotspot/src/share/vm/c1/c1_LIR.cpp +++ b/hotspot/src/share/vm/c1/c1_LIR.cpp @@ -527,8 +527,6 @@ void LIR_OpVisitState::visit(LIR_Op* op) { case lir_move: // input and result always valid, may have info case lir_pack64: // input and result always valid case lir_unpack64: // input and result always valid - case lir_prefetchr: // input always valid, result and info always invalid - case lir_prefetchw: // input always valid, result and info always invalid { assert(op->as_Op1() != NULL, "must be"); LIR_Op1* op1 = (LIR_Op1*)op; @@ -1266,13 +1264,6 @@ void LIR_List::volatile_load_unsafe_reg(LIR_Opr base, LIR_Opr offset, LIR_Opr ds } -void LIR_List::prefetch(LIR_Address* addr, bool is_store) { - append(new LIR_Op1( - is_store ? lir_prefetchw : lir_prefetchr, - LIR_OprFact::address(addr))); -} - - void LIR_List::store_mem_int(jint v, LIR_Opr base, int offset_in_bytes, BasicType type, CodeEmitInfo* info, LIR_PatchCode patch_code) { append(new LIR_Op1( lir_move, diff --git a/hotspot/src/share/vm/c1/c1_LIR.hpp b/hotspot/src/share/vm/c1/c1_LIR.hpp index e26c280c38a..ae2b994db46 100644 --- a/hotspot/src/share/vm/c1/c1_LIR.hpp +++ b/hotspot/src/share/vm/c1/c1_LIR.hpp @@ -1,5 +1,5 @@ /* - * Copyright (c) 2000, 2013, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2000, 2015, 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 @@ -925,8 +925,6 @@ enum LIR_Code { , lir_branch , lir_cond_float_branch , lir_move - , lir_prefetchr - , lir_prefetchw , lir_convert , lir_alloc_object , lir_monaddr @@ -2212,8 +2210,6 @@ class LIR_List: public CompilationResourceObj { void load(LIR_Address* addr, LIR_Opr src, CodeEmitInfo* info = NULL, LIR_PatchCode patch_code = lir_patch_none); - void prefetch(LIR_Address* addr, bool is_store); - void store_mem_int(jint v, LIR_Opr base, int offset_in_bytes, BasicType type, CodeEmitInfo* info, LIR_PatchCode patch_code = lir_patch_none); void store_mem_oop(jobject o, LIR_Opr base, int offset_in_bytes, BasicType type, CodeEmitInfo* info, LIR_PatchCode patch_code = lir_patch_none); void store(LIR_Opr src, LIR_Address* addr, CodeEmitInfo* info = NULL, LIR_PatchCode patch_code = lir_patch_none); diff --git a/hotspot/src/share/vm/c1/c1_LIRAssembler.cpp b/hotspot/src/share/vm/c1/c1_LIRAssembler.cpp index dc43a87389d..f82913e0d18 100644 --- a/hotspot/src/share/vm/c1/c1_LIRAssembler.cpp +++ b/hotspot/src/share/vm/c1/c1_LIRAssembler.cpp @@ -503,14 +503,6 @@ void LIR_Assembler::emit_op1(LIR_Op1* op) { } break; - case lir_prefetchr: - prefetchr(op->in_opr()); - break; - - case lir_prefetchw: - prefetchw(op->in_opr()); - break; - case lir_roundfp: { LIR_OpRoundFP* round_op = op->as_OpRoundFP(); roundfp_op(round_op->in_opr(), round_op->tmp(), round_op->result_opr(), round_op->pop_fpu_stack()); diff --git a/hotspot/src/share/vm/c1/c1_LIRAssembler.hpp b/hotspot/src/share/vm/c1/c1_LIRAssembler.hpp index 2211b0cc32c..b7891cb830b 100644 --- a/hotspot/src/share/vm/c1/c1_LIRAssembler.hpp +++ b/hotspot/src/share/vm/c1/c1_LIRAssembler.hpp @@ -1,5 +1,5 @@ /* - * Copyright (c) 2000, 2013, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2000, 2015, 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 @@ -182,9 +182,6 @@ class LIR_Assembler: public CompilationResourceObj { LIR_PatchCode patch_code, CodeEmitInfo* info, bool wide, bool unaligned); - void prefetchr (LIR_Opr src); - void prefetchw (LIR_Opr src); - void shift_op(LIR_Code code, LIR_Opr left, LIR_Opr count, LIR_Opr dest, LIR_Opr tmp); void shift_op(LIR_Code code, LIR_Opr left, jint count, LIR_Opr dest); diff --git a/hotspot/src/share/vm/c1/c1_LIRGenerator.cpp b/hotspot/src/share/vm/c1/c1_LIRGenerator.cpp index 199b840629a..9939243508b 100644 --- a/hotspot/src/share/vm/c1/c1_LIRGenerator.cpp +++ b/hotspot/src/share/vm/c1/c1_LIRGenerator.cpp @@ -1,5 +1,5 @@ /* - * Copyright (c) 2005, 2014, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2005, 2015, 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 @@ -2385,35 +2385,6 @@ void LIRGenerator::do_UnsafePutObject(UnsafePutObject* x) { } -void LIRGenerator::do_UnsafePrefetch(UnsafePrefetch* x, bool is_store) { - LIRItem src(x->object(), this); - LIRItem off(x->offset(), this); - - src.load_item(); - if (off.is_constant() && can_inline_as_constant(x->offset())) { - // let it be a constant - off.dont_load_item(); - } else { - off.load_item(); - } - - set_no_result(x); - - LIR_Address* addr = generate_address(src.result(), off.result(), 0, 0, T_BYTE); - __ prefetch(addr, is_store); -} - - -void LIRGenerator::do_UnsafePrefetchRead(UnsafePrefetchRead* x) { - do_UnsafePrefetch(x, false); -} - - -void LIRGenerator::do_UnsafePrefetchWrite(UnsafePrefetchWrite* x) { - do_UnsafePrefetch(x, true); -} - - void LIRGenerator::do_SwitchRanges(SwitchRangeArray* x, LIR_Opr value, BlockBegin* default_sux) { int lng = x->length(); diff --git a/hotspot/src/share/vm/c1/c1_LIRGenerator.hpp b/hotspot/src/share/vm/c1/c1_LIRGenerator.hpp index ba003e5851f..5095af782c9 100644 --- a/hotspot/src/share/vm/c1/c1_LIRGenerator.hpp +++ b/hotspot/src/share/vm/c1/c1_LIRGenerator.hpp @@ -1,5 +1,5 @@ /* - * Copyright (c) 2005, 2013, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2005, 2015, 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 @@ -251,8 +251,6 @@ class LIRGenerator: public InstructionVisitor, public BlockClosure { void do_Reference_get(Intrinsic* x); void do_update_CRC32(Intrinsic* x); - void do_UnsafePrefetch(UnsafePrefetch* x, bool is_store); - LIR_Opr call_runtime(BasicTypeArray* signature, LIRItemList* args, address entry, ValueType* result_type, CodeEmitInfo* info); LIR_Opr call_runtime(BasicTypeArray* signature, LIR_OprList* args, address entry, ValueType* result_type, CodeEmitInfo* info); @@ -539,8 +537,6 @@ class LIRGenerator: public InstructionVisitor, public BlockClosure { virtual void do_UnsafeGetObject(UnsafeGetObject* x); virtual void do_UnsafePutObject(UnsafePutObject* x); virtual void do_UnsafeGetAndSetObject(UnsafeGetAndSetObject* x); - virtual void do_UnsafePrefetchRead (UnsafePrefetchRead* x); - virtual void do_UnsafePrefetchWrite(UnsafePrefetchWrite* x); virtual void do_ProfileCall (ProfileCall* x); virtual void do_ProfileReturnType (ProfileReturnType* x); virtual void do_ProfileInvoke (ProfileInvoke* x); diff --git a/hotspot/src/share/vm/c1/c1_Optimizer.cpp b/hotspot/src/share/vm/c1/c1_Optimizer.cpp index f366462f60c..b44d74e12b4 100644 --- a/hotspot/src/share/vm/c1/c1_Optimizer.cpp +++ b/hotspot/src/share/vm/c1/c1_Optimizer.cpp @@ -1,5 +1,5 @@ /* - * Copyright (c) 1999, 2013, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 1999, 2015, 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 @@ -528,8 +528,6 @@ public: void do_UnsafeGetObject(UnsafeGetObject* x); void do_UnsafePutObject(UnsafePutObject* x); void do_UnsafeGetAndSetObject(UnsafeGetAndSetObject* x); - void do_UnsafePrefetchRead (UnsafePrefetchRead* x); - void do_UnsafePrefetchWrite(UnsafePrefetchWrite* x); void do_ProfileCall (ProfileCall* x); void do_ProfileReturnType (ProfileReturnType* x); void do_ProfileInvoke (ProfileInvoke* x); @@ -716,8 +714,6 @@ void NullCheckVisitor::do_UnsafePutRaw (UnsafePutRaw* x) {} void NullCheckVisitor::do_UnsafeGetObject(UnsafeGetObject* x) {} void NullCheckVisitor::do_UnsafePutObject(UnsafePutObject* x) {} void NullCheckVisitor::do_UnsafeGetAndSetObject(UnsafeGetAndSetObject* x) {} -void NullCheckVisitor::do_UnsafePrefetchRead (UnsafePrefetchRead* x) {} -void NullCheckVisitor::do_UnsafePrefetchWrite(UnsafePrefetchWrite* x) {} void NullCheckVisitor::do_ProfileCall (ProfileCall* x) { nce()->clear_last_explicit_null_check(); nce()->handle_ProfileCall(x); } void NullCheckVisitor::do_ProfileReturnType (ProfileReturnType* x) { nce()->handle_ProfileReturnType(x); } diff --git a/hotspot/src/share/vm/c1/c1_RangeCheckElimination.hpp b/hotspot/src/share/vm/c1/c1_RangeCheckElimination.hpp index f7b68af9862..2fd6cb59221 100644 --- a/hotspot/src/share/vm/c1/c1_RangeCheckElimination.hpp +++ b/hotspot/src/share/vm/c1/c1_RangeCheckElimination.hpp @@ -1,5 +1,5 @@ /* - * Copyright (c) 2012, 2013, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2012, 2015, 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 @@ -159,8 +159,6 @@ public: void do_UnsafeGetRaw (UnsafeGetRaw* x) { /* nothing to do */ }; void do_UnsafeGetObject(UnsafeGetObject* x) { /* nothing to do */ }; void do_UnsafeGetAndSetObject(UnsafeGetAndSetObject* x) { /* nothing to do */ }; - void do_UnsafePrefetchRead (UnsafePrefetchRead* x) { /* nothing to do */ }; - void do_UnsafePrefetchWrite(UnsafePrefetchWrite* x) { /* nothing to do */ }; void do_ProfileCall (ProfileCall* x) { /* nothing to do */ }; void do_ProfileReturnType (ProfileReturnType* x) { /* nothing to do */ }; void do_ProfileInvoke (ProfileInvoke* x) { /* nothing to do */ }; diff --git a/hotspot/src/share/vm/c1/c1_ValueMap.hpp b/hotspot/src/share/vm/c1/c1_ValueMap.hpp index e394118b1ce..3b3b02ee4b7 100644 --- a/hotspot/src/share/vm/c1/c1_ValueMap.hpp +++ b/hotspot/src/share/vm/c1/c1_ValueMap.hpp @@ -1,5 +1,5 @@ /* - * Copyright (c) 1999, 2013, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 1999, 2015, 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 @@ -200,8 +200,6 @@ class ValueNumberingVisitor: public InstructionVisitor { void do_RoundFP (RoundFP* x) { /* nothing to do */ } void do_UnsafeGetRaw (UnsafeGetRaw* x) { /* nothing to do */ } void do_UnsafeGetObject(UnsafeGetObject* x) { /* nothing to do */ } - void do_UnsafePrefetchRead (UnsafePrefetchRead* x) { /* nothing to do */ } - void do_UnsafePrefetchWrite(UnsafePrefetchWrite* x) { /* nothing to do */ } void do_ProfileCall (ProfileCall* x) { /* nothing to do */ } void do_ProfileReturnType (ProfileReturnType* x) { /* nothing to do */ } void do_ProfileInvoke (ProfileInvoke* x) { /* nothing to do */ }; diff --git a/hotspot/src/share/vm/classfile/vmSymbols.hpp b/hotspot/src/share/vm/classfile/vmSymbols.hpp index 6a5f1508076..ba641724c65 100644 --- a/hotspot/src/share/vm/classfile/vmSymbols.hpp +++ b/hotspot/src/share/vm/classfile/vmSymbols.hpp @@ -1,5 +1,5 @@ /* - * Copyright (c) 1997, 2014, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 1997, 2015, 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 @@ -1017,18 +1017,6 @@ do_intrinsic(_getAndSetObject, sun_misc_Unsafe, getAndSetObject_name, getAndSetObject_signature, F_R)\ do_name( getAndSetObject_name, "getAndSetObject") \ do_signature(getAndSetObject_signature, "(Ljava/lang/Object;JLjava/lang/Object;)Ljava/lang/Object;" ) \ - \ - /* prefetch_signature is shared by all prefetch variants */ \ - do_signature( prefetch_signature, "(Ljava/lang/Object;J)V") \ - \ - do_intrinsic(_prefetchRead, sun_misc_Unsafe, prefetchRead_name, prefetch_signature, F_RN) \ - do_name( prefetchRead_name, "prefetchRead") \ - do_intrinsic(_prefetchWrite, sun_misc_Unsafe, prefetchWrite_name, prefetch_signature, F_RN) \ - do_name( prefetchWrite_name, "prefetchWrite") \ - do_intrinsic(_prefetchReadStatic, sun_misc_Unsafe, prefetchReadStatic_name, prefetch_signature, F_SN) \ - do_name( prefetchReadStatic_name, "prefetchReadStatic") \ - do_intrinsic(_prefetchWriteStatic, sun_misc_Unsafe, prefetchWriteStatic_name, prefetch_signature, F_SN) \ - do_name( prefetchWriteStatic_name, "prefetchWriteStatic") \ /*== LAST_COMPILER_INLINE*/ \ /*the compiler does have special inlining code for these; bytecode inline is just fine */ \ \ @@ -1203,7 +1191,7 @@ class vmIntrinsics: AllStatic { #undef VM_INTRINSIC_ENUM ID_LIMIT, - LAST_COMPILER_INLINE = _prefetchWriteStatic, + LAST_COMPILER_INLINE = _getAndSetObject, FIRST_MH_SIG_POLY = _invokeGeneric, FIRST_MH_STATIC = _linkToVirtual, LAST_MH_SIG_POLY = _linkToInterface, diff --git a/hotspot/src/share/vm/opto/classes.hpp b/hotspot/src/share/vm/opto/classes.hpp index 238e3491862..5408807749f 100644 --- a/hotspot/src/share/vm/opto/classes.hpp +++ b/hotspot/src/share/vm/opto/classes.hpp @@ -1,5 +1,5 @@ /* - * Copyright (c) 1997, 2013, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 1997, 2015, 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 @@ -216,8 +216,6 @@ macro(PopCountI) macro(PopCountL) macro(PowD) macro(PrefetchAllocation) -macro(PrefetchRead) -macro(PrefetchWrite) macro(Proj) macro(RShiftI) macro(RShiftL) diff --git a/hotspot/src/share/vm/opto/library_call.cpp b/hotspot/src/share/vm/opto/library_call.cpp index 45eeb9672ff..6a950949c97 100644 --- a/hotspot/src/share/vm/opto/library_call.cpp +++ b/hotspot/src/share/vm/opto/library_call.cpp @@ -232,7 +232,6 @@ class LibraryCallKit : public GraphKit { // Unsafe.getObject should be recorded in an SATB log buffer. void insert_pre_barrier(Node* base_oop, Node* offset, Node* pre_val, bool need_mem_bar); bool inline_unsafe_access(bool is_native_ptr, bool is_store, BasicType type, bool is_volatile); - bool inline_unsafe_prefetch(bool is_native_ptr, bool is_store, bool is_static); static bool klass_needs_init_guard(Node* kls); bool inline_unsafe_allocate(); bool inline_unsafe_copyMemory(); @@ -796,11 +795,6 @@ bool LibraryCallKit::try_to_inline(int predicate) { case vmIntrinsics::_putFloatVolatile: return inline_unsafe_access(!is_native_ptr, is_store, T_FLOAT, is_volatile); case vmIntrinsics::_putDoubleVolatile: return inline_unsafe_access(!is_native_ptr, is_store, T_DOUBLE, is_volatile); - case vmIntrinsics::_prefetchRead: return inline_unsafe_prefetch(!is_native_ptr, !is_store, !is_static); - case vmIntrinsics::_prefetchWrite: return inline_unsafe_prefetch(!is_native_ptr, is_store, !is_static); - case vmIntrinsics::_prefetchReadStatic: return inline_unsafe_prefetch(!is_native_ptr, !is_store, is_static); - case vmIntrinsics::_prefetchWriteStatic: return inline_unsafe_prefetch(!is_native_ptr, is_store, is_static); - case vmIntrinsics::_compareAndSwapObject: return inline_unsafe_load_store(T_OBJECT, LS_cmpxchg); case vmIntrinsics::_compareAndSwapInt: return inline_unsafe_load_store(T_INT, LS_cmpxchg); case vmIntrinsics::_compareAndSwapLong: return inline_unsafe_load_store(T_LONG, LS_cmpxchg); @@ -2506,7 +2500,7 @@ bool LibraryCallKit::inline_unsafe_access(bool is_native_ptr, bool is_store, Bas Node* receiver = argument(0); // type: oop - // Build address expression. See the code in inline_unsafe_prefetch. + // Build address expression. Node* adr; Node* heap_base_oop = top(); Node* offset = top(); @@ -2695,73 +2689,6 @@ bool LibraryCallKit::inline_unsafe_access(bool is_native_ptr, bool is_store, Bas return true; } -//----------------------------inline_unsafe_prefetch---------------------------- - -bool LibraryCallKit::inline_unsafe_prefetch(bool is_native_ptr, bool is_store, bool is_static) { -#ifndef PRODUCT - { - ResourceMark rm; - // Check the signatures. - ciSignature* sig = callee()->signature(); -#ifdef ASSERT - // Object getObject(Object base, int/long offset), etc. - BasicType rtype = sig->return_type()->basic_type(); - if (!is_native_ptr) { - assert(sig->count() == 2, "oop prefetch has 2 arguments"); - assert(sig->type_at(0)->basic_type() == T_OBJECT, "prefetch base is object"); - assert(sig->type_at(1)->basic_type() == T_LONG, "prefetcha offset is correct"); - } else { - assert(sig->count() == 1, "native prefetch has 1 argument"); - assert(sig->type_at(0)->basic_type() == T_LONG, "prefetch base is long"); - } -#endif // ASSERT - } -#endif // !PRODUCT - - C->set_has_unsafe_access(true); // Mark eventual nmethod as "unsafe". - - const int idx = is_static ? 0 : 1; - if (!is_static) { - null_check_receiver(); - if (stopped()) { - return true; - } - } - - // Build address expression. See the code in inline_unsafe_access. - Node *adr; - if (!is_native_ptr) { - // The base is either a Java object or a value produced by Unsafe.staticFieldBase - Node* base = argument(idx + 0); // type: oop - // The offset is a value produced by Unsafe.staticFieldOffset or Unsafe.objectFieldOffset - Node* offset = argument(idx + 1); // type: long - // We currently rely on the cookies produced by Unsafe.xxxFieldOffset - // to be plain byte offsets, which are also the same as those accepted - // by oopDesc::field_base. - assert(Unsafe_field_offset_to_byte_offset(11) == 11, - "fieldOffset must be byte-scaled"); - // 32-bit machines ignore the high half! - offset = ConvL2X(offset); - adr = make_unsafe_address(base, offset); - } else { - Node* ptr = argument(idx + 0); // type: long - ptr = ConvL2X(ptr); // adjust Java long to machine word - adr = make_unsafe_address(NULL, ptr); - } - - // Generate the read or write prefetch - Node *prefetch; - if (is_store) { - prefetch = new PrefetchWriteNode(i_o(), adr); - } else { - prefetch = new PrefetchReadNode(i_o(), adr); - } - prefetch->init_req(0, control()); - set_i_o(_gvn.transform(prefetch)); - - return true; -} - //----------------------------inline_unsafe_load_store---------------------------- // This method serves a couple of different customers (depending on LoadStoreKind): // diff --git a/hotspot/src/share/vm/opto/matcher.cpp b/hotspot/src/share/vm/opto/matcher.cpp index 8ecb54b2dc9..d35b8608f35 100644 --- a/hotspot/src/share/vm/opto/matcher.cpp +++ b/hotspot/src/share/vm/opto/matcher.cpp @@ -1,5 +1,5 @@ /* - * Copyright (c) 1997, 2014, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 1997, 2015, 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 @@ -884,8 +884,6 @@ static void match_alias_type(Compile* C, Node* n, Node* m) { // %%% Kludgery. Instead, fix ideal adr_type methods for all these cases: if (nidx == Compile::AliasIdxTop && midx == Compile::AliasIdxRaw) { switch (n->Opcode()) { - case Op_PrefetchRead: - case Op_PrefetchWrite: case Op_PrefetchAllocation: nidx = Compile::AliasIdxRaw; nat = TypeRawPtr::BOTTOM; diff --git a/hotspot/src/share/vm/opto/memnode.hpp b/hotspot/src/share/vm/opto/memnode.hpp index d32a4fa0c09..282961799d7 100644 --- a/hotspot/src/share/vm/opto/memnode.hpp +++ b/hotspot/src/share/vm/opto/memnode.hpp @@ -1,5 +1,5 @@ /* - * Copyright (c) 1997, 2014, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 1997, 2015, 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 @@ -1376,26 +1376,6 @@ class MergeMemStream : public StackObj { //------------------------------Prefetch--------------------------------------- -// Non-faulting prefetch load. Prefetch for many reads. -class PrefetchReadNode : public Node { -public: - PrefetchReadNode(Node *abio, Node *adr) : Node(0,abio,adr) {} - virtual int Opcode() const; - virtual uint ideal_reg() const { return NotAMachineReg; } - virtual uint match_edge(uint idx) const { return idx==2; } - virtual const Type *bottom_type() const { return Type::ABIO; } -}; - -// Non-faulting prefetch load. Prefetch for many reads & many writes. -class PrefetchWriteNode : public Node { -public: - PrefetchWriteNode(Node *abio, Node *adr) : Node(0,abio,adr) {} - virtual int Opcode() const; - virtual uint ideal_reg() const { return NotAMachineReg; } - virtual uint match_edge(uint idx) const { return idx==2; } - virtual const Type *bottom_type() const { return Type::ABIO; } -}; - // Allocation prefetch which may fault, TLAB size have to be adjusted. class PrefetchAllocationNode : public Node { public: diff --git a/hotspot/src/share/vm/runtime/vmStructs.cpp b/hotspot/src/share/vm/runtime/vmStructs.cpp index e83fe1ab3dc..c2a513588be 100644 --- a/hotspot/src/share/vm/runtime/vmStructs.cpp +++ b/hotspot/src/share/vm/runtime/vmStructs.cpp @@ -1920,8 +1920,6 @@ typedef CompactHashtable SymbolCompactHashTable; declare_c2_type(CompareAndSwapINode, LoadStoreNode) \ declare_c2_type(CompareAndSwapPNode, LoadStoreNode) \ declare_c2_type(CompareAndSwapNNode, LoadStoreNode) \ - declare_c2_type(PrefetchReadNode, Node) \ - declare_c2_type(PrefetchWriteNode, Node) \ declare_c2_type(MulNode, Node) \ declare_c2_type(MulINode, MulNode) \ declare_c2_type(MulLNode, MulNode) \ From 89d88a42c434d4aaa41d5f876479d69046eb3c38 Mon Sep 17 00:00:00 2001 From: Tom Benson Date: Tue, 10 Feb 2015 15:44:42 -0500 Subject: [PATCH 083/116] 8072056: Remove unnecessary header file #include TenuredGeneration.cpp needlessly includes parGCAllocBuffer.hpp Reviewed-by: tschatzl, kbarrett, jprovino --- hotspot/src/share/vm/memory/tenuredGeneration.cpp | 3 +-- 1 file changed, 1 insertion(+), 2 deletions(-) diff --git a/hotspot/src/share/vm/memory/tenuredGeneration.cpp b/hotspot/src/share/vm/memory/tenuredGeneration.cpp index 3ad812cb4c2..fff78747791 100644 --- a/hotspot/src/share/vm/memory/tenuredGeneration.cpp +++ b/hotspot/src/share/vm/memory/tenuredGeneration.cpp @@ -1,5 +1,5 @@ /* - * Copyright (c) 2001, 2014, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2001, 2015, 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 @@ -25,7 +25,6 @@ #include "precompiled.hpp" #include "gc_implementation/shared/collectorCounters.hpp" #include "gc_implementation/shared/gcTimer.hpp" -#include "gc_implementation/shared/parGCAllocBuffer.hpp" #include "memory/allocation.inline.hpp" #include "memory/blockOffsetTable.inline.hpp" #include "memory/cardGeneration.inline.hpp" From 2c63608419e47d79a99fff39744e132e97df80b0 Mon Sep 17 00:00:00 2001 From: Tom Benson Date: Tue, 10 Feb 2015 17:41:19 -0500 Subject: [PATCH 084/116] 8065093: Remove unused variable/output argument Remove total_reserved from GenCollectedHeap::initialize and ::allocate Reviewed-by: tschatzl, kbarrett --- hotspot/src/share/vm/memory/genCollectedHeap.cpp | 8 ++------ hotspot/src/share/vm/memory/genCollectedHeap.hpp | 6 ++++-- 2 files changed, 6 insertions(+), 8 deletions(-) diff --git a/hotspot/src/share/vm/memory/genCollectedHeap.cpp b/hotspot/src/share/vm/memory/genCollectedHeap.cpp index 392f896de1f..4fa0f84cfa2 100644 --- a/hotspot/src/share/vm/memory/genCollectedHeap.cpp +++ b/hotspot/src/share/vm/memory/genCollectedHeap.cpp @@ -1,5 +1,5 @@ /* - * Copyright (c) 2000, 2014, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2000, 2015, 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 @@ -108,12 +108,11 @@ jint GenCollectedHeap::initialize() { // Allocate space for the heap. char* heap_address; - size_t total_reserved = 0; ReservedSpace heap_rs; size_t heap_alignment = collector_policy()->heap_alignment(); - heap_address = allocate(heap_alignment, &total_reserved, &heap_rs); + heap_address = allocate(heap_alignment, &heap_rs); if (!heap_rs.is_reserved()) { vm_shutdown_during_initialization( @@ -149,7 +148,6 @@ jint GenCollectedHeap::initialize() { char* GenCollectedHeap::allocate(size_t alignment, - size_t* _total_reserved, ReservedSpace* heap_rs){ const char overflow_msg[] = "The size of the object heap + VM data exceeds " "the maximum representable size"; @@ -171,8 +169,6 @@ char* GenCollectedHeap::allocate(size_t alignment, err_msg("Gen size; total_reserved=" SIZE_FORMAT ", alignment=" SIZE_FORMAT, total_reserved, alignment)); - *_total_reserved = total_reserved; - *heap_rs = Universe::reserve_heap(total_reserved, alignment); return heap_rs->base(); } diff --git a/hotspot/src/share/vm/memory/genCollectedHeap.hpp b/hotspot/src/share/vm/memory/genCollectedHeap.hpp index dc132f67f1a..36cd895c03a 100644 --- a/hotspot/src/share/vm/memory/genCollectedHeap.hpp +++ b/hotspot/src/share/vm/memory/genCollectedHeap.hpp @@ -1,5 +1,5 @@ /* - * Copyright (c) 2000, 2014, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2000, 2015, 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 @@ -124,7 +124,9 @@ public: // Returns JNI_OK on success virtual jint initialize(); - char* allocate(size_t alignment, size_t* _total_reserved, ReservedSpace* heap_rs); + + // Reserve aligned space for the heap as needed by the contained generations. + char* allocate(size_t alignment, ReservedSpace* heap_rs); // Does operations required after initialization has been done. void post_initialize(); From 20bfd4cf7c702f9c7ccfa2b4e940c04319ad0ff4 Mon Sep 17 00:00:00 2001 From: Marcus Larsson Date: Wed, 11 Feb 2015 14:47:21 +0100 Subject: [PATCH 085/116] 8066566: Refactor ParNewGeneration to contain ParNewTracer Reviewed-by: ehelin, kbarrett --- .../parNew/parNewGeneration.cpp | 35 +++++++++---------- .../parNew/parNewGeneration.hpp | 9 ++++- .../parallelScavenge/parallelScavengeHeap.cpp | 2 +- .../parallelScavenge/parallelScavengeHeap.hpp | 2 +- .../vm/gc_implementation/shared/gcTrace.cpp | 2 +- .../vm/gc_implementation/shared/gcTrace.hpp | 2 +- .../share/vm/gc_interface/collectedHeap.cpp | 6 ++-- .../share/vm/gc_interface/collectedHeap.hpp | 6 ++-- 8 files changed, 35 insertions(+), 29 deletions(-) diff --git a/hotspot/src/share/vm/gc_implementation/parNew/parNewGeneration.cpp b/hotspot/src/share/vm/gc_implementation/parNew/parNewGeneration.cpp index 30ef7ceb2c1..c4b0f9717e4 100644 --- a/hotspot/src/share/vm/gc_implementation/parNew/parNewGeneration.cpp +++ b/hotspot/src/share/vm/gc_implementation/parNew/parNewGeneration.cpp @@ -308,7 +308,7 @@ public: inline ParScanThreadState& thread_state(int i); - void trace_promotion_failed(YoungGCTracer& gc_tracer); + void trace_promotion_failed(const YoungGCTracer* gc_tracer); void reset(int active_workers, bool promotion_failed); void flush(); @@ -357,10 +357,10 @@ inline ParScanThreadState& ParScanThreadStateSet::thread_state(int i) return ((ParScanThreadState*)_data)[i]; } -void ParScanThreadStateSet::trace_promotion_failed(YoungGCTracer& gc_tracer) { +void ParScanThreadStateSet::trace_promotion_failed(const YoungGCTracer* gc_tracer) { for (int i = 0; i < length(); ++i) { if (thread_state(i).promotion_failed()) { - gc_tracer.report_promotion_failed(thread_state(i).promotion_failed_info()); + gc_tracer->report_promotion_failed(thread_state(i).promotion_failed_info()); thread_state(i).promotion_failed_info().reset(); } } @@ -883,7 +883,7 @@ void EvacuateFollowersClosureGeneral::do_void() { // A Generation that does parallel young-gen collection. -void ParNewGeneration::handle_promotion_failed(GenCollectedHeap* gch, ParScanThreadStateSet& thread_state_set, ParNewTracer& gc_tracer) { +void ParNewGeneration::handle_promotion_failed(GenCollectedHeap* gch, ParScanThreadStateSet& thread_state_set) { assert(_promo_failure_scan_stack.is_empty(), "post condition"); _promo_failure_scan_stack.clear(true); // Clear cached segments. @@ -899,10 +899,10 @@ void ParNewGeneration::handle_promotion_failed(GenCollectedHeap* gch, ParScanThr _next_gen->promotion_failure_occurred(); // Trace promotion failure in the parallel GC threads - thread_state_set.trace_promotion_failed(gc_tracer); + thread_state_set.trace_promotion_failed(gc_tracer()); // Single threaded code may have reported promotion failure to the global state if (_promotion_failed_info.has_failed()) { - gc_tracer.report_promotion_failed(_promotion_failed_info); + _gc_tracer.report_promotion_failed(_promotion_failed_info); } // Reset the PromotionFailureALot counters. NOT_PRODUCT(Universe::heap()->reset_promotion_should_fail();) @@ -941,9 +941,8 @@ void ParNewGeneration::collect(bool full, } assert(to()->is_empty(), "Else not collection_attempt_is_safe"); - ParNewTracer gc_tracer; - gc_tracer.report_gc_start(gch->gc_cause(), _gc_timer->gc_start()); - gch->trace_heap_before_gc(&gc_tracer); + _gc_tracer.report_gc_start(gch->gc_cause(), _gc_timer->gc_start()); + gch->trace_heap_before_gc(gc_tracer()); init_assuming_no_promotion_failure(); @@ -952,7 +951,7 @@ void ParNewGeneration::collect(bool full, size_policy->minor_collection_begin(); } - GCTraceTime t1(GCCauseString("GC", gch->gc_cause()), PrintGC && !PrintGCDetails, true, NULL, gc_tracer.gc_id()); + GCTraceTime t1(GCCauseString("GC", gch->gc_cause()), PrintGC && !PrintGCDetails, true, NULL, _gc_tracer.gc_id()); // Capture heap used before collection (for printing). size_t gch_prev_used = gch->used(); @@ -994,7 +993,7 @@ void ParNewGeneration::collect(bool full, // Trace and reset failed promotion info. if (promotion_failed()) { - thread_state_set.trace_promotion_failed(gc_tracer); + thread_state_set.trace_promotion_failed(gc_tracer()); } // Process (weak) reference objects found during scavenge. @@ -1015,16 +1014,16 @@ void ParNewGeneration::collect(bool full, ParNewRefProcTaskExecutor task_executor(*this, thread_state_set); stats = rp->process_discovered_references(&is_alive, &keep_alive, &evacuate_followers, &task_executor, - _gc_timer, gc_tracer.gc_id()); + _gc_timer, _gc_tracer.gc_id()); } else { thread_state_set.flush(); gch->set_par_threads(0); // 0 ==> non-parallel. gch->save_marks(); stats = rp->process_discovered_references(&is_alive, &keep_alive, &evacuate_followers, NULL, - _gc_timer, gc_tracer.gc_id()); + _gc_timer, _gc_tracer.gc_id()); } - gc_tracer.report_gc_reference_stats(stats); + _gc_tracer.report_gc_reference_stats(stats); if (!promotion_failed()) { // Swap the survivor spaces. eden()->clear(SpaceDecorator::Mangle); @@ -1049,7 +1048,7 @@ void ParNewGeneration::collect(bool full, adjust_desired_tenuring_threshold(); } else { - handle_promotion_failed(gch, thread_state_set, gc_tracer); + handle_promotion_failed(gch, thread_state_set); } // set new iteration safe limit for the survivor spaces from()->set_concurrent_iteration_safe_limit(from()->top()); @@ -1088,12 +1087,12 @@ void ParNewGeneration::collect(bool full, } rp->verify_no_references_recorded(); - gch->trace_heap_after_gc(&gc_tracer); - gc_tracer.report_tenuring_threshold(tenuring_threshold()); + gch->trace_heap_after_gc(gc_tracer()); + _gc_tracer.report_tenuring_threshold(tenuring_threshold()); _gc_timer->register_gc_end(); - gc_tracer.report_gc_end(_gc_timer->gc_end(), _gc_timer->time_partitions()); + _gc_tracer.report_gc_end(_gc_timer->gc_end(), _gc_timer->time_partitions()); } static int sum; diff --git a/hotspot/src/share/vm/gc_implementation/parNew/parNewGeneration.hpp b/hotspot/src/share/vm/gc_implementation/parNew/parNewGeneration.hpp index 13f7b67299e..ef0b0581765 100644 --- a/hotspot/src/share/vm/gc_implementation/parNew/parNewGeneration.hpp +++ b/hotspot/src/share/vm/gc_implementation/parNew/parNewGeneration.hpp @@ -333,6 +333,9 @@ class ParNewGeneration: public DefNewGeneration { // references to live referent. DefNewGeneration::IsAliveClosure _is_alive_closure; + // GC tracer that should be used during collection. + ParNewTracer _gc_tracer; + static oop real_forwardee_slow(oop obj); static void waste_some_time(); @@ -340,7 +343,7 @@ class ParNewGeneration: public DefNewGeneration { // word being overwritten with a self-forwarding-pointer. void preserve_mark_if_necessary(oop obj, markOop m); - void handle_promotion_failed(GenCollectedHeap* gch, ParScanThreadStateSet& thread_state_set, ParNewTracer& gc_tracer); + void handle_promotion_failed(GenCollectedHeap* gch, ParScanThreadStateSet& thread_state_set); protected: @@ -411,6 +414,10 @@ class ParNewGeneration: public DefNewGeneration { return _plab_stats.desired_plab_sz(); } + const ParNewTracer* gc_tracer() const { + return &_gc_tracer; + } + static oop real_forwardee(oop obj); DEBUG_ONLY(static bool is_legal_forward_ptr(oop p);) diff --git a/hotspot/src/share/vm/gc_implementation/parallelScavenge/parallelScavengeHeap.cpp b/hotspot/src/share/vm/gc_implementation/parallelScavenge/parallelScavengeHeap.cpp index 0a410ccb0f6..d9515ada2de 100644 --- a/hotspot/src/share/vm/gc_implementation/parallelScavenge/parallelScavengeHeap.cpp +++ b/hotspot/src/share/vm/gc_implementation/parallelScavenge/parallelScavengeHeap.cpp @@ -663,7 +663,7 @@ void ParallelScavengeHeap::print_heap_change(size_t prev_used) { } } -void ParallelScavengeHeap::trace_heap(GCWhen::Type when, GCTracer* gc_tracer) { +void ParallelScavengeHeap::trace_heap(GCWhen::Type when, const GCTracer* gc_tracer) { const PSHeapSummary& heap_summary = create_ps_heap_summary(); gc_tracer->report_gc_heap_summary(when, heap_summary); diff --git a/hotspot/src/share/vm/gc_implementation/parallelScavenge/parallelScavengeHeap.hpp b/hotspot/src/share/vm/gc_implementation/parallelScavenge/parallelScavengeHeap.hpp index 5173ff94ece..722ed9eeafd 100644 --- a/hotspot/src/share/vm/gc_implementation/parallelScavenge/parallelScavengeHeap.hpp +++ b/hotspot/src/share/vm/gc_implementation/parallelScavenge/parallelScavengeHeap.hpp @@ -64,7 +64,7 @@ class ParallelScavengeHeap : public CollectedHeap { // The task manager static GCTaskManager* _gc_task_manager; - void trace_heap(GCWhen::Type when, GCTracer* tracer); + void trace_heap(GCWhen::Type when, const GCTracer* tracer); protected: static inline size_t total_invocations(); diff --git a/hotspot/src/share/vm/gc_implementation/shared/gcTrace.cpp b/hotspot/src/share/vm/gc_implementation/shared/gcTrace.cpp index 79af8d24eb4..ae89c847c8c 100644 --- a/hotspot/src/share/vm/gc_implementation/shared/gcTrace.cpp +++ b/hotspot/src/share/vm/gc_implementation/shared/gcTrace.cpp @@ -162,7 +162,7 @@ void YoungGCTracer::report_gc_end_impl(const Ticks& timestamp, TimePartitions* t _tenuring_threshold = UNSET_TENURING_THRESHOLD; } -void YoungGCTracer::report_promotion_failed(const PromotionFailedInfo& pf_info) { +void YoungGCTracer::report_promotion_failed(const PromotionFailedInfo& pf_info) const { assert_set_gc_id(); send_promotion_failed_event(pf_info); diff --git a/hotspot/src/share/vm/gc_implementation/shared/gcTrace.hpp b/hotspot/src/share/vm/gc_implementation/shared/gcTrace.hpp index 9774dcb9537..9a16b693262 100644 --- a/hotspot/src/share/vm/gc_implementation/shared/gcTrace.hpp +++ b/hotspot/src/share/vm/gc_implementation/shared/gcTrace.hpp @@ -153,7 +153,7 @@ class YoungGCTracer : public GCTracer { virtual void report_gc_end_impl(const Ticks& timestamp, TimePartitions* time_partitions); public: - void report_promotion_failed(const PromotionFailedInfo& pf_info); + void report_promotion_failed(const PromotionFailedInfo& pf_info) const; void report_tenuring_threshold(const uint tenuring_threshold); /* diff --git a/hotspot/src/share/vm/gc_interface/collectedHeap.cpp b/hotspot/src/share/vm/gc_interface/collectedHeap.cpp index 0a71498f031..6927f273848 100644 --- a/hotspot/src/share/vm/gc_interface/collectedHeap.cpp +++ b/hotspot/src/share/vm/gc_interface/collectedHeap.cpp @@ -132,7 +132,7 @@ void CollectedHeap::unregister_nmethod(nmethod* nm) { assert_locked_or_safepoint(CodeCache_lock); } -void CollectedHeap::trace_heap(GCWhen::Type when, GCTracer* gc_tracer) { +void CollectedHeap::trace_heap(GCWhen::Type when, const GCTracer* gc_tracer) { const GCHeapSummary& heap_summary = create_heap_summary(); gc_tracer->report_gc_heap_summary(when, heap_summary); @@ -140,11 +140,11 @@ void CollectedHeap::trace_heap(GCWhen::Type when, GCTracer* gc_tracer) { gc_tracer->report_metaspace_summary(when, metaspace_summary); } -void CollectedHeap::trace_heap_before_gc(GCTracer* gc_tracer) { +void CollectedHeap::trace_heap_before_gc(const GCTracer* gc_tracer) { trace_heap(GCWhen::BeforeGC, gc_tracer); } -void CollectedHeap::trace_heap_after_gc(GCTracer* gc_tracer) { +void CollectedHeap::trace_heap_after_gc(const GCTracer* gc_tracer) { trace_heap(GCWhen::AfterGC, gc_tracer); } diff --git a/hotspot/src/share/vm/gc_interface/collectedHeap.hpp b/hotspot/src/share/vm/gc_interface/collectedHeap.hpp index bbd778c3463..8a4ec92a11b 100644 --- a/hotspot/src/share/vm/gc_interface/collectedHeap.hpp +++ b/hotspot/src/share/vm/gc_interface/collectedHeap.hpp @@ -175,7 +175,7 @@ class CollectedHeap : public CHeapObj { // Fill with a single object (either an int array or a java.lang.Object). static inline void fill_with_object_impl(HeapWord* start, size_t words, bool zap = true); - virtual void trace_heap(GCWhen::Type when, GCTracer* tracer); + virtual void trace_heap(GCWhen::Type when, const GCTracer* tracer); // Verification functions virtual void check_for_bad_heap_word_value(HeapWord* addr, size_t size) @@ -606,8 +606,8 @@ class CollectedHeap : public CHeapObj { virtual void register_nmethod(nmethod* nm); virtual void unregister_nmethod(nmethod* nm); - void trace_heap_before_gc(GCTracer* gc_tracer); - void trace_heap_after_gc(GCTracer* gc_tracer); + void trace_heap_before_gc(const GCTracer* gc_tracer); + void trace_heap_after_gc(const GCTracer* gc_tracer); // Heap verification virtual void verify(bool silent, VerifyOption option) = 0; From 654c89317047127abd0b36c1320f2297805bf888 Mon Sep 17 00:00:00 2001 From: Daniel Fuchs Date: Wed, 11 Feb 2015 17:41:55 +0100 Subject: [PATCH 086/116] 8072482: Cleanup: In jvm.cpp and other shared files declaration of 64bits constants should use the CONST64/UCONST64 macros instead of the LL suffix Reviewed-by: dholmes, coleenp --- hotspot/src/share/vm/opto/divnode.cpp | 4 ++-- hotspot/src/share/vm/prims/jvm.cpp | 2 +- 2 files changed, 3 insertions(+), 3 deletions(-) diff --git a/hotspot/src/share/vm/opto/divnode.cpp b/hotspot/src/share/vm/opto/divnode.cpp index 4677d00a9f7..002417d0f55 100644 --- a/hotspot/src/share/vm/opto/divnode.cpp +++ b/hotspot/src/share/vm/opto/divnode.cpp @@ -1,5 +1,5 @@ /* - * Copyright (c) 1997, 2012, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 1997, 2015, 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 @@ -219,7 +219,7 @@ static Node *transform_int_divide( PhaseGVN *phase, Node *dividend, jint divisor static bool magic_long_divide_constants(jlong d, jlong &M, jint &s) { int64_t p; uint64_t ad, anc, delta, q1, r1, q2, r2, t; - const uint64_t two63 = 0x8000000000000000LL; // 2**63. + const uint64_t two63 = UCONST64(0x8000000000000000); // 2**63. ad = ABS(d); if (d == 0 || d == 1) return false; diff --git a/hotspot/src/share/vm/prims/jvm.cpp b/hotspot/src/share/vm/prims/jvm.cpp index f73eca83b5c..29b96c94a7c 100644 --- a/hotspot/src/share/vm/prims/jvm.cpp +++ b/hotspot/src/share/vm/prims/jvm.cpp @@ -303,7 +303,7 @@ JVM_END // java.lang.System, but we choose to keep it here so that it stays next // to JVM_CurrentTimeMillis and JVM_NanoTime -const jlong MAX_DIFF_SECS = 0x0100000000LL; // 2^32 +const jlong MAX_DIFF_SECS = CONST64(0x0100000000); // 2^32 const jlong MIN_DIFF_SECS = -MAX_DIFF_SECS; // -2^32 JVM_LEAF(jlong, JVM_GetNanoTimeAdjustment(JNIEnv *env, jclass ignored, jlong offset_secs)) From 103110ad85ad828491e81eaf5655610181aba729 Mon Sep 17 00:00:00 2001 From: Jaroslav Bachorik Date: Thu, 12 Feb 2015 08:33:47 +0100 Subject: [PATCH 087/116] 8069286: Unexpected count of notification in LowMemoryTest Reviewed-by: mchung --- jdk/test/ProblemList.txt | 3 --- .../MemoryMXBean/LowMemoryTest.java | 20 ++++++++++++++----- 2 files changed, 15 insertions(+), 8 deletions(-) diff --git a/jdk/test/ProblemList.txt b/jdk/test/ProblemList.txt index 94a5a50bffb..b8bcd0e1dc9 100644 --- a/jdk/test/ProblemList.txt +++ b/jdk/test/ProblemList.txt @@ -141,9 +141,6 @@ java/lang/instrument/BootClassPath/BootClassPathTest.sh macosx-all # 8058492 java/lang/management/ThreadMXBean/FindDeadlocks.java generic-all -# 8069286 -java/lang/management/MemoryMXBean/LowMemoryTest.java generic-all - ############################################################################ # jdk_jmx diff --git a/jdk/test/java/lang/management/MemoryMXBean/LowMemoryTest.java b/jdk/test/java/lang/management/MemoryMXBean/LowMemoryTest.java index 96b9f0884f9..ce107bfb6de 100644 --- a/jdk/test/java/lang/management/MemoryMXBean/LowMemoryTest.java +++ b/jdk/test/java/lang/management/MemoryMXBean/LowMemoryTest.java @@ -32,8 +32,7 @@ * * @library /lib/testlibrary/ * @build jdk.testlibrary.* LowMemoryTest MemoryUtil RunUtil - * @requires vm.opt.ExplicitGCInvokesConcurrent == "false" | vm.opt.ExplicitGCInvokesConcurrent == "null" - * @run main/timeout=600 LowMemoryTest + * @run main/timeout=600 LowMemoryTest * @requires vm.opt.ExplicitGCInvokesConcurrent != "true" * @requires vm.opt.ExplicitGCInvokesConcurrentAndUnloadsClasses != "true" * @requires vm.opt.DisableExplicitGC != "true" @@ -116,14 +115,13 @@ public class LowMemoryTest { triggers++; } public void checkResult() throws Exception { - if ((!isRelaxed && triggers != NUM_TRIGGERS) || - (isRelaxed && triggers < NUM_TRIGGERS)) { + if (!checkValue(triggers, NUM_TRIGGERS)) { throw new RuntimeException("Unexpected number of triggers = " + triggers + " but expected to be " + NUM_TRIGGERS); } for (int i = 0; i < triggers; i++) { - if (count[i] != i+1) { + if (!checkValue(count[i], i + 1)) { throw new RuntimeException("Unexpected count of" + " notification #" + i + " count = " + count[i] + @@ -136,6 +134,18 @@ public class LowMemoryTest { } } } + + private boolean checkValue(int value, int target) { + return checkValue((long)value, target); + } + + private boolean checkValue(long value, int target) { + if (!isRelaxed) { + return value == target; + } else { + return value >= target; + } + } } private static long newThreshold; From 2c4a9ce20bd4b8cdeed34d45195fb69eeb27aae3 Mon Sep 17 00:00:00 2001 From: Jaroslav Bachorik Date: Thu, 12 Feb 2015 17:01:10 +0100 Subject: [PATCH 088/116] 8072932: Test fails with java.security.AccessControlException: access denied ("java.security.SecurityPermission" "getDomainCombiner") Reviewed-by: mullan --- .../java.base/share/classes/java/security/ProtectionDomain.java | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/jdk/src/java.base/share/classes/java/security/ProtectionDomain.java b/jdk/src/java.base/share/classes/java/security/ProtectionDomain.java index 8903ffcffcc..2e505d74554 100644 --- a/jdk/src/java.base/share/classes/java/security/ProtectionDomain.java +++ b/jdk/src/java.base/share/classes/java/security/ProtectionDomain.java @@ -88,7 +88,7 @@ public class ProtectionDomain { } private static AccessControlContext getCombinedACC(AccessControlContext context, AccessControlContext stack) { - AccessControlContext acc = new AccessControlContext(context, stack.getDomainCombiner(), true); + AccessControlContext acc = new AccessControlContext(context, stack.getCombiner(), true); return new AccessControlContext(stack.getContext(), acc).optimize(); } From 351ed3d735a3b372933ab44fd7ee8535760055c0 Mon Sep 17 00:00:00 2001 From: Weijun Wang Date: Fri, 13 Feb 2015 11:03:13 +0800 Subject: [PATCH 089/116] 8071338: Move policytool from JRE to JDK Reviewed-by: alanb, erikj, ihse, mchung --- common/bin/unshuffle_list.txt | 2 +- make/Images.gmk | 2 +- modules.xml | 6 ++---- 3 files changed, 4 insertions(+), 6 deletions(-) diff --git a/common/bin/unshuffle_list.txt b/common/bin/unshuffle_list.txt index eba22894ea8..0638141a5ac 100644 --- a/common/bin/unshuffle_list.txt +++ b/common/bin/unshuffle_list.txt @@ -1303,6 +1303,7 @@ jdk/src/jdk.deploy.osx/macosx/native/libosx/KeystoreImpl.m : jdk/src/macosx/nati jdk/src/jdk.dev/share/classes/com/sun/jarsigner : jdk/src/share/classes/com/sun/jarsigner jdk/src/jdk.dev/share/classes/com/sun/tools/hat : jdk/src/share/classes/com/sun/tools/hat jdk/src/jdk.dev/share/classes/sun/security/tools/jarsigner : jdk/src/share/classes/sun/security/tools/jarsigner +jdk/src/jdk.dev/share/classes/sun/security/tools/policytool : jdk/src/share/classes/sun/security/tools/policytool jdk/src/jdk.dev/share/classes/sun/tools/jar : jdk/src/share/classes/sun/tools/jar jdk/src/jdk.dev/share/classes/sun/tools/native2ascii : jdk/src/share/classes/sun/tools/native2ascii jdk/src/jdk.hprof.agent/share/classes/com/sun/demo/jvmti/hprof : jdk/src/share/classes/com/sun/demo/jvmti/hprof @@ -1443,7 +1444,6 @@ jdk/src/jdk.rmic/share/classes/sun/tools/java : jdk/src/share/classes/sun/tools/ jdk/src/jdk.rmic/share/classes/sun/tools/tree : jdk/src/share/classes/sun/tools/tree jdk/src/jdk.rmic/share/classes/sun/tools/util : jdk/src/share/classes/sun/tools/util jdk/src/jdk.runtime/share/classes/com/sun/tracing : jdk/src/share/classes/com/sun/tracing -jdk/src/jdk.runtime/share/classes/sun/security/tools/policytool : jdk/src/share/classes/sun/security/tools/policytool jdk/src/jdk.runtime/share/classes/sun/tracing : jdk/src/share/classes/sun/tracing jdk/src/jdk.runtime/share/native/common-unpack/bands.cpp : jdk/src/share/native/com/sun/java/util/jar/pack/bands.cpp jdk/src/jdk.runtime/share/native/common-unpack/bands.h : jdk/src/share/native/com/sun/java/util/jar/pack/bands.h diff --git a/make/Images.gmk b/make/Images.gmk index 5913c0703df..56704b08f8e 100644 --- a/make/Images.gmk +++ b/make/Images.gmk @@ -183,7 +183,6 @@ ifneq ($(OPENJDK_TARGET_OS), windows) keytool.1 \ orbd.1 \ pack200.1 \ - policytool.1 \ rmid.1 \ rmiregistry.1 \ servertool.1 \ @@ -220,6 +219,7 @@ ifneq ($(OPENJDK_TARGET_OS), windows) jstat.1 \ jstatd.1 \ native2ascii.1 \ + policytool.1 \ rmic.1 \ schemagen.1 \ serialver.1 \ diff --git a/modules.xml b/modules.xml index 1844706864c..2184ba6b8b4 100644 --- a/modules.xml +++ b/modules.xml @@ -358,7 +358,7 @@ java.rmi java.security.jgss jdk.crypto.pkcs11 - jdk.runtime + jdk.dev jdk.security.auth @@ -391,7 +391,6 @@ jdk.crypto.ucrypto jdk.deploy.osx jdk.dev - jdk.runtime jdk.security.auth @@ -1576,6 +1575,7 @@ java.base java.scripting java.xml + java.desktop jdk.compiler jdk.rmic jdk.xml.bind @@ -1710,8 +1710,6 @@ jdk.runtime java.base - java.desktop - java.se jdk.scripting.nashorn From 3cb54779b0e0aa1bc86f03171355a88dff8d1172 Mon Sep 17 00:00:00 2001 From: Weijun Wang Date: Fri, 13 Feb 2015 11:03:57 +0800 Subject: [PATCH 090/116] 8071338: Move policytool from JRE to JDK Reviewed-by: alanb, erikj, ihse, mchung --- jdk/make/launcher/Launcher-jdk.dev.gmk | 6 ++++++ jdk/make/launcher/Launcher-jdk.runtime.gmk | 6 ------ .../classes/sun/security/tools/policytool/PolicyTool.java | 0 .../classes/sun/security/tools/policytool/Resources.java | 0 .../classes/sun/security/tools/policytool/Resources_de.java | 0 .../classes/sun/security/tools/policytool/Resources_es.java | 0 .../classes/sun/security/tools/policytool/Resources_fr.java | 0 .../classes/sun/security/tools/policytool/Resources_it.java | 0 .../classes/sun/security/tools/policytool/Resources_ja.java | 0 .../classes/sun/security/tools/policytool/Resources_ko.java | 0 .../sun/security/tools/policytool/Resources_pt_BR.java | 0 .../classes/sun/security/tools/policytool/Resources_sv.java | 0 .../sun/security/tools/policytool/Resources_zh_CN.java | 0 .../sun/security/tools/policytool/Resources_zh_HK.java | 0 .../sun/security/tools/policytool/Resources_zh_TW.java | 0 jdk/test/TEST.groups | 2 +- 16 files changed, 7 insertions(+), 7 deletions(-) rename jdk/src/{jdk.runtime => jdk.dev}/share/classes/sun/security/tools/policytool/PolicyTool.java (100%) rename jdk/src/{jdk.runtime => jdk.dev}/share/classes/sun/security/tools/policytool/Resources.java (100%) rename jdk/src/{jdk.runtime => jdk.dev}/share/classes/sun/security/tools/policytool/Resources_de.java (100%) rename jdk/src/{jdk.runtime => jdk.dev}/share/classes/sun/security/tools/policytool/Resources_es.java (100%) rename jdk/src/{jdk.runtime => jdk.dev}/share/classes/sun/security/tools/policytool/Resources_fr.java (100%) rename jdk/src/{jdk.runtime => jdk.dev}/share/classes/sun/security/tools/policytool/Resources_it.java (100%) rename jdk/src/{jdk.runtime => jdk.dev}/share/classes/sun/security/tools/policytool/Resources_ja.java (100%) rename jdk/src/{jdk.runtime => jdk.dev}/share/classes/sun/security/tools/policytool/Resources_ko.java (100%) rename jdk/src/{jdk.runtime => jdk.dev}/share/classes/sun/security/tools/policytool/Resources_pt_BR.java (100%) rename jdk/src/{jdk.runtime => jdk.dev}/share/classes/sun/security/tools/policytool/Resources_sv.java (100%) rename jdk/src/{jdk.runtime => jdk.dev}/share/classes/sun/security/tools/policytool/Resources_zh_CN.java (100%) rename jdk/src/{jdk.runtime => jdk.dev}/share/classes/sun/security/tools/policytool/Resources_zh_HK.java (100%) rename jdk/src/{jdk.runtime => jdk.dev}/share/classes/sun/security/tools/policytool/Resources_zh_TW.java (100%) diff --git a/jdk/make/launcher/Launcher-jdk.dev.gmk b/jdk/make/launcher/Launcher-jdk.dev.gmk index 6008ffd3b6d..92b6d1bacb9 100644 --- a/jdk/make/launcher/Launcher-jdk.dev.gmk +++ b/jdk/make/launcher/Launcher-jdk.dev.gmk @@ -31,6 +31,12 @@ $(eval $(call SetupLauncher,jar, \ $(eval $(call SetupLauncher,jarsigner, \ -DJAVA_ARGS='{ "-J-ms8m"$(COMMA) "sun.security.tools.jarsigner.Main"$(COMMA) }')) +ifndef BUILD_HEADLESS_ONLY + $(eval $(call SetupLauncher,policytool, \ + -DJAVA_ARGS='{ "-J-ms8m"$(COMMA) "sun.security.tools.policytool.PolicyTool"$(COMMA) }',, \ + $(XLIBS))) +endif + $(eval $(call SetupLauncher,jdeps, \ -DEXPAND_CLASSPATH_WILDCARDS \ -DNEVER_ACT_AS_SERVER_CLASS_MACHINE \ diff --git a/jdk/make/launcher/Launcher-jdk.runtime.gmk b/jdk/make/launcher/Launcher-jdk.runtime.gmk index 96c02be5689..366dc5cc9a2 100644 --- a/jdk/make/launcher/Launcher-jdk.runtime.gmk +++ b/jdk/make/launcher/Launcher-jdk.runtime.gmk @@ -25,12 +25,6 @@ include LauncherCommon.gmk -ifndef BUILD_HEADLESS_ONLY - $(eval $(call SetupLauncher,policytool, \ - -DJAVA_ARGS='{ "-J-ms8m"$(COMMA) "sun.security.tools.policytool.PolicyTool"$(COMMA) }',, \ - $(XLIBS))) -endif - $(eval $(call SetupLauncher,pack200, \ -DJAVA_ARGS='{ "-J-ms8m"$(COMMA) "com.sun.java.util.jar.pack.Driver"$(COMMA) }')) diff --git a/jdk/src/jdk.runtime/share/classes/sun/security/tools/policytool/PolicyTool.java b/jdk/src/jdk.dev/share/classes/sun/security/tools/policytool/PolicyTool.java similarity index 100% rename from jdk/src/jdk.runtime/share/classes/sun/security/tools/policytool/PolicyTool.java rename to jdk/src/jdk.dev/share/classes/sun/security/tools/policytool/PolicyTool.java diff --git a/jdk/src/jdk.runtime/share/classes/sun/security/tools/policytool/Resources.java b/jdk/src/jdk.dev/share/classes/sun/security/tools/policytool/Resources.java similarity index 100% rename from jdk/src/jdk.runtime/share/classes/sun/security/tools/policytool/Resources.java rename to jdk/src/jdk.dev/share/classes/sun/security/tools/policytool/Resources.java diff --git a/jdk/src/jdk.runtime/share/classes/sun/security/tools/policytool/Resources_de.java b/jdk/src/jdk.dev/share/classes/sun/security/tools/policytool/Resources_de.java similarity index 100% rename from jdk/src/jdk.runtime/share/classes/sun/security/tools/policytool/Resources_de.java rename to jdk/src/jdk.dev/share/classes/sun/security/tools/policytool/Resources_de.java diff --git a/jdk/src/jdk.runtime/share/classes/sun/security/tools/policytool/Resources_es.java b/jdk/src/jdk.dev/share/classes/sun/security/tools/policytool/Resources_es.java similarity index 100% rename from jdk/src/jdk.runtime/share/classes/sun/security/tools/policytool/Resources_es.java rename to jdk/src/jdk.dev/share/classes/sun/security/tools/policytool/Resources_es.java diff --git a/jdk/src/jdk.runtime/share/classes/sun/security/tools/policytool/Resources_fr.java b/jdk/src/jdk.dev/share/classes/sun/security/tools/policytool/Resources_fr.java similarity index 100% rename from jdk/src/jdk.runtime/share/classes/sun/security/tools/policytool/Resources_fr.java rename to jdk/src/jdk.dev/share/classes/sun/security/tools/policytool/Resources_fr.java diff --git a/jdk/src/jdk.runtime/share/classes/sun/security/tools/policytool/Resources_it.java b/jdk/src/jdk.dev/share/classes/sun/security/tools/policytool/Resources_it.java similarity index 100% rename from jdk/src/jdk.runtime/share/classes/sun/security/tools/policytool/Resources_it.java rename to jdk/src/jdk.dev/share/classes/sun/security/tools/policytool/Resources_it.java diff --git a/jdk/src/jdk.runtime/share/classes/sun/security/tools/policytool/Resources_ja.java b/jdk/src/jdk.dev/share/classes/sun/security/tools/policytool/Resources_ja.java similarity index 100% rename from jdk/src/jdk.runtime/share/classes/sun/security/tools/policytool/Resources_ja.java rename to jdk/src/jdk.dev/share/classes/sun/security/tools/policytool/Resources_ja.java diff --git a/jdk/src/jdk.runtime/share/classes/sun/security/tools/policytool/Resources_ko.java b/jdk/src/jdk.dev/share/classes/sun/security/tools/policytool/Resources_ko.java similarity index 100% rename from jdk/src/jdk.runtime/share/classes/sun/security/tools/policytool/Resources_ko.java rename to jdk/src/jdk.dev/share/classes/sun/security/tools/policytool/Resources_ko.java diff --git a/jdk/src/jdk.runtime/share/classes/sun/security/tools/policytool/Resources_pt_BR.java b/jdk/src/jdk.dev/share/classes/sun/security/tools/policytool/Resources_pt_BR.java similarity index 100% rename from jdk/src/jdk.runtime/share/classes/sun/security/tools/policytool/Resources_pt_BR.java rename to jdk/src/jdk.dev/share/classes/sun/security/tools/policytool/Resources_pt_BR.java diff --git a/jdk/src/jdk.runtime/share/classes/sun/security/tools/policytool/Resources_sv.java b/jdk/src/jdk.dev/share/classes/sun/security/tools/policytool/Resources_sv.java similarity index 100% rename from jdk/src/jdk.runtime/share/classes/sun/security/tools/policytool/Resources_sv.java rename to jdk/src/jdk.dev/share/classes/sun/security/tools/policytool/Resources_sv.java diff --git a/jdk/src/jdk.runtime/share/classes/sun/security/tools/policytool/Resources_zh_CN.java b/jdk/src/jdk.dev/share/classes/sun/security/tools/policytool/Resources_zh_CN.java similarity index 100% rename from jdk/src/jdk.runtime/share/classes/sun/security/tools/policytool/Resources_zh_CN.java rename to jdk/src/jdk.dev/share/classes/sun/security/tools/policytool/Resources_zh_CN.java diff --git a/jdk/src/jdk.runtime/share/classes/sun/security/tools/policytool/Resources_zh_HK.java b/jdk/src/jdk.dev/share/classes/sun/security/tools/policytool/Resources_zh_HK.java similarity index 100% rename from jdk/src/jdk.runtime/share/classes/sun/security/tools/policytool/Resources_zh_HK.java rename to jdk/src/jdk.dev/share/classes/sun/security/tools/policytool/Resources_zh_HK.java diff --git a/jdk/src/jdk.runtime/share/classes/sun/security/tools/policytool/Resources_zh_TW.java b/jdk/src/jdk.dev/share/classes/sun/security/tools/policytool/Resources_zh_TW.java similarity index 100% rename from jdk/src/jdk.runtime/share/classes/sun/security/tools/policytool/Resources_zh_TW.java rename to jdk/src/jdk.dev/share/classes/sun/security/tools/policytool/Resources_zh_TW.java diff --git a/jdk/test/TEST.groups b/jdk/test/TEST.groups index 7acb6ab9147..e102455ec8d 100644 --- a/jdk/test/TEST.groups +++ b/jdk/test/TEST.groups @@ -407,6 +407,7 @@ needs_jdk = \ com/sun/tools \ demo \ sun/security/tools/jarsigner \ + sun/security/tools/policytool \ sun/rmi/rmic \ sun/tools \ sun/jvmstat \ @@ -456,7 +457,6 @@ needs_jre = \ com/oracle/security/ucrypto/TestRSA.java \ sun/net/ftp \ sun/net/www/protocol/ftp \ - sun/security/tools/policytool \ java/net/URI/URItoURLTest.java \ java/net/URL/URIToURLTest.java \ java/net/URLConnection/HandleContentTypeWithAttrs.java \ From 4b2af9acf9f52f506a4da99d4a342da48fc174e8 Mon Sep 17 00:00:00 2001 From: Paul Sandoz Date: Fri, 13 Feb 2015 11:13:27 +0100 Subject: [PATCH 091/116] 8071670: java.util.Optional: please add a way to specify if-else behavior Reviewed-by: dfuchs, lowasser --- .../share/classes/java/util/Optional.java | 33 +++-- .../classes/java/util/OptionalDouble.java | 33 +++-- .../share/classes/java/util/OptionalInt.java | 33 +++-- .../share/classes/java/util/OptionalLong.java | 33 +++-- jdk/test/java/util/Optional/Basic.java | 70 ++++++++++- jdk/test/java/util/Optional/BasicDouble.java | 111 +++++++++++++---- jdk/test/java/util/Optional/BasicInt.java | 67 ++++++++++- jdk/test/java/util/Optional/BasicLong.java | 113 ++++++++++++++---- 8 files changed, 413 insertions(+), 80 deletions(-) diff --git a/jdk/src/java.base/share/classes/java/util/Optional.java b/jdk/src/java.base/share/classes/java/util/Optional.java index eb8301b2361..21fef4c13e0 100644 --- a/jdk/src/java.base/share/classes/java/util/Optional.java +++ b/jdk/src/java.base/share/classes/java/util/Optional.java @@ -38,8 +38,8 @@ import java.util.stream.Stream; *

Additional methods that depend on the presence or absence of a contained * value are provided, such as {@link #orElse(java.lang.Object) orElse()} * (return a default value if value not present) and - * {@link #ifPresent(java.util.function.Consumer) ifPresent()} (execute a block - * of code if the value is present). + * {@link #ifPresent(java.util.function.Consumer) ifPresent()} (perform an + * action if the value is present). * *

This is a value-based * class; use of identity-sensitive operations (including reference equality @@ -148,16 +148,35 @@ public final class Optional { } /** - * If a value is present, invoke the specified consumer with the value, + * If a value is present, perform the given action with the value, * otherwise do nothing. * - * @param consumer block to be executed if a value is present - * @throws NullPointerException if value is present and {@code consumer} is + * @param action the action to be performed if a value is present + * @throws NullPointerException if a value is present and {@code action} is * null */ - public void ifPresent(Consumer consumer) { + public void ifPresent(Consumer action) { if (value != null) { - consumer.accept(value); + action.accept(value); + } + } + + /** + * If a value is present, perform the given action with the value, + * otherwise perform the given empty-based action. + * + * @param action the action to be performed if a value is present + * @param emptyAction the empty-based action to be performed if a value is + * not present + * @throws NullPointerException if a value is present and {@code action} is + * null, or a value is not present and {@code emptyAction} is null. + * @since 1.9 + */ + public void ifPresentOrElse(Consumer action, Runnable emptyAction) { + if (value != null) { + action.accept(value); + } else { + emptyAction.run(); } } diff --git a/jdk/src/java.base/share/classes/java/util/OptionalDouble.java b/jdk/src/java.base/share/classes/java/util/OptionalDouble.java index e699c53d517..3de841e80f4 100644 --- a/jdk/src/java.base/share/classes/java/util/OptionalDouble.java +++ b/jdk/src/java.base/share/classes/java/util/OptionalDouble.java @@ -37,8 +37,8 @@ import java.util.stream.DoubleStream; *

Additional methods that depend on the presence or absence of a contained * value are provided, such as {@link #orElse(double) orElse()} * (return a default value if value not present) and - * {@link #ifPresent(java.util.function.DoubleConsumer) ifPresent()} (execute a block - * of code if the value is present). + * {@link #ifPresent(java.util.function.DoubleConsumer) ifPresent()} (perform an + * action if the value is present). * *

This is a value-based * class; use of identity-sensitive operations (including reference equality @@ -131,16 +131,35 @@ public final class OptionalDouble { } /** - * Have the specified consumer accept the value if a value is present, + * If a value is present, perform the given action with the value, * otherwise do nothing. * - * @param consumer block to be executed if a value is present - * @throws NullPointerException if value is present and {@code consumer} is + * @param action the action to be performed if a value is present + * @throws NullPointerException if a value is present and {@code action} is * null */ - public void ifPresent(DoubleConsumer consumer) { + public void ifPresent(DoubleConsumer action) { if (isPresent) { - consumer.accept(value); + action.accept(value); + } + } + + /** + * If a value is present, perform the given action with the value, + * otherwise perform the given empty-based action. + * + * @param action the action to be performed if a value is present + * @param emptyAction the empty-based action to be performed if a value is + * not present + * @throws NullPointerException if a value is present and {@code action} is + * null, or a value is not present and {@code emptyAction} is null. + * @since 1.9 + */ + public void ifPresentOrElse(DoubleConsumer action, Runnable emptyAction) { + if (isPresent) { + action.accept(value); + } else { + emptyAction.run(); } } diff --git a/jdk/src/java.base/share/classes/java/util/OptionalInt.java b/jdk/src/java.base/share/classes/java/util/OptionalInt.java index d8d9382633d..38b9bd0294c 100644 --- a/jdk/src/java.base/share/classes/java/util/OptionalInt.java +++ b/jdk/src/java.base/share/classes/java/util/OptionalInt.java @@ -37,8 +37,8 @@ import java.util.stream.IntStream; *

Additional methods that depend on the presence or absence of a contained * value are provided, such as {@link #orElse(int) orElse()} * (return a default value if value not present) and - * {@link #ifPresent(java.util.function.IntConsumer) ifPresent()} (execute a block - * of code if the value is present). + * {@link #ifPresent(java.util.function.IntConsumer) ifPresent()} (perform an + * action if the value is present). * *

This is a value-based * class; use of identity-sensitive operations (including reference equality @@ -131,16 +131,35 @@ public final class OptionalInt { } /** - * Have the specified consumer accept the value if a value is present, + * If a value is present, perform the given action with the value, * otherwise do nothing. * - * @param consumer block to be executed if a value is present - * @throws NullPointerException if value is present and {@code consumer} is + * @param action the action to be performed if a value is present + * @throws NullPointerException if value is present and {@code action} is * null */ - public void ifPresent(IntConsumer consumer) { + public void ifPresent(IntConsumer action) { if (isPresent) { - consumer.accept(value); + action.accept(value); + } + } + + /** + * If a value is present, perform the given action with the value, + * otherwise perform the given empty-based action. + * + * @param action the action to be performed if a value is present + * @param emptyAction the empty-based action to be performed if a value is + * not present + * @throws NullPointerException if a value is present and {@code action} is + * null, or a value is not present and {@code emptyAction} is null. + * @since 1.9 + */ + public void ifPresentOrElse(IntConsumer action, Runnable emptyAction) { + if (isPresent) { + action.accept(value); + } else { + emptyAction.run(); } } diff --git a/jdk/src/java.base/share/classes/java/util/OptionalLong.java b/jdk/src/java.base/share/classes/java/util/OptionalLong.java index 4e2a44873b3..d6d56b9aee4 100644 --- a/jdk/src/java.base/share/classes/java/util/OptionalLong.java +++ b/jdk/src/java.base/share/classes/java/util/OptionalLong.java @@ -37,8 +37,8 @@ import java.util.stream.LongStream; *

Additional methods that depend on the presence or absence of a contained * value are provided, such as {@link #orElse(long) orElse()} * (return a default value if value not present) and - * {@link #ifPresent(java.util.function.LongConsumer) ifPresent()} (execute a block - * of code if the value is present). + * {@link #ifPresent(java.util.function.LongConsumer) ifPresent()} (perform an + * action if the value is present). * *

This is a value-based * class; use of identity-sensitive operations (including reference equality @@ -131,16 +131,35 @@ public final class OptionalLong { } /** - * Have the specified consumer accept the value if a value is present, + * If a value is present, perform the given action with the value, * otherwise do nothing. * - * @param consumer block to be executed if a value is present - * @throws NullPointerException if value is present and {@code consumer} is + * @param action the action to be performed if a value is present + * @throws NullPointerException if a value is present and {@code action} is * null */ - public void ifPresent(LongConsumer consumer) { + public void ifPresent(LongConsumer action) { if (isPresent) { - consumer.accept(value); + action.accept(value); + } + } + + /** + * If a value is present, perform the given action with the value, + * otherwise perform the given empty-based action. + * + * @param action the action to be performed if a value is present + * @param emptyAction the empty-based action to be performed if a value is + * not present + * @throws NullPointerException if a value is present and {@code action} is + * null, or a value is not present and {@code emptyAction} is null. + * @since 1.9 + */ + public void ifPresentOrElse(LongConsumer action, Runnable emptyAction) { + if (isPresent) { + action.accept(value); + } else { + emptyAction.run(); } } diff --git a/jdk/test/java/util/Optional/Basic.java b/jdk/test/java/util/Optional/Basic.java index f37397d90b9..e07fc62ce40 100644 --- a/jdk/test/java/util/Optional/Basic.java +++ b/jdk/test/java/util/Optional/Basic.java @@ -27,8 +27,12 @@ * @run testng Basic */ +import java.lang.AssertionError; +import java.lang.NullPointerException; +import java.lang.Throwable; import java.util.NoSuchElementException; import java.util.Optional; +import java.util.concurrent.atomic.AtomicBoolean; import java.util.stream.Stream; import static org.testng.Assert.*; @@ -51,7 +55,23 @@ public class Basic { assertTrue(!empty.toString().isEmpty()); assertTrue(!empty.toString().equals(presentEmptyString.toString())); assertTrue(!empty.isPresent()); - empty.ifPresent(v -> { fail(); }); + + empty.ifPresent(v -> fail()); + + AtomicBoolean emptyCheck = new AtomicBoolean(); + empty.ifPresentOrElse(v -> fail(), () -> emptyCheck.set(true)); + assertTrue(emptyCheck.get()); + + try { + empty.ifPresentOrElse(v -> fail(), () -> { throw new ObscureException(); }); + fail(); + } catch (ObscureException expected) { + } catch (AssertionError e) { + throw e; + } catch (Throwable t) { + fail(); + } + assertSame(null, empty.orElse(null)); RuntimeException orElse = new RuntimeException() { }; assertSame(Boolean.FALSE, empty.orElse(Boolean.FALSE)); @@ -59,6 +79,31 @@ public class Basic { assertSame(Boolean.FALSE, empty.orElseGet(() -> Boolean.FALSE)); } + @Test(groups = "unit") + public void testIfPresentAndOrElseAndNull() { + Optional empty = Optional.empty(); + Optional present = Optional.of(Boolean.TRUE); + + // No NPE + present.ifPresentOrElse(v -> {}, null); + empty.ifPresent(null); + empty.ifPresentOrElse(null, () -> {}); + + // NPE + try { + present.ifPresent(null); + fail(); + } catch (NullPointerException ex) {} + try { + present.ifPresentOrElse(null, () -> {}); + fail(); + } catch (NullPointerException ex) {} + try { + empty.ifPresentOrElse(v -> {}, null); + fail(); + } catch (NullPointerException ex) {} + } + @Test(expectedExceptions=NoSuchElementException.class) public void testEmptyGet() { Optional empty = Optional.empty(); @@ -102,12 +147,33 @@ public class Basic { assertTrue(!present.toString().equals(presentEmptyString.toString())); assertTrue(-1 != present.toString().indexOf(Boolean.TRUE.toString())); assertSame(Boolean.TRUE, present.get()); + + AtomicBoolean presentCheck = new AtomicBoolean(); + present.ifPresent(v -> presentCheck.set(true)); + assertTrue(presentCheck.get()); + presentCheck.set(false); + present.ifPresentOrElse(v -> presentCheck.set(true), () -> fail()); + assertTrue(presentCheck.get()); + try { present.ifPresent(v -> { throw new ObscureException(); }); fail(); } catch (ObscureException expected) { - + } catch (AssertionError e) { + throw e; + } catch (Throwable t) { + fail(); } + try { + present.ifPresentOrElse(v -> { throw new ObscureException(); }, () -> fail()); + fail(); + } catch (ObscureException expected) { + } catch (AssertionError e) { + throw e; + } catch (Throwable t) { + fail(); + } + assertSame(Boolean.TRUE, present.orElse(null)); assertSame(Boolean.TRUE, present.orElse(Boolean.FALSE)); assertSame(Boolean.TRUE, present.orElseGet(null)); diff --git a/jdk/test/java/util/Optional/BasicDouble.java b/jdk/test/java/util/Optional/BasicDouble.java index df8ae9e0431..efff275b4d8 100644 --- a/jdk/test/java/util/Optional/BasicDouble.java +++ b/jdk/test/java/util/Optional/BasicDouble.java @@ -29,6 +29,7 @@ import java.util.NoSuchElementException; import java.util.OptionalDouble; +import java.util.concurrent.atomic.AtomicBoolean; import java.util.stream.DoubleStream; import static org.testng.Assert.*; @@ -49,41 +50,82 @@ public class BasicDouble { assertTrue(0 == empty.hashCode()); assertTrue(!empty.toString().isEmpty()); assertTrue(!empty.isPresent()); + empty.ifPresent(v -> { fail(); }); + + AtomicBoolean emptyCheck = new AtomicBoolean(); + empty.ifPresentOrElse(v -> fail(), () -> emptyCheck.set(true)); + assertTrue(emptyCheck.get()); + + try { + empty.ifPresentOrElse(v -> fail(), () -> { throw new ObscureException(); }); + fail(); + } catch (ObscureException expected) { + } catch (AssertionError e) { + throw e; + } catch (Throwable t) { + fail(); + } + assertEquals(2.0, empty.orElse(2.0)); assertEquals(2.0, empty.orElseGet(()-> 2.0)); } - @Test(expectedExceptions=NoSuchElementException.class) - public void testEmptyGet() { - OptionalDouble empty = OptionalDouble.empty(); + @Test(groups = "unit") + public void testIfPresentAndOrElseAndNull() { + OptionalDouble empty = OptionalDouble.empty(); + OptionalDouble present = OptionalDouble.of(1.0); - double got = empty.getAsDouble(); - } + // No NPE + present.ifPresentOrElse(v -> {}, null); + empty.ifPresent(null); + empty.ifPresentOrElse(null, () -> {}); - @Test(expectedExceptions=NullPointerException.class) - public void testEmptyOrElseGetNull() { - OptionalDouble empty = OptionalDouble.empty(); + // NPE + try { + present.ifPresent(null); + fail(); + } catch (NullPointerException ex) {} + try { + present.ifPresentOrElse(null, () -> {}); + fail(); + } catch (NullPointerException ex) {} + try { + empty.ifPresentOrElse(v -> {}, null); + fail(); + } catch (NullPointerException ex) {} + } - double got = empty.orElseGet(null); - } + @Test(expectedExceptions=NoSuchElementException.class) + public void testEmptyGet() { + OptionalDouble empty = OptionalDouble.empty(); - @Test(expectedExceptions=NullPointerException.class) - public void testEmptyOrElseThrowNull() throws Throwable { - OptionalDouble empty = OptionalDouble.empty(); + double got = empty.getAsDouble(); + } - double got = empty.orElseThrow(null); - } + @Test(expectedExceptions=NullPointerException.class) + public void testEmptyOrElseGetNull() { + OptionalDouble empty = OptionalDouble.empty(); - @Test(expectedExceptions=ObscureException.class) - public void testEmptyOrElseThrow() throws Exception { - OptionalDouble empty = OptionalDouble.empty(); + double got = empty.orElseGet(null); + } - double got = empty.orElseThrow(ObscureException::new); - } + @Test(expectedExceptions=NullPointerException.class) + public void testEmptyOrElseThrowNull() throws Throwable { + OptionalDouble empty = OptionalDouble.empty(); - @Test(groups = "unit") - public void testPresent() { + double got = empty.orElseThrow(null); + } + + @Test(expectedExceptions=ObscureException.class) + public void testEmptyOrElseThrow() throws Exception { + OptionalDouble empty = OptionalDouble.empty(); + + double got = empty.orElseThrow(ObscureException::new); + } + + @Test(groups = "unit") + public void testPresent() { OptionalDouble empty = OptionalDouble.empty(); OptionalDouble present = OptionalDouble.of(1.0); @@ -96,12 +138,33 @@ public class BasicDouble { assertFalse(present.toString().isEmpty()); assertTrue(-1 != present.toString().indexOf(Double.toString(present.getAsDouble()).toString())); assertEquals(1.0, present.getAsDouble()); + + AtomicBoolean presentCheck = new AtomicBoolean(); + present.ifPresent(v -> presentCheck.set(true)); + assertTrue(presentCheck.get()); + presentCheck.set(false); + present.ifPresentOrElse(v -> presentCheck.set(true), () -> fail()); + assertTrue(presentCheck.get()); + try { present.ifPresent(v -> { throw new ObscureException(); }); fail(); - } catch(ObscureException expected) { - + } catch (ObscureException expected) { + } catch (AssertionError e) { + throw e; + } catch (Throwable t) { + fail(); } + try { + present.ifPresentOrElse(v -> { throw new ObscureException(); }, () -> fail()); + fail(); + } catch (ObscureException expected) { + } catch (AssertionError e) { + throw e; + } catch (Throwable t) { + fail(); + } + assertEquals(1.0, present.orElse(2.0)); assertEquals(1.0, present.orElseGet(null)); assertEquals(1.0, present.orElseGet(()-> 2.0)); diff --git a/jdk/test/java/util/Optional/BasicInt.java b/jdk/test/java/util/Optional/BasicInt.java index 8f3b2d5d82c..b9f4620273d 100644 --- a/jdk/test/java/util/Optional/BasicInt.java +++ b/jdk/test/java/util/Optional/BasicInt.java @@ -29,6 +29,7 @@ import java.util.NoSuchElementException; import java.util.OptionalInt; +import java.util.concurrent.atomic.AtomicBoolean; import java.util.stream.IntStream; import static org.testng.Assert.*; @@ -49,11 +50,52 @@ public class BasicInt { assertTrue(0 == empty.hashCode()); assertTrue(!empty.toString().isEmpty()); assertTrue(!empty.isPresent()); + empty.ifPresent(v -> { fail(); }); + + AtomicBoolean emptyCheck = new AtomicBoolean(); + empty.ifPresentOrElse(v -> fail(), () -> emptyCheck.set(true)); + assertTrue(emptyCheck.get()); + + try { + empty.ifPresentOrElse(v -> fail(), () -> { throw new ObscureException(); }); + fail(); + } catch (ObscureException expected) { + } catch (AssertionError e) { + throw e; + } catch (Throwable t) { + fail(); + } + assertEquals(2, empty.orElse(2)); assertEquals(2, empty.orElseGet(()-> 2)); } + @Test(groups = "unit") + public void testIfPresentAndOrElseAndNull() { + OptionalInt empty = OptionalInt.empty(); + OptionalInt present = OptionalInt.of(1); + + // No NPE + present.ifPresentOrElse(v -> {}, null); + empty.ifPresent(null); + empty.ifPresentOrElse(null, () -> {}); + + // NPE + try { + present.ifPresent(null); + fail(); + } catch (NullPointerException ex) {} + try { + present.ifPresentOrElse(null, () -> {}); + fail(); + } catch (NullPointerException ex) {} + try { + empty.ifPresentOrElse(v -> {}, null); + fail(); + } catch (NullPointerException ex) {} + } + @Test(expectedExceptions=NoSuchElementException.class) public void testEmptyGet() { OptionalInt empty = OptionalInt.empty(); @@ -96,12 +138,33 @@ public class BasicInt { assertFalse(present.toString().isEmpty()); assertTrue(-1 != present.toString().indexOf(Integer.toString(present.getAsInt()).toString())); assertEquals(1, present.getAsInt()); + + AtomicBoolean presentCheck = new AtomicBoolean(); + present.ifPresent(v -> presentCheck.set(true)); + assertTrue(presentCheck.get()); + presentCheck.set(false); + present.ifPresentOrElse(v -> presentCheck.set(true), () -> fail()); + assertTrue(presentCheck.get()); + try { present.ifPresent(v -> { throw new ObscureException(); }); fail(); - } catch(ObscureException expected) { - + } catch (ObscureException expected) { + } catch (AssertionError e) { + throw e; + } catch (Throwable t) { + fail(); } + try { + present.ifPresentOrElse(v -> { throw new ObscureException(); }, () -> fail()); + fail(); + } catch (ObscureException expected) { + } catch (AssertionError e) { + throw e; + } catch (Throwable t) { + fail(); + } + assertEquals(1, present.orElse(2)); assertEquals(1, present.orElseGet(null)); assertEquals(1, present.orElseGet(()-> 2)); diff --git a/jdk/test/java/util/Optional/BasicLong.java b/jdk/test/java/util/Optional/BasicLong.java index 39b29375cac..656a25e13c2 100644 --- a/jdk/test/java/util/Optional/BasicLong.java +++ b/jdk/test/java/util/Optional/BasicLong.java @@ -29,6 +29,7 @@ import java.util.NoSuchElementException; import java.util.OptionalLong; +import java.util.concurrent.atomic.AtomicBoolean; import java.util.stream.LongStream; import static org.testng.Assert.*; @@ -49,41 +50,82 @@ public class BasicLong { assertTrue(0 == empty.hashCode()); assertTrue(!empty.toString().isEmpty()); assertTrue(!empty.isPresent()); + empty.ifPresent(v -> { fail(); }); + + AtomicBoolean emptyCheck = new AtomicBoolean(); + empty.ifPresentOrElse(v -> fail(), () -> emptyCheck.set(true)); + assertTrue(emptyCheck.get()); + + try { + empty.ifPresentOrElse(v -> fail(), () -> { throw new ObscureException(); }); + fail(); + } catch (ObscureException expected) { + } catch (AssertionError e) { + throw e; + } catch (Throwable t) { + fail(); + } + assertEquals(2, empty.orElse(2)); assertEquals(2, empty.orElseGet(()-> 2)); } - @Test(expectedExceptions=NoSuchElementException.class) - public void testEmptyGet() { - OptionalLong empty = OptionalLong.empty(); + @Test(groups = "unit") + public void testIfPresentAndOrElseAndNull() { + OptionalLong empty = OptionalLong.empty(); + OptionalLong present = OptionalLong.of(1); - long got = empty.getAsLong(); - } + // No NPE + present.ifPresentOrElse(v -> {}, null); + empty.ifPresent(null); + empty.ifPresentOrElse(null, () -> {}); - @Test(expectedExceptions=NullPointerException.class) - public void testEmptyOrElseGetNull() { - OptionalLong empty = OptionalLong.empty(); + // NPE + try { + present.ifPresent(null); + fail(); + } catch (NullPointerException ex) {} + try { + present.ifPresentOrElse(null, () -> {}); + fail(); + } catch (NullPointerException ex) {} + try { + empty.ifPresentOrElse(v -> {}, null); + fail(); + } catch (NullPointerException ex) {} + } - long got = empty.orElseGet(null); - } + @Test(expectedExceptions=NoSuchElementException.class) + public void testEmptyGet() { + OptionalLong empty = OptionalLong.empty(); - @Test(expectedExceptions=NullPointerException.class) - public void testEmptyOrElseThrowNull() throws Throwable { - OptionalLong empty = OptionalLong.empty(); + long got = empty.getAsLong(); + } - long got = empty.orElseThrow(null); - } + @Test(expectedExceptions=NullPointerException.class) + public void testEmptyOrElseGetNull() { + OptionalLong empty = OptionalLong.empty(); - @Test(expectedExceptions=ObscureException.class) - public void testEmptyOrElseThrow() throws Exception { - OptionalLong empty = OptionalLong.empty(); + long got = empty.orElseGet(null); + } - long got = empty.orElseThrow(ObscureException::new); - } + @Test(expectedExceptions=NullPointerException.class) + public void testEmptyOrElseThrowNull() throws Throwable { + OptionalLong empty = OptionalLong.empty(); - @Test(groups = "unit") - public void testPresent() { + long got = empty.orElseThrow(null); + } + + @Test(expectedExceptions=ObscureException.class) + public void testEmptyOrElseThrow() throws Exception { + OptionalLong empty = OptionalLong.empty(); + + long got = empty.orElseThrow(ObscureException::new); + } + + @Test(groups = "unit") + public void testPresent() { OptionalLong empty = OptionalLong.empty(); OptionalLong present = OptionalLong.of(1L); @@ -96,12 +138,35 @@ public class BasicLong { assertFalse(present.toString().isEmpty()); assertTrue(-1 != present.toString().indexOf(Long.toString(present.getAsLong()).toString())); assertEquals(1L, present.getAsLong()); + + AtomicBoolean presentCheck = new AtomicBoolean(); + present.ifPresent(v -> presentCheck.set(true)); + assertTrue(presentCheck.get()); + presentCheck.set(false); + present.ifPresentOrElse(v -> presentCheck.set(true), () -> fail()); + assertTrue(presentCheck.get()); + try { present.ifPresent(v -> { throw new ObscureException(); }); fail(); - } catch(ObscureException expected) { - + } catch (ObscureException expected) { + } catch (AssertionError e) { + throw e; + } catch (Throwable t) { + fail(); } + try { + present.ifPresentOrElse(v -> { + throw new ObscureException(); + }, () -> fail()); + fail(); + } catch (ObscureException expected) { + } catch (AssertionError e) { + throw e; + } catch (Throwable t) { + fail(); + } + assertEquals(1, present.orElse(2)); assertEquals(1, present.orElseGet(null)); assertEquals(1, present.orElseGet(()-> 2)); From a12ad151103256ecd8ab2ab2610624795b017a03 Mon Sep 17 00:00:00 2001 From: Paul Sandoz Date: Fri, 13 Feb 2015 11:13:30 +0100 Subject: [PATCH 092/116] 8069325: Pattern.splitAsStream does not return input if it is empty and there is no match Reviewed-by: sherman --- .../share/classes/java/util/regex/Pattern.java | 4 ++++ jdk/test/java/util/regex/PatternStreamTest.java | 11 +++++++++++ 2 files changed, 15 insertions(+) diff --git a/jdk/src/java.base/share/classes/java/util/regex/Pattern.java b/jdk/src/java.base/share/classes/java/util/regex/Pattern.java index c3bcfcc07c0..b22e9b936b4 100644 --- a/jdk/src/java.base/share/classes/java/util/regex/Pattern.java +++ b/jdk/src/java.base/share/classes/java/util/regex/Pattern.java @@ -5819,6 +5819,10 @@ NEXT: while (i <= last) { MatcherIterator() { this.matcher = matcher(input); + // If the input is an empty string then the result can only be a + // stream of the input. Induce that by setting the empty + // element count to 1 + this.emptyElementCount = input.length() == 0 ? 1 : 0; } public String next() { diff --git a/jdk/test/java/util/regex/PatternStreamTest.java b/jdk/test/java/util/regex/PatternStreamTest.java index 374b62378e9..325e07883d8 100644 --- a/jdk/test/java/util/regex/PatternStreamTest.java +++ b/jdk/test/java/util/regex/PatternStreamTest.java @@ -114,9 +114,20 @@ public class PatternStreamTest extends OpTestCase { data.add(new Object[]{description, input, pattern, expected}); + description = "Empty input"; input = ""; pattern = Pattern.compile("\u56da"); expected = new ArrayList<>(); + expected.add(""); + + data.add(new Object[]{description, input, pattern, expected}); + + + description = "Empty input with empty pattern"; + input = ""; + pattern = Pattern.compile(""); + expected = new ArrayList<>(); + expected.add(""); data.add(new Object[]{description, input, pattern, expected}); From 137f13474383d72a0d2e392bc2f8926ad69d3da6 Mon Sep 17 00:00:00 2001 From: Volker Simonis Date: Fri, 13 Feb 2015 19:14:44 +0100 Subject: [PATCH 093/116] 8072770: [TESTBUG] Some Introspector tests fail with a Java heap bigger than 4GB Reviewed-by: serb --- jdk/test/java/beans/Introspector/7064279/Test7064279.java | 1 + jdk/test/java/beans/Introspector/Test7172865.java | 1 + jdk/test/java/beans/Introspector/Test7195106.java | 1 + 3 files changed, 3 insertions(+) diff --git a/jdk/test/java/beans/Introspector/7064279/Test7064279.java b/jdk/test/java/beans/Introspector/7064279/Test7064279.java index 91d10fe7d42..5ae166e7b76 100644 --- a/jdk/test/java/beans/Introspector/7064279/Test7064279.java +++ b/jdk/test/java/beans/Introspector/7064279/Test7064279.java @@ -26,6 +26,7 @@ * @bug 7064279 * @summary Tests that Introspector does not have strong references to context class loader * @author Sergey Malenkov + * @run main/othervm -Xmx128m Test7064279 */ import java.beans.Introspector; diff --git a/jdk/test/java/beans/Introspector/Test7172865.java b/jdk/test/java/beans/Introspector/Test7172865.java index 6647225ca8f..655ca069ba7 100644 --- a/jdk/test/java/beans/Introspector/Test7172865.java +++ b/jdk/test/java/beans/Introspector/Test7172865.java @@ -30,6 +30,7 @@ import java.beans.PropertyDescriptor; * @bug 7172854 7172865 * @summary Tests that cached methods are not lost * @author Sergey Malenkov + * @run main/othervm -Xmx128m Test7172865 */ public class Test7172865 { diff --git a/jdk/test/java/beans/Introspector/Test7195106.java b/jdk/test/java/beans/Introspector/Test7195106.java index e47512a91b0..abc64fb2ab8 100644 --- a/jdk/test/java/beans/Introspector/Test7195106.java +++ b/jdk/test/java/beans/Introspector/Test7195106.java @@ -26,6 +26,7 @@ * @bug 7195106 * @summary Tests that explicit BeanInfo is not collected * @author Sergey Malenkov + * @run main/othervm -Xmx128m Test7195106 */ import java.awt.Image; From ad70e041335c6035ff6a6fcb7b364f2cb44881a1 Mon Sep 17 00:00:00 2001 From: Anthony Scarpino Date: Fri, 13 Feb 2015 10:44:53 -0800 Subject: [PATCH 094/116] 8022313: sun/security/pkcs11/rsa/TestKeyPairGenerator.java failed in aurora Reviewed-by: mullan --- jdk/test/sun/security/pkcs11/rsa/TestKeyPairGenerator.java | 3 ++- 1 file changed, 2 insertions(+), 1 deletion(-) diff --git a/jdk/test/sun/security/pkcs11/rsa/TestKeyPairGenerator.java b/jdk/test/sun/security/pkcs11/rsa/TestKeyPairGenerator.java index 85818721b8a..92eb0f91b93 100644 --- a/jdk/test/sun/security/pkcs11/rsa/TestKeyPairGenerator.java +++ b/jdk/test/sun/security/pkcs11/rsa/TestKeyPairGenerator.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2003, 2012, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2003, 2015, 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 @@ -27,6 +27,7 @@ * @summary Verify that the RSA KeyPairGenerator works * @author Andreas Sterbenz * @library .. + * @run main/othervm TestKeyPairGenerator */ import java.io.*; From c717b07bc57f32bc241d95b26780d23de68b7773 Mon Sep 17 00:00:00 2001 From: Mark Sheppard Date: Mon, 16 Feb 2015 00:10:42 +0000 Subject: [PATCH 095/116] 8068682: Deprivilege/move java.corba to the ext class loader Reviewed-by: alanb, mchung --- jdk/make/src/classes/build/tools/module/boot.modules | 1 - jdk/make/src/classes/build/tools/module/ext.modules | 1 + jdk/src/java.base/share/conf/security/java.policy | 4 ++++ 3 files changed, 5 insertions(+), 1 deletion(-) diff --git a/jdk/make/src/classes/build/tools/module/boot.modules b/jdk/make/src/classes/build/tools/module/boot.modules index 7c7748e4167..0ca6b716642 100644 --- a/jdk/make/src/classes/build/tools/module/boot.modules +++ b/jdk/make/src/classes/build/tools/module/boot.modules @@ -1,7 +1,6 @@ java.base java.desktop java.compiler -java.corba java.instrument java.logging java.management diff --git a/jdk/make/src/classes/build/tools/module/ext.modules b/jdk/make/src/classes/build/tools/module/ext.modules index 882ead8ce76..aa7a48d8995 100644 --- a/jdk/make/src/classes/build/tools/module/ext.modules +++ b/jdk/make/src/classes/build/tools/module/ext.modules @@ -1,3 +1,4 @@ +java.corba java.activation java.annotations.common java.xml.bind diff --git a/jdk/src/java.base/share/conf/security/java.policy b/jdk/src/java.base/share/conf/security/java.policy index 2ca6ec7f1b2..b9485d80e97 100644 --- a/jdk/src/java.base/share/conf/security/java.policy +++ b/jdk/src/java.base/share/conf/security/java.policy @@ -1,4 +1,8 @@ // permissions required by each component +grant codeBase "jrt:/java.corba" { + permission java.security.AllPermission; +}; + grant codeBase "jrt:/jdk.zipfs" { permission java.io.FilePermission "<>", "read,write,delete"; permission java.lang.RuntimePermission "fileSystemProvider"; From b5a98a12fe4e9aa46d042808dae778a8aa75837f Mon Sep 17 00:00:00 2001 From: Mark Sheppard Date: Mon, 16 Feb 2015 00:12:13 +0000 Subject: [PATCH 096/116] 8068682: Deprivilege/move java.corba to the ext class loader Reviewed-by: alanb, mchung --- .../classes/com/sun/corba/se/spi/orb/ORB.java | 37 +------------------ .../classes/sun/corba/SharedSecrets.java | 18 ++++++++- 2 files changed, 19 insertions(+), 36 deletions(-) diff --git a/corba/src/java.corba/share/classes/com/sun/corba/se/spi/orb/ORB.java b/corba/src/java.corba/share/classes/com/sun/corba/se/spi/orb/ORB.java index e597b1daa03..3f8056cff4d 100644 --- a/corba/src/java.corba/share/classes/com/sun/corba/se/spi/orb/ORB.java +++ b/corba/src/java.corba/share/classes/com/sun/corba/se/spi/orb/ORB.java @@ -176,42 +176,9 @@ public abstract class ORB extends com.sun.corba.se.org.omg.CORBA.ORB staticWrapper = ORBUtilSystemException.get( CORBALogDomains.RPC_PRESENTATION ) ; - boolean useDynamicStub = - ((Boolean)AccessController.doPrivileged( - new PrivilegedAction() { - public java.lang.Object run() { - return Boolean.valueOf( Boolean.getBoolean ( - ORBConstants.USE_DYNAMIC_STUB_PROPERTY ) ) ; - } - } - )).booleanValue() ; + boolean useDynamicStub = false; - PresentationManager.StubFactoryFactory dynamicStubFactoryFactory = - (PresentationManager.StubFactoryFactory)AccessController.doPrivileged( - new PrivilegedAction() { - public java.lang.Object run() { - PresentationManager.StubFactoryFactory sff = - PresentationDefaults.getProxyStubFactoryFactory() ; - - String className = System.getProperty( - ORBConstants.DYNAMIC_STUB_FACTORY_FACTORY_CLASS, - "com.sun.corba.se.impl.presentation.rmi.bcel.StubFactoryFactoryBCELImpl" ) ; - - try { - // First try the configured class name, if any - Class cls = - sun.corba.SharedSecrets.getJavaCorbaAccess().loadClass(className); - sff = (PresentationManager.StubFactoryFactory)cls.newInstance(); - } catch (Exception exc) { - // Use the default. Log the error as a warning. - staticWrapper.errorInSettingDynamicStubFactoryFactory( - exc, className ) ; - } - - return sff ; - } - } - ) ; + PresentationManager.StubFactoryFactory dynamicStubFactoryFactory = null; PresentationManager pm = new PresentationManagerImpl( useDynamicStub ) ; pm.setStubFactoryFactory( false, diff --git a/corba/src/java.corba/share/classes/sun/corba/SharedSecrets.java b/corba/src/java.corba/share/classes/sun/corba/SharedSecrets.java index aba3ee0767a..b4c56080f9f 100644 --- a/corba/src/java.corba/share/classes/sun/corba/SharedSecrets.java +++ b/corba/src/java.corba/share/classes/sun/corba/SharedSecrets.java @@ -28,7 +28,9 @@ package sun.corba; import com.sun.corba.se.impl.io.ValueUtility; import sun.misc.Unsafe; +import java.lang.reflect.Field; import java.security.AccessController; +import java.security.PrivilegedAction; /** A repository of "shared secrets", which are a mechanism for calling implementation-private methods in another package without @@ -41,9 +43,23 @@ import java.security.AccessController; // SharedSecrets cloned in corba repo to avoid build issues public class SharedSecrets { - private static final Unsafe unsafe = Unsafe.getUnsafe(); + private static final Unsafe unsafe = getUnsafe(); private static JavaCorbaAccess javaCorbaAccess; + private static Unsafe getUnsafe() { + PrivilegedAction pa = () -> { + Class unsafeClass = sun.misc.Unsafe.class ; + try { + Field f = unsafeClass.getDeclaredField("theUnsafe"); + f.setAccessible(true); + return (Unsafe) f.get(null); + } catch (Exception e) { + throw new Error(e); + } + }; + return AccessController.doPrivileged(pa); + } + public static JavaCorbaAccess getJavaCorbaAccess() { if (javaCorbaAccess == null) { // Ensure ValueUtility is initialized; we know that that class From 7208abd71e3b14935288104d05d58ad55ec630e5 Mon Sep 17 00:00:00 2001 From: Erik Joelsson Date: Mon, 16 Feb 2015 12:25:56 +0100 Subject: [PATCH 097/116] 8073166: Unable to successfully build the merge of jdk9/hs with jdk9/dev Reviewed-by: alanb --- make/Main.gmk | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/make/Main.gmk b/make/Main.gmk index b6533169a70..a775a6b7541 100644 --- a/make/Main.gmk +++ b/make/Main.gmk @@ -347,8 +347,8 @@ else $(foreach m, $(RMIC_MODULES), $(eval $m-rmic: $m-java)) # Declare dependencies from -lib to -java - # Skip jdk.jdwp.agent as it contains no java code. - $(foreach m, $(filter-out jdk.jdwp.agent, $(LIBS_MODULES)), $(eval $m-libs: $m-java)) + # Skip modules that do not have java source. + $(foreach m, $(filter $(JAVA_MODULES), $(LIBS_MODULES)), $(eval $m-libs: $m-java)) # Declare dependencies from all other -lib to java.base-lib $(foreach t, $(filter-out java.base-libs, $(LIBS_TARGETS)), \ From 8104906db24e04cbe049a76a5e78c009c32bdfa4 Mon Sep 17 00:00:00 2001 From: Alan Bateman Date: Mon, 16 Feb 2015 18:30:16 +0000 Subject: [PATCH 098/116] 8068680: Move java.transaction to the ext class loader Reviewed-by: lancea, mchung --- jdk/make/src/classes/build/tools/module/boot.modules | 5 ++--- jdk/make/src/classes/build/tools/module/ext.modules | 5 +++-- 2 files changed, 5 insertions(+), 5 deletions(-) diff --git a/jdk/make/src/classes/build/tools/module/boot.modules b/jdk/make/src/classes/build/tools/module/boot.modules index 0ca6b716642..c78612b843c 100644 --- a/jdk/make/src/classes/build/tools/module/boot.modules +++ b/jdk/make/src/classes/build/tools/module/boot.modules @@ -1,6 +1,6 @@ java.base -java.desktop java.compiler +java.desktop java.instrument java.logging java.management @@ -13,7 +13,6 @@ java.security.sasl java.smartcardio java.sql java.sql.rowset -java.transaction java.xml java.xml.crypto jdk.charsets @@ -21,9 +20,9 @@ jdk.deploy jdk.deploy.osx jdk.hprof.agent jdk.httpserver +jdk.jfr jdk.naming.rmi jdk.sctp jdk.security.auth jdk.security.jgss -jdk.jfr jdk.snmp diff --git a/jdk/make/src/classes/build/tools/module/ext.modules b/jdk/make/src/classes/build/tools/module/ext.modules index aa7a48d8995..934d4e9ba16 100644 --- a/jdk/make/src/classes/build/tools/module/ext.modules +++ b/jdk/make/src/classes/build/tools/module/ext.modules @@ -1,8 +1,10 @@ -java.corba java.activation java.annotations.common +java.corba +java.transaction java.xml.bind java.xml.ws +jdk.accessbridge jdk.crypto.ec jdk.crypto.mscapi jdk.crypto.pkcs11 @@ -11,4 +13,3 @@ jdk.localedata jdk.naming.dns jdk.scripting.nashorn jdk.zipfs -jdk.accessbridge From 1eb1419d72dae4e3e2abf7fd72a97e30d560c545 Mon Sep 17 00:00:00 2001 From: Xueming Shen Date: Mon, 16 Feb 2015 14:53:59 -0800 Subject: [PATCH 099/116] 8073152: Update Standard/ExtendedCharsets to work with module system To reorganize the standard and extendec charset configuration during build time Reviewed-by: alanb --- .../charsetmapping/DoubleByte-X.java.template | 3 +- jdk/make/data/charsetmapping/charsets | 1818 +++++++++++++++++ jdk/make/data/charsetmapping/dbcs | 36 - jdk/make/data/charsetmapping/extsbcs | 76 - jdk/make/data/charsetmapping/list_old | 149 ++ jdk/make/data/charsetmapping/sbcs | 28 - .../data/charsetmapping/standard-charsets | 337 --- jdk/make/data/charsetmapping/stdcs-linux | 19 + jdk/make/data/charsetmapping/stdcs-solaris | 23 + jdk/make/data/charsetmapping/stdcs-windows | 16 + jdk/make/gensrc/Gensrc-jdk.charsets.gmk | 24 +- jdk/make/gensrc/GensrcCharsetMapping.gmk | 107 +- .../build/tools/charsetmapping/Charset.java | 42 + .../build/tools/charsetmapping/DBCS.java | 67 +- .../build/tools/charsetmapping/HKSCS.java | 48 +- .../build/tools/charsetmapping/Hasher.java | 265 +++ .../build/tools/charsetmapping/Main.java | 190 +- .../build/tools/charsetmapping/SBCS.java | 136 +- .../build/tools/charsetmapping/SPI.java | 141 ++ .../build/tools/charsetmapping/SRC.java | 64 + .../sun/nio/cs/AbstractCharsetProvider.java | 6 + .../sun/nio/cs}/DelegatableDecoder.java | 4 +- .../share/classes/sun/nio/cs}/DoubleByte.java | 34 +- .../share/classes/sun/nio/cs}/HKSCS.java | 7 +- .../sun/nio/cs/StandardCharsets.java.template | 182 +- .../share/classes/sun/awt/HKSCS.java | 14 +- .../unix/classes/sun/awt/motif/X11GB2312.java | 1 + .../unix/classes/sun/awt/motif/X11GBK.java | 1 + .../classes/sun/awt/motif/X11JIS0201.java | 2 +- .../classes/sun/awt/motif/X11JIS0208.java | 3 +- .../classes/sun/awt/motif/X11JIS0212.java | 3 +- .../classes/sun/awt/motif/X11KSC5601.java | 1 + ...g5_HKSCS.java => Big5_HKSCS.java.template} | 8 +- .../sun/nio/cs/ext/Big5_HKSCS_2001.java | 2 + ...olaris.java => Big5_Solaris.java.template} | 5 +- .../ext/{EUC_JP.java => EUC_JP.java.template} | 7 +- ..._LINUX.java => EUC_JP_LINUX.java.template} | 7 +- ...JP_Open.java => EUC_JP_Open.java.template} | 8 +- .../sun/nio/cs/ext/ExtendedCharsets.java | 1326 ------------ .../nio/cs/ext/ExtendedCharsets.java.template | 256 +++ .../share/classes/sun/nio/cs/ext/IBM834.java | 1 + .../share/classes/sun/nio/cs/ext/IBM942C.java | 1 + .../share/classes/sun/nio/cs/ext/IBM943C.java | 1 + .../share/classes/sun/nio/cs/ext/IBM949C.java | 1 + .../classes/sun/nio/cs/ext/ISO2022_CN.java | 2 + .../classes/sun/nio/cs/ext/ISO2022_CN_GB.java | 1 + .../classes/sun/nio/cs/ext/ISO2022_JP.java | 3 + .../classes/sun/nio/cs/ext/ISO2022_JP_2.java | 2 + .../classes/sun/nio/cs/ext/ISO2022_KR.java | 2 +- .../classes/sun/nio/cs/ext/JISAutoDetect.java | 2 + .../share/classes/sun/nio/cs/ext/MS50220.java | 2 + .../share/classes/sun/nio/cs/ext/MS50221.java | 1 + .../classes/sun/nio/cs/ext/MS932_0213.java | 2 + .../classes/sun/nio/cs/ext/MS950_HKSCS.java | 1 + ...S_XP.java => MS950_HKSCS_XP.java.template} | 6 +- .../classes/sun/nio/cs/ext/MSISO2022JP.java | 1 + .../classes/sun/nio/cs/ext/SJIS_0213.java | 1 + .../Charset/NIOCharsetAvailabilityTest.java | 10 +- 58 files changed, 3383 insertions(+), 2123 deletions(-) create mode 100644 jdk/make/data/charsetmapping/charsets delete mode 100644 jdk/make/data/charsetmapping/dbcs delete mode 100644 jdk/make/data/charsetmapping/extsbcs create mode 100644 jdk/make/data/charsetmapping/list_old delete mode 100644 jdk/make/data/charsetmapping/sbcs delete mode 100644 jdk/make/data/charsetmapping/standard-charsets create mode 100644 jdk/make/data/charsetmapping/stdcs-linux create mode 100644 jdk/make/data/charsetmapping/stdcs-solaris create mode 100644 jdk/make/data/charsetmapping/stdcs-windows create mode 100644 jdk/make/src/classes/build/tools/charsetmapping/Charset.java create mode 100644 jdk/make/src/classes/build/tools/charsetmapping/Hasher.java create mode 100644 jdk/make/src/classes/build/tools/charsetmapping/SPI.java create mode 100644 jdk/make/src/classes/build/tools/charsetmapping/SRC.java rename jdk/src/{jdk.charsets/share/classes/sun/nio/cs/ext => java.base/share/classes/sun/nio/cs}/DelegatableDecoder.java (96%) rename jdk/src/{jdk.charsets/share/classes/sun/nio/cs/ext => java.base/share/classes/sun/nio/cs}/DoubleByte.java (97%) rename jdk/src/{jdk.charsets/share/classes/sun/nio/cs/ext => java.base/share/classes/sun/nio/cs}/HKSCS.java (98%) rename jdk/src/jdk.charsets/share/classes/sun/nio/cs/ext/{Big5_HKSCS.java => Big5_HKSCS.java.template} (93%) rename jdk/src/jdk.charsets/share/classes/sun/nio/cs/ext/{Big5_Solaris.java => Big5_Solaris.java.template} (97%) rename jdk/src/jdk.charsets/share/classes/sun/nio/cs/ext/{EUC_JP.java => EUC_JP.java.template} (99%) rename jdk/src/jdk.charsets/share/classes/sun/nio/cs/ext/{EUC_JP_LINUX.java => EUC_JP_LINUX.java.template} (93%) rename jdk/src/jdk.charsets/share/classes/sun/nio/cs/ext/{EUC_JP_Open.java => EUC_JP_Open.java.template} (95%) delete mode 100644 jdk/src/jdk.charsets/share/classes/sun/nio/cs/ext/ExtendedCharsets.java create mode 100644 jdk/src/jdk.charsets/share/classes/sun/nio/cs/ext/ExtendedCharsets.java.template rename jdk/src/jdk.charsets/share/classes/sun/nio/cs/ext/{MS950_HKSCS_XP.java => MS950_HKSCS_XP.java.template} (96%) diff --git a/jdk/make/data/charsetmapping/DoubleByte-X.java.template b/jdk/make/data/charsetmapping/DoubleByte-X.java.template index 17476e0bff1..4ef582c9317 100644 --- a/jdk/make/data/charsetmapping/DoubleByte-X.java.template +++ b/jdk/make/data/charsetmapping/DoubleByte-X.java.template @@ -32,7 +32,8 @@ import java.nio.charset.CharsetDecoder; import java.nio.charset.CharsetEncoder; import java.util.Arrays; import sun.nio.cs.HistoricallyNamedCharset; -import sun.nio.cs.ext.DoubleByte; +import sun.nio.cs.DoubleByte; +import sun.nio.cs.*; public class $NAME_CLZ$ extends Charset $IMPLEMENTS$ diff --git a/jdk/make/data/charsetmapping/charsets b/jdk/make/data/charsetmapping/charsets new file mode 100644 index 00000000000..682a14ca46c --- /dev/null +++ b/jdk/make/data/charsetmapping/charsets @@ -0,0 +1,1818 @@ +# +# Copyright (c) 2000, 2015, 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. Oracle designates this +# particular file as subject to the "Classpath" exception as provided +# by Oracle in the LICENSE file that accompanied this code. +# +# 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. +# + +######################################################## +# +# Standard charsets provided by StandardCharsets provider. +# +# Note that these "standard" charsets listed here are not +# necessary to be the "Standard charsets" defined in the +# specification of java.nio.charset.Charset. Instead these +# are the charsets that this implementation believes should +# be packaged into the charsets provider class "StandardCharsets" +# which is initialized at startup time by java.nio.charset.Charset, +# compared to the charsets packaged in "ExtendedCharsets" provider, +# which is lazy initialized. +######################################################## + +charset US-ASCII US_ASCII + package sun.nio.cs + type source + alias iso-ir-6 # IANA aliases + alias ANSI_X3.4-1986 + alias ISO_646.irv:1991 + alias ASCII + alias ISO646-US + alias us + alias IBM367 + alias cp367 + alias csASCII + alias default + # Other aliases + alias 646 # Solaris POSIX locale + alias iso_646.irv:1983 + alias ANSI_X3.4-1968 # Linux POSIX locale (RedHat) + alias ascii7 + +charset UTF-8 UTF_8 + package sun.nio.cs + type source + alias UTF8 # JDK historical + alias unicode-1-1-utf-8 + +charset CESU-8 CESU_8 + package sun.nio.cs + type source + alias CESU8 + alias csCESU-8 + +charset UTF-16 UTF_16 + package sun.nio.cs + type source + alias UTF_16 # JDK historical + alias utf16 + alias unicode + alias UnicodeBig + +charset UTF-16BE UTF_16BE + package sun.nio.cs + type source + alias UTF_16BE + alias ISO-10646-UCS-2 + alias X-UTF-16BE + alias UnicodeBigUnmarked + +charset UTF-16LE UTF_16LE + package sun.nio.cs + type source + alias UTF_16LE + alias X-UTF-16LE + alias UnicodeLittleUnmarked + +charset x-UTF-16LE-BOM UTF_16LE_BOM + package sun.nio.cs + type source + alias UnicodeLittle + +charset UTF-32 UTF_32 + package sun.nio.cs + type source + alias UTF_32 + alias UTF32 + +charset UTF-32LE UTF_32LE + package sun.nio.cs + type source + alias UTF_32LE + alias X-UTF-32LE + +charset UTF-32BE UTF_32BE + package sun.nio.cs + type source + alias UTF_32BE + alias X-UTF-32BE + +charset X-UTF-32LE-BOM UTF_32LE_BOM + package sun.nio.cs + type source + alias UTF_32LE_BOM + alias UTF-32LE-BOM + +charset X-UTF-32BE-BOM UTF_32BE_BOM + package sun.nio.cs + type source + alias UTF_32BE_BOM + alias UTF-32BE-BOM + +charset ISO-8859-1 ISO_8859_1 + package sun.nio.cs + type source + alias iso-ir-100 # IANA aliases + alias ISO_8859-1 + alias latin1 + alias l1 + alias IBM819 + alias cp819 + alias csISOLatin1 + alias 819 # Other aliases + alias IBM-819 + alias ISO8859_1 + alias ISO_8859-1:1987 + alias ISO_8859_1 + alias 8859_1 + alias ISO8859-1 + +charset ISO-8859-2 ISO_8859_2 + package sun.nio.cs + type sbcs + hisname ISO8859_2 + ascii true + alias iso8859_2 # JDK historical + alias 8859_2 + alias iso-ir-101 + alias ISO_8859-2 + alias ISO_8859-2:1987 + alias ISO8859-2 + alias latin2 + alias l2 + alias ibm912 + alias ibm-912 + alias cp912 + alias 912 + alias csISOLatin2 + +charset ISO-8859-4 ISO_8859_4 + package sun.nio.cs + type sbcs + hisname ISO8859_4 + ascii true + alias iso8859_4 # JDK historical + alias iso8859-4 + alias 8859_4 + alias iso-ir-110 + alias ISO_8859-4 + alias ISO_8859-4:1988 + alias latin4 + alias l4 + alias ibm914 + alias ibm-914 + alias cp914 + alias 914 + alias csISOLatin4 + +charset ISO-8859-5 ISO_8859_5 + package sun.nio.cs + type sbcs + hisname ISO8859_5 + ascii true + alias iso8859_5 # JDK historical + alias 8859_5 + alias iso-ir-144 + alias ISO_8859-5 + alias ISO_8859-5:1988 + alias ISO8859-5 + alias cyrillic + alias ibm915 + alias ibm-915 + alias cp915 + alias 915 + alias csISOLatinCyrillic + +charset ISO-8859-7 ISO_8859_7 + package sun.nio.cs + type sbcs + hisname ISO8859_7 + ascii true + alias iso8859_7 # JDK historical + alias 8859_7 + alias iso-ir-126 + alias ISO_8859-7 + alias ISO_8859-7:1987 + alias ELOT_928 + alias ECMA-118 + alias greek + alias greek8 + alias csISOLatinGreek + alias sun_eu_greek # Solaris 7/8 compatibility + alias ibm813 + alias ibm-813 + alias 813 + alias cp813 + alias iso8859-7 # Solaris 9 compatibility + +charset ISO-8859-9 ISO_8859_9 + package sun.nio.cs + type sbcs + hisname ISO8859_9 + ascii true + alias iso8859_9 # JDK historical + alias 8859_9 + alias iso-ir-148 + alias ISO_8859-9 + alias ISO_8859-9:1989 + alias ISO8859-9 + alias latin5 + alias l5 + alias ibm920 + alias ibm-920 + alias 920 + alias cp920 + alias csISOLatin5 + +charset ISO-8859-13 ISO_8859_13 + package sun.nio.cs + type sbcs + hisname ISO8859_13 + ascii true + alias iso8859_13 # JDK historical + alias 8859_13 + alias iso_8859-13 + alias ISO8859-13 + +charset ISO-8859-15 ISO_8859_15 + package sun.nio.cs + type sbcs + hisname ISO8859_15 + ascii true + alias ISO_8859-15 # IANA alias + alias 8859_15 # Other aliases + alias ISO-8859-15 + alias ISO8859_15 + alias ISO8859-15 + alias IBM923 + alias IBM-923 + alias cp923 + alias 923 + alias LATIN0 + alias LATIN9 + alias L9 + alias csISOlatin0 + alias csISOlatin9 + alias ISO8859_15_FDIS + +charset KOI8-R KOI8_R + package sun.nio.cs + type sbcs + hisname KOI8_R + ascii true + alias koi8_r # JDK historical + alias koi8 + alias cskoi8r + +charset KOI8-U KOI8_U + package sun.nio.cs + type sbcs + hisname KOI8_U + ascii true + alias koi8_u + +charset windows-1250 MS1250 + package sun.nio.cs + type sbcs + hisname Cp1250 + ascii true + alias cp1250 # JDK historical + alias cp5346 # Euro IBM CCSID + +charset windows-1251 MS1251 + package sun.nio.cs + type sbcs + hisname Cp1251 + ascii true + alias cp1251 # JDK historical + alias cp5347 # Euro IBM CCSID + alias ansi-1251 # Solaris compatibility + +charset windows-1252 MS1252 + package sun.nio.cs + type sbcs + hisname Cp1252 + ascii true + alias cp1252 # JDK historical + alias cp5348 # Euro IBM CCSID + +charset windows-1253 MS1253 + package sun.nio.cs + type sbcs + hisname Cp1253 + ascii true + alias cp1253 # JDK historical + alias cp5349 # Euro IBM CCSID + +charset windows-1254 MS1254 + package sun.nio.cs + type sbcs + hisname Cp1254 + ascii true + alias cp1254 # JDK historical + alias cp5350 # Euro IBM CCSID + +charset windows-1257 MS1257 + package sun.nio.cs + type sbcs + hisname Cp1257 + ascii true + alias cp1257 # JDK historical + alias cp5353 # Euro IBM CCSID + + +charset IBM437 IBM437 + package sun.nio.cs + type sbcs + hisname Cp437 + ascii false + alias cp437 #JDK historical + alias ibm437 + alias ibm-437 + alias 437 + alias cspc8codepage437 + alias windows-437 + +charset x-IBM737 IBM737 + package sun.nio.cs + type sbcs + hisname Cp737 + ascii false + alias cp737 #JDK historical + alias ibm737 + alias ibm-737 + alias 737 + +charset IBM775 IBM775 + package sun.nio.cs + type sbcs + hisname Cp775 + ascii false + alias cp775 #JDK historical + alias ibm775 + alias ibm-775 + alias 775 + +charset IBM850 IBM850 + package sun.nio.cs + type sbcs + hisname Cp850 + ascii false + alias cp850 #JDK historical + alias ibm-850 + alias ibm850 + alias 850 + alias cspc850multilingual + +charset IBM852 IBM852 + package sun.nio.cs + type sbcs + hisname Cp852 + ascii false + alias cp852 #JDK historical + alias ibm852 + alias ibm-852 + alias 852 + alias csPCp852 + +charset IBM855 IBM855 + package sun.nio.cs + type sbcs + hisname Cp855 + ascii false + alias cp855 #JDK historical + alias ibm-855 + alias ibm855 + alias 855 + alias cspcp855 + +charset IBM857 IBM857 + package sun.nio.cs + type sbcs + hisname Cp857 + ascii false + alias cp857 #JDK historical + alias ibm857 + alias ibm-857 + alias 857 + alias csIBM857 + +charset IBM00858 IBM858 + package sun.nio.cs + type sbcs + hisname Cp858 + ascii false + alias cp858 #JDK historical + alias ccsid00858 + alias cp00858 + alias 858 + alias PC-Multilingual-850+euro + +charset IBM862 IBM862 + package sun.nio.cs + type sbcs + hisname Cp862 + ascii false + alias cp862 #JDK historical + alias ibm862 + alias ibm-862 + alias 862 + alias csIBM862 + alias cspc862latinhebrew + +charset IBM866 IBM866 + package sun.nio.cs + type sbcs + hisname Cp866 + ascii false + alias cp866 #JDK historical + alias ibm866 + alias ibm-866 + alias 866 + alias csIBM866 + +charset x-IBM874 IBM874 + package sun.nio.cs + type sbcs + hisname Cp874 + ascii false + alias cp874 #JDK historical + alias ibm874 + alias ibm-874 + alias 874 + +######################################################## +# +# charsets provided by ExtendedCharsets provider. +# +######################################################## +charset Big5 Big5 + package sun.nio.cs.ext + type dbcs + hisname Big5 + ascii true + minmax 0xa1 0xf9 0x40 0xfe + alias csBig5 # IANA aliases + +charset x-MS950-HKSCS-XP MS950_HKSCS_XP + package sun.nio.cs.ext + type template + alias MS950_HKSCS_XP # JDK historical; + +charset x-MS950-HKSCS MS950_HKSCS + package sun.nio.cs.ext + type source + hisname MS950_HKSCS + ascii true + alias MS950_HKSCS # JDK historical; + +charset x-windows-950 MS950 + package sun.nio.cs.ext + type dbcs + hisname MS950 + ascii true + minmax 0x81 0xfe 0x40 0xfe + alias ms950 # JDK historical + alias windows-950 + +charset x-windows-874 MS874 + package sun.nio.cs.ext + type sbcs + hisname MS874 + ascii true + alias ms874 # JDK historical + alias ms-874 + alias windows-874 + +charset x-EUC-TW EUC_TW + package sun.nio.cs.ext + type source + alias euc_tw # JDK historical + alias euctw + alias cns11643 + alias EUC-TW + +charset Big5-HKSCS Big5_HKSCS + package sun.nio.cs.ext + type template + hisname Big5_HKSCS + ascii true + alias Big5_HKSCS # JDK historical + alias big5hk + alias big5-hkscs + alias big5hkscs # Linux alias + +charset x-Big5-HKSCS-2001 Big5_HKSCS_2001 + package sun.nio.cs.ext + type source + alias Big5_HKSCS_2001 + alias big5hk-2001 + alias big5-hkscs-2001 + alias big5-hkscs:unicode3.0 + alias big5hkscs-2001 + +charset x-Big5-Solaris Big5_Solaris + package sun.nio.cs.ext + type template + hisname Big5_Solaris + ascii true + alias Big5_Solaris # JDK historical + + +charset GBK GBK # Simplified Chinese + package sun.nio.cs.ext + type dbcs + hisname GBK + ascii true + minmax 0x81 0xfe 0x40 0xfe + alias windows-936 + alias CP936 + +charset GB18030 GB18030 + package sun.nio.cs.ext + type source + alias gb18030-2000 + +charset GB2312 EUC_CN + package sun.nio.cs.ext + type dbcs + hisname EUC_CN + ascii true + minmax 0xa1 0xf7 0xa1 0xfe + # IANA aliases + alias gb2312 + alias gb2312-80 + alias gb2312-1980 + alias euc-cn + alias euccn + alias x-EUC-CN # 1.4 compatibility + alias EUC_CN # JDK historical + +charset x-mswin-936 MS936 + package sun.nio.cs.ext + type dbcs + hisname MS936 + ascii true + minmax 0x81 0xfe 0x40 0xfe + alias ms936 # JDK historical + alias ms_936 // IANA aliases + +# The definition of this charset may be overridden by the init method, +# below, if the sun.nio.cs.map property is defined. +# +charset Shift_JIS SJIS + package sun.nio.cs.ext + type dbcs + hisname SJIS + ascii true + minmax 0x81 0xfc 0x40 0xfc + # IANA aliases + alias sjis # historical + alias shift_jis + alias shift-jis + alias ms_kanji + alias x-sjis + alias csShiftJIS + +# The definition of this charset may be overridden by the init method, +# below, if the sun.nio.cs.map property is defined. +charset windows-31j MS932 + package sun.nio.cs.ext + type dbcs + hisname MS932 + ascii true + minmax 0x81 0xfc 0x40 0xfc + alias MS932 # JDK historical + alias windows-932 + alias csWindows31J + +charset JIS_X0201 JIS_X_0201 + package sun.nio.cs.ext + type sbcs + hisname JIS_X0201 + ascii true + alias JIS0201 # JDK historical + # IANA aliases + alias JIS_X0201 + alias X0201 + alias csHalfWidthKatakana + +charset x-JIS0208 JIS_X_0208 + package sun.nio.cs.ext + type dbcsonly + hisname JIS0208 + ascii false + minmax 0x21 0x7e 0x21 0x7e + alias JIS0208 # JDK historical + # IANA aliases + alias JIS_C6226-1983 + alias iso-ir-87 + alias x0208 + alias JIS_X0208-1983 + alias csISO87JISX0208 + +charset JIS_X0212-1990 JIS_X_0212 + package sun.nio.cs.ext + type dbcsonly + hisname JIS0212 + ascii false + minmax 0x21 0x7e 0x21 0x7e + alias JIS0212 # JDK historical + # IANA aliases + alias jis_x0212-1990 + alias x0212 + alias iso-ir-159 + alias csISO159JISX02121990 + +charset x-SJIS_0213 SJIS_0213 + package sun.nio.cs.ext + type source + alias sjis-0213 + alias sjis_0213 + alias sjis:2004 + alias sjis_0213:2004 + alias shift_jis_0213:2004 + alias shift_jis:2004 + +charset x-MS932_0213 MS932_0213 + package sun.nio.cs.ext + type source + alias MS932-0213 + alias MS932_0213 + alias MS932:2004 + alias windows-932-0213 + alias windows-932:2004 + +charset EUC-JP EUC_JP + package sun.nio.cs.ext + type template + hisname EUC_JP + ascii true + alias euc_jp # JDK historical + alias eucjis # IANA aliases + alias eucjp + alias Extended_UNIX_Code_Packed_Format_for_Japanese + alias csEUCPkdFmtjapanese + alias x-euc-jp + alias x-eucjp + +charset x-euc-jp-linux EUC_JP_LINUX + package sun.nio.cs.ext + type template + hisname EUC_JP_LINUX + ascii true + alias euc_jp_linux # JDK historical + alias euc-jp-linux + +charset x-eucjp-open EUC_JP_Open + package sun.nio.cs.ext + type template + hisname EUC_JP_Solari + ascii true + alias EUC_JP_Solaris # JDK historical + alias eucJP-open + +charset x-PCK PCK + package sun.nio.cs.ext + type dbcs + hisname PCK + ascii true + minmax 0x81 0xfc 0x40 0xfc + # IANA aliases + alias pck # JDK historical + +charset ISO-2022-JP ISO2022_JP + package sun.nio.cs.ext + type source + # IANA aliases + alias iso2022jp # JDK historical + alias jis + alias csISO2022JP + alias jis_encoding + alias csjisencoding + +charset ISO-2022-JP-2 ISO2022_JP_2 + package sun.nio.cs.ext + type source + # IANA aliases + alias csISO2022JP2 + alias iso2022jp2 + +charset x-windows-50221 MS50221 + package sun.nio.cs.ext + type source + alias ms50221 # JDK historical + alias cp50221 + +charset x-windows-50220 MS50220 + package sun.nio.cs.ext + type source + alias ms50220 # JDK historical + alias cp50220 + +charset x-windows-iso2022jp MSISO2022JP + package sun.nio.cs.ext + type source + alias windows-iso2022jp # JDK historical + +charset x-JISAutoDetect JISAutoDetect + package sun.nio.cs.ext + type source + alias JISAutoDetect # JDK historical + + +charset EUC-KR EUC_KR # Korean + package sun.nio.cs.ext + type dbcs + hisname EUC_KR + ascii true + minmax 0xa1 0xfd 0xa1 0xfe + alias euc_kr # JDK historical + # IANA aliases + alias ksc5601 + alias euckr + alias ks_c_5601-1987 + alias ksc5601-1987 + alias ksc5601_1987 + alias ksc_5601 + alias csEUCKR + alias 5601 + +charset x-windows-949 MS949 + package sun.nio.cs.ext + type dbcs + hisname MS949 + ascii true + minmax 0x81 0xfe 0x41 0xfe + alias ms949 # JDK historical + alias windows949 + alias windows-949 + alias ms_949 # IANA aliases + +charset x-Johab Johab + package sun.nio.cs.ext + type dbcs + hisname x-Johab + ascii true + minmax 0x84 0xf9 0x31 0xfe + alias ksc5601-1992 + alias ksc5601_1992 + alias ms1361 + alias johab # JDK historical + +charset ISO-2022-KR ISO2022_KR + package sun.nio.cs.ext + type source + alias ISO2022KR # JDK historical + alias csISO2022KR + +charset ISO-2022-CN ISO2022_CN + package sun.nio.cs.ext + type source + alias ISO2022CN # JDK historical + alias csISO2022CN + +charset x-ISO-2022-CN-CNS ISO2022_CN_CNS + package sun.nio.cs.ext + type source + alias ISO2022CN_CNS # JDK historical + alias ISO-2022-CN-CNS + +charset x-ISO-2022-CN-GB ISO2022_CN_GB + package sun.nio.cs.ext + type source + alias ISO2022CN_GB # JDK historical + alias ISO-2022-CN-GB + +charset x-ISCII91 ISCII91 + package sun.nio.cs.ext + type source + alias iscii + alias ST_SEV_358-88 + alias iso-ir-153 + alias csISO153GOST1976874 + alias ISCII91 # JDK historical + +charset ISO-8859-3 ISO_8859_3 + package sun.nio.cs.ext + type sbcs + hisname ISO8859_3 + ascii true + alias iso8859_3 # JDK historical + alias 8859_3 + alias ISO_8859-3:1988 + alias iso-ir-109 + alias ISO_8859-3 + alias ISO8859-3 + alias latin3 + alias l3 + alias ibm913 + alias ibm-913 + alias cp913 + alias 913 + alias csISOLatin3 + +charset ISO-8859-6 ISO_8859_6 + package sun.nio.cs.ext + type sbcs + hisname ISO8859_6 + ascii true + alias iso8859_6 # JDK historical + alias 8859_6 + alias iso-ir-127 + alias ISO_8859-6 + alias ISO_8859-6:1987 + alias ISO8859-6 + alias ECMA-114 + alias ASMO-708 + alias arabic + alias ibm1089 + alias ibm-1089 + alias cp1089 + alias 1089 + alias csISOLatinArabic + +charset ISO-8859-8 ISO_8859_8 + package sun.nio.cs.ext + type sbcs + hisname ISO8859_8 + ascii true + alias iso8859_8 # JDK historical + alias 8859_8 + alias iso-ir-138 + alias ISO_8859-8 + alias ISO_8859-8:1988 + alias ISO8859-8 + alias cp916 + alias 916 + alias ibm916 + alias ibm-916 + alias hebrew + alias csISOLatinHebrew + +charset x-iso-8859-11 ISO_8859_11 + package sun.nio.cs.ext + type sbcs + hisname x-iso-8859-11 + ascii true + alias iso-8859-11 + alias iso8859_11 + +charset TIS-620 TIS_620 + package sun.nio.cs.ext + type sbcs + hisname TIS620 + ascii true + alias tis620 # JDK historical + alias tis620.2533 + +# Microsoft Windows codepages + +charset windows-1255 MS1255 + package sun.nio.cs.ext + type sbcs + hisname Cp1255 + ascii true + alias cp1255 # JDK historical + +charset windows-1256 MS1256 + package sun.nio.cs.ext + type sbcs + hisname Cp1256 + ascii true + alias cp1256 # JDK historical + +charset windows-1258 MS1258 + package sun.nio.cs.ext + type sbcs + hisname Cp1258 + ascii true + alias cp1258 # JDK historical + +charset x-IBM942 IBM942 # IBM & PC/MSDOS encodings + package sun.nio.cs.ext + type dbcs + hisname Cp942 + ascii false + minmax 0x81 0xfc 0x40 0xfc + alias cp942 # JDK historical + alias ibm942 + alias ibm-942 + alias 942 + +charset x-IBM942C IBM942C + package sun.nio.cs.ext + type source + alias cp942C # JDK historical + alias ibm942C + alias ibm-942C + alias 942C + +charset x-IBM943 IBM943 + package sun.nio.cs.ext + type dbcs + hisname Cp943 + ascii false + minmax 0x81 0xfc 0x40 0xfc + alias cp943 # JDK historical + alias ibm943 + alias ibm-943 + alias 943 + +charset x-IBM943C IBM943C + package sun.nio.cs.ext + type source + alias cp943C # JDK historical + alias ibm943C + alias ibm-943C + alias 943C + +charset x-IBM948 IBM948 + package sun.nio.cs.ext + type dbcs + hisname Cp948 + ascii true + minmax 0x81 0xfe 0x40 0xfc + alias cp948 # JDK historical + alias ibm948 + alias ibm-948 + alias 948 + +charset x-IBM950 IBM950 + package sun.nio.cs.ext + type dbcs + hisname Cp950 + ascii true + minmax 0x81 0xfe 0x40 0xfe + alias cp950 # JDK historical + alias ibm950 + alias ibm-950 + alias 950 + +charset x-IBM930 IBM930 + package sun.nio.cs.ext + type ebcdic + hisname Cp930 + ascii false + minmax 0x40 0x7f 0x40 0xfe + alias cp930 # JDK historical + alias ibm930 + alias ibm-930 + alias 930 + +charset x-IBM935 IBM935 + package sun.nio.cs.ext + type ebcdic + hisname Cp935 + ascii false + minmax 0x40 0x7f 0x40 0xfe + alias cp935 # JDK historical + alias ibm935 + alias ibm-935 + alias 935 + +charset x-IBM937 IBM937 + package sun.nio.cs.ext + type ebcdic + hisname Cp937 + ascii false + minmax 0x40 0xe2 0x40 0xfe + alias cp937 # JDK historical + alias ibm937 + alias ibm-937 + alias 937 + +charset x-IBM856 IBM856 + package sun.nio.cs.ext + type sbcs + hisname Cp856 + ascii false + alias cp856 # JDK historical + alias ibm-856 + alias ibm856 + alias 856 + +charset IBM860 IBM860 + package sun.nio.cs.ext + type sbcs + hisname Cp860 + ascii false + alias cp860 # JDK historical + alias ibm860 + alias ibm-860 + alias 860 + alias csIBM860 + +charset IBM861 IBM861 + package sun.nio.cs.ext + type sbcs + hisname Cp861 + ascii false + alias cp861 # JDK historical + alias ibm861 + alias ibm-861 + alias 861 + alias csIBM861 + alias cp-is + +charset IBM863 IBM863 + package sun.nio.cs.ext + type sbcs + hisname Cp863 + ascii false + alias cp863 # JDK historical + alias ibm863 + alias ibm-863 + alias 863 + alias csIBM863 + +charset IBM864 IBM864 + package sun.nio.cs.ext + type sbcs + hisname Cp864 + ascii false + alias cp864 # JDK historical + alias ibm864 + alias ibm-864 + alias 864 + alias csIBM864 + + +charset IBM865 IBM865 + package sun.nio.cs.ext + type sbcs + hisname Cp865 + ascii false + alias cp865 # JDK historical + alias ibm865 + alias ibm-865 + alias 865 + alias csIBM865 + +charset IBM868 IBM868 + package sun.nio.cs.ext + type sbcs + hisname Cp868 + ascii false + alias cp868 # JDK historical + alias ibm868 + alias ibm-868 + alias 868 + alias cp-ar + alias csIBM868 + +charset IBM869 IBM869 + package sun.nio.cs.ext + type sbcs + hisname Cp869 + ascii false + alias cp869 # JDK historical + alias ibm869 + alias ibm-869 + alias 869 + alias cp-gr + alias csIBM869 + +charset x-IBM921 IBM921 + package sun.nio.cs.ext + type sbcs + hisname Cp921 + ascii false + alias cp921 # JDK historical + alias ibm921 + alias ibm-921 + alias 921 + +charset x-IBM1006 IBM1006 + package sun.nio.cs.ext + type sbcs + hisname Cp1006 + ascii false + alias cp1006 # JDK historical + alias ibm1006 + alias ibm-1006 + alias 1006 + +charset x-IBM1046 IBM1046 + package sun.nio.cs.ext + type sbcs + hisname Cp1046 + ascii false + alias cp1046 # JDK historical + alias ibm1046 + alias ibm-1046 + alias 1046 + +charset IBM1047 IBM1047 + package sun.nio.cs.ext + type sbcs + hisname Cp1047 + ascii false + alias cp1047 # JDK historical + alias ibm-1047 + alias 1047 + +charset x-IBM1098 IBM1098 + package sun.nio.cs.ext + type sbcs + hisname Cp1098 + ascii false + alias cp1098 # JDK historical + alias ibm1098 + alias ibm-1098 + alias 1098 + +charset IBM037 IBM037 + package sun.nio.cs.ext + type sbcs + hisname Cp037 + ascii false + alias cp037 # JDK historical + alias ibm037 + alias ebcdic-cp-us + alias ebcdic-cp-ca + alias ebcdic-cp-wt + alias ebcdic-cp-nl + alias csIBM037 + alias cs-ebcdic-cp-us + alias cs-ebcdic-cp-ca + alias cs-ebcdic-cp-wt + alias cs-ebcdic-cp-nl + alias ibm-037 + alias ibm-37 + alias cpibm37 + alias 037 + +charset x-IBM1025 IBM1025 + package sun.nio.cs.ext + type sbcs + hisname Cp1025 + ascii false + alias cp1025 # JDK historical + alias ibm1025 + alias ibm-1025 + alias 1025 + +charset IBM1026 IBM1026 + package sun.nio.cs.ext + type sbcs + hisname Cp1026 + ascii false + alias cp1026 # JDK historical + alias ibm1026 + alias ibm-1026 + alias 1026 + +charset x-IBM1112 IBM1112 + package sun.nio.cs.ext + type sbcs + hisname Cp1112 + ascii false + alias cp1112 # JDK historical + alias ibm1112 + alias ibm-1112 + alias 1112 + +charset x-IBM1122 IBM1122 + package sun.nio.cs.ext + type sbcs + hisname Cp1122 + ascii false + alias cp1122 # JDK historical + alias ibm1122 + alias ibm-1122 + alias 1122 + +charset x-IBM1123 IBM1123 + package sun.nio.cs.ext + type sbcs + hisname Cp1123 + ascii false + alias cp1123 # JDK historical + alias ibm1123 + alias ibm-1123 + alias 1123 + +charset x-IBM1124 IBM1124 + package sun.nio.cs.ext + type sbcs + hisname Cp1124 + ascii false + alias cp1124 # JDK historical + alias ibm1124 + alias ibm-1124 + alias 1124 + +charset x-IBM1364 IBM1364 + package sun.nio.cs.ext + type ebcdic + hisname Cp1364 + ascii false + minmax 0x40 0xde 0x40 0xfe + alias cp1364 + alias ibm1364 + alias ibm-1364 + alias 1364 + +charset IBM273 IBM273 + package sun.nio.cs.ext + type sbcs + hisname Cp273 + ascii false + alias cp273 # JDK historical + alias ibm273 + alias ibm-273 + alias 273 + +charset IBM277 IBM277 + package sun.nio.cs.ext + type sbcs + hisname Cp277 + ascii false + alias cp277 # JDK historical + alias ibm277 + alias ibm-277 + alias 277 + +charset IBM278 IBM278 + package sun.nio.cs.ext + type sbcs + hisname Cp278 + ascii false + alias cp278 # JDK historical + alias ibm278 + alias ibm-278 + alias 278 + alias ebcdic-sv + alias ebcdic-cp-se + alias csIBM278 + +charset IBM280 IBM280 + package sun.nio.cs.ext + type sbcs + hisname Cp280 + ascii false + alias cp280 # JDK historical + alias ibm280 + alias ibm-280 + alias 280 + +charset IBM284 IBM284 + package sun.nio.cs.ext + type sbcs + hisname Cp284 + ascii false + alias cp284 # JDK historical + alias ibm284 + alias ibm-284 + alias 284 + alias csIBM284 + alias cpibm284 + +charset IBM285 IBM285 + package sun.nio.cs.ext + type sbcs + hisname Cp285 + ascii false + alias cp285 # JDK historical + alias ibm285 + alias ibm-285 + alias 285 + alias ebcdic-cp-gb + alias ebcdic-gb + alias csIBM285 + alias cpibm285 + +charset IBM297 IBM297 + package sun.nio.cs.ext + type sbcs + hisname Cp297 + ascii false + alias cp297 # JDK historical + alias ibm297 + alias ibm-297 + alias 297 + alias ebcdic-cp-fr + alias cpibm297 + alias csIBM297 + +charset IBM420 IBM420 + package sun.nio.cs.ext + type sbcs + hisname Cp420 + ascii false + alias cp420 # JDK historical + alias ibm420 + alias ibm-420 + alias ebcdic-cp-ar1 + alias 420 + alias csIBM420 + +charset IBM424 IBM424 + package sun.nio.cs.ext + type sbcs + hisname Cp424 + ascii false + alias cp424 # JDK historical + alias ibm424 + alias ibm-424 + alias 424 + alias ebcdic-cp-he + alias csIBM424 + +charset IBM500 IBM500 + package sun.nio.cs.ext + type sbcs + hisname Cp500 + ascii false + alias cp500 # JDK historical + alias ibm500 + alias ibm-500 + alias 500 + alias ebcdic-cp-ch + alias ebcdic-cp-bh + alias csIBM500 + +charset x-IBM833 IBM833 + package sun.nio.cs.ext + type sbcs + hisname Cp833 + ascii false + alias cp833 + alias ibm833 + alias ibm-833 + + +charset x-IBM834 IBM834 # EBCDIC DBCS-only Korean + package sun.nio.cs.ext + type source + alias cp834 + alias ibm834 + alias 834 + alias ibm-834 + +charset IBM-Thai IBM838 + package sun.nio.cs.ext + type sbcs + hisname Cp838 + ascii false + alias cp838 # JDK historical + alias ibm838 + alias ibm-838 + alias 838 + +charset IBM870 IBM870 + package sun.nio.cs.ext + type sbcs + hisname Cp870 + ascii false + alias cp870 # JDK historical + alias ibm870 + alias ibm-870 + alias 870 + alias ebcdic-cp-roece + alias ebcdic-cp-yu + alias csIBM870 + +charset IBM871 IBM871 + package sun.nio.cs.ext + type sbcs + hisname Cp871 + ascii false + alias cp871 # JDK historical + alias ibm871 + alias ibm-871 + alias 871 + alias ebcdic-cp-is + alias csIBM871 + +charset x-IBM875 IBM875 + package sun.nio.cs.ext + type sbcs + hisname Cp875 + ascii false + alias cp875 # JDK historical + alias ibm875 + alias ibm-875 + alias 875 + +charset IBM918 IBM918 + package sun.nio.cs.ext + type sbcs + hisname Cp918 + ascii false + alias cp918 # JDK historical + alias ibm-918 + alias 918 + alias ebcdic-cp-ar2 + +charset x-IBM922 IBM922 + package sun.nio.cs.ext + type sbcs + hisname Cp922 + ascii false + alias cp922 # JDK historical + alias ibm922 + alias ibm-922 + alias 922 + +charset x-IBM1097 IBM1097 + package sun.nio.cs.ext + type sbcs + hisname Cp1097 + ascii false + alias cp1097 # JDK historical + alias ibm1097 + alias ibm-1097 + alias 1097 + +charset x-IBM949 IBM949 + package sun.nio.cs.ext + type dbcs + hisname Cp949 + ascii false + minmax 0x8f 0xfe 0xa1 0xfe + alias cp949 # JDK historical + alias ibm949 + alias ibm-949 + alias 949 + +charset x-IBM949C IBM949C + package sun.nio.cs.ext + type source + alias cp949C # JDK historical + alias ibm949C + alias ibm-949C + alias 949C + +charset x-IBM939 IBM939 + package sun.nio.cs.ext + type ebcdic + hisname Cp939 + ascii false + minmax 0x40 0x7f 0x40 0xfe + alias cp939 # JDK historical + alias ibm939 + alias ibm-939 + alias 939 + +charset x-IBM933 IBM933 + package sun.nio.cs.ext + type ebcdic + hisname Cp933 + ascii false + minmax 0x40 0xdd 0x40 0xfe + alias cp933 # JDK historical + alias ibm933 + alias ibm-933 + alias 933 + +charset x-IBM1381 IBM1381 + package sun.nio.cs.ext + type dbcs + hisname Cp1381 + ascii true + minmax 0x8c 0xf7 0xa1 0xfe + alias cp1381 # JDK historical + alias ibm1381 + alias ibm-1381 + alias 1381 + +charset x-IBM1383 IBM1383 + package sun.nio.cs.ext + type euc_sim + hisname Cp1383 + ascii true + minmax 0xa1 0xfe 0xa1 0xfe + alias cp1383 # JDK historical + alias ibm1383 + alias ibm-1383 + alias 1383 + +charset x-IBM970 IBM970 + package sun.nio.cs.ext + type euc_sim + hisname Cp970 + ascii true + minmax 0xa1 0xfe 0xa1 0xfe + alias cp970 # JDK historical + alias ibm970 + alias ibm-970 + alias ibm-eucKR + alias 970 + +charset x-IBM964 IBM964 + package sun.nio.cs.ext + type source + alias cp964 # JDK historical + alias ibm964 + alias ibm-964 + alias 964 + +charset x-IBM33722 IBM33722 + package sun.nio.cs.ext + type source + alias cp33722 # JDK historical + alias ibm33722 + alias ibm-33722 + alias ibm-5050 # from IBM alias list + alias ibm-33722_vascii_vpua # from IBM alias list + alias 33722 + +charset IBM01140 IBM1140 + package sun.nio.cs.ext + type sbcs + hisname Cp1140 + ascii false + alias cp1140 # JDK historical + alias ccsid01140 + alias cp01140 + alias 1140 + alias ebcdic-us-037+euro + +charset IBM01141 IBM1141 + package sun.nio.cs.ext + type sbcs + hisname Cp1141 + ascii false + alias cp1141 # JDK historical + alias ccsid01141 + alias cp01141 + alias 1141 + alias ebcdic-de-273+euro + +charset IBM01142 IBM1142 + package sun.nio.cs.ext + type sbcs + hisname Cp1142 + ascii false + alias cp1142 # JDK historical + alias ccsid01142 + alias cp01142 + alias 1142 + alias ebcdic-no-277+euro + alias ebcdic-dk-277+euro + +charset IBM01143 IBM1143 + package sun.nio.cs.ext + type sbcs + hisname Cp1143 + ascii false + alias cp1143 # JDK historical + alias ccsid01143 + alias cp01143 + alias 1143 + alias ebcdic-fi-278+euro + alias ebcdic-se-278+euro + +charset IBM01144 IBM1144 + package sun.nio.cs.ext + type sbcs + hisname Cp1144 + ascii false + alias cp1144 # JDK historical + alias ccsid01144 + alias cp01144 + alias 1144 + alias ebcdic-it-280+euro + +charset IBM01145 IBM1145 + package sun.nio.cs.ext + type sbcs + hisname Cp1145 + ascii false + alias cp1145 # JDK historical + alias ccsid01145 + alias cp01145 + alias 1145 + alias ebcdic-es-284+euro + +charset IBM01146 IBM1146 + package sun.nio.cs.ext + type sbcs + hisname Cp1146 + ascii false + alias cp1146 # JDK historical + alias ccsid01146 + alias cp01146 + alias 1146 + alias ebcdic-gb-285+euro + +charset IBM01147 IBM1147 + package sun.nio.cs.ext + type sbcs + hisname Cp1147 + ascii false + alias cp1147 # JDK historical + alias ccsid01147 + alias cp01147 + alias 1147 + alias ebcdic-fr-277+euro + +charset IBM01148 IBM1148 + package sun.nio.cs.ext + type sbcs + hisname Cp1148 + ascii false + alias cp1148 # JDK historical + alias ccsid01148 + alias cp01148 + alias 1148 + alias ebcdic-international-500+euro + +charset IBM01149 IBM1149 + package sun.nio.cs.ext + type sbcs + hisname Cp1149 + ascii false + alias cp1149 # JDK historical + alias ccsid01149 + alias cp01149 + alias 1149 + alias ebcdic-s-871+euro + +charset IBM290 IBM290 + package sun.nio.cs.ext + type sbcs + hisname Cp290 + ascii false + alias cp290 + alias ibm290 + alias ibm-290 + alias csIBM290 + alias EBCDIC-JP-kana + alias 290 + +charset x-IBM300 IBM300 + package sun.nio.cs.ext + type dbcsonly + hisname Cp300 + ascii false + minmax 0x40 0x7f 0x40 0xfe + alias cp300 + alias ibm300 + alias ibm-300 + alias 300 + +# Macintosh MacOS/Apple char encodingd + +charset x-MacRoman MacRoman + package sun.nio.cs.ext + type sbcs + hisname MacRoman + ascii false + alias MacRoman # JDK historical + +charset x-MacCentralEurope MacCentralEurope + package sun.nio.cs.ext + type sbcs + hisname MacCentralEurope + ascii false + alias MacCentralEurope # JDK historical + +charset x-MacCroatian MacCroatian + package sun.nio.cs.ext + type sbcs + hisname MacCroatian + ascii false + alias MacCroatian # JDK historical + +charset x-MacGreek MacGreek + package sun.nio.cs.ext + type sbcs + hisname MacGreek + ascii false + alias MacGreek # JDK historical + +charset x-MacCyrillic MacCyrillic + package sun.nio.cs.ext + type sbcs + hisname MacCyrillic + ascii false + alias MacCyrillic # JDK historical + +charset x-MacUkraine MacUkraine + package sun.nio.cs.ext + type sbcs + hisname MacUkraine + ascii false + alias MacUkraine # JDK historical + +charset x-MacTurkish MacTurkish + package sun.nio.cs.ext + type sbcs + hisname MacTurkish + ascii false + alias MacTurkish # JDK historical + +charset x-MacArabic MacArabic + package sun.nio.cs.ext + type sbcs + hisname MacArabic + ascii false + alias MacArabic # JDK historical + +charset x-MacHebrew MacHebrew + package sun.nio.cs.ext + type sbcs + hisname MacHebrew + ascii false + alias MacHebrew # JDK historical + +charset x-MacIceland MacIceland + package sun.nio.cs.ext + type sbcs + hisname MacIceland + ascii false + alias MacIceland # JDK historical + +charset x-MacRomania MacRomania + package sun.nio.cs.ext + type sbcs + hisname MacRomania + ascii false + alias MacRomania # JDK historical + +charset x-MacThai MacThai + package sun.nio.cs.ext + type sbcs + hisname MacThai + ascii false + alias MacThai # JDK historical + +charset x-MacSymbol MacSymbol + package sun.nio.cs.ext + type sbcs + hisname MacSymbol + ascii false + alias MacSymbol # JDK historical + +charset x-MacDingbat MacDingbat + package sun.nio.cs.ext + type sbcs + hisname MacDingbat + ascii false + alias MacDingbat # JDK historical + +######################################################## +# +# internal use, not to be registered into spi +# +######################################################## + +charset x-JIS0208_Solaris JIS_X_0208_Solaris + package sun.nio.cs.ext + type dbcsonly + hisname JIS0208 + ascii false + minmax 0x21 0x9e 0x21 0x7e + internal true + +charset x-JIS0208_MS5022X JIS_X_0208_MS5022X + package sun.nio.cs.ext + type dbcsonly + hisname JIS_X_0208_MS5022X + ascii false + minmax 0x21 0x7e 0x21 0x7e + internal true + +charset x-JIS0208_MS932 JIS_X_0208_MS932 + package sun.nio.cs.ext + type dbcsonly + hisname JIS_X_0208_MS932 + ascii false + minmax 0x21 0x7e 0x21 0x7e + internal true # "internal implementation + +charset x-JIS0212_Solaris JIS_X_0212_Solaris + package sun.nio.cs.ext + type dbcsonly + hisname JIS_X_0212_Solaris + ascii false + minmax 0x21 0x7e 0x21 0x7e + internal true # "internal implementation + +charset x-JIS0212_MS5022X JIS_X_0212_MS5022X + package sun.nio.cs.ext + type dbcsonly + hisname JIS_X_0212_MS5022X + ascii false + minmax 0x21 0x7e 0x21 0x7e + internal true # "internal implementation diff --git a/jdk/make/data/charsetmapping/dbcs b/jdk/make/data/charsetmapping/dbcs deleted file mode 100644 index a22e886977f..00000000000 --- a/jdk/make/data/charsetmapping/dbcs +++ /dev/null @@ -1,36 +0,0 @@ -# -#clzName csName hisName dbtype pkg ascii b1min b1max b2min b2max -# -Big5 Big5 Big5 basic sun.nio.cs.ext true 0xa1 0xf9 0x40 0xfe -Johab x-Johab x-Johab basic sun.nio.cs.ext true 0x84 0xf9 0x31 0xfe -EUC_CN GB2312 EUC_CN basic sun.nio.cs.ext true 0xa1 0xf7 0xa1 0xfe -EUC_KR EUC-KR EUC_KR basic sun.nio.cs.ext true 0xa1 0xfd 0xa1 0xfe -MS932 windows-31j MS932 basic sun.nio.cs.ext true 0x81 0xfc 0x40 0xfc -MS936 x-mswin-936 MS936 basic sun.nio.cs.ext true 0x81 0xfe 0x40 0xfe -MS949 x-windows-949 MS949 basic sun.nio.cs.ext true 0x81 0xfe 0x41 0xfe -MS950 x-windows-950 MS950 basic sun.nio.cs.ext true 0x81 0xfe 0x40 0xfe -GBK GBK GBK basic sun.nio.cs.ext true 0x81 0xfe 0x40 0xfe -SJIS Shift_JIS SJIS basic sun.nio.cs.ext true 0x81 0xfc 0x40 0xfc -PCK x-PCK PCK basic sun.nio.cs.ext true 0x81 0xfc 0x40 0xfc -IBM1364 x-IBM1364 Cp1364 ebcdic sun.nio.cs.ext false 0x40 0xde 0x40 0xfe -IBM1381 x-IBM1381 Cp1381 basic sun.nio.cs.ext true 0x8c 0xf7 0xa1 0xfe -IBM1383 x-IBM1383 Cp1383 euc_sim sun.nio.cs.ext true 0xa1 0xfe 0xa1 0xfe -IBM300 x-IBM300 Cp300 dbcsonly sun.nio.cs.ext false 0x40 0x7f 0x40 0xfe -IBM930 x-IBM930 Cp930 ebcdic sun.nio.cs.ext false 0x40 0x7f 0x40 0xfe -IBM933 x-IBM933 Cp933 ebcdic sun.nio.cs.ext false 0x40 0xdd 0x40 0xfe -IBM935 x-IBM935 Cp935 ebcdic sun.nio.cs.ext false 0x40 0x7f 0x40 0xfe -IBM937 x-IBM937 Cp937 ebcdic sun.nio.cs.ext false 0x40 0xe2 0x40 0xfe -IBM939 x-IBM939 Cp939 ebcdic sun.nio.cs.ext false 0x40 0x7f 0x40 0xfe -IBM942 x-IBM942 Cp942 basic sun.nio.cs.ext false 0x81 0xfc 0x40 0xfc -IBM943 x-IBM943 Cp943 basic sun.nio.cs.ext false 0x81 0xfc 0x40 0xfc -IBM948 x-IBM948 Cp948 basic sun.nio.cs.ext true 0x81 0xfe 0x40 0xfc -IBM949 x-IBM949 Cp949 basic sun.nio.cs.ext false 0x8f 0xfe 0xa1 0xfe -IBM950 x-IBM950 Cp950 basic sun.nio.cs.ext true 0x81 0xfe 0x40 0xfe -IBM970 x-IBM970 Cp970 euc_sim sun.nio.cs.ext true 0xa1 0xfe 0xa1 0xfe -JIS_X_0208 x-JIS0208 JIS0208 dbcsonly sun.nio.cs.ext false 0x21 0x7e 0x21 0x7e -JIS_X_0212 JIS_X0212-1990 JIS0212 dbcsonly sun.nio.cs.ext false 0x21 0x7e 0x21 0x7e -JIS_X_0208_Solaris x-JIS0208_Solaris JIS0208_Solaris dbcsonly sun.nio.cs.ext false 0x21 0x9e 0x21 0x7e -JIS_X_0208_MS5022X x-JIS0208_MS5022X JIS0208_MS5022X dbcsonly sun.nio.cs.ext false 0x21 0x7e 0x21 0x7e -JIS_X_0208_MS932 x-JIS0208_MS932 JIS0208_MS932 dbcsonly sun.nio.cs.ext false 0x21 0x7e 0x21 0x7e -JIS_X_0212_Solaris x-JIS0212_Solaris JIS0212_Solaris dbcsonly sun.nio.cs.ext false 0x21 0x7e 0x21 0x7e -JIS_X_0212_MS5022X x-JIS0212_MS5022X JIS0212_MS5022X dbcsonly sun.nio.cs.ext false 0x21 0x7e 0x21 0x7e diff --git a/jdk/make/data/charsetmapping/extsbcs b/jdk/make/data/charsetmapping/extsbcs deleted file mode 100644 index ed82dbe82d9..00000000000 --- a/jdk/make/data/charsetmapping/extsbcs +++ /dev/null @@ -1,76 +0,0 @@ -# clzName csName hisName containASCII pkg -IBM037 IBM037 Cp037 false sun.nio.cs.ext -IBM1006 x-IBM1006 Cp1006 false sun.nio.cs.ext -IBM1025 x-IBM1025 Cp1025 false sun.nio.cs.ext -IBM1026 IBM1026 Cp1026 false sun.nio.cs.ext -IBM1046 x-IBM1046 Cp1046 false sun.nio.cs.ext -IBM1047 IBM1047 Cp1047 false sun.nio.cs.ext -IBM1097 x-IBM1097 Cp1097 false sun.nio.cs.ext -IBM1098 x-IBM1098 Cp1098 false sun.nio.cs.ext -IBM1112 x-IBM1112 Cp1112 false sun.nio.cs.ext -IBM1122 x-IBM1122 Cp1122 false sun.nio.cs.ext -IBM1123 x-IBM1123 Cp1123 false sun.nio.cs.ext -IBM1124 x-IBM1124 Cp1124 false sun.nio.cs.ext -# map tables for 1140-1149 are updated manualy with the u+20ac entry -IBM1140 IBM01140 Cp1140 false sun.nio.cs.ext -IBM1141 IBM01141 Cp1141 false sun.nio.cs.ext -IBM1142 IBM01142 Cp1142 false sun.nio.cs.ext -IBM1143 IBM01143 Cp1143 false sun.nio.cs.ext -IBM1144 IBM01144 Cp1144 false sun.nio.cs.ext -IBM1145 IBM01145 Cp1145 false sun.nio.cs.ext -IBM1146 IBM01146 Cp1146 false sun.nio.cs.ext -IBM1147 IBM01147 Cp1147 false sun.nio.cs.ext -IBM1148 IBM01148 Cp1148 false sun.nio.cs.ext -IBM1149 IBM01149 Cp1149 false sun.nio.cs.ext -IBM273 IBM273 Cp273 false sun.nio.cs.ext -IBM277 IBM277 Cp277 false sun.nio.cs.ext -IBM278 IBM278 Cp278 false sun.nio.cs.ext -IBM280 IBM280 Cp280 false sun.nio.cs.ext -IBM284 IBM284 Cp284 false sun.nio.cs.ext -IBM285 IBM285 Cp285 false sun.nio.cs.ext -IBM290 IBM290 Cp290 false sun.nio.cs.ext -IBM297 IBM297 Cp297 false sun.nio.cs.ext -IBM420 IBM420 Cp420 false sun.nio.cs.ext -IBM424 IBM424 Cp424 false sun.nio.cs.ext -IBM500 IBM500 Cp500 false sun.nio.cs.ext -IBM833 x-IBM833 Cp833 false sun.nio.cs.ext -IBM838 IBM-Thai Cp838 false sun.nio.cs.ext -IBM856 x-IBM856 Cp856 false sun.nio.cs.ext -IBM860 IBM860 Cp860 false sun.nio.cs.ext -IBM861 IBM861 Cp861 false sun.nio.cs.ext -IBM863 IBM863 Cp863 false sun.nio.cs.ext -IBM864 IBM864 Cp864 false sun.nio.cs.ext -IBM865 IBM865 Cp865 false sun.nio.cs.ext -IBM868 IBM868 Cp868 false sun.nio.cs.ext -IBM869 IBM869 Cp869 false sun.nio.cs.ext -IBM870 IBM870 Cp870 false sun.nio.cs.ext -IBM871 IBM871 Cp871 false sun.nio.cs.ext -IBM875 x-IBM875 Cp875 false sun.nio.cs.ext -IBM918 IBM918 Cp918 false sun.nio.cs.ext -IBM921 x-IBM921 Cp921 false sun.nio.cs.ext -IBM922 x-IBM922 Cp922 false sun.nio.cs.ext -# use name as hisname as well, cs did not support hisname prevously -ISO_8859_11 x-iso-8859-11 x-iso-8859-11 true sun.nio.cs.ext -ISO_8859_3 ISO-8859-3 ISO8859_3 true sun.nio.cs.ext -ISO_8859_6 ISO-8859-6 ISO8859_6 true sun.nio.cs.ext -ISO_8859_8 ISO-8859-8 ISO8859_8 true sun.nio.cs.ext -JIS_X_0201 JIS_X0201 JIS_X0201 true sun.nio.cs.ext -MS1255 windows-1255 Cp1255 true sun.nio.cs.ext -MS1256 windows-1256 Cp1256 true sun.nio.cs.ext -MS1258 windows-1258 Cp1258 true sun.nio.cs.ext -MS874 x-windows-874 MS874 true sun.nio.cs.ext -MacArabic x-MacArabic MacArabic false sun.nio.cs.ext -MacCentralEurope x-MacCentralEurope MacCentralEurope false sun.nio.cs.ext -MacCroatian x-MacCroatian MacCroatian false sun.nio.cs.ext -MacCyrillic x-MacCyrillic MacCyrillic false sun.nio.cs.ext -MacDingbat x-MacDingbat MacDingbat false sun.nio.cs.ext -MacGreek x-MacGreek MacGreek false sun.nio.cs.ext -MacHebrew x-MacHebrew MacHebrew false sun.nio.cs.ext -MacIceland x-MacIceland MacIceland false sun.nio.cs.ext -MacRoman x-MacRoman MacRoman false sun.nio.cs.ext -MacRomania x-MacRomania MacRomania false sun.nio.cs.ext -MacSymbol x-MacSymbol MacSymbol false sun.nio.cs.ext -MacThai x-MacThai MacThai false sun.nio.cs.ext -MacTurkish x-MacTurkish MacTurkish false sun.nio.cs.ext -MacUkraine x-MacUkraine MacUkraine false sun.nio.cs.ext -TIS_620 TIS-620 TIS620 true sun.nio.cs.ext diff --git a/jdk/make/data/charsetmapping/list_old b/jdk/make/data/charsetmapping/list_old new file mode 100644 index 00000000000..ca03b40921b --- /dev/null +++ b/jdk/make/data/charsetmapping/list_old @@ -0,0 +1,149 @@ +# +# This is the copy of the old configuration files sbcs, dbcs and extsbcs +# used in jdk8. +############################### sbcs ######################################### +# +# clzName csName hisName containASCII pkg +# +IBM437 IBM437 Cp437 false sun.nio.cs +IBM737 x-IBM737 Cp737 false sun.nio.cs +IBM775 IBM775 Cp775 false sun.nio.cs +IBM850 IBM850 Cp850 false sun.nio.cs +IBM852 IBM852 Cp852 false sun.nio.cs +IBM855 IBM855 Cp855 false sun.nio.cs +IBM857 IBM857 Cp857 false sun.nio.cs +IBM858 IBM00858 Cp858 false sun.nio.cs +IBM862 IBM862 Cp862 false sun.nio.cs +IBM866 IBM866 Cp866 false sun.nio.cs +IBM874 x-IBM874 Cp874 false sun.nio.cs +ISO_8859_2 ISO-8859-2 ISO8859_2 true sun.nio.cs +ISO_8859_4 ISO-8859-4 ISO8859_4 true sun.nio.cs +ISO_8859_5 ISO-8859-5 ISO8859_5 true sun.nio.cs +ISO_8859_7 ISO-8859-7 ISO8859_7 true sun.nio.cs +ISO_8859_9 ISO-8859-9 ISO8859_9 true sun.nio.cs +ISO_8859_13 ISO-8859-13 ISO8859_13 true sun.nio.cs +ISO_8859_15 ISO-8859-15 ISO8859_15 true sun.nio.cs +KOI8_R KOI8-R KOI8_R true sun.nio.cs +KOI8_U KOI8-U KOI8_U true sun.nio.cs +MS1250 windows-1250 Cp1250 true sun.nio.cs +MS1251 windows-1251 Cp1251 true sun.nio.cs +MS1252 windows-1252 Cp1252 true sun.nio.cs +MS1253 windows-1253 Cp1253 true sun.nio.cs +MS1254 windows-1254 Cp1254 true sun.nio.cs +MS1257 windows-1257 Cp1257 true sun.nio.cs +# +############################### extsbcs ####################################### +# +IBM037 IBM037 Cp037 false sun.nio.cs.ext +IBM1006 x-IBM1006 Cp1006 false sun.nio.cs.ext +IBM1025 x-IBM1025 Cp1025 false sun.nio.cs.ext +IBM1026 IBM1026 Cp1026 false sun.nio.cs.ext +IBM1046 x-IBM1046 Cp1046 false sun.nio.cs.ext +IBM1047 IBM1047 Cp1047 false sun.nio.cs.ext +IBM1097 x-IBM1097 Cp1097 false sun.nio.cs.ext +IBM1098 x-IBM1098 Cp1098 false sun.nio.cs.ext +IBM1112 x-IBM1112 Cp1112 false sun.nio.cs.ext +IBM1122 x-IBM1122 Cp1122 false sun.nio.cs.ext +IBM1123 x-IBM1123 Cp1123 false sun.nio.cs.ext +IBM1124 x-IBM1124 Cp1124 false sun.nio.cs.ext +# map tables for 1140-1149 are updated manualy with the u+20ac entry +IBM1140 IBM01140 Cp1140 false sun.nio.cs.ext +IBM1141 IBM01141 Cp1141 false sun.nio.cs.ext +IBM1142 IBM01142 Cp1142 false sun.nio.cs.ext +IBM1143 IBM01143 Cp1143 false sun.nio.cs.ext +IBM1144 IBM01144 Cp1144 false sun.nio.cs.ext +IBM1145 IBM01145 Cp1145 false sun.nio.cs.ext +IBM1146 IBM01146 Cp1146 false sun.nio.cs.ext +IBM1147 IBM01147 Cp1147 false sun.nio.cs.ext +IBM1148 IBM01148 Cp1148 false sun.nio.cs.ext +IBM1149 IBM01149 Cp1149 false sun.nio.cs.ext +IBM273 IBM273 Cp273 false sun.nio.cs.ext +IBM277 IBM277 Cp277 false sun.nio.cs.ext +IBM278 IBM278 Cp278 false sun.nio.cs.ext +IBM280 IBM280 Cp280 false sun.nio.cs.ext +IBM284 IBM284 Cp284 false sun.nio.cs.ext +IBM285 IBM285 Cp285 false sun.nio.cs.ext +IBM290 IBM290 Cp290 false sun.nio.cs.ext +IBM297 IBM297 Cp297 false sun.nio.cs.ext +IBM420 IBM420 Cp420 false sun.nio.cs.ext +IBM424 IBM424 Cp424 false sun.nio.cs.ext +IBM500 IBM500 Cp500 false sun.nio.cs.ext +IBM833 x-IBM833 Cp833 false sun.nio.cs.ext +IBM838 IBM-Thai Cp838 false sun.nio.cs.ext +IBM856 x-IBM856 Cp856 false sun.nio.cs.ext +IBM860 IBM860 Cp860 false sun.nio.cs.ext +IBM861 IBM861 Cp861 false sun.nio.cs.ext +IBM863 IBM863 Cp863 false sun.nio.cs.ext +IBM864 IBM864 Cp864 false sun.nio.cs.ext +IBM865 IBM865 Cp865 false sun.nio.cs.ext +IBM868 IBM868 Cp868 false sun.nio.cs.ext +IBM869 IBM869 Cp869 false sun.nio.cs.ext +IBM870 IBM870 Cp870 false sun.nio.cs.ext +IBM871 IBM871 Cp871 false sun.nio.cs.ext +IBM875 x-IBM875 Cp875 false sun.nio.cs.ext +IBM918 IBM918 Cp918 false sun.nio.cs.ext +IBM921 x-IBM921 Cp921 false sun.nio.cs.ext +IBM922 x-IBM922 Cp922 false sun.nio.cs.ext +# use name as hisname as well, cs did not support hisname prevously +ISO_8859_11 x-iso-8859-11 x-iso-8859-11 true sun.nio.cs.ext +ISO_8859_3 ISO-8859-3 ISO8859_3 true sun.nio.cs.ext +ISO_8859_6 ISO-8859-6 ISO8859_6 true sun.nio.cs.ext +ISO_8859_8 ISO-8859-8 ISO8859_8 true sun.nio.cs.ext +JIS_X_0201 JIS_X0201 JIS_X0201 true sun.nio.cs.ext +MS1255 windows-1255 Cp1255 true sun.nio.cs.ext +MS1256 windows-1256 Cp1256 true sun.nio.cs.ext +MS1258 windows-1258 Cp1258 true sun.nio.cs.ext +MS874 x-windows-874 MS874 true sun.nio.cs.ext +MacArabic x-MacArabic MacArabic false sun.nio.cs.ext +MacCentralEurope x-MacCentralEurope MacCentralEurope false sun.nio.cs.ext +MacCroatian x-MacCroatian MacCroatian false sun.nio.cs.ext +MacCyrillic x-MacCyrillic MacCyrillic false sun.nio.cs.ext +MacDingbat x-MacDingbat MacDingbat false sun.nio.cs.ext +MacGreek x-MacGreek MacGreek false sun.nio.cs.ext +MacHebrew x-MacHebrew MacHebrew false sun.nio.cs.ext +MacIceland x-MacIceland MacIceland false sun.nio.cs.ext +MacRoman x-MacRoman MacRoman false sun.nio.cs.ext +MacRomania x-MacRomania MacRomania false sun.nio.cs.ext +MacSymbol x-MacSymbol MacSymbol false sun.nio.cs.ext +MacThai x-MacThai MacThai false sun.nio.cs.ext +MacTurkish x-MacTurkish MacTurkish false sun.nio.cs.ext +MacUkraine x-MacUkraine MacUkraine false sun.nio.cs.ext +TIS_620 TIS-620 TIS620 true sun.nio.cs.ext +# +############################### dbcs ######################################### +# +#clzName csName hisName dbtype pkg ascii b1min b1max b2min b2max +# +Big5 Big5 Big5 basic sun.nio.cs.ext true 0xa1 0xf9 0x40 0xfe +Johab x-Johab x-Johab basic sun.nio.cs.ext true 0x84 0xf9 0x31 0xfe +EUC_CN GB2312 EUC_CN basic sun.nio.cs.ext true 0xa1 0xf7 0xa1 0xfe +EUC_KR EUC-KR EUC_KR basic sun.nio.cs.ext true 0xa1 0xfd 0xa1 0xfe +MS932 windows-31j MS932 basic sun.nio.cs.ext true 0x81 0xfc 0x40 0xfc +MS936 x-mswin-936 MS936 basic sun.nio.cs.ext true 0x81 0xfe 0x40 0xfe +MS949 x-windows-949 MS949 basic sun.nio.cs.ext true 0x81 0xfe 0x41 0xfe +MS950 x-windows-950 MS950 basic sun.nio.cs.ext true 0x81 0xfe 0x40 0xfe +GBK GBK GBK basic sun.nio.cs.ext true 0x81 0xfe 0x40 0xfe +SJIS Shift_JIS SJIS basic sun.nio.cs.ext true 0x81 0xfc 0x40 0xfc +PCK x-PCK PCK basic sun.nio.cs.ext true 0x81 0xfc 0x40 0xfc +IBM1364 x-IBM1364 Cp1364 ebcdic sun.nio.cs.ext false 0x40 0xde 0x40 0xfe +IBM1381 x-IBM1381 Cp1381 basic sun.nio.cs.ext true 0x8c 0xf7 0xa1 0xfe +IBM1383 x-IBM1383 Cp1383 euc_sim sun.nio.cs.ext true 0xa1 0xfe 0xa1 0xfe +IBM300 x-IBM300 Cp300 dbcsonly sun.nio.cs.ext false 0x40 0x7f 0x40 0xfe +IBM930 x-IBM930 Cp930 ebcdic sun.nio.cs.ext false 0x40 0x7f 0x40 0xfe +IBM933 x-IBM933 Cp933 ebcdic sun.nio.cs.ext false 0x40 0xdd 0x40 0xfe +IBM935 x-IBM935 Cp935 ebcdic sun.nio.cs.ext false 0x40 0x7f 0x40 0xfe +IBM937 x-IBM937 Cp937 ebcdic sun.nio.cs.ext false 0x40 0xe2 0x40 0xfe +IBM939 x-IBM939 Cp939 ebcdic sun.nio.cs.ext false 0x40 0x7f 0x40 0xfe +IBM942 x-IBM942 Cp942 basic sun.nio.cs.ext false 0x81 0xfc 0x40 0xfc +IBM943 x-IBM943 Cp943 basic sun.nio.cs.ext false 0x81 0xfc 0x40 0xfc +IBM948 x-IBM948 Cp948 basic sun.nio.cs.ext true 0x81 0xfe 0x40 0xfc +IBM949 x-IBM949 Cp949 basic sun.nio.cs.ext false 0x8f 0xfe 0xa1 0xfe +IBM950 x-IBM950 Cp950 basic sun.nio.cs.ext true 0x81 0xfe 0x40 0xfe +IBM970 x-IBM970 Cp970 euc_sim sun.nio.cs.ext true 0xa1 0xfe 0xa1 0xfe +JIS_X_0208 x-JIS0208 JIS0208 dbcsonly sun.nio.cs.ext false 0x21 0x7e 0x21 0x7e +JIS_X_0212 JIS_X0212-1990 JIS0212 dbcsonly sun.nio.cs.ext false 0x21 0x7e 0x21 0x7e +JIS_X_0208_Solaris x-JIS0208_Solaris JIS0208_Solaris dbcsonly sun.nio.cs.ext false 0x21 0x9e 0x21 0x7e +JIS_X_0208_MS5022X x-JIS0208_MS5022X JIS0208_MS5022X dbcsonly sun.nio.cs.ext false 0x21 0x7e 0x21 0x7e +JIS_X_0208_MS932 x-JIS0208_MS932 JIS0208_MS932 dbcsonly sun.nio.cs.ext false 0x21 0x7e 0x21 0x7e +JIS_X_0212_Solaris x-JIS0212_Solaris JIS0212_Solaris dbcsonly sun.nio.cs.ext false 0x21 0x7e 0x21 0x7e +JIS_X_0212_MS5022X x-JIS0212_MS5022X JIS0212_MS5022X dbcsonly sun.nio.cs.ext false 0x21 0x7e 0x21 0x7e diff --git a/jdk/make/data/charsetmapping/sbcs b/jdk/make/data/charsetmapping/sbcs deleted file mode 100644 index 0b11960411b..00000000000 --- a/jdk/make/data/charsetmapping/sbcs +++ /dev/null @@ -1,28 +0,0 @@ -# clzName csName hisName containASCII pkg -IBM437 IBM437 Cp437 false sun.nio.cs -IBM737 x-IBM737 Cp737 false sun.nio.cs -IBM775 IBM775 Cp775 false sun.nio.cs -IBM850 IBM850 Cp850 false sun.nio.cs -IBM852 IBM852 Cp852 false sun.nio.cs -IBM855 IBM855 Cp855 false sun.nio.cs -IBM857 IBM857 Cp857 false sun.nio.cs -IBM858 IBM00858 Cp858 false sun.nio.cs -IBM862 IBM862 Cp862 false sun.nio.cs -IBM866 IBM866 Cp866 false sun.nio.cs -IBM874 x-IBM874 Cp874 false sun.nio.cs -ISO_8859_2 ISO-8859-2 ISO8859_2 true sun.nio.cs -ISO_8859_4 ISO-8859-4 ISO8859_4 true sun.nio.cs -ISO_8859_5 ISO-8859-5 ISO8859_5 true sun.nio.cs -ISO_8859_7 ISO-8859-7 ISO8859_7 true sun.nio.cs -ISO_8859_9 ISO-8859-9 ISO8859_9 true sun.nio.cs -ISO_8859_13 ISO-8859-13 ISO8859_13 true sun.nio.cs -ISO_8859_15 ISO-8859-15 ISO8859_15 true sun.nio.cs -KOI8_R KOI8-R KOI8_R true sun.nio.cs -KOI8_U KOI8-U KOI8_U true sun.nio.cs -MS1250 windows-1250 Cp1250 true sun.nio.cs -MS1251 windows-1251 Cp1251 true sun.nio.cs -MS1252 windows-1252 Cp1252 true sun.nio.cs -MS1253 windows-1253 Cp1253 true sun.nio.cs -MS1254 windows-1254 Cp1254 true sun.nio.cs -MS1257 windows-1257 Cp1257 true sun.nio.cs - diff --git a/jdk/make/data/charsetmapping/standard-charsets b/jdk/make/data/charsetmapping/standard-charsets deleted file mode 100644 index f9f4db12c6a..00000000000 --- a/jdk/make/data/charsetmapping/standard-charsets +++ /dev/null @@ -1,337 +0,0 @@ -# -# Copyright (c) 2000, 2014, 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. Oracle designates this -# particular file as subject to the "Classpath" exception as provided -# by Oracle in the LICENSE file that accompanied this code. -# -# 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. -# - -# Standard charsets provided by StandardCharsets provider. -# -# Note that these "standard" charsets listed here are not -# necessary to be the "Standard charsets" defined in the -# specification of java.nio.charset.Charset. Instead these -# are the charsets that this implementation believes should -# be packaged into the charsets provider class "StandardCharsets" -# which is initialized at startup time by java.nio.charset.Charset, -# compared to the charsets packaged in "ExtendedCharsets" provider, -# which is lazy initialized. - -charset US-ASCII US_ASCII - - # IANA aliases - alias iso-ir-6 - alias ANSI_X3.4-1986 - alias ISO_646.irv:1991 - alias ASCII - alias ISO646-US - alias us - alias IBM367 - alias cp367 - alias csASCII - alias default - - # Other aliases - alias 646 # Solaris POSIX locale - alias iso_646.irv:1983 - alias ANSI_X3.4-1968 # Linux POSIX locale (RedHat) - alias ascii7 - -charset UTF-8 UTF_8 - alias UTF8 # JDK historical - alias unicode-1-1-utf-8 - -charset CESU-8 CESU_8 - alias CESU8 - alias csCESU-8 - -charset UTF-16 UTF_16 - alias UTF_16 # JDK historical - alias utf16 - alias unicode - alias UnicodeBig - -charset UTF-16BE UTF_16BE - alias UTF_16BE - alias ISO-10646-UCS-2 - alias X-UTF-16BE - alias UnicodeBigUnmarked - -charset UTF-16LE UTF_16LE - alias UTF_16LE - alias X-UTF-16LE - alias UnicodeLittleUnmarked - -charset x-UTF-16LE-BOM UTF_16LE_BOM - alias UnicodeLittle - -charset UTF-32 UTF_32 - alias UTF_32 - alias UTF32 - -charset UTF-32LE UTF_32LE - alias UTF_32LE - alias X-UTF-32LE - -charset UTF-32BE UTF_32BE - alias UTF_32BE - alias X-UTF-32BE - -charset X-UTF-32LE-BOM UTF_32LE_BOM - alias UTF_32LE_BOM - alias UTF-32LE-BOM - -charset X-UTF-32BE-BOM UTF_32BE_BOM - alias UTF_32BE_BOM - alias UTF-32BE-BOM - -charset ISO-8859-1 ISO_8859_1 - - # IANA aliases - alias iso-ir-100 - alias ISO_8859-1 - alias latin1 - alias l1 - alias IBM819 - alias cp819 - alias csISOLatin1 - - # Other aliases - alias 819 - alias IBM-819 - alias ISO8859_1 - alias ISO_8859-1:1987 - alias ISO_8859_1 - alias 8859_1 - alias ISO8859-1 - -charset ISO-8859-2 ISO_8859_2 - alias iso8859_2 # JDK historical - alias 8859_2 - alias iso-ir-101 - alias ISO_8859-2 - alias ISO_8859-2:1987 - alias ISO8859-2 - alias latin2 - alias l2 - alias ibm912 - alias ibm-912 - alias cp912 - alias 912 - alias csISOLatin2 - -charset ISO-8859-4 ISO_8859_4 - alias iso8859_4 # JDK historical - alias iso8859-4 - alias 8859_4 - alias iso-ir-110 - alias ISO_8859-4 - alias ISO_8859-4:1988 - alias latin4 - alias l4 - alias ibm914 - alias ibm-914 - alias cp914 - alias 914 - alias csISOLatin4 - -charset ISO-8859-5 ISO_8859_5 - alias iso8859_5 # JDK historical - alias 8859_5 - alias iso-ir-144 - alias ISO_8859-5 - alias ISO_8859-5:1988 - alias ISO8859-5 - alias cyrillic - alias ibm915 - alias ibm-915 - alias cp915 - alias 915 - alias csISOLatinCyrillic - -charset ISO-8859-7 ISO_8859_7 - alias iso8859_7 # JDK historical - alias 8859_7 - alias iso-ir-126 - alias ISO_8859-7 - alias ISO_8859-7:1987 - alias ELOT_928 - alias ECMA-118 - alias greek - alias greek8 - alias csISOLatinGreek - alias sun_eu_greek # Solaris 7/8 compatibility - alias ibm813 - alias ibm-813 - alias 813 - alias cp813 - alias iso8859-7 # Solaris 9 compatibility - -charset ISO-8859-9 ISO_8859_9 - alias iso8859_9 # JDK historical - alias 8859_9 - alias iso-ir-148 - alias ISO_8859-9 - alias ISO_8859-9:1989 - alias ISO8859-9 - alias latin5 - alias l5 - alias ibm920 - alias ibm-920 - alias 920 - alias cp920 - alias csISOLatin5 - -charset ISO-8859-13 ISO_8859_13 - alias iso8859_13 # JDK historical - alias 8859_13 - alias iso_8859-13 - alias ISO8859-13 - -charset ISO-8859-15 ISO_8859_15 - - # IANA alias - alias ISO_8859-15 - - # Other aliases - alias 8859_15 - alias ISO-8859-15 - alias ISO8859_15 - alias ISO8859-15 - alias IBM923 - alias IBM-923 - alias cp923 - alias 923 - alias LATIN0 - alias LATIN9 - alias L9 - alias csISOlatin0 - alias csISOlatin9 - alias ISO8859_15_FDIS - -charset KOI8-R KOI8_R - alias koi8_r # JDK historical - alias koi8 - alias cskoi8r - -charset KOI8-U KOI8_U - alias koi8_u - -charset windows-1250 MS1250 - alias cp1250 # JDK historical - alias cp5346 # Euro IBM CCSID - -charset windows-1251 MS1251 - alias cp1251 # JDK historical - alias cp5347 # Euro IBM CCSID - alias ansi-1251 # Solaris compatibility - -charset windows-1252 MS1252 - alias cp1252 # JDK historical - alias cp5348 # Euro IBM CCSID - -charset windows-1253 MS1253 - alias cp1253 # JDK historical - alias cp5349 # Euro IBM CCSID - -charset windows-1254 MS1254 - alias cp1254 # JDK historical - alias cp5350 # Euro IBM CCSID - -charset windows-1257 MS1257 - alias cp1257 # JDK historical - alias cp5353 # Euro IBM CCSID - - -charset IBM437 IBM437 - alias cp437 #JDK historical - alias ibm437 - alias ibm-437 - alias 437 - alias cspc8codepage437 - alias windows-437 - -charset x-IBM737 IBM737 - alias cp737 #JDK historical - alias ibm737 - alias ibm-737 - alias 737 - -charset IBM775 IBM775 - alias cp775 #JDK historical - alias ibm775 - alias ibm-775 - alias 775 - -charset IBM850 IBM850 - alias cp850 #JDK historical - alias ibm-850 - alias ibm850 - alias 850 - alias cspc850multilingual - -charset IBM852 IBM852 - alias cp852 #JDK historical - alias ibm852 - alias ibm-852 - alias 852 - alias csPCp852 - -charset IBM855 IBM855 - alias cp855 #JDK historical - alias ibm-855 - alias ibm855 - alias 855 - alias cspcp855 - -charset IBM857 IBM857 - alias cp857 #JDK historical - alias ibm857 - alias ibm-857 - alias 857 - alias csIBM857 - -charset IBM00858 IBM858 - alias cp858 #JDK historical - alias ccsid00858 - alias cp00858 - alias 858 - alias PC-Multilingual-850+euro - -charset IBM862 IBM862 - alias cp862 #JDK historical - alias ibm862 - alias ibm-862 - alias 862 - alias csIBM862 - alias cspc862latinhebrew - -charset IBM866 IBM866 - alias cp866 #JDK historical - alias ibm866 - alias ibm-866 - alias 866 - alias csIBM866 - -charset x-IBM874 IBM874 - alias cp874 #JDK historical - alias ibm874 - alias ibm-874 - alias 874 diff --git a/jdk/make/data/charsetmapping/stdcs-linux b/jdk/make/data/charsetmapping/stdcs-linux new file mode 100644 index 00000000000..6ab35ee715e --- /dev/null +++ b/jdk/make/data/charsetmapping/stdcs-linux @@ -0,0 +1,19 @@ +# +# generate these charsets into sun.nio.cs +# +Big5 +Big5_Solaris +Big5_HKSCS +EUC_CN +EUC_KR +EUC_JP +EUC_JP_LINUX +EUC_JP_Open +GBK +Johab +PCK +JIS_X_0201 +JIS_X_0208 +JIS_X_0212 +JIS_X_0208_Solaris +JIS_X_0212_Solaris diff --git a/jdk/make/data/charsetmapping/stdcs-solaris b/jdk/make/data/charsetmapping/stdcs-solaris new file mode 100644 index 00000000000..6e57033b3c7 --- /dev/null +++ b/jdk/make/data/charsetmapping/stdcs-solaris @@ -0,0 +1,23 @@ +# +# generate these charsets into sun.nio.cs +# +Big5 +Big5_Solaris +Big5_HKSCS # always together with Big5 +EUC_CN +EUC_KR +EUC_JP +EUC_JP_LINUX +EUC_JP_Open +GBK +ISO_8859_11 +ISO_8859_3 +ISO_8859_6 +ISO_8859_8 +Johab +PCK +JIS_X_0201 +JIS_X_0208 +JIS_X_0212 +JIS_X_0208_Solaris +JIS_X_0212_Solaris diff --git a/jdk/make/data/charsetmapping/stdcs-windows b/jdk/make/data/charsetmapping/stdcs-windows new file mode 100644 index 00000000000..e579c89cb52 --- /dev/null +++ b/jdk/make/data/charsetmapping/stdcs-windows @@ -0,0 +1,16 @@ +# +# generate these charsets into sun.nio.cs +# +GBK +Johab +MS1255 +MS1256 +MS1258 +MS874 +MS932 +JIS_X_0201 # JIS_X_0201 is used by MS932 in its contains() method +SJIS # SJIS must go together with MS932 to support sun.nio.cs.map +MS936 +MS949 +MS950 +MS950_HKSCS_XP diff --git a/jdk/make/gensrc/Gensrc-jdk.charsets.gmk b/jdk/make/gensrc/Gensrc-jdk.charsets.gmk index a646099c339..67e4c3c1f1e 100644 --- a/jdk/make/gensrc/Gensrc-jdk.charsets.gmk +++ b/jdk/make/gensrc/Gensrc-jdk.charsets.gmk @@ -30,23 +30,26 @@ include GensrcCommon.gmk # Generate files using the charsetmapping tool # CHARSET_DATA_DIR := $(JDK_TOPDIR)/make/data/charsetmapping + CHARSET_GENSRC_JAVA_DIR_CS := $(SUPPORT_OUTPUTDIR)/gensrc/jdk.charsets/sun/nio/cs/ext CHARSET_DONE_CS := $(CHARSET_GENSRC_JAVA_DIR_CS)/_the.charsetmapping CHARSET_COPYRIGHT_HEADER := $(JDK_TOPDIR)/make/src/classes/build/tools/charsetmapping CHARSET_TEMPLATES := \ $(CHARSET_DATA_DIR)/SingleByte-X.java.template \ $(CHARSET_DATA_DIR)/DoubleByte-X.java.template +CHARSET_EXTENDED_JAVA_TEMPLATES := \ + $(JDK_TOPDIR)/src/jdk.charsets/share/classes/sun/nio/cs/ext/ExtendedCharsets.java.template +CHARSET_EXTENDED_JAVA_DIR := $(JDK_TOPDIR)/src/jdk.charsets/share/classes/sun/nio/cs/ext +CHARSET_EXTENDED := extcs +CHARSET_STANDARD_OS := stdcs-$(OPENJDK_TARGET_OS) -$(CHARSET_DONE_CS)-extsbcs: $(CHARSET_DATA_DIR)/extsbcs \ - $(CHARSET_TEMPLATES) $(BUILD_TOOLS_JDK) +$(CHARSET_DONE_CS)-extcs: $(CHARSET_DATA_DIR)/charsets \ + $(CHARSET_TEMPLATES) $(CHARSET_EXTENDED_DATA) $(BUILD_TOOLS_JDK) $(MKDIR) -p $(@D) - $(TOOL_CHARSETMAPPING) $(CHARSET_DATA_DIR) $(CHARSET_GENSRC_JAVA_DIR_CS) extsbcs - $(TOUCH) '$@' - -$(CHARSET_DONE_CS)-dbcs: $(CHARSET_DATA_DIR)/dbcs \ - $(CHARSET_TEMPLATES) $(BUILD_TOOLS_JDK) - $(MKDIR) -p $(@D) - $(TOOL_CHARSETMAPPING) $(CHARSET_DATA_DIR) $(CHARSET_GENSRC_JAVA_DIR_CS) dbcs + $(TOOL_CHARSETMAPPING) $(CHARSET_DATA_DIR) $(CHARSET_GENSRC_JAVA_DIR_CS) \ + extcs charsets $(CHARSET_STANDARD_OS) \ + $(CHARSET_EXTENDED_JAVA_TEMPLATES) \ + $(CHARSET_EXTENDED_JAVA_DIR) $(TOUCH) '$@' $(CHARSET_DONE_CS)-hkscs: $(CHARSET_COPYRIGHT_HEADER)/HKSCS.java \ @@ -67,8 +70,7 @@ $(CHARSET_GENSRC_JAVA_DIR_CS)/sjis0213.dat: $(CHARSET_DATA_DIR)/sjis0213.map \ $(TOOL_CHARSETMAPPING) '$<' '$@' sjis0213 GENSRC_JDK_CHARSETS += \ - $(CHARSET_DONE_CS)-extsbcs \ - $(CHARSET_DONE_CS)-dbcs \ + $(CHARSET_DONE_CS)-extcs \ $(CHARSET_DONE_CS)-hkscs \ $(CHARSET_DONE_CS)-euctw \ $(CHARSET_GENSRC_JAVA_DIR_CS)/sjis0213.dat \ diff --git a/jdk/make/gensrc/GensrcCharsetMapping.gmk b/jdk/make/gensrc/GensrcCharsetMapping.gmk index af1e9f08ce4..e38efd8bf62 100644 --- a/jdk/make/gensrc/GensrcCharsetMapping.gmk +++ b/jdk/make/gensrc/GensrcCharsetMapping.gmk @@ -25,112 +25,27 @@ ################################################################################ # -# Generate files using the charsetmapping tool +# Generate StandardCharsets.java and individul sun.nio.cs charset class using +# the charsetmapping tool # CHARSET_DATA_DIR := $(JDK_TOPDIR)/make/data/charsetmapping +CHARSET_EXTSRC_DIR := $(JDK_TOPDIR)/src/jdk.charsets/share/classes/sun/nio/cs/ext CHARSET_GENSRC_JAVA_DIR_BASE := $(SUPPORT_OUTPUTDIR)/gensrc/java.base/sun/nio/cs CHARSET_DONE_BASE := $(CHARSET_GENSRC_JAVA_DIR_BASE)/_the.charsetmapping CHARSET_TEMPLATES := \ $(CHARSET_DATA_DIR)/SingleByte-X.java.template \ $(CHARSET_DATA_DIR)/DoubleByte-X.java.template +CHARSET_STANDARD_JAVA_TEMPLATES := \ + $(JDK_TOPDIR)/src/java.base/share/classes/sun/nio/cs/StandardCharsets.java.template +CHARSET_STANDARD_OS := stdcs-$(OPENJDK_TARGET_OS) -$(CHARSET_DONE_BASE)-sbcs: $(CHARSET_DATA_DIR)/sbcs \ +$(CHARSET_DONE_BASE)-stdcs: $(CHARSET_DATA_DIR)/charsets \ $(CHARSET_TEMPLATES) $(BUILD_TOOLS_JDK) $(MKDIR) -p $(@D) - $(TOOL_CHARSETMAPPING) $(CHARSET_DATA_DIR) $(CHARSET_GENSRC_JAVA_DIR_BASE) sbcs + $(TOOL_CHARSETMAPPING) $(CHARSET_DATA_DIR) $(CHARSET_GENSRC_JAVA_DIR_BASE) \ + stdcs charsets $(CHARSET_STANDARD_OS) \ + $(CHARSET_STANDARD_JAVA_TEMPLATES) $(CHARSET_EXTSRC_DIR) \ $(TOUCH) '$@' -GENSRC_JAVA_BASE += $(CHARSET_DONE_BASE)-sbcs +GENSRC_JAVA_BASE += $(CHARSET_DONE_BASE)-stdcs -################################################################################ -# -# Generate the sun/nio/cs/StandardCharsets.java file -# -CHARSET_STANDARD_GENSRC_DIR := $(SUPPORT_OUTPUTDIR)/gensrc/java.base/_standardcharsets -CHARSET_STANDARD_DATA := $(CHARSET_DATA_DIR)/standard-charsets -CHARSET_STANDARD_JAVA := sun/nio/cs/StandardCharsets.java - -CHARSET_ALIASES_TABLES_AWK := ' \ - BEGIN { n = 1; m = 1; } \ - /^[ \t]*charset / { \ - csn = $$2; cln = $$3; \ - lcsn = tolower(csn); \ - lcsns[n++] = lcsn; \ - csns[lcsn] = csn; \ - classMap[lcsn] = cln; \ - if (n > 2) \ - printf " };\n\n"; \ - printf " static final String[] aliases_%s = new String[] {\n", cln; \ - } \ - /^[ \t]*alias / { \ - acsns[m++] = tolower($$2); \ - aliasMap[tolower($$2)] = lcsn; \ - printf " \"%s\",\n", $$2; \ - } \ - END { \ - printf " };\n\n"; \ - } ' - -CHARSET_ALIASES_MAP_AWK := ' \ - /^[ \t]*charset / { \ - csn = $$2; \ - lcsn = tolower(csn); \ - } \ - /^[ \t]*alias / { \ - an = tolower($$2); \ - printf "%-20s \"%s\"\n", an, lcsn; \ - } ' - -CHARSET_CLASSES_MAP_AWK := ' \ - /^[ \t]*charset / { \ - csn = $$2; cln = $$3; \ - lcsn = tolower(csn); \ - printf "%-20s \"%s\"\n", lcsn, cln; \ - } ' - -# This target should be referenced using the order-only operator (|) -$(CHARSET_STANDARD_GENSRC_DIR): - $(MKDIR) -p '$@' - -$(CHARSET_STANDARD_GENSRC_DIR)/aliases-tables.java.snippet: $(CHARSET_STANDARD_DATA) \ - | $(CHARSET_STANDARD_GENSRC_DIR) - $(NAWK) < '$<' > '$@' $(CHARSET_ALIASES_TABLES_AWK) - -$(CHARSET_STANDARD_GENSRC_DIR)/aliases-map: $(CHARSET_STANDARD_DATA) \ - | $(CHARSET_STANDARD_GENSRC_DIR) - $(NAWK) < '$<' > '$@' $(CHARSET_ALIASES_MAP_AWK) - -$(CHARSET_STANDARD_GENSRC_DIR)/classes-map: $(CHARSET_STANDARD_DATA) \ - | $(CHARSET_STANDARD_GENSRC_DIR) - $(NAWK) < '$<' > '$@' $(CHARSET_CLASSES_MAP_AWK) - -$(CHARSET_STANDARD_GENSRC_DIR)/aliases-map.java.snippet: $(CHARSET_STANDARD_GENSRC_DIR)/aliases-map \ - $(BUILD_TOOLS_JDK) | $(CHARSET_STANDARD_GENSRC_DIR) - $(TOOL_HASHER) -i Aliases < '$<' > '$@' - -$(CHARSET_STANDARD_GENSRC_DIR)/classes-map.java.snippet: $(CHARSET_STANDARD_GENSRC_DIR)/classes-map \ - $(BUILD_TOOLS_JDK) | $(CHARSET_STANDARD_GENSRC_DIR) - $(TOOL_HASHER) -i Classes < '$<' > '$@' - -$(CHARSET_STANDARD_GENSRC_DIR)/cache-map.java.snippet: $(CHARSET_STANDARD_GENSRC_DIR)/classes-map \ - $(BUILD_TOOLS_JDK) | $(CHARSET_STANDARD_GENSRC_DIR) - $(TOOL_HASHER) -i -e Cache -t Charset < '$<' > '$@' - -$(eval $(call SetupTextFileProcessing, BUILD_CHARSET_STANDARD, \ - SOURCE_FILES := $(JDK_TOPDIR)/src/java.base/share/classes/$(CHARSET_STANDARD_JAVA).template, \ - OUTPUT_FILE := $(SUPPORT_OUTPUTDIR)/gensrc/java.base/$(CHARSET_STANDARD_JAVA), \ - INCLUDES := \ - _INCLUDE_ALIASES_TABLES_ => $(CHARSET_STANDARD_GENSRC_DIR)/aliases-tables.java.snippet ; \ - _INCLUDE_ALIASES_MAP_ => $(CHARSET_STANDARD_GENSRC_DIR)/aliases-map.java.snippet ; \ - _INCLUDE_CLASSES_MAP_ => $(CHARSET_STANDARD_GENSRC_DIR)/classes-map.java.snippet ; \ - _INCLUDE_CACHE_MAP_ => $(CHARSET_STANDARD_GENSRC_DIR)/cache-map.java.snippet ; , \ -)) - -# Processing of template depends on the snippets being generated first -$(BUILD_CHARSET_STANDARD): \ - $(CHARSET_STANDARD_GENSRC_DIR)/aliases-tables.java.snippet \ - $(CHARSET_STANDARD_GENSRC_DIR)/aliases-map.java.snippet \ - $(CHARSET_STANDARD_GENSRC_DIR)/classes-map.java.snippet \ - $(CHARSET_STANDARD_GENSRC_DIR)/cache-map.java.snippet - -GENSRC_JAVA_BASE += $(BUILD_CHARSET_STANDARD) diff --git a/jdk/make/src/classes/build/tools/charsetmapping/Charset.java b/jdk/make/src/classes/build/tools/charsetmapping/Charset.java new file mode 100644 index 00000000000..94d61c35f0d --- /dev/null +++ b/jdk/make/src/classes/build/tools/charsetmapping/Charset.java @@ -0,0 +1,42 @@ +/* + * Copyright (c) 2015, 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. Oracle designates this + * particular file as subject to the "Classpath" exception as provided + * by Oracle in the LICENSE file that accompanied this code. + * + * 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. + */ + +package build.tools.charsetmapping; + +class Charset { + String pkgName; + String clzName; + String csName; + String hisName; + String type; + boolean isASCII; + int b1Min; + int b1Max; + int b2Min; + int b2Max; + String[] aliases; + boolean isGenSrc = false; + boolean isInternal = false; +} diff --git a/jdk/make/src/classes/build/tools/charsetmapping/DBCS.java b/jdk/make/src/classes/build/tools/charsetmapping/DBCS.java index d54d20582dc..bd4bd7140f6 100644 --- a/jdk/make/src/classes/build/tools/charsetmapping/DBCS.java +++ b/jdk/make/src/classes/build/tools/charsetmapping/DBCS.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2010, 2013, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2010, 2015, 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 @@ -24,71 +24,32 @@ */ package build.tools.charsetmapping; + import java.io.*; import java.util.Arrays; import java.util.ArrayList; import java.util.Scanner; import java.util.Formatter; -import java.util.regex.*; -import java.nio.charset.*; +import java.util.regex.Pattern; import static build.tools.charsetmapping.Utils.*; public class DBCS { // pattern used by this class to read in mapping table static Pattern mPattern = Pattern.compile("(?:0x)?(\\p{XDigit}++)\\s++(?:0x)?(\\p{XDigit}++)(?:\\s++#.*)?"); - public static void genClass(String args[]) throws Exception { - - Scanner s = new Scanner(new File(args[0], args[2])); - while (s.hasNextLine()) { - String line = s.nextLine(); - if (line.startsWith("#") || line.length() == 0) - continue; - String[] fields = line.split("\\s+"); - if (fields.length < 10) { - System.err.println("Misconfiged sbcs line <" + line + ">?"); - continue; - } - String clzName = fields[0]; - String csName = fields[1]; - String hisName = ("null".equals(fields[2]))?null:fields[2]; - String type = fields[3].toUpperCase(); - if ("BASIC".equals(type)) - type = ""; - else - type = "_" + type; - String pkgName = fields[4]; - boolean isASCII = Boolean.valueOf(fields[5]); - int b1Min = toInteger(fields[6]); - int b1Max = toInteger(fields[7]); - int b2Min = toInteger(fields[8]); - int b2Max = toInteger(fields[9]); - System.out.printf("%s,%s,%s,%b,%s%n", clzName, csName, hisName, isASCII, pkgName); - genClass0(args[0], args[1], "DoubleByte-X.java.template", - clzName, csName, hisName, pkgName, - isASCII, type, - b1Min, b1Max, b2Min, b2Max); - } - } - - static int toInteger(String s) { - if (s.startsWith("0x") || s.startsWith("0X")) - return Integer.valueOf(s.substring(2), 16); - else - return Integer.valueOf(s); - } - - private static void genClass0(String srcDir, String dstDir, String template, - String clzName, - String csName, - String hisName, - String pkgName, - boolean isASCII, - String type, - int b1Min, int b1Max, - int b2Min, int b2Max) + public static void genClass(String type, Charset cs, + String srcDir, String dstDir, String template) throws Exception { + String clzName = cs.clzName; + String csName = cs.csName; + String hisName = cs.hisName; + String pkgName = cs.pkgName; + boolean isASCII = cs.isASCII; + int b1Min = cs.b1Min; + int b1Max = cs.b1Max; + int b2Min = cs.b2Min; + int b2Max = cs.b2Max; StringBuilder b2cSB = new StringBuilder(); StringBuilder b2cNRSB = new StringBuilder(); diff --git a/jdk/make/src/classes/build/tools/charsetmapping/HKSCS.java b/jdk/make/src/classes/build/tools/charsetmapping/HKSCS.java index b37b0e3fea5..18c0a24ad7b 100644 --- a/jdk/make/src/classes/build/tools/charsetmapping/HKSCS.java +++ b/jdk/make/src/classes/build/tools/charsetmapping/HKSCS.java @@ -42,38 +42,51 @@ public class HKSCS { private static Pattern hkscs = Pattern.compile("(?:0x)?+(\\p{XDigit}++)\\s++(?:0x|U\\+)?+(\\p{XDigit}++)?\\s*+(?:0x|U\\+)?(\\p{XDigit}++)?\\s*+.*"); - static void genClass(String args[]) throws Exception { - + static void genClass2008(String srcDir, String dstDir, String pkgName) + throws Exception + { // hkscs2008 - genClass0(new FileInputStream(new File(args[0], "HKSCS2008.map")), - new FileInputStream(new File(args[0], "HKSCS2008.c2b")), - new PrintStream(new File(args[1], "HKSCSMapping.java"), + genClass0(new FileInputStream(new File(srcDir, "HKSCS2008.map")), + new FileInputStream(new File(srcDir, "HKSCS2008.c2b")), + new PrintStream(new File(dstDir, "HKSCSMapping.java"), "ISO-8859-1"), + pkgName, "HKSCSMapping", - getCopyright(new File(args[3]))); + true, + ""); + } - - // xp2001 - genClass0(new FileInputStream(new File(args[0], "HKSCS_XP.map")), + static void genClassXP(String srcDir, String dstDir, String pkgName) + throws Exception + { + genClass0(new FileInputStream(new File(srcDir, "HKSCS_XP.map")), null, - new PrintStream(new File(args[1], "HKSCS_XPMapping.java"), + new PrintStream(new File(dstDir, "HKSCS_XPMapping.java"), "ISO-8859-1"), + pkgName, "HKSCS_XPMapping", - getCopyright(new File(args[3]))); + false, + ""); + } + static void genClass2001(String args[]) throws Exception { // hkscs2001 genClass0(new FileInputStream(new File(args[0], "HKSCS2001.map")), new FileInputStream(new File(args[0], "HKSCS2001.c2b")), new PrintStream(new File(args[1], "HKSCS2001Mapping.java"), "ISO-8859-1"), + "sun.nio.cs.ext", "HKSCS2001Mapping", + false, getCopyright(new File(args[3]))); } static void genClass0(InputStream isB2C, InputStream isC2B, PrintStream ps, + String pkgName, String clzName, + boolean isPublic, String copyright) throws Exception { @@ -132,8 +145,8 @@ public class HKSCS { out.format(copyright); out.format("%n// -- This file was mechanically generated: Do not edit! -- //%n"); - out.format("package sun.nio.cs.ext;%n%n"); - out.format("class %s {%n%n", clzName); + out.format("package %s;%n%n", pkgName); + out.format("%sclass %s {%n%n", isPublic ? "public " : "", clzName); /* hardcoded in sun.nio.cs.ext.HKSCS.java out.format(" final static int b1Min = 0x%x;%n", b1Min); @@ -143,7 +156,8 @@ public class HKSCS { */ // bmp tables - out.format("%n static final String[] b2cBmpStr = new String[] {%n"); + out.format("%n %sstatic final String[] b2cBmpStr = new String[] {%n", + isPublic ? "public " : ""); for (int i = 0; i < 0x100; i++) { if (b2cBmp[i]) out.format(bmp, i, b2Min, b2Max, ","); @@ -153,7 +167,8 @@ public class HKSCS { out.format(" };%n"); // supp tables - out.format("%n static final String[] b2cSuppStr ="); + out.format("%n %sstatic final String[] b2cSuppStr =", + isPublic ? "public " : ""); if (hasSupp) { out.format(" new String[] {%n"); for (int i = 0; i < 0x100; i++) { @@ -168,7 +183,8 @@ public class HKSCS { } // private area tables - out.format("%n final static String pua ="); + out.format("%n %sfinal static String pua =", + isPublic ? "public " : ""); if (hasPua) { out.format("%n"); out.format(pua, 0, pua.length, ";"); diff --git a/jdk/make/src/classes/build/tools/charsetmapping/Hasher.java b/jdk/make/src/classes/build/tools/charsetmapping/Hasher.java new file mode 100644 index 00000000000..f935202a522 --- /dev/null +++ b/jdk/make/src/classes/build/tools/charsetmapping/Hasher.java @@ -0,0 +1,265 @@ +/* + * Copyright (c) 2004, 2013, 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. Oracle designates this + * particular file as subject to the "Classpath" exception as provided + * by Oracle in the LICENSE file that accompanied this code. + * + * 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. + */ + +package build.tools.charsetmapping; + +import java.io.*; +import java.util.*; + + +/** + * Reads a map in the form of a sequence of key/value-expression pairs from the + * standard input, attempts to construct a hash map that fits within the given + * table-size and chain-depth constraints, and, if successful, writes source + * code to the standard output for a subclass of sun.util.PreHashedMap that + * implements the map. + * + * @see sun.util.PreHashedMap + * + * @author Mark Reinhold + */ + +public class Hasher { + + private PrintStream err = System.err; + + boolean verbose = false; + List keys = new ArrayList<>(); // Key strings + List values = new ArrayList<>(); // Value expressions + String pkg = null; // Package prefix for generated class + String cln = null; // Name of generated class + String vtype = null; // Value type + int maxBits = 11; // lg table size + int maxDepth = 3; // Max chain depth + boolean inner = false; // Generating an inner class? + boolean empty = false; // Generating an empty table? + + Object[] ht; // Hash table itself + int nb; // Number of bits (lg table size) + int md; // Maximum chain depth + int mask; // Hash-code mask + int shift; // Hash-code shift size + + int hash(String w) { + return (w.hashCode() >> shift) & mask; + } + + // Build a hash table of size 2^nb, shifting the hash code by s bits + // + void build(int nb, int s) { + + this.nb = nb; + this.shift = s; + int n = 1 << nb; + this.mask = n - 1; + ht = new Object[n]; + int nw = keys.size(); + + for (int i = 0; i < nw; i++) { + String w = keys.get(i); + String v = values.get(i); + int h = hash(w); + if (ht[h] == null) + ht[h] = new Object[] { w, v }; + else + ht[h] = new Object[] { w, v, ht[h] }; + } + + this.md = 0; + for (int i = 0; i < n; i++) { + int d = 1; + for (Object[] a = (Object[])ht[i]; + a != null && a.length > 2; + a = (Object[])a[2], d++); + this.md = Math.max(md, d); + } + + } + + Hasher build() { + // Iterate through acceptable table sizes + for (int nb = 2; nb < maxBits; nb++) { + // Iterate through possible shift sizes + for (int s = 0; s < (32 - nb); s++) { + build(nb, s); + if (verbose) + err.println("nb=" + nb + " s=" + s + " md=" + md); + if (md <= maxDepth) { + // Success + if (verbose) { + if (cln != null) + err.print(cln + ": "); + err.println("Table size " + (1 << nb) + " (" + nb + " bits)" + + ", shift " + shift + + ", max chain depth " + md); + } + return this; + } + } + } + throw new RuntimeException("Cannot find a suitable size" + + " within given constraints"); + } + + // Look for the given key in the hash table + // + String get(String k) { + int h = hash(k); + Object[] a = (Object[])ht[h]; + for (;;) { + if (a[0].equals(k)) + return (String)a[1]; + if (a.length < 3) + return null; + a = (Object[])a[2]; + } + } + + // Test that all input keys can be found in the table + // + Hasher test() { + if (verbose) + err.println(); + for (int i = 0, n = keys.size(); i < n; i++) { + String w = keys.get(i); + String v = get(w); + if (verbose) + err.println(hash(w) + "\t" + w); + if (!v.equals(values.get(i))) + throw new Error("Incorrect value: " + w + " --> " + + v + ", should be " + values.get(i)); + } + return this; + } + + String ind = ""; // Indent prefix + + // Generate code for a single table entry + // + void genEntry(Object[] a, int depth, PrintStream out) { + Object v = empty ? null : a[1]; + out.print("new Object[] { \"" + a[0] + "\", " + v); + if (a.length < 3) { + out.print(" }"); + return; + } + out.println(","); + out.print(ind + " "); + for (int i = 0; i < depth; i++) + out.print(" "); + genEntry((Object[])a[2], depth + 1, out); + out.print(" }"); + } + + // Generate a PreHashedMap subclass from the computed hash table + // + Hasher generate(PrintStream out) throws IOException { + if (cln == null) + return this; + + if (inner) + ind = " "; + + if (!inner && pkg != null) { + out.println(); + out.println("package " + pkg + ";"); + out.println(); + } + + if (inner) { + out.println(ind + "private static final class " + cln); + } else { + out.println(); + out.println("public final class " + cln); + } + out.println(ind + " extends sun.util.PreHashedMap<" + vtype +">"); + out.println(ind + "{"); + + out.println(); + out.println(ind + " private static final int ROWS = " + + ht.length + ";"); + out.println(ind + " private static final int SIZE = " + + keys.size() + ";"); + out.println(ind + " private static final int SHIFT = " + + shift + ";"); + out.println(ind + " private static final int MASK = 0x" + + Integer.toHexString(mask) + ";"); + out.println(); + + out.println(ind + " " + (inner ? "private " : "public ") + + cln + "() {"); + out.println(ind + " super(ROWS, SIZE, SHIFT, MASK);"); + out.println(ind + " }"); + out.println(); + + out.println(ind + " protected void init(Object[] ht) {"); + for (int i = 0; i < ht.length; i++) { + if (ht[i] == null) + continue; + Object[] a = (Object[])ht[i]; + out.print(ind + " ht[" + i + "] = "); + genEntry(a, 0, out); + out.println(";"); + } + out.println(ind + " }"); + out.println(); + + out.println(ind + "}"); + if (inner) + out.println(); + + return this; + } + + private Hasher(List keys, List values, + String pkg, String cln, String vtype, + int maxBits, int maxDepth, + boolean inner, boolean empty, + boolean verbose) { + this.keys = keys; + this.values = values; + this.pkg = pkg; + this.cln = cln; + this.vtype = vtype; + this.maxBits = maxBits; + this.maxDepth = maxDepth; + this.inner = inner; + this.empty = empty; + this.verbose = verbose; + } + + public static void genClass(PrintStream out, + List keys, List values, + String pkg, String cln, String vtype, + int maxBits, int maxDepth, + boolean inner, boolean empty, boolean verbose) + throws IOException { + new Hasher(keys, values, pkg, cln, vtype, + maxBits, maxDepth, inner, empty, verbose) + .build() + .test() + .generate(out); + } +} diff --git a/jdk/make/src/classes/build/tools/charsetmapping/Main.java b/jdk/make/src/classes/build/tools/charsetmapping/Main.java index 0312cb646b4..780ff093b2d 100644 --- a/jdk/make/src/classes/build/tools/charsetmapping/Main.java +++ b/jdk/make/src/classes/build/tools/charsetmapping/Main.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2009, 2013, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2009, 2015, 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 @@ -26,25 +26,193 @@ package build.tools.charsetmapping; import java.io.*; +import java.util.ArrayList; import java.util.Scanner; +import java.util.LinkedHashMap; +import java.util.Locale; public class Main { - public static void main(String args[]) throws Exception { + public static void main(String args[]) throws Throwable { + int SRC_DIR = 0; + int DST_DIR = 1; + int TYPE = 2; + int CHARSETS = 3; + int OS = 4; + int TEMPLATE = 5; + int EXT_SRC = 6; + if (args.length < 3 ) { - System.out.println("Usage: java -jar charsetmapping.jar src dst mType [copyrightSrc]"); + System.out.println("Usage: java -jar charsetmapping.jar src dst spiType charsets os [template]"); System.exit(1); } - if ("sbcs".equals(args[2]) || "extsbcs".equals(args[2])) { - SBCS.genClass(args); - } else if ("dbcs".equals(args[2])) { - DBCS.genClass(args); - } else if ("euctw".equals(args[2])) { + boolean isStandard = "stdcs".equals(args[TYPE]); + boolean isExtended = "extcs".equals(args[TYPE]); + if (isStandard || isExtended) { + LinkedHashMap charsets = getCharsets( + new File(args[SRC_DIR], args[CHARSETS])); + String[] osStdcs = getOSStdCSList(new File(args[SRC_DIR], args[OS])); + boolean hasBig5_HKSCS = false; + boolean hasMS950_HKSCS_XP = false; + for (String name : osStdcs) { + Charset cs = charsets.get(name); + if (cs != null) { + cs.pkgName = "sun.nio.cs"; + } + if (name.equals("Big5_HKSCS")) { + hasBig5_HKSCS = true; + } else if (name.equals("MS950_HKSCS_XP")) { + hasMS950_HKSCS_XP = true; + } + } + for (Charset cs : charsets.values()) { + if (isStandard && cs.pkgName.equals("sun.nio.cs.ext") || + isExtended && cs.pkgName.equals("sun.nio.cs")) { + continue; + } + verbose(cs); + switch (cs.type) { + case "template": + SRC.genClass(cs, args[EXT_SRC], args[DST_DIR]); + break; + case "sbcs": + SBCS.genClass(cs, args[SRC_DIR], args[DST_DIR], + "SingleByte-X.java.template"); + break; + case "source": + break; // source file, do nothing + default: // dbcs + DBCS.genClass("dbcs".equals(cs.type) ? + "" : "_" + cs.type.toUpperCase(Locale.ENGLISH), + cs, args[SRC_DIR], args[DST_DIR], + "DoubleByte-X.java.template"); + } + } + // provider StandardCharsets.java / ExtendedCharsets.java + SPI.genClass(args[TYPE], charsets, args[SRC_DIR], args[DST_DIR], args[TEMPLATE]); + + // HKSCSMapping2008/XP.java goes together with Big5/MS950XP_HKSCS + if (isStandard && hasBig5_HKSCS || isExtended && !hasBig5_HKSCS) { + HKSCS.genClass2008(args[SRC_DIR], args[DST_DIR], + isStandard ? "sun.nio.cs" : "sun.nio.cs.ext"); + } + if (isStandard && hasMS950_HKSCS_XP || isExtended && !hasMS950_HKSCS_XP) { + HKSCS.genClassXP(args[SRC_DIR], args[DST_DIR], + isStandard ? "sun.nio.cs" : "sun.nio.cs.ext"); + } + } else if ("euctw".equals(args[TYPE])) { EUC_TW.genClass(args); - } else if ("sjis0213".equals(args[2])) { + } else if ("sjis0213".equals(args[TYPE])) { JIS0213.genClass(args); - } else if ("hkscs".equals(args[2])) { - HKSCS.genClass(args); + } else if ("hkscs".equals(args[TYPE])) { + HKSCS.genClass2001(args); } } + + private static LinkedHashMap getCharsets(File cslist) + throws Throwable + { + LinkedHashMap charsets = new LinkedHashMap<>(); + try (Scanner s = new Scanner(cslist)) { + Charset cs = null; + ArrayList names = new ArrayList<>(); + while (s.hasNextLine()) { + String line = s.nextLine(); + if (line.startsWith("#") || line.length() == 0) { + continue; + } + String[] tokens = line.split("\\s+"); + if (tokens.length < 2) { + continue; + } + if ("charset".equals(tokens[0])) { + if (cs != null) { + cs.aliases = names.toArray(new String[names.size()]); + charsets.put(cs.clzName, cs); + cs = null; + names.clear(); + } + if (tokens.length < 3) { + throw new RuntimeException("Error: incorrect charset line [" + line + "]"); + } + if ((cs = charsets.get(tokens[2])) != null) { + throw new RuntimeException("Error: deplicate charset line [" + line + "]"); + } + cs = new Charset(); + cs.csName = tokens[1]; + cs.clzName = tokens[2]; + } else { + String key = tokens[1]; // leading empty str + switch (key) { + case "alias": + if (tokens.length < 3) { + throw new RuntimeException("Error: incorrect alias line [" + line + "]"); + } else if (names != null) { + names.add(tokens[2]); // ALIAS_NAME + } + break; + case "package": + cs.pkgName = tokens[2]; + break; + case "type": + cs.type = tokens[2]; + break; + case "hisname": + cs.hisName = tokens[2]; + break; + case "ascii": + cs.isASCII = Boolean.parseBoolean(tokens[2]); + break; + case "minmax": + cs.b1Min = toInteger(tokens[2]); + cs.b1Max = toInteger(tokens[3]); + cs.b2Min = toInteger(tokens[4]); + cs.b2Max = toInteger(tokens[5]); + break; + case "internal": + cs.isInternal = Boolean.parseBoolean(tokens[2]); + break; + default: // ignore + } + } + } + if (cs != null) { + cs.aliases = names.toArray(new String[names.size()]); + charsets.put(cs.clzName, cs); + } + } + return charsets; + } + + private static String[] getOSStdCSList(File stdcsos) throws Throwable + { + ArrayList names = new ArrayList<>(); + if (stdcsos.exists()) { + try (Scanner s = new Scanner(stdcsos)) { + while (s.hasNextLine()) { + String line = s.nextLine(); + int i = line.indexOf('#'); + if (i != -1) { + line = line.substring(0, i); + } + line = line.trim(); + if (line.length() != 0) { + names.add(line); + } + } + } + } + return names.toArray(new String[names.size()]); + } + + static void verbose(Charset cs) { + System.err.printf("%s, %s, %s, %s, %s %b%n", + cs.clzName, cs.csName, cs.hisName, cs.pkgName, cs.type, cs.isASCII); + } + + static int toInteger(String s) { + return (s.startsWith("0x") || s.startsWith("0X")) + ? Integer.valueOf(s.substring(2), 16) + : Integer.valueOf(s); + } } diff --git a/jdk/make/src/classes/build/tools/charsetmapping/SBCS.java b/jdk/make/src/classes/build/tools/charsetmapping/SBCS.java index a7a136dad23..fa294f13b9b 100644 --- a/jdk/make/src/classes/build/tools/charsetmapping/SBCS.java +++ b/jdk/make/src/classes/build/tools/charsetmapping/SBCS.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2008, 2013, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2008, 2015, 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 @@ -30,93 +30,23 @@ import java.util.Arrays; import java.util.ArrayList; import java.util.Scanner; import java.util.Formatter; -import java.util.regex.*; -import java.nio.charset.*; +import java.util.regex.Pattern; import static build.tools.charsetmapping.Utils.*; public class SBCS { - public static void genClass(String args[]) throws Exception { - - Scanner s = new Scanner(new File(args[0], args[2])); - while (s.hasNextLine()) { - String line = s.nextLine(); - if (line.startsWith("#") || line.length() == 0) - continue; - String[] fields = line.split("\\s+"); - if (fields.length < 5) { - System.err.println("Misconfiged sbcs line <" + line + ">?"); - continue; - } - String clzName = fields[0]; - String csName = fields[1]; - String hisName = fields[2]; - boolean isASCII = Boolean.valueOf(fields[3]); - String pkgName = fields[4]; - System.out.printf("%s,%s,%s,%b,%s%n", clzName, csName, hisName, isASCII, pkgName); - - genClass0(args[0], args[1], "SingleByte-X.java.template", - clzName, csName, hisName, pkgName, isASCII); - } - } - - private static void toString(char[] sb, int off, int end, - Formatter out, String closure, - boolean comment) { - while (off < end) { - out.format(" \""); - for (int j = 0; j < 8; j++) { - if (off == end) - break; - char c = sb[off++]; - switch (c) { - case '\b': - out.format("\\b"); break; - case '\t': - out.format("\\t"); break; - case '\n': - out.format("\\n"); break; - case '\f': - out.format("\\f"); break; - case '\r': - out.format("\\r"); break; - case '\"': - out.format("\\\""); break; - case '\'': - out.format("\\'"); break; - case '\\': - out.format("\\\\"); break; - default: - out.format("\\u%04X", c & 0xffff); - } - } - if (comment) { - if (off == end) - out.format("\" %s // 0x%02x - 0x%02x%n", - closure, off-8, off-1); - else - out.format("\" + // 0x%02x - 0x%02x%n", - off-8, off-1); - } else { - if (off == end) - out.format("\"%s%n", closure); - else - out.format("\" +%n"); - } - } - } - static Pattern sbmap = Pattern.compile("0x(\\p{XDigit}++)\\s++(?:U\\+|0x)?(\\p{XDigit}++)(?:\\s++#.*)?"); - private static void genClass0(String srcDir, String dstDir, - String template, - String clzName, - String csName, - String hisName, - String pkgName, - boolean isASCII) + public static void genClass(Charset cs, + String srcDir, String dstDir, String template) throws Exception { + String clzName = cs.clzName; + String csName = cs.csName; + String hisName = cs.hisName; + String pkgName = cs.pkgName; + boolean isASCII = cs.isASCII; + StringBuilder b2cSB = new StringBuilder(); StringBuilder b2cNRSB = new StringBuilder(); StringBuilder c2bNRSB = new StringBuilder(); @@ -266,4 +196,50 @@ public class SBCS { } out.close(); } + + private static void toString(char[] sb, int off, int end, + Formatter out, String closure, boolean comment) + { + while (off < end) { + out.format(" \""); + for (int j = 0; j < 8; j++) { + if (off == end) + break; + char c = sb[off++]; + switch (c) { + case '\b': + out.format("\\b"); break; + case '\t': + out.format("\\t"); break; + case '\n': + out.format("\\n"); break; + case '\f': + out.format("\\f"); break; + case '\r': + out.format("\\r"); break; + case '\"': + out.format("\\\""); break; + case '\'': + out.format("\\'"); break; + case '\\': + out.format("\\\\"); break; + default: + out.format("\\u%04X", c & 0xffff); + } + } + if (comment) { + if (off == end) + out.format("\" %s // 0x%02x - 0x%02x%n", + closure, off-8, off-1); + else + out.format("\" + // 0x%02x - 0x%02x%n", + off-8, off-1); + } else { + if (off == end) + out.format("\"%s%n", closure); + else + out.format("\" +%n"); + } + } + } } diff --git a/jdk/make/src/classes/build/tools/charsetmapping/SPI.java b/jdk/make/src/classes/build/tools/charsetmapping/SPI.java new file mode 100644 index 00000000000..e0e2458bc40 --- /dev/null +++ b/jdk/make/src/classes/build/tools/charsetmapping/SPI.java @@ -0,0 +1,141 @@ +/* + * Copyright (c) 2015, 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. Oracle designates this + * particular file as subject to the "Classpath" exception as provided + * by Oracle in the LICENSE file that accompanied this code. + * + * 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. + */ + +package build.tools.charsetmapping; + +import java.io.*; +import java.util.Locale; +import java.util.ArrayList; +import java.util.LinkedHashMap; +import java.util.Scanner; + +public class SPI { + + public static void genClass(String type, LinkedHashMap charsets, + String srcDir, String dstDir, String template) + throws Exception + { + try (Scanner s = new Scanner(new File(template)); + PrintStream out = new PrintStream(new FileOutputStream( + new File(dstDir, new File( + template.replace(".template", "")).getName()))); ) { + if (type.startsWith("extcs")) { // ExtendedCharsets.java + while (s.hasNextLine()) { + String line = s.nextLine(); + if (line.indexOf("_CHARSETS_DEF_LIST_") == -1) { + out.println(line); + } else { + charsets.values() + .stream() + .filter(cs -> cs.pkgName.equals("sun.nio.cs.ext") && + !cs.isInternal) + .forEach( cs -> { + out.printf(" charset(\"%s\", \"%s\",%n", cs.csName, cs.clzName); + out.printf(" new String[] {%n"); + for (String alias : cs.aliases) { + out.printf(" \"%s\",%n", alias); + } + out.printf(" });%n%n"); + }); + } + } + } else if (type.startsWith("stdcs")) { // StandardCharsets.java + ArrayList aliasKeys = new ArrayList<>(); + ArrayList aliasValues = new ArrayList<>(); + ArrayList clzKeys = new ArrayList<>(); + ArrayList clzValues = new ArrayList<>(); + charsets.values() + .stream() + .filter(cs -> cs.pkgName.equals("sun.nio.cs") && + !cs.isInternal) + .forEach( cs -> { + String csname = cs.csName.toLowerCase(Locale.ENGLISH); + clzKeys.add(csname); + clzValues.add("\"" + cs.clzName + "\""); + if (cs.aliases != null) { + csname = "\"" + csname + "\""; + for (String alias : cs.aliases) { + aliasKeys.add(alias.toLowerCase(Locale.ENGLISH)); + aliasValues.add(csname); + } + } + }); + while (s.hasNextLine()) { + String line = s.nextLine(); + if (line.indexOf("_INCLUDE_ALIASES_TABLES_") != -1) { + charsets.values() + .stream() + .filter(cs -> cs.pkgName.equals("sun.nio.cs")) + .forEach( cs -> { + if (cs.aliases == null || cs.aliases.length == 0) { + out.printf(" static final String[] aliases_%s = null;%n%n", + cs.clzName); + } else { + // non-final for SJIS and MS932 to support sun.nio.cs.map + if (cs.clzName.equals("SJIS") || cs.clzName.equals("MS932")) { + out.printf(" static String[] aliases_%s = new String[] {%n", + cs.clzName); + } else { + out.printf(" static final String[] aliases_%s = new String[] {%n", + cs.clzName); + } + for (String alias : cs.aliases) { + out.printf(" \"%s\",%n", alias); + } + out.printf(" };%n%n"); + } + }); + Charset cs = charsets.get("SJIS"); + if (cs == null || cs.pkgName.equals("sun.nio.cs.ext")) { + // StandardCharsets.java has explicit reference + // to aliases_SJIS/MS932. If we don't have these + // two in std, just put a pair of dummy fields to + // make the compiler happy. + out.printf(" static String[] aliases_SJIS = null;%n%n"); + out.printf(" static String[] aliases_MS932 = null;%n%n"); + } + } else if (line.indexOf("_INCLUDE_ALIASES_MAP_") != -1) { + Hasher.genClass(out, aliasKeys, aliasValues, + null, "Aliases", "String", + 11, 3, true, false, false); + } else if (line.indexOf("_INCLUDE_CLASSES_MAP_") != -1) { + Hasher.genClass(out, clzKeys, clzValues, + null, "Classes", "String", + 11, 3, true, false, false); + } else if (line.indexOf("_INCLUDE_CACHE_MAP_") != -1) { + Hasher.genClass(out, clzKeys, clzValues, + null, "Cache", "Charset", + 11, 3, true, true, false); + } else { + out.println(line); + } + } + } else { + throw new RuntimeException("Unknown type:" + type); + } + } + + } +} diff --git a/jdk/make/src/classes/build/tools/charsetmapping/SRC.java b/jdk/make/src/classes/build/tools/charsetmapping/SRC.java new file mode 100644 index 00000000000..326f3c181b8 --- /dev/null +++ b/jdk/make/src/classes/build/tools/charsetmapping/SRC.java @@ -0,0 +1,64 @@ +/* + * Copyright (c) 2015, 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. Oracle designates this + * particular file as subject to the "Classpath" exception as provided + * by Oracle in the LICENSE file that accompanied this code. + * + * 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. + */ + +package build.tools.charsetmapping; + +import java.io.*; +import java.util.Scanner; + +public class SRC { + + public static void genClass(Charset cs, String srcDir, String dstDir) + throws Exception + { + String clzName = cs.clzName; + String csName = cs.csName; + String pkgName = cs.pkgName; + + try (Scanner s = new Scanner(new File(srcDir, clzName + ".java.template")); + PrintStream out = new PrintStream(new FileOutputStream( + new File(dstDir, clzName + ".java")));) { + while (s.hasNextLine()) { + String line = s.nextLine(); + if (line.indexOf("$") < 0) { + out.println(line); + continue; + } + if (line.indexOf("$PACKAGE$") != -1) { + out.println(line.replace("$PACKAGE$", pkgName)); + } else if (line.indexOf("$ALIASES$") != -1) { + if ("sun.nio.cs".equals(pkgName)) + out.println(line.replace("$ALIASES$", + "StandardCharsets.aliases_" + clzName)); + else + out.println(line.replace("$ALIASES$", + "ExtendedCharsets.aliasesFor(\"" + csName + "\")")); + } else { + out.println(line); + } + } + } + } +} diff --git a/jdk/src/java.base/share/classes/sun/nio/cs/AbstractCharsetProvider.java b/jdk/src/java.base/share/classes/sun/nio/cs/AbstractCharsetProvider.java index dd0fd23fd15..e10a9400280 100644 --- a/jdk/src/java.base/share/classes/sun/nio/cs/AbstractCharsetProvider.java +++ b/jdk/src/java.base/share/classes/sun/nio/cs/AbstractCharsetProvider.java @@ -111,6 +111,12 @@ public class AbstractCharsetProvider } } + protected boolean hasCharset(String name) { + synchronized (this) { + return classMap.containsKey(name); + } + } + /* Late initialization hook, needed by some providers */ protected void init() { } diff --git a/jdk/src/jdk.charsets/share/classes/sun/nio/cs/ext/DelegatableDecoder.java b/jdk/src/java.base/share/classes/sun/nio/cs/DelegatableDecoder.java similarity index 96% rename from jdk/src/jdk.charsets/share/classes/sun/nio/cs/ext/DelegatableDecoder.java rename to jdk/src/java.base/share/classes/sun/nio/cs/DelegatableDecoder.java index 13b49755a1c..efbaf687797 100644 --- a/jdk/src/jdk.charsets/share/classes/sun/nio/cs/ext/DelegatableDecoder.java +++ b/jdk/src/java.base/share/classes/sun/nio/cs/DelegatableDecoder.java @@ -23,7 +23,7 @@ * questions. */ -package sun.nio.cs.ext; +package sun.nio.cs; import java.nio.ByteBuffer; import java.nio.CharBuffer; @@ -34,7 +34,7 @@ import java.nio.charset.CoderResult; * when normal inheritance cannot be used. * Used by autodecting decoders. */ -interface DelegatableDecoder { +public interface DelegatableDecoder { CoderResult decodeLoop(ByteBuffer src, CharBuffer dst); void implReset(); CoderResult implFlush(CharBuffer out); diff --git a/jdk/src/jdk.charsets/share/classes/sun/nio/cs/ext/DoubleByte.java b/jdk/src/java.base/share/classes/sun/nio/cs/DoubleByte.java similarity index 97% rename from jdk/src/jdk.charsets/share/classes/sun/nio/cs/ext/DoubleByte.java rename to jdk/src/java.base/share/classes/sun/nio/cs/DoubleByte.java index ddc19044cf4..7b55339cab1 100644 --- a/jdk/src/jdk.charsets/share/classes/sun/nio/cs/ext/DoubleByte.java +++ b/jdk/src/java.base/share/classes/sun/nio/cs/DoubleByte.java @@ -23,7 +23,7 @@ * questions. */ -package sun.nio.cs.ext; +package sun.nio.cs; import java.nio.ByteBuffer; import java.nio.CharBuffer; @@ -130,9 +130,9 @@ public class DoubleByte { return CoderResult.unmappableForLength(2); } - Decoder(Charset cs, float avgcpb, float maxcpb, - char[][] b2c, char[] b2cSB, - int b2Min, int b2Max) { + public Decoder(Charset cs, float avgcpb, float maxcpb, + char[][] b2c, char[] b2cSB, + int b2Min, int b2Max) { super(cs, avgcpb, maxcpb); this.b2c = b2c; this.b2cSB = b2cSB; @@ -140,7 +140,7 @@ public class DoubleByte { this.b2Max = b2Max; } - Decoder(Charset cs, char[][] b2c, char[] b2cSB, int b2Min, int b2Max) { + public Decoder(Charset cs, char[][] b2c, char[] b2cSB, int b2Min, int b2Max) { this(cs, 0.5f, 1.0f, b2c, b2cSB, b2Min, b2Max); } @@ -273,7 +273,7 @@ public class DoubleByte { private static final int SI = 0x0f; private int currentState; - Decoder_EBCDIC(Charset cs, + public Decoder_EBCDIC(Charset cs, char[][] b2c, char[] b2cSB, int b2Min, int b2Max) { super(cs, b2c, b2cSB, b2Min, b2Max); } @@ -451,7 +451,7 @@ public class DoubleByte { b2cSB_UNMAPPABLE = new char[0x100]; Arrays.fill(b2cSB_UNMAPPABLE, UNMAPPABLE_DECODING); } - Decoder_DBCSONLY(Charset cs, char[][] b2c, char[] b2cSB, int b2Min, int b2Max) { + public Decoder_DBCSONLY(Charset cs, char[][] b2c, char[] b2cSB, int b2Min, int b2Max) { super(cs, 0.5f, 1.0f, b2c, b2cSB_UNMAPPABLE, b2Min, b2Max); } } @@ -463,7 +463,7 @@ public class DoubleByte { private final int SS2 = 0x8E; private final int SS3 = 0x8F; - Decoder_EUC_SIM(Charset cs, + public Decoder_EUC_SIM(Charset cs, char[][] b2c, char[] b2cSB, int b2Min, int b2Max) { super(cs, b2c, b2cSB, b2Min, b2Max); } @@ -511,18 +511,18 @@ public class DoubleByte { public static class Encoder extends CharsetEncoder implements ArrayEncoder { - final int MAX_SINGLEBYTE = 0xff; + protected final int MAX_SINGLEBYTE = 0xff; private final char[] c2b; private final char[] c2bIndex; - Surrogate.Parser sgp; + protected Surrogate.Parser sgp; - protected Encoder(Charset cs, char[] c2b, char[] c2bIndex) { + public Encoder(Charset cs, char[] c2b, char[] c2bIndex) { super(cs, 2.0f, 2.0f); this.c2b = c2b; this.c2bIndex = c2bIndex; } - Encoder(Charset cs, float avg, float max, byte[] repl, char[] c2b, char[] c2bIndex) { + public Encoder(Charset cs, float avg, float max, byte[] repl, char[] c2b, char[] c2bIndex) { super(cs, avg, max, repl); this.c2b = c2b; this.c2bIndex = c2bIndex; @@ -532,7 +532,7 @@ public class DoubleByte { return encodeChar(c) != UNMAPPABLE_ENCODING; } - Surrogate.Parser sgp() { + protected Surrogate.Parser sgp() { if (sgp == null) sgp = new Surrogate.Parser(); return sgp; @@ -657,7 +657,7 @@ public class DoubleByte { } // init the c2b and c2bIndex tables from b2c. - static void initC2B(String[] b2c, String b2cSB, String b2cNR, String c2bNR, + public static void initC2B(String[] b2c, String b2cSB, String b2cNR, String c2bNR, int b2Min, int b2Max, char[] c2b, char[] c2bIndex) { @@ -741,7 +741,7 @@ public class DoubleByte { } public static class Encoder_DBCSONLY extends Encoder { - Encoder_DBCSONLY(Charset cs, byte[] repl, + public Encoder_DBCSONLY(Charset cs, byte[] repl, char[] c2b, char[] c2bIndex) { super(cs, 2.0f, 2.0f, repl, c2b, c2bIndex); } @@ -764,7 +764,7 @@ public class DoubleByte { protected int currentState = SBCS; - Encoder_EBCDIC(Charset cs, char[] c2b, char[] c2bIndex) { + public Encoder_EBCDIC(Charset cs, char[] c2b, char[] c2bIndex) { super(cs, 4.0f, 5.0f, new byte[] {(byte)0x6f}, c2b, c2bIndex); } @@ -921,7 +921,7 @@ public class DoubleByte { // EUC_SIMPLE public static class Encoder_EUC_SIM extends Encoder { - Encoder_EUC_SIM(Charset cs, char[] c2b, char[] c2bIndex) { + public Encoder_EUC_SIM(Charset cs, char[] c2b, char[] c2bIndex) { super(cs, c2b, c2bIndex); } } diff --git a/jdk/src/jdk.charsets/share/classes/sun/nio/cs/ext/HKSCS.java b/jdk/src/java.base/share/classes/sun/nio/cs/HKSCS.java similarity index 98% rename from jdk/src/jdk.charsets/share/classes/sun/nio/cs/ext/HKSCS.java rename to jdk/src/java.base/share/classes/sun/nio/cs/HKSCS.java index 07be74d9581..ba22341ae85 100644 --- a/jdk/src/jdk.charsets/share/classes/sun/nio/cs/ext/HKSCS.java +++ b/jdk/src/java.base/share/classes/sun/nio/cs/HKSCS.java @@ -23,7 +23,7 @@ * questions. */ -package sun.nio.cs.ext; +package sun.nio.cs; import java.nio.ByteBuffer; import java.nio.CharBuffer; @@ -32,6 +32,7 @@ import java.nio.charset.CharsetDecoder; import java.nio.charset.CharsetEncoder; import java.nio.charset.CoderResult; import java.util.Arrays; +import sun.nio.cs.DoubleByte; import sun.nio.cs.Surrogate; import static sun.nio.cs.CharsetMapping.*; @@ -216,7 +217,7 @@ public class HKSCS { return decodeBufferLoop(src, dst); } - static void initb2c(char[][]b2c, String[] b2cStr) + public static void initb2c(char[][]b2c, String[] b2cStr) { for (int i = 0; i < b2cStr.length; i++) { if (b2cStr[i] == null) @@ -395,7 +396,7 @@ public class HKSCS { Arrays.fill(C2B_UNMAPPABLE, (char)UNMAPPABLE_ENCODING); } - static void initc2b(char[][] c2b, String[] b2cStr, String pua) { + public static void initc2b(char[][] c2b, String[] b2cStr, String pua) { // init c2b/c2bSupp from b2cStr and supp int b2Min = 0x40; Arrays.fill(c2b, C2B_UNMAPPABLE); diff --git a/jdk/src/java.base/share/classes/sun/nio/cs/StandardCharsets.java.template b/jdk/src/java.base/share/classes/sun/nio/cs/StandardCharsets.java.template index 468934b017a..63a5dc62139 100644 --- a/jdk/src/java.base/share/classes/sun/nio/cs/StandardCharsets.java.template +++ b/jdk/src/java.base/share/classes/sun/nio/cs/StandardCharsets.java.template @@ -1,5 +1,5 @@ /* - * Copyright (c) 2000, 2014, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2000, 2015, Oracle and/or its affiliates. All rights reserved. * * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * @@ -29,20 +29,188 @@ package sun.nio.cs; -import java.nio.charset.*; +import java.nio.charset.Charset; +import java.nio.charset.spi.CharsetProvider; +import java.util.Iterator; +import java.util.Locale; +import java.util.Map; +import java.security.AccessController; +import java.security.PrivilegedAction; - -public class StandardCharsets - extends FastCharsetProvider -{ +public class StandardCharsets extends CharsetProvider { _INCLUDE_ALIASES_TABLES_ _INCLUDE_ALIASES_MAP_ _INCLUDE_CLASSES_MAP_ _INCLUDE_CACHE_MAP_ + // Maps canonical names to class names + private Map classMap; + // Maps alias names to canonical names + private Map aliasMap; + // Maps canonical names to cached instances + private Map cache; + + private String packagePrefix = "sun.nio.cs"; + public StandardCharsets() { - super("sun.nio.cs", new Aliases(), new Classes(), new Cache()); + this.aliasMap = new Aliases(); + this.classMap = new Classes(); + this.cache = new Cache(); } + private String canonicalize(String csn) { + String acn = aliasMap.get(csn); + return (acn != null) ? acn : csn; + } + + // Private ASCII-only version, optimized for interpretation during startup + // + private static String toLower(String s) { + int n = s.length(); + boolean allLower = true; + for (int i = 0; i < n; i++) { + int c = s.charAt(i); + if (((c - 'A') | ('Z' - c)) >= 0) { + allLower = false; + break; + } + } + if (allLower) + return s; + char[] ca = new char[n]; + for (int i = 0; i < n; i++) { + int c = s.charAt(i); + if (((c - 'A') | ('Z' - c)) >= 0) + ca[i] = (char)(c + 0x20); + else + ca[i] = (char)c; + } + return new String(ca); + } + + private Charset lookup(String charsetName) { + init(); + String csn = canonicalize(toLower(charsetName)); + + // Check cache first + Charset cs = cache.get(csn); + if (cs != null) + return cs; + + // Do we even support this charset? + String cln = classMap.get(csn); + if (cln == null) + return null; + + if (cln.equals("US_ASCII")) { + cs = new US_ASCII(); + cache.put(csn, cs); + return cs; + } + + // Instantiate the charset and cache it + try { + Class c = Class.forName(packagePrefix + "." + cln, + true, + this.getClass().getClassLoader()); + cs = (Charset)c.newInstance(); + cache.put(csn, cs); + return cs; + } catch (ClassNotFoundException | + IllegalAccessException | + InstantiationException x) { + return null; + } + } + + public final Charset charsetForName(String charsetName) { + synchronized (this) { + return lookup(canonicalize(charsetName)); + } + } + + public final Iterator charsets() { + synchronized (this) { + init(); + } + return new Iterator() { + + Iterator i = classMap.keySet().iterator(); + + public boolean hasNext() { + return i.hasNext(); + } + + public Charset next() { + String csn = i.next(); + return lookup(csn); + } + + public void remove() { + throw new UnsupportedOperationException(); + } + + }; + } + + private boolean initialized = false; + + /* provider the sun.nio.cs.map property fir sjis/ms932 mapping hack + */ + private void init() { + if (initialized) + return; + if (!sun.misc.VM.isBooted()) + return; + initialized = true; + + String map = getProperty("sun.nio.cs.map"); + if (map != null) { + String[] maps = map.split(","); + for (int i = 0; i < maps.length; i++) { + if (maps[i].equalsIgnoreCase("Windows-31J/Shift_JIS")) { + // if we dont have both sjis and ms932, do nothing + if (classMap.get("shift_jis") == null || + classMap.get("windows-31j") == null) { + break; + } + aliases_MS932 = new String[] { + "MS932", // JDK historical + "windows-932", + "csWindows31J", + "shift-jis", + "ms_kanji", + "x-sjis", + "csShiftJIS", + // This alias takes precedence over the actual + // Shift_JIS charset itself since aliases are always + // resolved first, before looking up canonical names. + "shift_jis" + }; + aliases_SJIS = new String[] { "sjis" }; + + for (String alias : aliases_MS932) { + aliasMap.put(toLower(alias), "windows-31j"); + } + cache.put("shift_jis", null); + break; + } + } + } + } + + private static String getProperty(String key) { + // this method may be called during initialization of + // system class loader and thus not using lambda + return AccessController.doPrivileged( + new PrivilegedAction() { + @Override + public String run() { + return System.getProperty(key); + } + }); + } + + } diff --git a/jdk/src/java.desktop/share/classes/sun/awt/HKSCS.java b/jdk/src/java.desktop/share/classes/sun/awt/HKSCS.java index 08924208b78..f4b7662c39f 100644 --- a/jdk/src/java.desktop/share/classes/sun/awt/HKSCS.java +++ b/jdk/src/java.desktop/share/classes/sun/awt/HKSCS.java @@ -34,11 +34,21 @@ import java.nio.charset.CharsetDecoder; ExtendedCharsets class, because if we want to have a public HKSCS, it probably should be HKSCS_2001 not HKSCS. */ -public class HKSCS extends sun.nio.cs.ext.MS950_HKSCS_XP { +public class HKSCS extends Charset { + private static Charset cs = Charset.forName("x-MS950-HKSCS-XP"); + public HKSCS () { - super(); + super("HKSCS", null); } public boolean contains(Charset cs) { return (cs instanceof HKSCS); } + + public CharsetDecoder newDecoder() { + return cs.newDecoder(); + } + + public CharsetEncoder newEncoder() { + return cs.newEncoder(); + } } diff --git a/jdk/src/java.desktop/unix/classes/sun/awt/motif/X11GB2312.java b/jdk/src/java.desktop/unix/classes/sun/awt/motif/X11GB2312.java index fb0e17712dd..880ec9c8f43 100644 --- a/jdk/src/java.desktop/unix/classes/sun/awt/motif/X11GB2312.java +++ b/jdk/src/java.desktop/unix/classes/sun/awt/motif/X11GB2312.java @@ -28,6 +28,7 @@ package sun.awt.motif; import java.nio.CharBuffer; import java.nio.ByteBuffer; import java.nio.charset.*; +import sun.nio.cs.*; import sun.nio.cs.ext.*; import static sun.nio.cs.CharsetMapping.*; diff --git a/jdk/src/java.desktop/unix/classes/sun/awt/motif/X11GBK.java b/jdk/src/java.desktop/unix/classes/sun/awt/motif/X11GBK.java index 5302638c535..e082c526dae 100644 --- a/jdk/src/java.desktop/unix/classes/sun/awt/motif/X11GBK.java +++ b/jdk/src/java.desktop/unix/classes/sun/awt/motif/X11GBK.java @@ -26,6 +26,7 @@ package sun.awt.motif; import java.nio.charset.*; +import sun.nio.cs.*; import sun.nio.cs.ext.*; import static sun.nio.cs.CharsetMapping.*; diff --git a/jdk/src/java.desktop/unix/classes/sun/awt/motif/X11JIS0201.java b/jdk/src/java.desktop/unix/classes/sun/awt/motif/X11JIS0201.java index dbac41c5a50..84b6a081be7 100644 --- a/jdk/src/java.desktop/unix/classes/sun/awt/motif/X11JIS0201.java +++ b/jdk/src/java.desktop/unix/classes/sun/awt/motif/X11JIS0201.java @@ -29,7 +29,7 @@ import java.nio.ByteBuffer; import java.nio.CharBuffer; import java.nio.charset.*; import sun.nio.cs.*; -import sun.nio.cs.ext.JIS_X_0201; +import sun.nio.cs.ext.*; import static sun.nio.cs.CharsetMapping.*; public class X11JIS0201 extends Charset { diff --git a/jdk/src/java.desktop/unix/classes/sun/awt/motif/X11JIS0208.java b/jdk/src/java.desktop/unix/classes/sun/awt/motif/X11JIS0208.java index 04ad2ed2899..b4dc5989323 100644 --- a/jdk/src/java.desktop/unix/classes/sun/awt/motif/X11JIS0208.java +++ b/jdk/src/java.desktop/unix/classes/sun/awt/motif/X11JIS0208.java @@ -28,7 +28,8 @@ package sun.awt.motif; import java.nio.charset.Charset; import java.nio.charset.CharsetEncoder; import java.nio.charset.CharsetDecoder; -import sun.nio.cs.ext.JIS_X_0208; +import sun.nio.cs.*; +import sun.nio.cs.ext.*; public class X11JIS0208 extends Charset { diff --git a/jdk/src/java.desktop/unix/classes/sun/awt/motif/X11JIS0212.java b/jdk/src/java.desktop/unix/classes/sun/awt/motif/X11JIS0212.java index 019ea19a910..94c02493d51 100644 --- a/jdk/src/java.desktop/unix/classes/sun/awt/motif/X11JIS0212.java +++ b/jdk/src/java.desktop/unix/classes/sun/awt/motif/X11JIS0212.java @@ -28,7 +28,8 @@ package sun.awt.motif; import java.nio.charset.Charset; import java.nio.charset.CharsetEncoder; import java.nio.charset.CharsetDecoder; -import sun.nio.cs.ext.JIS_X_0212; +import sun.nio.cs.*; +import sun.nio.cs.ext.*; public class X11JIS0212 extends Charset { private static Charset jis0212 = new JIS_X_0212(); diff --git a/jdk/src/java.desktop/unix/classes/sun/awt/motif/X11KSC5601.java b/jdk/src/java.desktop/unix/classes/sun/awt/motif/X11KSC5601.java index 8d9df5ca664..69591cfb062 100644 --- a/jdk/src/java.desktop/unix/classes/sun/awt/motif/X11KSC5601.java +++ b/jdk/src/java.desktop/unix/classes/sun/awt/motif/X11KSC5601.java @@ -28,6 +28,7 @@ package sun.awt.motif; import java.nio.CharBuffer; import java.nio.ByteBuffer; import java.nio.charset.*; +import sun.nio.cs.*; import sun.nio.cs.ext.*; import static sun.nio.cs.CharsetMapping.*; diff --git a/jdk/src/jdk.charsets/share/classes/sun/nio/cs/ext/Big5_HKSCS.java b/jdk/src/jdk.charsets/share/classes/sun/nio/cs/ext/Big5_HKSCS.java.template similarity index 93% rename from jdk/src/jdk.charsets/share/classes/sun/nio/cs/ext/Big5_HKSCS.java rename to jdk/src/jdk.charsets/share/classes/sun/nio/cs/ext/Big5_HKSCS.java.template index 7bed42eb07f..3b2ad7eb5d5 100644 --- a/jdk/src/jdk.charsets/share/classes/sun/nio/cs/ext/Big5_HKSCS.java +++ b/jdk/src/jdk.charsets/share/classes/sun/nio/cs/ext/Big5_HKSCS.java.template @@ -1,5 +1,5 @@ /* - * Copyright (c) 2010, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2010 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 @@ -23,18 +23,20 @@ * questions. */ -package sun.nio.cs.ext; +package $PACKAGE$; import java.nio.charset.Charset; import java.nio.charset.CharsetDecoder; import java.nio.charset.CharsetEncoder; +import sun.nio.cs.DoubleByte; +import sun.nio.cs.HKSCS; import sun.nio.cs.HistoricallyNamedCharset; import static sun.nio.cs.CharsetMapping.*; public class Big5_HKSCS extends Charset implements HistoricallyNamedCharset { public Big5_HKSCS() { - super("Big5-HKSCS", ExtendedCharsets.aliasesFor("Big5-HKSCS")); + super("Big5-HKSCS", $ALIASES$); } public String historicalName() { diff --git a/jdk/src/jdk.charsets/share/classes/sun/nio/cs/ext/Big5_HKSCS_2001.java b/jdk/src/jdk.charsets/share/classes/sun/nio/cs/ext/Big5_HKSCS_2001.java index 1514e2e5cb0..8c3e014ec73 100644 --- a/jdk/src/jdk.charsets/share/classes/sun/nio/cs/ext/Big5_HKSCS_2001.java +++ b/jdk/src/jdk.charsets/share/classes/sun/nio/cs/ext/Big5_HKSCS_2001.java @@ -28,7 +28,9 @@ package sun.nio.cs.ext; import java.nio.charset.Charset; import java.nio.charset.CharsetDecoder; import java.nio.charset.CharsetEncoder; +import sun.nio.cs.DoubleByte; import sun.nio.cs.HistoricallyNamedCharset; +import sun.nio.cs.*; public class Big5_HKSCS_2001 extends Charset { diff --git a/jdk/src/jdk.charsets/share/classes/sun/nio/cs/ext/Big5_Solaris.java b/jdk/src/jdk.charsets/share/classes/sun/nio/cs/ext/Big5_Solaris.java.template similarity index 97% rename from jdk/src/jdk.charsets/share/classes/sun/nio/cs/ext/Big5_Solaris.java rename to jdk/src/jdk.charsets/share/classes/sun/nio/cs/ext/Big5_Solaris.java.template index bf98320287b..e1810bd9268 100644 --- a/jdk/src/jdk.charsets/share/classes/sun/nio/cs/ext/Big5_Solaris.java +++ b/jdk/src/jdk.charsets/share/classes/sun/nio/cs/ext/Big5_Solaris.java.template @@ -23,11 +23,12 @@ * questions. */ -package sun.nio.cs.ext; +package $PACKAGE$; import java.nio.charset.Charset; import java.nio.charset.CharsetDecoder; import java.nio.charset.CharsetEncoder; +import sun.nio.cs.DoubleByte; import sun.nio.cs.HistoricallyNamedCharset; import java.util.Arrays; import static sun.nio.cs.CharsetMapping.*; @@ -35,7 +36,7 @@ import static sun.nio.cs.CharsetMapping.*; public class Big5_Solaris extends Charset implements HistoricallyNamedCharset { public Big5_Solaris() { - super("x-Big5-Solaris", ExtendedCharsets.aliasesFor("x-Big5-Solaris")); + super("x-Big5-Solaris", $ALIASES$); } public String historicalName() { diff --git a/jdk/src/jdk.charsets/share/classes/sun/nio/cs/ext/EUC_JP.java b/jdk/src/jdk.charsets/share/classes/sun/nio/cs/ext/EUC_JP.java.template similarity index 99% rename from jdk/src/jdk.charsets/share/classes/sun/nio/cs/ext/EUC_JP.java rename to jdk/src/jdk.charsets/share/classes/sun/nio/cs/ext/EUC_JP.java.template index 84ca4c2aada..1a1a9affe83 100644 --- a/jdk/src/jdk.charsets/share/classes/sun/nio/cs/ext/EUC_JP.java +++ b/jdk/src/jdk.charsets/share/classes/sun/nio/cs/ext/EUC_JP.java.template @@ -23,7 +23,7 @@ * questions. */ -package sun.nio.cs.ext; +package $PACKAGE$; import java.nio.ByteBuffer; import java.nio.CharBuffer; @@ -32,8 +32,11 @@ import java.nio.charset.CharsetDecoder; import java.nio.charset.CharsetEncoder; import java.nio.charset.CoderResult; import sun.nio.cs.HistoricallyNamedCharset; +import sun.nio.cs.DelegatableDecoder; +import sun.nio.cs.DoubleByte; import sun.nio.cs.Surrogate; import sun.nio.cs.SingleByte; +import sun.nio.cs.*; import static sun.nio.cs.CharsetMapping.*; public class EUC_JP @@ -41,7 +44,7 @@ public class EUC_JP implements HistoricallyNamedCharset { public EUC_JP() { - super("EUC-JP", ExtendedCharsets.aliasesFor("EUC-JP")); + super("EUC-JP", $ALIASES$); } public String historicalName() { diff --git a/jdk/src/jdk.charsets/share/classes/sun/nio/cs/ext/EUC_JP_LINUX.java b/jdk/src/jdk.charsets/share/classes/sun/nio/cs/ext/EUC_JP_LINUX.java.template similarity index 93% rename from jdk/src/jdk.charsets/share/classes/sun/nio/cs/ext/EUC_JP_LINUX.java rename to jdk/src/jdk.charsets/share/classes/sun/nio/cs/ext/EUC_JP_LINUX.java.template index 343e1d05b00..a96d5d27cb5 100644 --- a/jdk/src/jdk.charsets/share/classes/sun/nio/cs/ext/EUC_JP_LINUX.java +++ b/jdk/src/jdk.charsets/share/classes/sun/nio/cs/ext/EUC_JP_LINUX.java.template @@ -1,5 +1,5 @@ /* - * Copyright (c) 2002, 2012, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2002, 2015, 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 @@ -23,7 +23,7 @@ * questions. */ -package sun.nio.cs.ext; +package $PACKAGE$; import java.nio.ByteBuffer; import java.nio.CharBuffer; @@ -32,13 +32,14 @@ import java.nio.charset.CharsetDecoder; import java.nio.charset.CharsetEncoder; import java.nio.charset.CoderResult; import sun.nio.cs.HistoricallyNamedCharset; +import sun.nio.cs.*; public class EUC_JP_LINUX extends Charset implements HistoricallyNamedCharset { public EUC_JP_LINUX() { - super("x-euc-jp-linux", ExtendedCharsets.aliasesFor("x-euc-jp-linux")); + super("x-euc-jp-linux", $ALIASES$); } public String historicalName() { diff --git a/jdk/src/jdk.charsets/share/classes/sun/nio/cs/ext/EUC_JP_Open.java b/jdk/src/jdk.charsets/share/classes/sun/nio/cs/ext/EUC_JP_Open.java.template similarity index 95% rename from jdk/src/jdk.charsets/share/classes/sun/nio/cs/ext/EUC_JP_Open.java rename to jdk/src/jdk.charsets/share/classes/sun/nio/cs/ext/EUC_JP_Open.java.template index 277a09b77da..9c86e7ac719 100644 --- a/jdk/src/jdk.charsets/share/classes/sun/nio/cs/ext/EUC_JP_Open.java +++ b/jdk/src/jdk.charsets/share/classes/sun/nio/cs/ext/EUC_JP_Open.java.template @@ -1,5 +1,5 @@ /* - * Copyright (c) 2003, 2012, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2003, 2015, 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 @@ -23,7 +23,7 @@ * questions. */ -package sun.nio.cs.ext; +package $PACKAGE$; import java.nio.ByteBuffer; import java.nio.CharBuffer; @@ -31,7 +31,9 @@ import java.nio.charset.Charset; import java.nio.charset.CharsetDecoder; import java.nio.charset.CharsetEncoder; import java.nio.charset.CoderResult; +import sun.nio.cs.DoubleByte; import sun.nio.cs.HistoricallyNamedCharset; +import sun.nio.cs.*; import static sun.nio.cs.CharsetMapping.*; public class EUC_JP_Open @@ -39,7 +41,7 @@ public class EUC_JP_Open implements HistoricallyNamedCharset { public EUC_JP_Open() { - super("x-eucJP-Open", ExtendedCharsets.aliasesFor("x-eucJP-Open")); + super("x-eucJP-Open", $ALIASES$); } public String historicalName() { diff --git a/jdk/src/jdk.charsets/share/classes/sun/nio/cs/ext/ExtendedCharsets.java b/jdk/src/jdk.charsets/share/classes/sun/nio/cs/ext/ExtendedCharsets.java deleted file mode 100644 index 7b1db203305..00000000000 --- a/jdk/src/jdk.charsets/share/classes/sun/nio/cs/ext/ExtendedCharsets.java +++ /dev/null @@ -1,1326 +0,0 @@ -/* - * Copyright (c) 2002, 2013, 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. Oracle designates this - * particular file as subject to the "Classpath" exception as provided - * by Oracle in the LICENSE file that accompanied this code. - * - * 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. - */ - -package sun.nio.cs.ext; - -import java.lang.ref.SoftReference; -import java.nio.charset.Charset; -import java.nio.charset.spi.CharsetProvider; -import sun.nio.cs.AbstractCharsetProvider; -import java.security.AccessController; -import java.security.PrivilegedAction; - -/** - * Provider for extended charsets. - */ - -public class ExtendedCharsets - extends AbstractCharsetProvider -{ - - static volatile ExtendedCharsets instance = null; - - public ExtendedCharsets() { - - super("sun.nio.cs.ext"); // identify provider pkg name. - - // Traditional Chinese - - charset("Big5", "Big5", - new String[] { - // IANA aliases - "csBig5" - }); - - charset("x-MS950-HKSCS-XP", "MS950_HKSCS_XP", - new String[] { - "MS950_HKSCS_XP" // JDK historical; - }); - - charset("x-MS950-HKSCS", "MS950_HKSCS", - new String[] { - // IANA aliases - "MS950_HKSCS" // JDK historical; - }); - - charset("x-windows-950", "MS950", - new String[] { - "ms950", // JDK historical - "windows-950" - }); - - charset("x-windows-874", "MS874", - new String[] { - "ms874", // JDK historical - "ms-874", - "windows-874" }); - - charset("x-EUC-TW", "EUC_TW", - new String[] { - "euc_tw", // JDK historical - "euctw", - "cns11643", - "EUC-TW" - }); - - charset("Big5-HKSCS", "Big5_HKSCS", - new String[] { - "Big5_HKSCS", // JDK historical - "big5hk", - "big5-hkscs", - "big5hkscs" // Linux alias - }); - - charset("x-Big5-HKSCS-2001", "Big5_HKSCS_2001", - new String[] { - "Big5_HKSCS_2001", - "big5hk-2001", - "big5-hkscs-2001", - "big5-hkscs:unicode3.0", - "big5hkscs-2001", - }); - - charset("x-Big5-Solaris", "Big5_Solaris", - new String[] { - "Big5_Solaris", // JDK historical - }); - - // Simplified Chinese - charset("GBK", "GBK", - new String[] { - "windows-936", - "CP936" - }); - - charset("GB18030", "GB18030", - new String[] { - "gb18030-2000" - }); - - charset("GB2312", "EUC_CN", - new String[] { - // IANA aliases - "gb2312", - "gb2312-80", - "gb2312-1980", - "euc-cn", - "euccn", - "x-EUC-CN", // 1.4 compatibility - "EUC_CN" //JDK historical - }); - - charset("x-mswin-936", "MS936", - new String[] { - "ms936", // historical - // IANA aliases - "ms_936" - }); - - // The definition of this charset may be overridden by the init method, - // below, if the sun.nio.cs.map property is defined. - // - charset("Shift_JIS", "SJIS", - new String[] { - // IANA aliases - "sjis", // historical - "shift_jis", - "shift-jis", - "ms_kanji", - "x-sjis", - "csShiftJIS" - }); - - // The definition of this charset may be overridden by the init method, - // below, if the sun.nio.cs.map property is defined. - // - charset("windows-31j", "MS932", - new String[] { - "MS932", // JDK historical - "windows-932", - "csWindows31J" - }); - - charset("JIS_X0201", "JIS_X_0201", - new String[] { - "JIS0201", // JDK historical - // IANA aliases - "JIS_X0201", - "X0201", - "csHalfWidthKatakana" - }); - - charset("x-JIS0208", "JIS_X_0208", - new String[] { - "JIS0208", // JDK historical - // IANA aliases - "JIS_C6226-1983", - "iso-ir-87", - "x0208", - "JIS_X0208-1983", - "csISO87JISX0208" - }); - - charset("JIS_X0212-1990", "JIS_X_0212", - new String[] { - "JIS0212", // JDK historical - // IANA aliases - "jis_x0212-1990", - "x0212", - "iso-ir-159", - "csISO159JISX02121990" - }); - - charset("x-SJIS_0213", "SJIS_0213", - new String[] { - "sjis-0213", - "sjis_0213", - "sjis:2004", - "sjis_0213:2004", - "shift_jis_0213:2004", - "shift_jis:2004" - }); - - charset("x-MS932_0213", "MS932_0213", - new String[] { - "MS932-0213", - "MS932_0213", - "MS932:2004", - "windows-932-0213", - "windows-932:2004" - }); - - charset("EUC-JP", "EUC_JP", - new String[] { - "euc_jp", // JDK historical - // IANA aliases - "eucjis", - "eucjp", - "Extended_UNIX_Code_Packed_Format_for_Japanese", - "csEUCPkdFmtjapanese", - "x-euc-jp", - "x-eucjp" - }); - - charset("x-euc-jp-linux", "EUC_JP_LINUX", - new String[] { - "euc_jp_linux", // JDK historical - "euc-jp-linux" - }); - - charset("x-eucjp-open", "EUC_JP_Open", - new String[] { - "EUC_JP_Solaris", // JDK historical - "eucJP-open" - }); - - charset("x-PCK", "PCK", - new String[] { - // IANA aliases - "pck" // historical - }); - - charset("ISO-2022-JP", "ISO2022_JP", - new String[] { - // IANA aliases - "iso2022jp", // historical - "jis", - "csISO2022JP", - "jis_encoding", - "csjisencoding" - }); - - charset("ISO-2022-JP-2", "ISO2022_JP_2", - new String[] { - // IANA aliases - "csISO2022JP2", - "iso2022jp2" - }); - - charset("x-windows-50221", "MS50221", - new String[] { - "ms50221", // historical - "cp50221", - }); - - charset("x-windows-50220", "MS50220", - new String[] { - "ms50220", // historical - "cp50220", - }); - - charset("x-windows-iso2022jp", "MSISO2022JP", - new String[] { - "windows-iso2022jp", // historical - }); - - charset("x-JISAutoDetect", "JISAutoDetect", - new String[] { - "JISAutoDetect" // historical - }); - - // Korean - charset("EUC-KR", "EUC_KR", - new String[] { - "euc_kr", // JDK historical - // IANA aliases - "ksc5601", - "euckr", - "ks_c_5601-1987", - "ksc5601-1987", - "ksc5601_1987", - "ksc_5601", - "csEUCKR", - "5601" - }); - - charset("x-windows-949", "MS949", - new String[] { - "ms949", // JDK historical - "windows949", - "windows-949", - // IANA aliases - "ms_949" - }); - - charset("x-Johab", "Johab", - new String[] { - "ksc5601-1992", - "ksc5601_1992", - "ms1361", - "johab" // JDK historical - }); - - charset("ISO-2022-KR", "ISO2022_KR", - new String[] { - "ISO2022KR", // JDK historical - "csISO2022KR" - }); - - charset("ISO-2022-CN", "ISO2022_CN", - new String[] { - "ISO2022CN", // JDK historical - "csISO2022CN" - }); - - charset("x-ISO-2022-CN-CNS", "ISO2022_CN_CNS", - new String[] { - "ISO2022CN_CNS", // JDK historical - "ISO-2022-CN-CNS" - }); - - charset("x-ISO-2022-CN-GB", "ISO2022_CN_GB", - new String[] { - "ISO2022CN_GB", // JDK historical - "ISO-2022-CN-GB" - }); - - charset("x-ISCII91", "ISCII91", - new String[] { - "iscii", - "ST_SEV_358-88", - "iso-ir-153", - "csISO153GOST1976874", - "ISCII91" // JDK historical - }); - - charset("ISO-8859-3", "ISO_8859_3", - new String[] { - "iso8859_3", // JDK historical - "8859_3", - "ISO_8859-3:1988", - "iso-ir-109", - "ISO_8859-3", - "ISO8859-3", - "latin3", - "l3", - "ibm913", - "ibm-913", - "cp913", - "913", - "csISOLatin3" - }); - - charset("ISO-8859-6", "ISO_8859_6", - new String[] { - "iso8859_6", // JDK historical - "8859_6", - "iso-ir-127", - "ISO_8859-6", - "ISO_8859-6:1987", - "ISO8859-6", - "ECMA-114", - "ASMO-708", - "arabic", - "ibm1089", - "ibm-1089", - "cp1089", - "1089", - "csISOLatinArabic" - }); - - charset("ISO-8859-8", "ISO_8859_8", - new String[] { - "iso8859_8", // JDK historical - "8859_8", - "iso-ir-138", - "ISO_8859-8", - "ISO_8859-8:1988", - "ISO8859-8", - "cp916", - "916", - "ibm916", - "ibm-916", - "hebrew", - "csISOLatinHebrew" - }); - - charset("x-ISO-8859-11", "ISO_8859_11", - new String[] { - "iso-8859-11", - "iso8859_11" - }); - - charset("TIS-620", "TIS_620", - new String[] { - "tis620", // JDK historical - "tis620.2533" - }); - - // Various Microsoft Windows international codepages - - charset("windows-1255", "MS1255", - new String[] { - "cp1255" // JDK historical - }); - - charset("windows-1256", "MS1256", - new String[] { - "cp1256" // JDK historical - }); - - charset("windows-1258", "MS1258", - new String[] { - "cp1258" // JDK historical - }); - - // IBM & PC/MSDOS encodings - - charset("x-IBM942", "IBM942", - new String[] { - "cp942", // JDK historical - "ibm942", - "ibm-942", - "942" - }); - - charset("x-IBM942C", "IBM942C", - new String[] { - "cp942C", // JDK historical - "ibm942C", - "ibm-942C", - "942C" - }); - - charset("x-IBM943", "IBM943", - new String[] { - "cp943", // JDK historical - "ibm943", - "ibm-943", - "943" - }); - - charset("x-IBM943C", "IBM943C", - new String[] { - "cp943C", // JDK historical - "ibm943C", - "ibm-943C", - "943C" - }); - - charset("x-IBM948", "IBM948", - new String[] { - "cp948", // JDK historical - "ibm948", - "ibm-948", - "948" - }); - - charset("x-IBM950", "IBM950", - new String[] { - "cp950", // JDK historical - "ibm950", - "ibm-950", - "950" - }); - - charset("x-IBM930", "IBM930", - new String[] { - "cp930", // JDK historical - "ibm930", - "ibm-930", - "930" - }); - - charset("x-IBM935", "IBM935", - new String[] { - "cp935", // JDK historical - "ibm935", - "ibm-935", - "935" - }); - - charset("x-IBM937", "IBM937", - new String[] { - "cp937", // JDK historical - "ibm937", - "ibm-937", - "937" - }); - - charset("x-IBM856", "IBM856", - new String[] { - "cp856", // JDK historical - "ibm-856", - "ibm856", - "856" - }); - - charset("IBM860", "IBM860", - new String[] { - "cp860", // JDK historical - "ibm860", - "ibm-860", - "860", - "csIBM860" - }); - charset("IBM861", "IBM861", - new String[] { - "cp861", // JDK historical - "ibm861", - "ibm-861", - "861", - "csIBM861", - "cp-is" - }); - - charset("IBM863", "IBM863", - new String[] { - "cp863", // JDK historical - "ibm863", - "ibm-863", - "863", - "csIBM863" - }); - - charset("IBM864", "IBM864", - new String[] { - "cp864", // JDK historical - "ibm864", - "ibm-864", - "864", - "csIBM864" - }); - - charset("IBM865", "IBM865", - new String[] { - "cp865", // JDK historical - "ibm865", - "ibm-865", - "865", - "csIBM865" - }); - - charset("IBM868", "IBM868", - new String[] { - "cp868", // JDK historical - "ibm868", - "ibm-868", - "868", - "cp-ar", - "csIBM868" - }); - - charset("IBM869", "IBM869", - new String[] { - "cp869", // JDK historical - "ibm869", - "ibm-869", - "869", - "cp-gr", - "csIBM869" - }); - - charset("x-IBM921", "IBM921", - new String[] { - "cp921", // JDK historical - "ibm921", - "ibm-921", - "921" - }); - - charset("x-IBM1006", "IBM1006", - new String[] { - "cp1006", // JDK historical - "ibm1006", - "ibm-1006", - "1006" - }); - - charset("x-IBM1046", "IBM1046", - new String[] { - "cp1046", // JDK historical - "ibm1046", - "ibm-1046", - "1046" - }); - - charset("IBM1047", "IBM1047", - new String[] { - "cp1047", // JDK historical - "ibm-1047", - "1047" - }); - - charset("x-IBM1098", "IBM1098", - new String[] { - "cp1098", // JDK historical - "ibm1098", - "ibm-1098", - "1098", - }); - - charset("IBM037", "IBM037", - new String[] { - "cp037", // JDK historical - "ibm037", - "ebcdic-cp-us", - "ebcdic-cp-ca", - "ebcdic-cp-wt", - "ebcdic-cp-nl", - "csIBM037", - "cs-ebcdic-cp-us", - "cs-ebcdic-cp-ca", - "cs-ebcdic-cp-wt", - "cs-ebcdic-cp-nl", - "ibm-037", - "ibm-37", - "cpibm37", - "037" - }); - - charset("x-IBM1025", "IBM1025", - new String[] { - "cp1025", // JDK historical - "ibm1025", - "ibm-1025", - "1025" - }); - - charset("IBM1026", "IBM1026", - new String[] { - "cp1026", // JDK historical - "ibm1026", - "ibm-1026", - "1026" - }); - - charset("x-IBM1112", "IBM1112", - new String[] { - "cp1112", // JDK historical - "ibm1112", - "ibm-1112", - "1112" - }); - - charset("x-IBM1122", "IBM1122", - new String[] { - "cp1122", // JDK historical - "ibm1122", - "ibm-1122", - "1122" - }); - - charset("x-IBM1123", "IBM1123", - new String[] { - "cp1123", // JDK historical - "ibm1123", - "ibm-1123", - "1123" - }); - - charset("x-IBM1124", "IBM1124", - new String[] { - "cp1124", // JDK historical - "ibm1124", - "ibm-1124", - "1124" - }); - - charset("x-IBM1364", "IBM1364", - new String[] { - "cp1364", - "ibm1364", - "ibm-1364", - "1364" - }); - - charset("IBM273", "IBM273", - new String[] { - "cp273", // JDK historical - "ibm273", - "ibm-273", - "273" - }); - - charset("IBM277", "IBM277", - new String[] { - "cp277", // JDK historical - "ibm277", - "ibm-277", - "277" - }); - - charset("IBM278", "IBM278", - new String[] { - "cp278", // JDK historical - "ibm278", - "ibm-278", - "278", - "ebcdic-sv", - "ebcdic-cp-se", - "csIBM278" - }); - - charset("IBM280", "IBM280", - new String[] { - "cp280", // JDK historical - "ibm280", - "ibm-280", - "280" - }); - - charset("IBM284", "IBM284", - new String[] { - "cp284", // JDK historical - "ibm284", - "ibm-284", - "284", - "csIBM284", - "cpibm284" - }); - - charset("IBM285", "IBM285", - new String[] { - "cp285", // JDK historical - "ibm285", - "ibm-285", - "285", - "ebcdic-cp-gb", - "ebcdic-gb", - "csIBM285", - "cpibm285" - }); - - charset("IBM297", "IBM297", - new String[] { - "cp297", // JDK historical - "ibm297", - "ibm-297", - "297", - "ebcdic-cp-fr", - "cpibm297", - "csIBM297", - }); - - charset("IBM420", "IBM420", - new String[] { - "cp420", // JDK historical - "ibm420", - "ibm-420", - "ebcdic-cp-ar1", - "420", - "csIBM420" - }); - - charset("IBM424", "IBM424", - new String[] { - "cp424", // JDK historical - "ibm424", - "ibm-424", - "424", - "ebcdic-cp-he", - "csIBM424" - }); - - charset("IBM500", "IBM500", - new String[] { - "cp500", // JDK historical - "ibm500", - "ibm-500", - "500", - "ebcdic-cp-ch", - "ebcdic-cp-bh", - "csIBM500" - }); - - charset("x-IBM833", "IBM833", - new String[] { - "cp833", - "ibm833", - "ibm-833" - }); - - //EBCDIC DBCS-only Korean - charset("x-IBM834", "IBM834", - new String[] { - "cp834", - "ibm834", - "834", - "ibm-834" - }); - - - charset("IBM-Thai", "IBM838", - new String[] { - "cp838", // JDK historical - "ibm838", - "ibm-838", - "838" - }); - - charset("IBM870", "IBM870", - new String[] { - "cp870", // JDK historical - "ibm870", - "ibm-870", - "870", - "ebcdic-cp-roece", - "ebcdic-cp-yu", - "csIBM870" - }); - - charset("IBM871", "IBM871", - new String[] { - "cp871", // JDK historical - "ibm871", - "ibm-871", - "871", - "ebcdic-cp-is", - "csIBM871" - }); - - charset("x-IBM875", "IBM875", - new String[] { - "cp875", // JDK historical - "ibm875", - "ibm-875", - "875" - }); - - charset("IBM918", "IBM918", - new String[] { - "cp918", // JDK historical - "ibm-918", - "918", - "ebcdic-cp-ar2" - }); - - charset("x-IBM922", "IBM922", - new String[] { - "cp922", // JDK historical - "ibm922", - "ibm-922", - "922" - }); - - charset("x-IBM1097", "IBM1097", - new String[] { - "cp1097", // JDK historical - "ibm1097", - "ibm-1097", - "1097" - }); - - charset("x-IBM949", "IBM949", - new String[] { - "cp949", // JDK historical - "ibm949", - "ibm-949", - "949" - }); - - charset("x-IBM949C", "IBM949C", - new String[] { - "cp949C", // JDK historical - "ibm949C", - "ibm-949C", - "949C" - }); - - charset("x-IBM939", "IBM939", - new String[] { - "cp939", // JDK historical - "ibm939", - "ibm-939", - "939" - }); - - charset("x-IBM933", "IBM933", - new String[] { - "cp933", // JDK historical - "ibm933", - "ibm-933", - "933" - }); - - charset("x-IBM1381", "IBM1381", - new String[] { - "cp1381", // JDK historical - "ibm1381", - "ibm-1381", - "1381" - }); - - charset("x-IBM1383", "IBM1383", - new String[] { - "cp1383", // JDK historical - "ibm1383", - "ibm-1383", - "1383" - }); - - charset("x-IBM970", "IBM970", - new String[] { - "cp970", // JDK historical - "ibm970", - "ibm-970", - "ibm-eucKR", - "970" - }); - - charset("x-IBM964", "IBM964", - new String[] { - "cp964", // JDK historical - "ibm964", - "ibm-964", - "964" - }); - - charset("x-IBM33722", "IBM33722", - new String[] { - "cp33722", // JDK historical - "ibm33722", - "ibm-33722", - "ibm-5050", // from IBM alias list - "ibm-33722_vascii_vpua", // from IBM alias list - "33722" - }); - - charset("IBM01140", "IBM1140", - new String[] { - "cp1140", // JDK historical - "ccsid01140", - "cp01140", - "1140", - "ebcdic-us-037+euro" - }); - - charset("IBM01141", "IBM1141", - new String[] { - "cp1141", // JDK historical - "ccsid01141", - "cp01141", - "1141", - "ebcdic-de-273+euro" - }); - - charset("IBM01142", "IBM1142", - new String[] { - "cp1142", // JDK historical - "ccsid01142", - "cp01142", - "1142", - "ebcdic-no-277+euro", - "ebcdic-dk-277+euro" - }); - - charset("IBM01143", "IBM1143", - new String[] { - "cp1143", // JDK historical - "ccsid01143", - "cp01143", - "1143", - "ebcdic-fi-278+euro", - "ebcdic-se-278+euro" - }); - - charset("IBM01144", "IBM1144", - new String[] { - "cp1144", // JDK historical - "ccsid01144", - "cp01144", - "1144", - "ebcdic-it-280+euro" - }); - - charset("IBM01145", "IBM1145", - new String[] { - "cp1145", // JDK historical - "ccsid01145", - "cp01145", - "1145", - "ebcdic-es-284+euro" - }); - - charset("IBM01146", "IBM1146", - new String[] { - "cp1146", // JDK historical - "ccsid01146", - "cp01146", - "1146", - "ebcdic-gb-285+euro" - }); - - charset("IBM01147", "IBM1147", - new String[] { - "cp1147", // JDK historical - "ccsid01147", - "cp01147", - "1147", - "ebcdic-fr-277+euro" - }); - - charset("IBM01148", "IBM1148", - new String[] { - "cp1148", // JDK historical - "ccsid01148", - "cp01148", - "1148", - "ebcdic-international-500+euro" - }); - - charset("IBM01149", "IBM1149", - new String[] { - "cp1149", // JDK historical - "ccsid01149", - "cp01149", - "1149", - "ebcdic-s-871+euro" - }); - - charset("IBM290", "IBM290", - new String[] { - "cp290", - "ibm290", - "ibm-290", - "csIBM290", - "EBCDIC-JP-kana", - "290" - }); - - charset("x-IBM300", "IBM300", - new String[] { - "cp300", - "ibm300", - "ibm-300", - "300" - }); - - // Macintosh MacOS/Apple char encodingd - - - charset("x-MacRoman", "MacRoman", - new String[] { - "MacRoman" // JDK historical - }); - - charset("x-MacCentralEurope", "MacCentralEurope", - new String[] { - "MacCentralEurope" // JDK historical - }); - - charset("x-MacCroatian", "MacCroatian", - new String[] { - "MacCroatian" // JDK historical - }); - - - charset("x-MacGreek", "MacGreek", - new String[] { - "MacGreek" // JDK historical - }); - - charset("x-MacCyrillic", "MacCyrillic", - new String[] { - "MacCyrillic" // JDK historical - }); - - charset("x-MacUkraine", "MacUkraine", - new String[] { - "MacUkraine" // JDK historical - }); - - charset("x-MacTurkish", "MacTurkish", - new String[] { - "MacTurkish" // JDK historical - }); - - charset("x-MacArabic", "MacArabic", - new String[] { - "MacArabic" // JDK historical - }); - - charset("x-MacHebrew", "MacHebrew", - new String[] { - "MacHebrew" // JDK historical - }); - - charset("x-MacIceland", "MacIceland", - new String[] { - "MacIceland" // JDK historical - }); - - charset("x-MacRomania", "MacRomania", - new String[] { - "MacRomania" // JDK historical - }); - - charset("x-MacThai", "MacThai", - new String[] { - "MacThai" // JDK historical - }); - - charset("x-MacSymbol", "MacSymbol", - new String[] { - "MacSymbol" // JDK historical - }); - - charset("x-MacDingbat", "MacDingbat", - new String[] { - "MacDingbat" // JDK historical - }); - - instance = this; - - } - - private boolean initialized = false; - - // If the sun.nio.cs.map property is defined on the command line we won't - // see it in the system-properties table until after the charset subsystem - // has been initialized. We therefore delay the effect of this property - // until after the JRE has completely booted. - // - // At the moment following values for this property are supported, property - // value string is case insensitive. - // - // (1)"Windows-31J/Shift_JIS" - // In 1.4.1 we added a correct implementation of the Shift_JIS charset - // but in previous releases this charset name had been treated as an alias - // for Windows-31J, aka MS932. Users who have existing code that depends - // upon this alias can restore the previous behavior by defining this - // property to have this value. - // - // (2)"x-windows-50221/ISO-2022-JP" - // "x-windows-50220/ISO-2022-JP" - // "x-windows-iso2022jp/ISO-2022-JP" - // The charset ISO-2022-JP is a "standard based" implementation by default, - // which supports ASCII, JIS_X_0201 and JIS_X_0208 mappings based encoding - // and decoding only. - // There are three Microsoft iso-2022-jp variants, namely x-windows-50220, - // x-windows-50221 and x-windows-iso2022jp which behaves "slightly" differently - // compared to the "standard based" implementation. See ISO2022_JP.java for - // detailed description. Users who prefer the behavior of MS iso-2022-jp - // variants should use these names explicitly instead of using "ISO-2022-JP" - // and its aliases. However for those who need the ISO-2022-JP charset behaves - // exactly the same as MS variants do, above properties can be defined to - // switch. - // - // If we need to define other charset-alias mappings in the future then - // this property could be further extended, the general idea being that its - // value should be of the form - // - // new-charset-1/old-charset-1,new-charset-2/old-charset-2,... - // - // where each charset named to the left of a slash is intended to replace - // (most) uses of the charset named to the right of the slash. - // - protected void init() { - if (initialized) - return; - if (!sun.misc.VM.isBooted()) - return; - - String map = getProperty("sun.nio.cs.map"); - boolean sjisIsMS932 = false; - boolean iso2022jpIsMS50221 = false; - boolean iso2022jpIsMS50220 = false; - boolean iso2022jpIsMSISO2022JP = false; - if (map != null) { - String[] maps = map.split(","); - for (int i = 0; i < maps.length; i++) { - if (maps[i].equalsIgnoreCase("Windows-31J/Shift_JIS")) { - sjisIsMS932 = true; - } else if (maps[i].equalsIgnoreCase("x-windows-50221/ISO-2022-JP")) { - iso2022jpIsMS50221 = true; - } else if (maps[i].equalsIgnoreCase("x-windows-50220/ISO-2022-JP")) { - iso2022jpIsMS50220 = true; - } else if (maps[i].equalsIgnoreCase("x-windows-iso2022jp/ISO-2022-JP")) { - iso2022jpIsMSISO2022JP = true; - } - } - } - if (sjisIsMS932) { - deleteCharset("Shift_JIS", - new String[] { - // IANA aliases - "sjis", // historical - "shift_jis", - "shift-jis", - "ms_kanji", - "x-sjis", - "csShiftJIS" - }); - deleteCharset("windows-31j", - new String[] { - "MS932", // JDK historical - "windows-932", - "csWindows31J" - }); - charset("Shift_JIS", "SJIS", - new String[] { - // IANA aliases - "sjis" // JDK historical - }); - charset("windows-31j", "MS932", - new String[] { - "MS932", // JDK historical - "windows-932", - "csWindows31J", - "shift-jis", - "ms_kanji", - "x-sjis", - "csShiftJIS", - // This alias takes precedence over the actual - // Shift_JIS charset itself since aliases are always - // resolved first, before looking up canonical names. - "shift_jis" - }); - } - if (iso2022jpIsMS50221 || - iso2022jpIsMS50220 || - iso2022jpIsMSISO2022JP) { - deleteCharset("ISO-2022-JP", - new String[] { - "iso2022jp", - "jis", - "csISO2022JP", - "jis_encoding", - "csjisencoding" - }); - if (iso2022jpIsMS50221) { - deleteCharset("x-windows-50221", - new String[] { - "cp50221", - "ms50221" - }); - charset("x-windows-50221", "MS50221", - new String[] { - "cp50221", - "ms50221", - "iso-2022-jp", - "iso2022jp", - "jis", - "csISO2022JP", - "jis_encoding", - "csjisencoding" - }); - } else if (iso2022jpIsMS50220) { - deleteCharset("x-windows-50220", - new String[] { - "cp50220", - "ms50220" - }); - charset("x-windows-50220", "MS50220", - new String[] { - "cp50220", - "ms50220", - "iso-2022-jp", - "iso2022jp", - "jis", - "csISO2022JP", - "jis_encoding", - "csjisencoding" - }); - } else { - deleteCharset("x-windows-iso2022jp", - new String[] { - "windows-iso2022jp" - }); - charset("x-windows-iso2022jp", "MSISO2022JP", - new String[] { - "windows-iso2022jp", - "iso-2022-jp", - "iso2022jp", - "jis", - "csISO2022JP", - "jis_encoding", - "csjisencoding" - }); - - - } - } - String osName = getProperty("os.name"); - if ("SunOS".equals(osName) || "Linux".equals(osName) || "AIX".equals(osName) - || osName.contains("OS X")) { - charset("x-COMPOUND_TEXT", "COMPOUND_TEXT", - new String[] { - "COMPOUND_TEXT", // JDK historical - "x11-compound_text", - "x-compound-text" - }); - } - initialized = true; - } - - private static String getProperty(String key) { - // this method may be called during initialization of - // system class loader and thus not using lambda - return AccessController.doPrivileged( - new PrivilegedAction() { - @Override - public String run() { - return System.getProperty(key); - } - }); - } - - public static String[] aliasesFor(String charsetName) { - if (instance == null) - return null; - return instance.aliases(charsetName); - } -} diff --git a/jdk/src/jdk.charsets/share/classes/sun/nio/cs/ext/ExtendedCharsets.java.template b/jdk/src/jdk.charsets/share/classes/sun/nio/cs/ext/ExtendedCharsets.java.template new file mode 100644 index 00000000000..a37d43b0787 --- /dev/null +++ b/jdk/src/jdk.charsets/share/classes/sun/nio/cs/ext/ExtendedCharsets.java.template @@ -0,0 +1,256 @@ +/* + * Copyright (c) 2000, 2015, 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. Oracle designates this + * particular file as subject to the "Classpath" exception as provided + * by Oracle in the LICENSE file that accompanied this code. + * + * 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. + * + */ + +// -- This file was mechanically generated: Do not edit! -- // + +package sun.nio.cs.ext; + +import java.lang.ref.SoftReference; +import java.nio.charset.Charset; +import java.nio.charset.spi.CharsetProvider; +import sun.nio.cs.AbstractCharsetProvider; +import java.security.AccessController; +import java.security.PrivilegedAction; +import sun.nio.cs.AbstractCharsetProvider; + +/** + * Provider for extended charsets. + */ + +public class ExtendedCharsets extends AbstractCharsetProvider { + + static volatile ExtendedCharsets instance = null; + + public ExtendedCharsets() { + + super("sun.nio.cs.ext"); // identify provider pkg name. + + _CHARSETS_DEF_LIST_ + + instance = this; + + } + + private boolean initialized = false; + + // If the sun.nio.cs.map property is defined on the command line we won't + // see it in the system-properties table until after the charset subsystem + // has been initialized. We therefore delay the effect of this property + // until after the JRE has completely booted. + // + // At the moment following values for this property are supported, property + // value string is case insensitive. + // + // (1)"Windows-31J/Shift_JIS" + // In 1.4.1 we added a correct implementation of the Shift_JIS charset + // but in previous releases this charset name had been treated as an alias + // for Windows-31J, aka MS932. Users who have existing code that depends + // upon this alias can restore the previous behavior by defining this + // property to have this value. + // + // (2)"x-windows-50221/ISO-2022-JP" + // "x-windows-50220/ISO-2022-JP" + // "x-windows-iso2022jp/ISO-2022-JP" + // The charset ISO-2022-JP is a "standard based" implementation by default, + // which supports ASCII, JIS_X_0201 and JIS_X_0208 mappings based encoding + // and decoding only. + // There are three Microsoft iso-2022-jp variants, namely x-windows-50220, + // x-windows-50221 and x-windows-iso2022jp which behaves "slightly" differently + // compared to the "standard based" implementation. See ISO2022_JP.java for + // detailed description. Users who prefer the behavior of MS iso-2022-jp + // variants should use these names explicitly instead of using "ISO-2022-JP" + // and its aliases. However for those who need the ISO-2022-JP charset behaves + // exactly the same as MS variants do, above properties can be defined to + // switch. + // + // If we need to define other charset-alias mappings in the future then + // this property could be further extended, the general idea being that its + // value should be of the form + // + // new-charset-1/old-charset-1,new-charset-2/old-charset-2,... + // + // where each charset named to the left of a slash is intended to replace + // (most) uses of the charset named to the right of the slash. + // + protected void init() { + if (initialized) + return; + if (!sun.misc.VM.isBooted()) + return; + + String map = getProperty("sun.nio.cs.map"); + boolean sjisIsMS932 = false; + boolean iso2022jpIsMS50221 = false; + boolean iso2022jpIsMS50220 = false; + boolean iso2022jpIsMSISO2022JP = false; + if (map != null) { + String[] maps = map.split(","); + for (int i = 0; i < maps.length; i++) { + if (maps[i].equalsIgnoreCase("Windows-31J/Shift_JIS")) { + sjisIsMS932 = true; + } else if (maps[i].equalsIgnoreCase("x-windows-50221/ISO-2022-JP")) { + iso2022jpIsMS50221 = true; + } else if (maps[i].equalsIgnoreCase("x-windows-50220/ISO-2022-JP")) { + iso2022jpIsMS50220 = true; + } else if (maps[i].equalsIgnoreCase("x-windows-iso2022jp/ISO-2022-JP")) { + iso2022jpIsMSISO2022JP = true; + } + } + } + if (sjisIsMS932 && hasCharset("Shift_JIS")) { + deleteCharset("Shift_JIS", + new String[] { + // IANA aliases + "sjis", // historical + "shift_jis", + "shift-jis", + "ms_kanji", + "x-sjis", + "csShiftJIS" + }); + deleteCharset("windows-31j", + new String[] { + "MS932", // JDK historical + "windows-932", + "csWindows31J" + }); + charset("Shift_JIS", "SJIS", + new String[] { + // IANA aliases + "sjis" // JDK historical + }); + charset("windows-31j", "MS932", + new String[] { + "MS932", // JDK historical + "windows-932", + "csWindows31J", + "shift-jis", + "ms_kanji", + "x-sjis", + "csShiftJIS", + // This alias takes precedence over the actual + // Shift_JIS charset itself since aliases are always + // resolved first, before looking up canonical names. + "shift_jis" + }); + } + if (iso2022jpIsMS50221 || + iso2022jpIsMS50220 || + iso2022jpIsMSISO2022JP) { + deleteCharset("ISO-2022-JP", + new String[] { + "iso2022jp", + "jis", + "csISO2022JP", + "jis_encoding", + "csjisencoding" + }); + if (iso2022jpIsMS50221) { + deleteCharset("x-windows-50221", + new String[] { + "cp50221", + "ms50221" + }); + charset("x-windows-50221", "MS50221", + new String[] { + "cp50221", + "ms50221", + "iso-2022-jp", + "iso2022jp", + "jis", + "csISO2022JP", + "jis_encoding", + "csjisencoding" + }); + } else if (iso2022jpIsMS50220) { + deleteCharset("x-windows-50220", + new String[] { + "cp50220", + "ms50220" + }); + charset("x-windows-50220", "MS50220", + new String[] { + "cp50220", + "ms50220", + "iso-2022-jp", + "iso2022jp", + "jis", + "csISO2022JP", + "jis_encoding", + "csjisencoding" + }); + } else { + deleteCharset("x-windows-iso2022jp", + new String[] { + "windows-iso2022jp" + }); + charset("x-windows-iso2022jp", "MSISO2022JP", + new String[] { + "windows-iso2022jp", + "iso-2022-jp", + "iso2022jp", + "jis", + "csISO2022JP", + "jis_encoding", + "csjisencoding" + }); + + + } + } + String osName = getProperty("os.name"); + if ("SunOS".equals(osName) || "Linux".equals(osName) || "AIX".equals(osName) + || osName.contains("OS X")) { + charset("x-COMPOUND_TEXT", "COMPOUND_TEXT", + new String[] { + "COMPOUND_TEXT", // JDK historical + "x11-compound_text", + "x-compound-text" + }); + } + initialized = true; + } + + private static String getProperty(String key) { + // this method may be called during initialization of + // system class loader and thus not using lambda + return AccessController.doPrivileged( + new PrivilegedAction() { + @Override + public String run() { + return System.getProperty(key); + } + }); + } + + public static String[] aliasesFor(String charsetName) { + if (instance == null) + return null; + return instance.aliases(charsetName); + } + +} diff --git a/jdk/src/jdk.charsets/share/classes/sun/nio/cs/ext/IBM834.java b/jdk/src/jdk.charsets/share/classes/sun/nio/cs/ext/IBM834.java index 8d54e9c9c97..513dc55f432 100644 --- a/jdk/src/jdk.charsets/share/classes/sun/nio/cs/ext/IBM834.java +++ b/jdk/src/jdk.charsets/share/classes/sun/nio/cs/ext/IBM834.java @@ -34,6 +34,7 @@ import java.nio.charset.Charset; import java.nio.charset.CharsetDecoder; import java.nio.charset.CharsetEncoder; import java.nio.charset.CoderResult; +import sun.nio.cs.DoubleByte; import static sun.nio.cs.CharsetMapping.*; // EBCDIC DBCS-only Korean diff --git a/jdk/src/jdk.charsets/share/classes/sun/nio/cs/ext/IBM942C.java b/jdk/src/jdk.charsets/share/classes/sun/nio/cs/ext/IBM942C.java index 0c631f6179a..2054609f5dc 100644 --- a/jdk/src/jdk.charsets/share/classes/sun/nio/cs/ext/IBM942C.java +++ b/jdk/src/jdk.charsets/share/classes/sun/nio/cs/ext/IBM942C.java @@ -29,6 +29,7 @@ import java.nio.charset.Charset; import java.nio.charset.CharsetDecoder; import java.nio.charset.CharsetEncoder; import java.util.Arrays; +import sun.nio.cs.DoubleByte; import sun.nio.cs.HistoricallyNamedCharset; import static sun.nio.cs.CharsetMapping.*; diff --git a/jdk/src/jdk.charsets/share/classes/sun/nio/cs/ext/IBM943C.java b/jdk/src/jdk.charsets/share/classes/sun/nio/cs/ext/IBM943C.java index b9d856a3b08..fefc9af4231 100644 --- a/jdk/src/jdk.charsets/share/classes/sun/nio/cs/ext/IBM943C.java +++ b/jdk/src/jdk.charsets/share/classes/sun/nio/cs/ext/IBM943C.java @@ -29,6 +29,7 @@ import java.nio.charset.Charset; import java.nio.charset.CharsetDecoder; import java.nio.charset.CharsetEncoder; import java.util.Arrays; +import sun.nio.cs.DoubleByte; import sun.nio.cs.HistoricallyNamedCharset; public class IBM943C extends Charset implements HistoricallyNamedCharset diff --git a/jdk/src/jdk.charsets/share/classes/sun/nio/cs/ext/IBM949C.java b/jdk/src/jdk.charsets/share/classes/sun/nio/cs/ext/IBM949C.java index a77fbfedddf..194b56719fd 100644 --- a/jdk/src/jdk.charsets/share/classes/sun/nio/cs/ext/IBM949C.java +++ b/jdk/src/jdk.charsets/share/classes/sun/nio/cs/ext/IBM949C.java @@ -29,6 +29,7 @@ import java.nio.charset.Charset; import java.nio.charset.CharsetDecoder; import java.nio.charset.CharsetEncoder; import java.util.Arrays; +import sun.nio.cs.DoubleByte; import sun.nio.cs.HistoricallyNamedCharset; public class IBM949C extends Charset implements HistoricallyNamedCharset diff --git a/jdk/src/jdk.charsets/share/classes/sun/nio/cs/ext/ISO2022_CN.java b/jdk/src/jdk.charsets/share/classes/sun/nio/cs/ext/ISO2022_CN.java index 3c7a7d47cd6..4041522754d 100644 --- a/jdk/src/jdk.charsets/share/classes/sun/nio/cs/ext/ISO2022_CN.java +++ b/jdk/src/jdk.charsets/share/classes/sun/nio/cs/ext/ISO2022_CN.java @@ -35,8 +35,10 @@ import java.nio.charset.CharsetDecoder; import java.nio.charset.CharsetEncoder; import java.nio.charset.CoderResult; import java.nio.charset.CharacterCodingException; +import sun.nio.cs.DoubleByte; import sun.nio.cs.HistoricallyNamedCharset; import sun.nio.cs.US_ASCII; +import sun.nio.cs.*; public class ISO2022_CN extends Charset diff --git a/jdk/src/jdk.charsets/share/classes/sun/nio/cs/ext/ISO2022_CN_GB.java b/jdk/src/jdk.charsets/share/classes/sun/nio/cs/ext/ISO2022_CN_GB.java index 518b7f7c500..1faaa537d7f 100644 --- a/jdk/src/jdk.charsets/share/classes/sun/nio/cs/ext/ISO2022_CN_GB.java +++ b/jdk/src/jdk.charsets/share/classes/sun/nio/cs/ext/ISO2022_CN_GB.java @@ -34,6 +34,7 @@ import java.nio.CharBuffer; import java.nio.charset.CharsetDecoder; import java.nio.charset.CharsetEncoder; import java.nio.charset.CoderResult; +import sun.nio.cs.*; import sun.nio.cs.HistoricallyNamedCharset; public class ISO2022_CN_GB extends ISO2022 implements HistoricallyNamedCharset diff --git a/jdk/src/jdk.charsets/share/classes/sun/nio/cs/ext/ISO2022_JP.java b/jdk/src/jdk.charsets/share/classes/sun/nio/cs/ext/ISO2022_JP.java index 40e9a1a7556..1125ffb7914 100644 --- a/jdk/src/jdk.charsets/share/classes/sun/nio/cs/ext/ISO2022_JP.java +++ b/jdk/src/jdk.charsets/share/classes/sun/nio/cs/ext/ISO2022_JP.java @@ -32,9 +32,12 @@ import java.nio.charset.CharsetDecoder; import java.nio.charset.CharsetEncoder; import java.nio.charset.CoderResult; import java.nio.charset.CodingErrorAction; +import sun.nio.cs.DelegatableDecoder; +import sun.nio.cs.DoubleByte; import sun.nio.cs.HistoricallyNamedCharset; import sun.nio.cs.Surrogate; import sun.nio.cs.US_ASCII; +import sun.nio.cs.*; import static sun.nio.cs.CharsetMapping.*; /* diff --git a/jdk/src/jdk.charsets/share/classes/sun/nio/cs/ext/ISO2022_JP_2.java b/jdk/src/jdk.charsets/share/classes/sun/nio/cs/ext/ISO2022_JP_2.java index 8d0d4e0bdaf..3a00b7480b5 100644 --- a/jdk/src/jdk.charsets/share/classes/sun/nio/cs/ext/ISO2022_JP_2.java +++ b/jdk/src/jdk.charsets/share/classes/sun/nio/cs/ext/ISO2022_JP_2.java @@ -28,6 +28,8 @@ package sun.nio.cs.ext; import java.nio.charset.Charset; import java.nio.charset.CharsetDecoder; import java.nio.charset.CharsetEncoder; +import sun.nio.cs.DoubleByte; +import sun.nio.cs.*; public class ISO2022_JP_2 extends ISO2022_JP { diff --git a/jdk/src/jdk.charsets/share/classes/sun/nio/cs/ext/ISO2022_KR.java b/jdk/src/jdk.charsets/share/classes/sun/nio/cs/ext/ISO2022_KR.java index 5385b05a2d4..6d96acde6f1 100644 --- a/jdk/src/jdk.charsets/share/classes/sun/nio/cs/ext/ISO2022_KR.java +++ b/jdk/src/jdk.charsets/share/classes/sun/nio/cs/ext/ISO2022_KR.java @@ -35,7 +35,7 @@ import java.nio.charset.CharsetDecoder; import java.nio.charset.CharsetEncoder; import java.nio.charset.CoderResult; import sun.nio.cs.HistoricallyNamedCharset; -import sun.nio.cs.ext.EUC_KR; +import sun.nio.cs.*; public class ISO2022_KR extends ISO2022 implements HistoricallyNamedCharset diff --git a/jdk/src/jdk.charsets/share/classes/sun/nio/cs/ext/JISAutoDetect.java b/jdk/src/jdk.charsets/share/classes/sun/nio/cs/ext/JISAutoDetect.java index a3bedd9ab8e..1219c4fda5b 100644 --- a/jdk/src/jdk.charsets/share/classes/sun/nio/cs/ext/JISAutoDetect.java +++ b/jdk/src/jdk.charsets/share/classes/sun/nio/cs/ext/JISAutoDetect.java @@ -33,9 +33,11 @@ import java.nio.charset.CharsetEncoder; import java.nio.charset.CoderResult; import java.nio.charset.CharacterCodingException; import java.nio.charset.MalformedInputException; +import sun.nio.cs.DelegatableDecoder; import sun.nio.cs.HistoricallyNamedCharset; import java.security.AccessController; import java.security.PrivilegedAction; +import sun.nio.cs.*; import static java.lang.Character.UnicodeBlock; diff --git a/jdk/src/jdk.charsets/share/classes/sun/nio/cs/ext/MS50220.java b/jdk/src/jdk.charsets/share/classes/sun/nio/cs/ext/MS50220.java index 9cb36f3a40d..2b18f7d419d 100644 --- a/jdk/src/jdk.charsets/share/classes/sun/nio/cs/ext/MS50220.java +++ b/jdk/src/jdk.charsets/share/classes/sun/nio/cs/ext/MS50220.java @@ -28,6 +28,8 @@ package sun.nio.cs.ext; import java.nio.charset.Charset; import java.nio.charset.CharsetDecoder; import java.nio.charset.CharsetEncoder; +import sun.nio.cs.DoubleByte; +import sun.nio.cs.*; public class MS50220 extends ISO2022_JP { diff --git a/jdk/src/jdk.charsets/share/classes/sun/nio/cs/ext/MS50221.java b/jdk/src/jdk.charsets/share/classes/sun/nio/cs/ext/MS50221.java index cdc1894406a..aaf052e106b 100644 --- a/jdk/src/jdk.charsets/share/classes/sun/nio/cs/ext/MS50221.java +++ b/jdk/src/jdk.charsets/share/classes/sun/nio/cs/ext/MS50221.java @@ -26,6 +26,7 @@ package sun.nio.cs.ext; import java.nio.charset.Charset; +import sun.nio.cs.*; public class MS50221 extends MS50220 { diff --git a/jdk/src/jdk.charsets/share/classes/sun/nio/cs/ext/MS932_0213.java b/jdk/src/jdk.charsets/share/classes/sun/nio/cs/ext/MS932_0213.java index 035ba6a34ba..4eb2ca4db3e 100644 --- a/jdk/src/jdk.charsets/share/classes/sun/nio/cs/ext/MS932_0213.java +++ b/jdk/src/jdk.charsets/share/classes/sun/nio/cs/ext/MS932_0213.java @@ -28,6 +28,8 @@ package sun.nio.cs.ext; import java.nio.charset.Charset; import java.nio.charset.CharsetEncoder; import java.nio.charset.CharsetDecoder; +import sun.nio.cs.DoubleByte; +import sun.nio.cs.*; import static sun.nio.cs.CharsetMapping.*; public class MS932_0213 extends Charset { diff --git a/jdk/src/jdk.charsets/share/classes/sun/nio/cs/ext/MS950_HKSCS.java b/jdk/src/jdk.charsets/share/classes/sun/nio/cs/ext/MS950_HKSCS.java index 505e4471910..bf7ff2bd20c 100644 --- a/jdk/src/jdk.charsets/share/classes/sun/nio/cs/ext/MS950_HKSCS.java +++ b/jdk/src/jdk.charsets/share/classes/sun/nio/cs/ext/MS950_HKSCS.java @@ -29,6 +29,7 @@ import java.nio.charset.Charset; import java.nio.charset.CharsetDecoder; import java.nio.charset.CharsetEncoder; import sun.nio.cs.HistoricallyNamedCharset; +import sun.nio.cs.*; import static sun.nio.cs.CharsetMapping.*; public class MS950_HKSCS extends Charset implements HistoricallyNamedCharset diff --git a/jdk/src/jdk.charsets/share/classes/sun/nio/cs/ext/MS950_HKSCS_XP.java b/jdk/src/jdk.charsets/share/classes/sun/nio/cs/ext/MS950_HKSCS_XP.java.template similarity index 96% rename from jdk/src/jdk.charsets/share/classes/sun/nio/cs/ext/MS950_HKSCS_XP.java rename to jdk/src/jdk.charsets/share/classes/sun/nio/cs/ext/MS950_HKSCS_XP.java.template index 2fddb927914..bc009b0a264 100644 --- a/jdk/src/jdk.charsets/share/classes/sun/nio/cs/ext/MS950_HKSCS_XP.java +++ b/jdk/src/jdk.charsets/share/classes/sun/nio/cs/ext/MS950_HKSCS_XP.java.template @@ -23,18 +23,20 @@ * questions. */ -package sun.nio.cs.ext; +package $PACKAGE$; import java.nio.charset.Charset; import java.nio.charset.CharsetDecoder; import java.nio.charset.CharsetEncoder; +import sun.nio.cs.DoubleByte; +import sun.nio.cs.HKSCS; import sun.nio.cs.HistoricallyNamedCharset; import static sun.nio.cs.CharsetMapping.*; public class MS950_HKSCS_XP extends Charset { public MS950_HKSCS_XP() { - super("x-MS950-HKSCS-XP", ExtendedCharsets.aliasesFor("x-MS950-HKSCS-XP")); + super("x-MS950-HKSCS-XP", $ALIASES$); } public boolean contains(Charset cs) { diff --git a/jdk/src/jdk.charsets/share/classes/sun/nio/cs/ext/MSISO2022JP.java b/jdk/src/jdk.charsets/share/classes/sun/nio/cs/ext/MSISO2022JP.java index 188116ed34e..0949960775d 100644 --- a/jdk/src/jdk.charsets/share/classes/sun/nio/cs/ext/MSISO2022JP.java +++ b/jdk/src/jdk.charsets/share/classes/sun/nio/cs/ext/MSISO2022JP.java @@ -28,6 +28,7 @@ package sun.nio.cs.ext; import java.nio.charset.Charset; import java.nio.charset.CharsetDecoder; import java.nio.charset.CharsetEncoder; +import sun.nio.cs.DoubleByte; public class MSISO2022JP extends ISO2022_JP { diff --git a/jdk/src/jdk.charsets/share/classes/sun/nio/cs/ext/SJIS_0213.java b/jdk/src/jdk.charsets/share/classes/sun/nio/cs/ext/SJIS_0213.java index 10fd8b726a6..9a6efd7ecf5 100644 --- a/jdk/src/jdk.charsets/share/classes/sun/nio/cs/ext/SJIS_0213.java +++ b/jdk/src/jdk.charsets/share/classes/sun/nio/cs/ext/SJIS_0213.java @@ -35,6 +35,7 @@ import java.security.AccessController; import java.security.PrivilegedAction; import java.util.Arrays; import sun.nio.cs.CharsetMapping; +import sun.nio.cs.*; /* * 5 types of entry in SJIS_X_0213/Unicode mapping table diff --git a/jdk/test/java/nio/charset/Charset/NIOCharsetAvailabilityTest.java b/jdk/test/java/nio/charset/Charset/NIOCharsetAvailabilityTest.java index a00cd804818..9b3e3a2597a 100644 --- a/jdk/test/java/nio/charset/Charset/NIOCharsetAvailabilityTest.java +++ b/jdk/test/java/nio/charset/Charset/NIOCharsetAvailabilityTest.java @@ -65,11 +65,17 @@ public class NIOCharsetAvailabilityTest { charsets.remove(Class.forName("sun.nio.cs.ext.ISO2022")); charsets.remove(Class.forName("sun.nio.cs.ext.ISO2022_CN_GB")); charsets.remove(Class.forName("sun.nio.cs.ext.ISO2022_CN_CNS")); - charsets.remove(Class.forName("sun.nio.cs.ext.JIS_X_0208_Solaris")); charsets.remove(Class.forName("sun.nio.cs.ext.JIS_X_0208_MS932")); charsets.remove(Class.forName("sun.nio.cs.ext.JIS_X_0212_MS5022X")); - charsets.remove(Class.forName("sun.nio.cs.ext.JIS_X_0212_Solaris")); charsets.remove(Class.forName("sun.nio.cs.ext.JIS_X_0208_MS5022X")); + try { + charsets.remove(Class.forName("sun.nio.cs.ext.JIS_X_0208_Solaris")); + charsets.remove(Class.forName("sun.nio.cs.ext.JIS_X_0212_Solaris")); + } catch (ClassNotFoundException x) { + // these two might be moved into stdcs + charsets.remove(Class.forName("sun.nio.cs.JIS_X_0208_Solaris")); + charsets.remove(Class.forName("sun.nio.cs.JIS_X_0212_Solaris")); + } // report the charsets that are implemented but not available iter = charsets.iterator(); From 0ad8cc755b88d8c531af4e963148d16299764867 Mon Sep 17 00:00:00 2001 From: Rob McKenna Date: Mon, 16 Feb 2015 22:57:17 +0000 Subject: [PATCH 100/116] 8067846: (sctp) InternalError when receiving SendFailedNotification Reviewed-by: chegar --- .../unix/native/libsctp/SctpChannelImpl.c | 7 +- .../nio/sctp/SctpMultiChannel/SendFailed.java | 189 ++++++++++++++++++ 2 files changed, 190 insertions(+), 6 deletions(-) create mode 100644 jdk/test/com/sun/nio/sctp/SctpMultiChannel/SendFailed.java diff --git a/jdk/src/jdk.sctp/unix/native/libsctp/SctpChannelImpl.c b/jdk/src/jdk.sctp/unix/native/libsctp/SctpChannelImpl.c index 2e8d1f9a59a..1e1b9f87685 100644 --- a/jdk/src/jdk.sctp/unix/native/libsctp/SctpChannelImpl.c +++ b/jdk/src/jdk.sctp/unix/native/libsctp/SctpChannelImpl.c @@ -1,5 +1,5 @@ /* - * Copyright (c) 2009, 2012, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2009, 2015, 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 @@ -464,11 +464,6 @@ JNIEXPORT jint JNICALL Java_sun_nio_ch_sctp_SctpChannelImpl_receive0 union sctp_notification *snp; jboolean allocated = JNI_FALSE; - if (rv > SCTP_NOTIFICATION_SIZE) { - JNU_ThrowInternalError(env, "should not reach here"); - return -1; - } - if (!(msg->msg_flags & MSG_EOR) && length < SCTP_NOTIFICATION_SIZE) { char* newBuf; int rvSAVE = rv; diff --git a/jdk/test/com/sun/nio/sctp/SctpMultiChannel/SendFailed.java b/jdk/test/com/sun/nio/sctp/SctpMultiChannel/SendFailed.java new file mode 100644 index 00000000000..18f7a4c7815 --- /dev/null +++ b/jdk/test/com/sun/nio/sctp/SctpMultiChannel/SendFailed.java @@ -0,0 +1,189 @@ +/* + * Copyright (c) 2015, 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. + */ + +/* @test + * @bug 8067846 + * @summary Test for send failed notification + */ + +import com.sun.nio.sctp.*; +import java.io.IOException; +import java.net.InetSocketAddress; +import java.net.SocketAddress; +import java.nio.ByteBuffer; +import static java.lang.System.out; +import static java.nio.ByteBuffer.*; + +public class SendFailed { + + static final SocketAddress remoteAddress = new InetSocketAddress("127.0.0.1", 3000); + + static final int[] bufferSizes = + { 20, 49, 50, 51, 100, 101, 1024, 1025, 4095, 4096, 4097, 8191, 8192, 8193}; + + void test(String[] args) throws IOException { + SocketAddress address = null; + + if (!Util.isSCTPSupported()) { + out.println("SCTP protocol is not supported"); + out.println("Test cannot be run"); + return; + } + + System.out.println("remote address: " + remoteAddress); + System.out.println("Note, remote address should not be up"); + + /* combinations with various buffer sizes, and offsets */ + for (int send=0; send < bufferSizes.length; send++) { + for (int recv=0; recv < bufferSizes.length; recv++) { + for (boolean direct : new boolean[] {true, false}) + runWithManyOffsets(bufferSizes[send], bufferSizes[recv], direct); + } + } + } + + void runWithManyOffsets(int sendBufferSize, int recvBufferSize, boolean direct) + throws IOException + { + doTest(sendBufferSize, recvBufferSize, direct, 0); + doTest(sendBufferSize, recvBufferSize, direct, 1); + doTest(sendBufferSize, recvBufferSize, direct, 3); + doTest(sendBufferSize, recvBufferSize, direct, 7); + doTest(sendBufferSize, recvBufferSize, direct, 9); + doTest(sendBufferSize, recvBufferSize, direct, 13); + doTest(sendBufferSize, recvBufferSize, direct, 15); + } + + void doTest(int sendBufferSize, int recvBufferSize, boolean direct, int offset) + throws IOException + { + debug("%n--- Testing with send size:[%d], recv size:[%d], offset:[%d] " + + ", direct [%s]. ", sendBufferSize, recvBufferSize, offset, direct); + + try (SctpMultiChannel channel = SctpMultiChannel.open()) { + MessageInfo messageInfo = MessageInfo.createOutgoing(remoteAddress, 0); + ByteBuffer sendBuffer = filledBuffer(sendBufferSize, direct); + + debug("%nAttempting to send to %s. ", remoteAddress); + int sent = channel.send(sendBuffer, messageInfo); + sendBuffer.flip(); + + SendFailedNotificationHandler handler = + new SendFailedNotificationHandler(); + ByteBuffer recvBuffer = direct ? allocateDirect(recvBufferSize) + : allocate((recvBufferSize)); + channel.receive(recvBuffer, null, handler); + + // verify sent buffer received by send failed notification + ByteBuffer buffer = handler.getSendFailedByteBuffer(); + check(buffer.remaining() == sent); + check(buffer.position() == 0); + check(buffer.limit() == sent); + assertSameContent(sendBuffer, handler.getSendFailedByteBuffer()); + } + } + + class SendFailedNotificationHandler extends AbstractNotificationHandler + { + /** Reference to the buffer captured in send failed notification */ + private ByteBuffer sentBuffer; + + @Override + public HandlerResult handleNotification( + Notification notification, Object attachment) { + fail("Unknown notification type"); + return HandlerResult.CONTINUE; + } + + @Override + public HandlerResult handleNotification( + AssociationChangeNotification notification, Object attachment) { + AssociationChangeNotification.AssocChangeEvent event = notification.event(); + debug("%nAssociationChangeNotification"); + debug("%n Association: %s. ", notification.association()); + debug("%n Event: %s. ", event); + return HandlerResult.CONTINUE; + } + + @Override + public HandlerResult handleNotification( + SendFailedNotification notification, Object attachment) { + debug("%nSendFailedNotification: %s. ", notification); + sentBuffer = notification.buffer(); + return HandlerResult.RETURN; + } + + public ByteBuffer getSendFailedByteBuffer() { + return sentBuffer; + } + + @Override + public HandlerResult handleNotification( + PeerAddressChangeNotification pacn, Object attachment) + { + debug("%nPeerAddressChangeNotification: %s", pacn); + return HandlerResult.CONTINUE; + } + + @Override + public HandlerResult handleNotification( + ShutdownNotification notification, Object attachment) { + debug("%nShutdownNotification"); + debug("%n Association: %s. ", notification.association()); + return HandlerResult.CONTINUE; + } + } + + static ByteBuffer filledBuffer(int size, boolean direct) { + ByteBuffer buffer = direct ? allocateDirect(size) : allocate((size)); + for (int i=0; i< size; i++) + buffer.put((byte)i); + buffer.flip(); + return buffer; + } + + static void assertSameContent(ByteBuffer bb1, ByteBuffer bb2) { + if (!bb1.equals(bb2)) + throw new RuntimeException("Buffers are not equal; bb1: " + bb1 + ", bb2: " + bb2); + } + + //--------------------- Infrastructure --------------------------- + boolean debug = true; + volatile int passed = 0, failed = 0; + void pass() {passed++;} + void fail() {failed++; Thread.dumpStack();} + void fail(String msg) {System.err.println(msg); fail();} + void unexpected(Throwable t) {failed++; t.printStackTrace();} + void check(boolean cond) {if (cond) pass(); else fail();} + void check(boolean cond, String failMessage) {if (cond) pass(); else fail(failMessage);} + void debug(String message, Object... args) {if(debug) { out.printf(message, args); } } + public static void main(String[] args) throws Throwable { + Class k = new Object(){}.getClass().getEnclosingClass(); + try {k.getMethod("instanceMain",String[].class) + .invoke( k.newInstance(), (Object) args);} + catch (Throwable e) {throw e.getCause();}} + public void instanceMain(String[] args) throws Throwable { + try {test(args);} catch (Throwable t) {unexpected(t);} + out.printf("%nPassed = %d, failed = %d%n%n", passed, failed); + if (failed > 0) throw new AssertionError("Some tests failed");} +} From a1d6f0cbcd836002dc869cdea2808d8b3826fc2b Mon Sep 17 00:00:00 2001 From: Lev Priima Date: Mon, 16 Feb 2015 19:16:50 -0500 Subject: [PATCH 101/116] 8073124: Tune test and document TimSort runs length stack size increase Reviewed-by: dholmes --- .../classes/java/util/ComparableTimSort.java | 4 ++++ .../share/classes/java/util/TimSort.java | 4 ++++ .../java/util/Arrays/TimSortStackSize2.java | 24 ++++++++++++------- 3 files changed, 24 insertions(+), 8 deletions(-) diff --git a/jdk/src/java.base/share/classes/java/util/ComparableTimSort.java b/jdk/src/java.base/share/classes/java/util/ComparableTimSort.java index 6237b3fd2e6..36c8d90f0f2 100644 --- a/jdk/src/java.base/share/classes/java/util/ComparableTimSort.java +++ b/jdk/src/java.base/share/classes/java/util/ComparableTimSort.java @@ -144,6 +144,10 @@ class ComparableTimSort { * large) stack lengths for smaller arrays. The "magic numbers" in the * computation below must be changed if MIN_MERGE is decreased. See * the MIN_MERGE declaration above for more information. + * The maximum value of 49 allows for an array up to length + * Integer.MAX_VALUE-4, if array is filled by the worst case stack size + * increasing scenario. More explanations are given in section 4 of: + * http://envisage-project.eu/wp-content/uploads/2015/02/sorting.pdf */ int stackLen = (len < 120 ? 5 : len < 1542 ? 10 : diff --git a/jdk/src/java.base/share/classes/java/util/TimSort.java b/jdk/src/java.base/share/classes/java/util/TimSort.java index af66d8092c5..ea0d58f5a85 100644 --- a/jdk/src/java.base/share/classes/java/util/TimSort.java +++ b/jdk/src/java.base/share/classes/java/util/TimSort.java @@ -174,6 +174,10 @@ class TimSort { * large) stack lengths for smaller arrays. The "magic numbers" in the * computation below must be changed if MIN_MERGE is decreased. See * the MIN_MERGE declaration above for more information. + * The maximum value of 49 allows for an array up to length + * Integer.MAX_VALUE-4, if array is filled by the worst case stack size + * increasing scenario. More explanations are given in section 4 of: + * http://envisage-project.eu/wp-content/uploads/2015/02/sorting.pdf */ int stackLen = (len < 120 ? 5 : len < 1542 ? 10 : diff --git a/jdk/test/java/util/Arrays/TimSortStackSize2.java b/jdk/test/java/util/Arrays/TimSortStackSize2.java index 86194320f59..c2971b14a6e 100644 --- a/jdk/test/java/util/Arrays/TimSortStackSize2.java +++ b/jdk/test/java/util/Arrays/TimSortStackSize2.java @@ -24,10 +24,10 @@ /* * @test * @bug 8072909 - * @run main/othervm TimSortStackSize2 67108864 + * @run main/othervm -Xmx385m TimSortStackSize2 67108864 * not for regular execution on all platforms: * run main/othervm -Xmx8g TimSortStackSize2 1073741824 - * run main/othervm -Xmx32g TimSortStackSize2 2147483644 + * run main/othervm -Xmx16g TimSortStackSize2 2147483644 * @summary Test TimSort stack size on big arrays */ import java.util.ArrayList; @@ -41,22 +41,30 @@ public class TimSortStackSize2 { int lengthOfTest = Integer.parseInt(args[0]); boolean passed = true; try { - Arrays.sort(new TimSortStackSize2(lengthOfTest).createArray(), - new Comparator() { + Integer [] a = new TimSortStackSize2(lengthOfTest).createArray(); + long begin = System.nanoTime(); + Arrays.sort(a, new Comparator() { @SuppressWarnings("unchecked") public int compare(Object first, Object second) { return ((Comparable)first).compareTo(second); } }); - System.out.println("TimSort OK"); + long end = System.nanoTime(); + System.out.println("TimSort: " + (end - begin)); + a = null; } catch (ArrayIndexOutOfBoundsException e){ - System.out.println("TimSort broken"); + System.out.println("TimSort broken:"); e.printStackTrace(); passed = false; } + try { - Arrays.sort(new TimSortStackSize2(lengthOfTest).createArray()); - System.out.println("ComparableTimSort OK"); + Integer [] a = new TimSortStackSize2(lengthOfTest).createArray(); + long begin = System.nanoTime(); + Arrays.sort(a); + long end = System.nanoTime(); + System.out.println("ComparableTimSort: " + (end - begin)); + a = null; } catch (ArrayIndexOutOfBoundsException e){ System.out.println("ComparableTimSort broken:"); e.printStackTrace(); From f9c63b42ed6286096b52644114352e512d1d37e4 Mon Sep 17 00:00:00 2001 From: Staffan Larsen Date: Tue, 17 Feb 2015 10:09:26 +0100 Subject: [PATCH 102/116] 8025636: Hide lambda proxy frames in stacktraces Reviewed-by: jrose, forax, jfranck, vlivanov --- .../invoke/InnerClassLambdaMetafactory.java | 2 + .../lang/invoke/lambda/LambdaStackTrace.java | 204 ++++++++++++++++++ 2 files changed, 206 insertions(+) create mode 100644 jdk/test/java/lang/invoke/lambda/LambdaStackTrace.java diff --git a/jdk/src/java.base/share/classes/java/lang/invoke/InnerClassLambdaMetafactory.java b/jdk/src/java.base/share/classes/java/lang/invoke/InnerClassLambdaMetafactory.java index 9d8db4eef78..421db68b464 100644 --- a/jdk/src/java.base/share/classes/java/lang/invoke/InnerClassLambdaMetafactory.java +++ b/jdk/src/java.base/share/classes/java/lang/invoke/InnerClassLambdaMetafactory.java @@ -285,6 +285,7 @@ import static jdk.internal.org.objectweb.asm.Opcodes.*; // Forward the SAM method MethodVisitor mv = cw.visitMethod(ACC_PUBLIC, samMethodName, samMethodType.toMethodDescriptorString(), null, null); + mv.visitAnnotation("Ljava/lang/invoke/LambdaForm$Hidden;", true); new ForwardingMethodGenerator(mv).generate(samMethodType); // Forward the bridges @@ -292,6 +293,7 @@ import static jdk.internal.org.objectweb.asm.Opcodes.*; for (MethodType mt : additionalBridges) { mv = cw.visitMethod(ACC_PUBLIC|ACC_BRIDGE, samMethodName, mt.toMethodDescriptorString(), null, null); + mv.visitAnnotation("Ljava/lang/invoke/LambdaForm$Hidden;", true); new ForwardingMethodGenerator(mv).generate(mt); } } diff --git a/jdk/test/java/lang/invoke/lambda/LambdaStackTrace.java b/jdk/test/java/lang/invoke/lambda/LambdaStackTrace.java new file mode 100644 index 00000000000..e2cdb7946a0 --- /dev/null +++ b/jdk/test/java/lang/invoke/lambda/LambdaStackTrace.java @@ -0,0 +1,204 @@ +/* + * Copyright (c) 2015, 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. + */ + +/* + * @test + * @bug 8025636 + * @summary Synthetic frames should be hidden in exceptions + * @compile -XDignore.symbol.file LUtils.java LambdaStackTrace.java + * @run main LambdaStackTrace + */ + +import jdk.internal.org.objectweb.asm.ClassWriter; + +import java.io.File; +import java.io.FileOutputStream; +import java.io.IOException; +import java.lang.reflect.InvocationTargetException; +import java.lang.reflect.Method; +import java.util.ArrayList; + +import static jdk.internal.org.objectweb.asm.Opcodes.ACC_ABSTRACT; +import static jdk.internal.org.objectweb.asm.Opcodes.ACC_INTERFACE; +import static jdk.internal.org.objectweb.asm.Opcodes.ACC_PUBLIC; +import static jdk.internal.org.objectweb.asm.Opcodes.V1_7; + +public class LambdaStackTrace { + + static File classes = new File(System.getProperty("test.classes")); + + public static void main(String[] args) throws Exception { + testBasic(); + testBridgeMethods(); + } + + /** + * Test the simple case + */ + private static void testBasic() throws Exception { + try { + Runnable r = () -> { + throw new RuntimeException(); + }; + r.run(); + } catch (Exception ex) { + // Before 8025636 the stacktrace would look like: + // at LambdaStackTrace.lambda$main$0(LambdaStackTrace.java:37) + // at LambdaStackTrace$$Lambda$1/1937396743.run(:1000000) + // at LambdaStackTrace.testBasic(LambdaStackTrace.java:40) + // at ... + // + // We are verifying that the middle frame above is gone. + + verifyFrames(ex.getStackTrace(), + "LambdaStackTrace\\..*", + "LambdaStackTrace.testBasic"); + } + } + + /** + * Test the more complicated case with bridge methods. + * + * We set up the following interfaces: + * + * interface Maker { + * Object make(); + * } + * interface StringMaker extends Maker { + * String make(); + * } + * + * And we will use them like so: + * + * StringMaker sm = () -> { throw new RuntimeException(); }; + * sm.make(); + * ((Maker)m).make(); + * + * The first call is a "normal" interface call, the second will use a + * bridge method. In both cases the generated lambda frame should + * be removed from the stack trace. + */ + private static void testBridgeMethods() throws Exception { + // setup + generateInterfaces(); + compileCaller(); + + // test + StackTraceElement[] frames = call("Caller", "callStringMaker"); + verifyFrames(frames, + "Caller\\..*", + "Caller.callStringMaker"); + + frames = call("Caller", "callMaker"); + verifyFrames(frames, + "Caller\\..*", + "Caller.callMaker"); + } + + private static void generateInterfaces() throws IOException { + // We can't let javac compile these interfaces because in > 1.8 it will insert + // bridge methods into the interfaces - we want code that looks like <= 1.7, + // so we generate it. + try (FileOutputStream fw = new FileOutputStream(new File(classes, "Maker.class"))) { + fw.write(generateMaker()); + } + try (FileOutputStream fw = new FileOutputStream(new File(classes, "StringMaker.class"))) { + fw.write(generateStringMaker()); + } + } + + private static byte[] generateMaker() { + // interface Maker { + // Object make(); + // } + ClassWriter cw = new ClassWriter(0); + cw.visit(V1_7, ACC_INTERFACE | ACC_ABSTRACT, "Maker", null, "java/lang/Object", null); + cw.visitMethod(ACC_PUBLIC | ACC_ABSTRACT, "make", + "()Ljava/lang/Object;", null, null); + cw.visitEnd(); + return cw.toByteArray(); + } + + private static byte[] generateStringMaker() { + // interface StringMaker extends Maker { + // String make(); + // } + ClassWriter cw = new ClassWriter(0); + cw.visit(V1_7, ACC_INTERFACE | ACC_ABSTRACT, "StringMaker", null, "java/lang/Object", new String[]{"Maker"}); + cw.visitMethod(ACC_PUBLIC | ACC_ABSTRACT, "make", + "()Ljava/lang/String;", null, null); + cw.visitEnd(); + return cw.toByteArray(); + } + + + static void emitCode(File f) { + ArrayList scratch = new ArrayList<>(); + scratch.add("public class Caller {"); + scratch.add(" public static void callStringMaker() {"); + scratch.add(" StringMaker sm = () -> { throw new RuntimeException(); };"); + scratch.add(" sm.make();"); + scratch.add(" }"); + scratch.add(" public static void callMaker() {"); + scratch.add(" StringMaker sm = () -> { throw new RuntimeException(); };"); + scratch.add(" ((Maker) sm).make();"); // <-- This will call the bridge method + scratch.add(" }"); + scratch.add("}"); + LUtils.createFile(f, scratch); + } + + static void compileCaller() { + File caller = new File(classes, "Caller.java"); + emitCode(caller); + LUtils.compile("-cp", classes.getAbsolutePath(), "-d", classes.getAbsolutePath(), caller.getAbsolutePath()); + } + + private static void verifyFrames(StackTraceElement[] stack, String... patterns) throws Exception { + for (int i = 0; i < patterns.length; i++) { + String cm = stack[i].getClassName() + "." + stack[i].getMethodName(); + if (!cm.matches(patterns[i])) { + System.err.println("Actual trace did not match expected trace at frame " + i); + System.err.println("Expected frame patterns:"); + for (int j = 0; j < patterns.length; j++) { + System.err.println(" " + j + ": " + patterns[j]); + } + System.err.println("Actual frames:"); + for (int j = 0; j < patterns.length; j++) { + System.err.println(" " + j + ": " + stack[j]); + } + throw new Exception("Incorrect stack frames found"); + } + } + } + + private static StackTraceElement[] call(String clazz, String method) throws Exception { + Class c = Class.forName(clazz); + try { + Method m = c.getDeclaredMethod(method); + m.invoke(null); + } catch(InvocationTargetException ex) { + return ex.getTargetException().getStackTrace(); + } + throw new Exception("Expected exception to be thrown"); + } +} From d2719e8bdf037151882d66d72eba5b9570d1cbeb Mon Sep 17 00:00:00 2001 From: Erik Joelsson Date: Tue, 17 Feb 2015 16:53:41 +0100 Subject: [PATCH 103/116] 8072950: api/xinclude/Harold/harold-97.html\#harold-97, api/xinclude/Harold/harold-67.html\#harold-67 fails on solaris with build port-stage-aarch64 Reviewed-by: tbell --- make/common/JavaCompilation.gmk | 6 +++++- 1 file changed, 5 insertions(+), 1 deletion(-) diff --git a/make/common/JavaCompilation.gmk b/make/common/JavaCompilation.gmk index 77f95d6a5f5..38b2cb1173b 100644 --- a/make/common/JavaCompilation.gmk +++ b/make/common/JavaCompilation.gmk @@ -362,6 +362,10 @@ endef # This is the new clean standard. Though it is to be superseded by # a standard annotation processor from with sjavac. # +# An empty echo ensures that the input to sed always ends with a newline. +# Certain implementations (e.g. Solaris) will skip the last line without +# it. +# # The sed expression does this: # 1. Add a backslash before any :, = or ! that do not have a backslash already. # 2. Apply the file unicode2x.sed which does a whole bunch of \u00XX to \xXX @@ -384,7 +388,7 @@ define add_file_to_clean # Now we can setup the depency that will trigger the copying. $$($1_BIN)$$($2_TARGET) : $2 $(MKDIR) -p $$(@D) - export LC_ALL=C ; $(CAT) $$< \ + export LC_ALL=C ; ( $(CAT) $$< && $(ECHO) "" ) \ | $(SED) -e 's/\([^\\]\):/\1\\:/g' -e 's/\([^\\]\)=/\1\\=/g' \ -e 's/\([^\\]\)!/\1\\!/g' -e 's/#.*/#/g' \ | $(SED) -f "$(SRC_ROOT)/make/common/support/unicode2x.sed" \ From 2b1139db7cb7e795bc85faddb044bda3ba0296a4 Mon Sep 17 00:00:00 2001 From: Brian Burkhalter Date: Tue, 17 Feb 2015 09:18:27 -0800 Subject: [PATCH 104/116] 8073207: javadoc typos in java.nio.channels.Pipe Correct the verbiage as suggested. Reviewed-by: alanb --- jdk/src/java.base/share/classes/java/nio/channels/Pipe.java | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/jdk/src/java.base/share/classes/java/nio/channels/Pipe.java b/jdk/src/java.base/share/classes/java/nio/channels/Pipe.java index d7046808ffe..f707de5d79f 100644 --- a/jdk/src/java.base/share/classes/java/nio/channels/Pipe.java +++ b/jdk/src/java.base/share/classes/java/nio/channels/Pipe.java @@ -35,7 +35,7 @@ import java.nio.channels.spi.*; *

A pipe consists of a pair of channels: A writable {@link * Pipe.SinkChannel sink} channel and a readable {@link Pipe.SourceChannel source} * channel. Once some bytes are written to the sink channel they can be read - * from source channel in exactlyAthe order in which they were written. + * from the source channel in exactly the order in which they were written. * *

Whether or not a thread writing bytes to a pipe will block until another * thread reads those bytes, or some previously-written bytes, from the pipe is From f7f4ab9df61d47e672c19d6cb6ddf170086e21c7 Mon Sep 17 00:00:00 2001 From: Jason Uh Date: Tue, 17 Feb 2015 10:48:24 -0800 Subject: [PATCH 105/116] 8042967: Add variant of DSA Signature algorithms that do not ASN.1 encode the signature bytes Reviewed-by: mullan --- .../classes/sun/security/provider/DSA.java | 177 +++++++++-- .../sun/security/provider/SunEntries.java | 11 +- .../util/DisabledAlgorithmConstraints.java | 5 +- .../dsig/internal/dom/DOMSignatureMethod.java | 297 +++++++++++++++--- .../sun/security/ec/ECDSASignature.java | 121 ++++++- .../classes/sun/security/ec/SunECEntries.java | 15 +- .../sun/security/pkcs11/P11Signature.java | 63 +++- .../sun/security/pkcs11/SunPKCS11.java | 25 +- .../sun/security/pkcs11/ec/TestECDSA.java | 35 ++- .../sun/security/provider/DSA/TestDSA2.java | 29 +- 10 files changed, 643 insertions(+), 135 deletions(-) diff --git a/jdk/src/java.base/share/classes/sun/security/provider/DSA.java b/jdk/src/java.base/share/classes/sun/security/provider/DSA.java index 66b83ad83bc..6f8c27a38c0 100644 --- a/jdk/src/java.base/share/classes/sun/security/provider/DSA.java +++ b/jdk/src/java.base/share/classes/sun/security/provider/DSA.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 1996, 2014, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 1996, 2015, 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 @@ -33,14 +33,11 @@ import java.nio.ByteBuffer; import java.security.*; import java.security.SecureRandom; import java.security.interfaces.*; -import java.security.spec.DSAParameterSpec; -import java.security.spec.InvalidParameterSpecException; import sun.security.util.Debug; import sun.security.util.DerValue; import sun.security.util.DerInputStream; import sun.security.util.DerOutputStream; -import sun.security.x509.AlgIdDSA; import sun.security.jca.JCAUtil; /** @@ -85,13 +82,28 @@ abstract class DSA extends SignatureSpi { /* The message digest object used */ private final MessageDigest md; + /* The format. true for the IEEE P1363 format. false (default) for ASN.1 */ + private final boolean p1363Format; + /** * Construct a blank DSA object. It must be * initialized before being usable for signing or verifying. */ DSA(MessageDigest md) { + this(md, false); + } + + /** + * Construct a blank DSA object that will use the specified + * signature format. {@code p1363Format} should be {@code true} to + * use the IEEE P1363 format. If {@code p1363Format} is {@code false}, + * the DER-encoded ASN.1 format will used. The DSA object must be + * initialized before being usable for signing or verifying. + */ + DSA(MessageDigest md, boolean p1363Format) { super(); this.md = md; + this.p1363Format = p1363Format; } /** @@ -178,12 +190,16 @@ abstract class DSA extends SignatureSpi { /** - * Sign all the data thus far updated. The signature is formatted + * Sign all the data thus far updated. The signature format is + * determined by {@code p1363Format}. If {@code p1363Format} is + * {@code false} (the default), then the signature is formatted * according to the Canonical Encoding Rules, returned as a DER - * sequence of Integer, r and s. + * sequence of Integers, r and s. If {@code p1363Format} is + * {@code false}, the signature is returned in the IEEE P1363 + * format, which is the concatenation or r and s. * - * @return a signature block formatted according to the Canonical - * Encoding Rules. + * @return a signature block formatted according to the format + * indicated by {@code p1363Format} * * @exception SignatureException if the signature object was not * properly initialized, or if another exception occurs. @@ -196,24 +212,48 @@ abstract class DSA extends SignatureSpi { BigInteger r = generateR(presetP, presetQ, presetG, k); BigInteger s = generateS(presetX, presetQ, r, k); - try { - DerOutputStream outseq = new DerOutputStream(100); - outseq.putInteger(r); - outseq.putInteger(s); - DerValue result = new DerValue(DerValue.tag_Sequence, - outseq.toByteArray()); + if (p1363Format) { + // Return the concatenation of r and s + byte[] rBytes = r.toByteArray(); + byte[] sBytes = s.toByteArray(); - return result.toByteArray(); + int size = presetQ.bitLength() / 8; + byte[] outseq = new byte[size * 2]; - } catch (IOException e) { - throw new SignatureException("error encoding signature"); + int rLength = rBytes.length; + int sLength = sBytes.length; + int i; + for (i = rLength; i > 0 && rBytes[rLength - i] == 0; i--); + + int j; + for (j = sLength; + j > 0 && sBytes[sLength - j] == 0; j--); + + System.arraycopy(rBytes, rLength - i, outseq, size - i, i); + System.arraycopy(sBytes, sLength - j, outseq, size * 2 - j, j); + + return outseq; + } else { + // Return the DER-encoded ASN.1 form + try { + DerOutputStream outseq = new DerOutputStream(100); + outseq.putInteger(r); + outseq.putInteger(s); + DerValue result = new DerValue(DerValue.tag_Sequence, + outseq.toByteArray()); + + return result.toByteArray(); + + } catch (IOException e) { + throw new SignatureException("error encoding signature"); + } } } /** * Verify all the data thus far updated. * - * @param signature the alledged signature, encoded using the + * @param signature the alleged signature, encoded using the * Canonical Encoding Rules, as a sequence of integers, r and s. * * @exception SignatureException if the signature object was not @@ -230,8 +270,13 @@ abstract class DSA extends SignatureSpi { /** * Verify all the data thus far updated. * - * @param signature the alledged signature, encoded using the - * Canonical Encoding Rules, as a sequence of integers, r and s. + * @param signature the alleged signature, encoded using the + * format indicated by {@code p1363Format}. If {@code p1363Format} + * is {@code false} (the default), then the signature is formatted + * according to the Canonical Encoding Rules, as a DER sequence of + * Integers, r and s. If {@code p1363Format} is {@code false}, + * the signature is in the IEEE P1363 format, which is the + * concatenation or r and s. * * @param offset the offset to start from in the array of bytes. * @@ -248,16 +293,28 @@ abstract class DSA extends SignatureSpi { BigInteger r = null; BigInteger s = null; - // first decode the signature. - try { - DerInputStream in = new DerInputStream(signature, offset, length); - DerValue[] values = in.getSequence(2); - r = values[0].getBigInteger(); - s = values[1].getBigInteger(); + if (p1363Format) { + if ((length & 1) == 1) { + // length of signature byte array should be even + throw new SignatureException("invalid signature format"); + } + int mid = length/2; + r = new BigInteger(Arrays.copyOfRange(signature, 0, mid)); + s = new BigInteger(Arrays.copyOfRange(signature, mid, length)); + } else { + // first decode the signature. + try { + DerInputStream in = new DerInputStream(signature, offset, + length); + DerValue[] values = in.getSequence(2); - } catch (IOException e) { - throw new SignatureException("invalid encoding for signature"); + r = values[0].getBigInteger(); + s = values[1].getBigInteger(); + + } catch (IOException e) { + throw new SignatureException("invalid encoding for signature"); + } } // some implementations do not correctly encode values in the ASN.1 @@ -420,6 +477,15 @@ abstract class DSA extends SignatureSpi { } } + /** + * SHA224withDSA implementation that uses the IEEE P1363 format. + */ + public static final class SHA224withDSAinP1363Format extends DSA { + public SHA224withDSAinP1363Format() throws NoSuchAlgorithmException { + super(MessageDigest.getInstance("SHA-224"), true); + } + } + /** * Standard SHA256withDSA implementation as defined in FIPS186-3. */ @@ -429,6 +495,15 @@ abstract class DSA extends SignatureSpi { } } + /** + * SHA256withDSA implementation that uses the IEEE P1363 format. + */ + public static final class SHA256withDSAinP1363Format extends DSA { + public SHA256withDSAinP1363Format() throws NoSuchAlgorithmException { + super(MessageDigest.getInstance("SHA-256"), true); + } + } + static class LegacyDSA extends DSA { /* The random seed used to generate k */ private int[] kSeed; @@ -441,7 +516,12 @@ abstract class DSA extends SignatureSpi { private int[] kSeedLast; public LegacyDSA(MessageDigest md) throws NoSuchAlgorithmException { - super(md); + this(md, false); + } + + private LegacyDSA(MessageDigest md, boolean p1363Format) + throws NoSuchAlgorithmException { + super(md, p1363Format); } @Deprecated @@ -636,6 +716,9 @@ abstract class DSA extends SignatureSpi { } } + /** + * Standard SHA1withDSA implementation. + */ public static final class SHA1withDSA extends LegacyDSA { public SHA1withDSA() throws NoSuchAlgorithmException { super(MessageDigest.getInstance("SHA-1")); @@ -643,13 +726,22 @@ abstract class DSA extends SignatureSpi { } /** - * RawDSA implementation. + * SHA1withDSA implementation that uses the IEEE P1363 format. + */ + public static final class SHA1withDSAinP1363Format extends LegacyDSA { + public SHA1withDSAinP1363Format() throws NoSuchAlgorithmException { + super(MessageDigest.getInstance("SHA-1"), true); + } + } + + /** + * Raw DSA. * - * RawDSA requires the data to be exactly 20 bytes long. If it is + * Raw DSA requires the data to be exactly 20 bytes long. If it is * not, a SignatureException is thrown when sign()/verify() is called * per JCA spec. */ - public static final class RawDSA extends LegacyDSA { + static class Raw extends LegacyDSA { // Internal special-purpose MessageDigest impl for RawDSA // Only override whatever methods used // NOTE: no clone support @@ -719,8 +811,27 @@ abstract class DSA extends SignatureSpi { } } + private Raw(boolean p1363Format) throws NoSuchAlgorithmException { + super(new NullDigest20(), p1363Format); + } + + } + + /** + * Standard Raw DSA implementation. + */ + public static final class RawDSA extends Raw { public RawDSA() throws NoSuchAlgorithmException { - super(new NullDigest20()); + super(false); + } + } + + /** + * Raw DSA implementation that uses the IEEE P1363 format. + */ + public static final class RawDSAinP1363Format extends Raw { + public RawDSAinP1363Format() throws NoSuchAlgorithmException { + super(true); } } } diff --git a/jdk/src/java.base/share/classes/sun/security/provider/SunEntries.java b/jdk/src/java.base/share/classes/sun/security/provider/SunEntries.java index 93e31a6faaf..c496910f7c9 100644 --- a/jdk/src/java.base/share/classes/sun/security/provider/SunEntries.java +++ b/jdk/src/java.base/share/classes/sun/security/provider/SunEntries.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 1996, 2014, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 1996, 2015, 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 @@ -130,6 +130,15 @@ final class SunEntries { map.put("Signature.SHA256withDSA", "sun.security.provider.DSA$SHA256withDSA"); + map.put("Signature.SHA1withDSAinP1363Format", + "sun.security.provider.DSA$SHA1withDSAinP1363Format"); + map.put("Signature.NONEwithDSAinP1363Format", + "sun.security.provider.DSA$RawDSAinP1363Format"); + map.put("Signature.SHA224withDSAinP1363Format", + "sun.security.provider.DSA$SHA224withDSAinP1363Format"); + map.put("Signature.SHA256withDSAinP1363Format", + "sun.security.provider.DSA$SHA256withDSAinP1363Format"); + String dsaKeyClasses = "java.security.interfaces.DSAPublicKey" + "|java.security.interfaces.DSAPrivateKey"; map.put("Signature.SHA1withDSA SupportedKeyClasses", dsaKeyClasses); diff --git a/jdk/src/java.base/share/classes/sun/security/util/DisabledAlgorithmConstraints.java b/jdk/src/java.base/share/classes/sun/security/util/DisabledAlgorithmConstraints.java index 17b56974ea3..94df91fe7f9 100644 --- a/jdk/src/java.base/share/classes/sun/security/util/DisabledAlgorithmConstraints.java +++ b/jdk/src/java.base/share/classes/sun/security/util/DisabledAlgorithmConstraints.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2010, 2012, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2010, 2015, 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 @@ -171,8 +171,9 @@ public class DisabledAlgorithmConstraints implements AlgorithmConstraints { // OAEPWithAndPadding // with // withand + // within Pattern pattern = - Pattern.compile("with|and", Pattern.CASE_INSENSITIVE); + Pattern.compile("with|and|in", Pattern.CASE_INSENSITIVE); String[] tokens = pattern.split(transTocken); for (String token : tokens) { diff --git a/jdk/src/java.xml.crypto/share/classes/org/jcp/xml/dsig/internal/dom/DOMSignatureMethod.java b/jdk/src/java.xml.crypto/share/classes/org/jcp/xml/dsig/internal/dom/DOMSignatureMethod.java index bb615d2b24b..9e367695d61 100644 --- a/jdk/src/java.xml.crypto/share/classes/org/jcp/xml/dsig/internal/dom/DOMSignatureMethod.java +++ b/jdk/src/java.xml.crypto/share/classes/org/jcp/xml/dsig/internal/dom/DOMSignatureMethod.java @@ -21,7 +21,7 @@ * under the License. */ /* - * Copyright (c) 2005, 2014, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2005, 2015, Oracle and/or its affiliates. All rights reserved. */ /* * $Id: DOMSignatureMethod.java 1333415 2012-05-03 12:03:51Z coheigea $ @@ -111,6 +111,34 @@ public abstract class DOMSignatureMethod extends AbstractDOMSignatureMethod { } } + /** + * Returns the signature bytes with any additional formatting + * necessary for the signature algorithm used. For RSA signatures, + * no changes are required, and this method should simply return + * back {@code sig}. For DSA and ECDSA, this method should return the + * signature in the IEEE P1363 format, the concatenation of r and s. + * + * @param key the key used to sign + * @param sig the signature returned by {@code Signature.sign()} + * @return the formatted signature + * @throws IOException + */ + abstract byte[] postSignFormat(Key key, byte[] sig) throws IOException; + + /** + * Returns the signature bytes with any conversions that are necessary + * before the signature can be verified. For RSA signatures, + * no changes are required, and this method should simply + * return back {@code sig}. For DSA and ECDSA, this method should + * return the signature in the DER-encoded ASN.1 format. + * + * @param key the key used to sign + * @param sig the signature + * @return the formatted signature + * @throws IOException + */ + abstract byte[] preVerifyFormat(Key key, byte[] sig) throws IOException; + static SignatureMethod unmarshal(Element smElem) throws MarshalException { String alg = DOMUtils.getAttributeValue(smElem, "Algorithm"); if (alg.equals(SignatureMethod.RSA_SHA1)) { @@ -151,6 +179,23 @@ public abstract class DOMSignatureMethod extends AbstractDOMSignatureMethod { return params; } + /** + * Returns an instance of Signature from the specified Provider. + * The algorithm is specified by the {@code getJCAAlgorithm()} method. + * + * @param p the Provider to use + * @return an instance of Signature implementing the algorithm + * specified by {@code getJCAAlgorithm()} + * @throws NoSuchAlgorithmException if the Provider does not support the + * signature algorithm + */ + Signature getSignature(Provider p) + throws NoSuchAlgorithmException { + return (p == null) + ? Signature.getInstance(getJCAAlgorithm()) + : Signature.getInstance(getJCAAlgorithm(), p); + } + boolean verify(Key key, SignedInfo si, byte[] sig, XMLValidateContext context) throws InvalidKeyException, SignatureException, XMLSignatureException @@ -163,38 +208,30 @@ public abstract class DOMSignatureMethod extends AbstractDOMSignatureMethod { throw new InvalidKeyException("key must be PublicKey"); } if (signature == null) { + Provider p = (Provider)context.getProperty( + "org.jcp.xml.dsig.internal.dom.SignatureProvider"); try { - Provider p = (Provider)context.getProperty - ("org.jcp.xml.dsig.internal.dom.SignatureProvider"); - signature = (p == null) - ? Signature.getInstance(getJCAAlgorithm()) - : Signature.getInstance(getJCAAlgorithm(), p); + signature = getSignature(p); } catch (NoSuchAlgorithmException nsae) { throw new XMLSignatureException(nsae); } } signature.initVerify((PublicKey)key); if (log.isLoggable(java.util.logging.Level.FINE)) { - log.log(java.util.logging.Level.FINE, "Signature provider:" + signature.getProvider()); + log.log(java.util.logging.Level.FINE, + "Signature provider:" + signature.getProvider()); log.log(java.util.logging.Level.FINE, "verifying with key: " + key); } ((DOMSignedInfo)si).canonicalize(context, new SignerOutputStream(signature)); - + byte[] s; try { - Type type = getAlgorithmType(); - if (type == Type.DSA) { - int size = ((DSAKey)key).getParams().getQ().bitLength(); - return signature.verify(JavaUtils.convertDsaXMLDSIGtoASN1(sig, - size/8)); - } else if (type == Type.ECDSA) { - return signature.verify(SignatureECDSA.convertXMLDSIGtoASN1(sig)); - } else { - return signature.verify(sig); - } + // Do any necessary format conversions + s = preVerifyFormat(key, sig); } catch (IOException ioe) { throw new XMLSignatureException(ioe); } + return signature.verify(s); } byte[] sign(Key key, SignedInfo si, XMLSignContext context) @@ -208,19 +245,18 @@ public abstract class DOMSignatureMethod extends AbstractDOMSignatureMethod { throw new InvalidKeyException("key must be PrivateKey"); } if (signature == null) { + Provider p = (Provider)context.getProperty( + "org.jcp.xml.dsig.internal.dom.SignatureProvider"); try { - Provider p = (Provider)context.getProperty - ("org.jcp.xml.dsig.internal.dom.SignatureProvider"); - signature = (p == null) - ? Signature.getInstance(getJCAAlgorithm()) - : Signature.getInstance(getJCAAlgorithm(), p); + signature = getSignature(p); } catch (NoSuchAlgorithmException nsae) { throw new XMLSignatureException(nsae); } } signature.initSign((PrivateKey)key); if (log.isLoggable(java.util.logging.Level.FINE)) { - log.log(java.util.logging.Level.FINE, "Signature provider:" + signature.getProvider()); + log.log(java.util.logging.Level.FINE, + "Signature provider:" + signature.getProvider()); log.log(java.util.logging.Level.FINE, "Signing with key: " + key); } @@ -228,24 +264,171 @@ public abstract class DOMSignatureMethod extends AbstractDOMSignatureMethod { new SignerOutputStream(signature)); try { - Type type = getAlgorithmType(); - if (type == Type.DSA) { - int size = ((DSAKey)key).getParams().getQ().bitLength(); - return JavaUtils.convertDsaASN1toXMLDSIG(signature.sign(), - size/8); - } else if (type == Type.ECDSA) { - return SignatureECDSA.convertASN1toXMLDSIG(signature.sign()); - } else { - return signature.sign(); - } - } catch (SignatureException se) { - throw new XMLSignatureException(se); - } catch (IOException ioe) { - throw new XMLSignatureException(ioe); + // Return signature with any necessary format conversions + return postSignFormat(key, signature.sign()); + } catch (SignatureException | IOException ex){ + throw new XMLSignatureException(ex); } } - static final class SHA1withRSA extends DOMSignatureMethod { + abstract static class AbstractRSASignatureMethod + extends DOMSignatureMethod { + + AbstractRSASignatureMethod(AlgorithmParameterSpec params) + throws InvalidAlgorithmParameterException { + super(params); + } + + AbstractRSASignatureMethod(Element dmElem) throws MarshalException { + super(dmElem); + } + + /** + * Returns {@code sig}. No extra formatting is necessary for RSA. + */ + @Override + byte[] postSignFormat(Key key, byte[] sig) { + return sig; + } + + /** + * Returns {@code sig}. No extra formatting is necessary for RSA. + */ + @Override + byte[] preVerifyFormat(Key key, byte[] sig) { + return sig; + } + } + + /** + * Abstract class to support signature algorithms that sign and verify + * signatures in the IEEE P1363 format. The P1363 format is the + * concatenation of r and s in DSA and ECDSA signatures, and thus, only + * DSA and ECDSA signature methods should extend this class. Subclasses + * must supply a fallback algorithm to be used when the provider does + * not offer signature algorithms that use the P1363 format. + */ + abstract static class AbstractP1363FormatSignatureMethod + extends DOMSignatureMethod { + + /* Set to true when the fallback algorithm is used */ + boolean asn1; + + AbstractP1363FormatSignatureMethod(AlgorithmParameterSpec params) + throws InvalidAlgorithmParameterException { + super(params); + } + + AbstractP1363FormatSignatureMethod(Element dmElem) + throws MarshalException { + super(dmElem); + } + + /** + * Return the fallback algorithm to be used when the provider does not + * support signatures in the IEEE P1363 format. This algorithm should + * return signatures in the DER-encoded ASN.1 format. + */ + abstract String getJCAFallbackAlgorithm(); + + /* + * Try to return an instance of Signature implementing signatures + * in the IEEE P1363 format. If the provider doesn't support the + * P1363 format, return an instance of Signature implementing + * signatures in the DER-encoded ASN.1 format. + */ + @Override + Signature getSignature(Provider p) + throws NoSuchAlgorithmException { + try { + return (p == null) + ? Signature.getInstance(getJCAAlgorithm()) + : Signature.getInstance(getJCAAlgorithm(), p); + } catch (NoSuchAlgorithmException nsae) { + Signature s = (p == null) + ? Signature.getInstance(getJCAFallbackAlgorithm()) + : Signature.getInstance(getJCAFallbackAlgorithm(), p); + asn1 = true; + return s; + } + } + } + + abstract static class AbstractDSASignatureMethod + extends AbstractP1363FormatSignatureMethod { + + AbstractDSASignatureMethod(AlgorithmParameterSpec params) + throws InvalidAlgorithmParameterException { + super(params); + } + + AbstractDSASignatureMethod(Element dmElem) throws MarshalException { + super(dmElem); + } + + @Override + byte[] postSignFormat(Key key, byte[] sig) throws IOException { + // If signature is in ASN.1 (i.e., if the fallback algorithm + // was used), convert the signature to the P1363 format + if (asn1) { + int size = ((DSAKey) key).getParams().getQ().bitLength(); + return JavaUtils.convertDsaASN1toXMLDSIG(sig, size / 8); + } else { + return sig; + } + } + + @Override + byte[] preVerifyFormat(Key key, byte[] sig) throws IOException { + // If signature needs to be in ASN.1 (i.e., if the fallback + // algorithm will be used to verify the sig), convert the signature + // to the ASN.1 format + if (asn1) { + int size = ((DSAKey) key).getParams().getQ().bitLength(); + return JavaUtils.convertDsaXMLDSIGtoASN1(sig, size / 8); + } else { + return sig; + } + } + } + + abstract static class AbstractECDSASignatureMethod + extends AbstractP1363FormatSignatureMethod { + + AbstractECDSASignatureMethod(AlgorithmParameterSpec params) + throws InvalidAlgorithmParameterException { + super(params); + } + + AbstractECDSASignatureMethod(Element dmElem) throws MarshalException { + super(dmElem); + } + + @Override + byte[] postSignFormat(Key key, byte[] sig) throws IOException { + // If signature is in ASN.1 (i.e., if the fallback algorithm + // was used), convert the signature to the P1363 format + if (asn1) { + return SignatureECDSA.convertASN1toXMLDSIG(sig); + } else { + return sig; + } + } + + @Override + byte[] preVerifyFormat(Key key, byte[] sig) throws IOException { + // If signature needs to be in ASN.1 (i.e., if the fallback + // algorithm will be used to verify the sig), convert the signature + // to the ASN.1 format + if (asn1) { + return SignatureECDSA.convertXMLDSIGtoASN1(sig); + } else { + return sig; + } + } + } + + static final class SHA1withRSA extends AbstractRSASignatureMethod { SHA1withRSA(AlgorithmParameterSpec params) throws InvalidAlgorithmParameterException { super(params); @@ -264,7 +447,7 @@ public abstract class DOMSignatureMethod extends AbstractDOMSignatureMethod { } } - static final class SHA256withRSA extends DOMSignatureMethod { + static final class SHA256withRSA extends AbstractRSASignatureMethod { SHA256withRSA(AlgorithmParameterSpec params) throws InvalidAlgorithmParameterException { super(params); @@ -283,7 +466,7 @@ public abstract class DOMSignatureMethod extends AbstractDOMSignatureMethod { } } - static final class SHA384withRSA extends DOMSignatureMethod { + static final class SHA384withRSA extends AbstractRSASignatureMethod { SHA384withRSA(AlgorithmParameterSpec params) throws InvalidAlgorithmParameterException { super(params); @@ -302,7 +485,7 @@ public abstract class DOMSignatureMethod extends AbstractDOMSignatureMethod { } } - static final class SHA512withRSA extends DOMSignatureMethod { + static final class SHA512withRSA extends AbstractRSASignatureMethod { SHA512withRSA(AlgorithmParameterSpec params) throws InvalidAlgorithmParameterException { super(params); @@ -321,7 +504,7 @@ public abstract class DOMSignatureMethod extends AbstractDOMSignatureMethod { } } - static final class SHA1withDSA extends DOMSignatureMethod { + static final class SHA1withDSA extends AbstractDSASignatureMethod { SHA1withDSA(AlgorithmParameterSpec params) throws InvalidAlgorithmParameterException { super(params); @@ -333,6 +516,9 @@ public abstract class DOMSignatureMethod extends AbstractDOMSignatureMethod { return SignatureMethod.DSA_SHA1; } String getJCAAlgorithm() { + return "SHA1withDSAinP1363Format"; + } + String getJCAFallbackAlgorithm() { return "SHA1withDSA"; } Type getAlgorithmType() { @@ -340,7 +526,7 @@ public abstract class DOMSignatureMethod extends AbstractDOMSignatureMethod { } } - static final class SHA256withDSA extends DOMSignatureMethod { + static final class SHA256withDSA extends AbstractDSASignatureMethod { SHA256withDSA(AlgorithmParameterSpec params) throws InvalidAlgorithmParameterException { super(params); @@ -352,6 +538,9 @@ public abstract class DOMSignatureMethod extends AbstractDOMSignatureMethod { return DSA_SHA256; } String getJCAAlgorithm() { + return "SHA256withDSAinP1363Format"; + } + String getJCAFallbackAlgorithm() { return "SHA256withDSA"; } Type getAlgorithmType() { @@ -359,7 +548,7 @@ public abstract class DOMSignatureMethod extends AbstractDOMSignatureMethod { } } - static final class SHA1withECDSA extends DOMSignatureMethod { + static final class SHA1withECDSA extends AbstractECDSASignatureMethod { SHA1withECDSA(AlgorithmParameterSpec params) throws InvalidAlgorithmParameterException { super(params); @@ -371,6 +560,9 @@ public abstract class DOMSignatureMethod extends AbstractDOMSignatureMethod { return ECDSA_SHA1; } String getJCAAlgorithm() { + return "SHA1withECDSAinP1363Format"; + } + String getJCAFallbackAlgorithm() { return "SHA1withECDSA"; } Type getAlgorithmType() { @@ -378,7 +570,7 @@ public abstract class DOMSignatureMethod extends AbstractDOMSignatureMethod { } } - static final class SHA256withECDSA extends DOMSignatureMethod { + static final class SHA256withECDSA extends AbstractECDSASignatureMethod { SHA256withECDSA(AlgorithmParameterSpec params) throws InvalidAlgorithmParameterException { super(params); @@ -390,6 +582,9 @@ public abstract class DOMSignatureMethod extends AbstractDOMSignatureMethod { return ECDSA_SHA256; } String getJCAAlgorithm() { + return "SHA256withECDSAinP1363Format"; + } + String getJCAFallbackAlgorithm() { return "SHA256withECDSA"; } Type getAlgorithmType() { @@ -397,7 +592,7 @@ public abstract class DOMSignatureMethod extends AbstractDOMSignatureMethod { } } - static final class SHA384withECDSA extends DOMSignatureMethod { + static final class SHA384withECDSA extends AbstractECDSASignatureMethod { SHA384withECDSA(AlgorithmParameterSpec params) throws InvalidAlgorithmParameterException { super(params); @@ -409,6 +604,9 @@ public abstract class DOMSignatureMethod extends AbstractDOMSignatureMethod { return ECDSA_SHA384; } String getJCAAlgorithm() { + return "SHA384withECDSAinP1363Format"; + } + String getJCAFallbackAlgorithm() { return "SHA384withECDSA"; } Type getAlgorithmType() { @@ -416,7 +614,7 @@ public abstract class DOMSignatureMethod extends AbstractDOMSignatureMethod { } } - static final class SHA512withECDSA extends DOMSignatureMethod { + static final class SHA512withECDSA extends AbstractECDSASignatureMethod { SHA512withECDSA(AlgorithmParameterSpec params) throws InvalidAlgorithmParameterException { super(params); @@ -428,6 +626,9 @@ public abstract class DOMSignatureMethod extends AbstractDOMSignatureMethod { return ECDSA_SHA512; } String getJCAAlgorithm() { + return "SHA512withECDSAinP1363Format"; + } + String getJCAFallbackAlgorithm() { return "SHA512withECDSA"; } Type getAlgorithmType() { diff --git a/jdk/src/jdk.crypto.ec/share/classes/sun/security/ec/ECDSASignature.java b/jdk/src/jdk.crypto.ec/share/classes/sun/security/ec/ECDSASignature.java index e20120bc8a1..a6bb8795d4a 100644 --- a/jdk/src/jdk.crypto.ec/share/classes/sun/security/ec/ECDSASignature.java +++ b/jdk/src/jdk.crypto.ec/share/classes/sun/security/ec/ECDSASignature.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2009, 2013, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2009, 2015, 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 @@ -45,6 +45,12 @@ import sun.security.util.*; * . "SHA256withECDSA" * . "SHA384withECDSA" * . "SHA512withECDSA" + * . "NONEwithECDSAinP1363Format" + * . "SHA1withECDSAinP1363Format" + * . "SHA224withECDSAinP1363Format" + * . "SHA256withECDSAinP1363Format" + * . "SHA384withECDSAinP1363Format" + * . "SHA512withECDSAinP1363Format" * * @since 1.7 */ @@ -65,29 +71,56 @@ abstract class ECDSASignature extends SignatureSpi { // public key, if initialized for verifying private ECPublicKey publicKey; + // The format. true for the IEEE P1363 format. false (default) for ASN.1 + private final boolean p1363Format; + /** - * Constructs a new ECDSASignature. Used by Raw subclass. + * Constructs a new ECDSASignature. * * @exception ProviderException if the native ECC library is unavailable. */ ECDSASignature() { - messageDigest = null; + this(false); + } + + /** + * Constructs a new ECDSASignature that will use the specified + * signature format. {@code p1363Format} should be {@code true} to + * use the IEEE P1363 format. If {@code p1363Format} is {@code false}, + * the DER-encoded ASN.1 format will be used. This constructor is + * used by the RawECDSA subclasses. + */ + ECDSASignature(boolean p1363Format) { + this.messageDigest = null; + this.p1363Format = p1363Format; } /** * Constructs a new ECDSASignature. Used by subclasses. */ ECDSASignature(String digestName) { + this(digestName, false); + } + + /** + * Constructs a new ECDSASignature that will use the specified + * digest and signature format. {@code p1363Format} should be + * {@code true} to use the IEEE P1363 format. If {@code p1363Format} + * is {@code false}, the DER-encoded ASN.1 format will be used. This + * constructor is used by subclasses. + */ + ECDSASignature(String digestName, boolean p1363Format) { try { messageDigest = MessageDigest.getInstance(digestName); } catch (NoSuchAlgorithmException e) { throw new ProviderException(e); } - needsReset = false; + this.needsReset = false; + this.p1363Format = p1363Format; } - // Nested class for NONEwithECDSA signatures - public static final class Raw extends ECDSASignature { + // Class for Raw ECDSA signatures. + static class RawECDSA extends ECDSASignature { // the longest supported digest is 512 bits (SHA-512) private static final int RAW_ECDSA_MAX = 64; @@ -95,7 +128,8 @@ abstract class ECDSASignature extends SignatureSpi { private final byte[] precomputedDigest; private int offset = 0; - public Raw() { + RawECDSA(boolean p1363Format) { + super(p1363Format); precomputedDigest = new byte[RAW_ECDSA_MAX]; } @@ -156,6 +190,20 @@ abstract class ECDSASignature extends SignatureSpi { } } + // Nested class for NONEwithECDSA signatures + public static final class Raw extends RawECDSA { + public Raw() { + super(false); + } + } + + // Nested class for NONEwithECDSAinP1363Format signatures + public static final class RawinP1363Format extends RawECDSA { + public RawinP1363Format() { + super(true); + } + } + // Nested class for SHA1withECDSA signatures public static final class SHA1 extends ECDSASignature { public SHA1() { @@ -163,6 +211,13 @@ abstract class ECDSASignature extends SignatureSpi { } } + // Nested class for SHA1withECDSAinP1363Format signatures + public static final class SHA1inP1363Format extends ECDSASignature { + public SHA1inP1363Format() { + super("SHA1", true); + } + } + // Nested class for SHA224withECDSA signatures public static final class SHA224 extends ECDSASignature { public SHA224() { @@ -170,6 +225,13 @@ abstract class ECDSASignature extends SignatureSpi { } } + // Nested class for SHA224withECDSAinP1363Format signatures + public static final class SHA224inP1363Format extends ECDSASignature { + public SHA224inP1363Format() { + super("SHA-224", true); + } + } + // Nested class for SHA256withECDSA signatures public static final class SHA256 extends ECDSASignature { public SHA256() { @@ -177,6 +239,13 @@ abstract class ECDSASignature extends SignatureSpi { } } + // Nested class for SHA256withECDSAinP1363Format signatures + public static final class SHA256inP1363Format extends ECDSASignature { + public SHA256inP1363Format() { + super("SHA-256", true); + } + } + // Nested class for SHA384withECDSA signatures public static final class SHA384 extends ECDSASignature { public SHA384() { @@ -184,6 +253,13 @@ abstract class ECDSASignature extends SignatureSpi { } } + // Nested class for SHA384withECDSAinP1363Format signatures + public static final class SHA384inP1363Format extends ECDSASignature { + public SHA384inP1363Format() { + super("SHA-384", true); + } + } + // Nested class for SHA512withECDSA signatures public static final class SHA512 extends ECDSASignature { public SHA512() { @@ -191,6 +267,13 @@ abstract class ECDSASignature extends SignatureSpi { } } + // Nested class for SHA512withECDSAinP1363Format signatures + public static final class SHA512inP1363Format extends ECDSASignature { + public SHA512inP1363Format() { + super("SHA-512", true); + } + } + // initialize for verification. See JCA doc @Override protected void engineInitVerify(PublicKey publicKey) @@ -286,14 +369,18 @@ abstract class ECDSASignature extends SignatureSpi { } random.nextBytes(seed); + byte[] sig; try { - - return encodeSignature( - signDigest(getDigestValue(), s, encodedParams, seed)); - + sig = signDigest(getDigestValue(), s, encodedParams, seed); } catch (GeneralSecurityException e) { throw new SignatureException("Could not sign data", e); } + + if (p1363Format) { + return sig; + } else { + return encodeSignature(sig); + } } // verify the data and return the result. See JCA doc @@ -311,11 +398,15 @@ abstract class ECDSASignature extends SignatureSpi { w = ECUtil.encodePoint(publicKey.getW(), params.getCurve()); } + byte[] sig; + if (p1363Format) { + sig = signature; + } else { + sig = decodeSignature(signature); + } + try { - - return verifySignedDigest( - decodeSignature(signature), getDigestValue(), w, encodedParams); - + return verifySignedDigest(sig, getDigestValue(), w, encodedParams); } catch (GeneralSecurityException e) { throw new SignatureException("Could not verify signature", e); } diff --git a/jdk/src/jdk.crypto.ec/share/classes/sun/security/ec/SunECEntries.java b/jdk/src/jdk.crypto.ec/share/classes/sun/security/ec/SunECEntries.java index aa6ad6e7cc3..104f6b2718c 100644 --- a/jdk/src/jdk.crypto.ec/share/classes/sun/security/ec/SunECEntries.java +++ b/jdk/src/jdk.crypto.ec/share/classes/sun/security/ec/SunECEntries.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2009, 2014, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2009, 2015, 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 @@ -131,6 +131,19 @@ final class SunECEntries { map.put("Alg.Alias.Signature.OID.1.2.840.10045.4.3.4", "SHA512withECDSA"); map.put("Alg.Alias.Signature.1.2.840.10045.4.3.4", "SHA512withECDSA"); + map.put("Signature.NONEwithECDSAinP1363Format", + "sun.security.ec.ECDSASignature$RawinP1363Format"); + map.put("Signature.SHA1withECDSAinP1363Format", + "sun.security.ec.ECDSASignature$SHA1inP1363Format"); + map.put("Signature.SHA224withECDSAinP1363Format", + "sun.security.ec.ECDSASignature$SHA224inP1363Format"); + map.put("Signature.SHA256withECDSAinP1363Format", + "sun.security.ec.ECDSASignature$SHA256inP1363Format"); + map.put("Signature.SHA384withECDSAinP1363Format", + "sun.security.ec.ECDSASignature$SHA384inP1363Format"); + map.put("Signature.SHA512withECDSAinP1363Format", + "sun.security.ec.ECDSASignature$SHA512inP1363Format"); + String ecKeyClasses = "java.security.interfaces.ECPublicKey" + "|java.security.interfaces.ECPrivateKey"; map.put("Signature.NONEwithECDSA SupportedKeyClasses", ecKeyClasses); diff --git a/jdk/src/jdk.crypto.pkcs11/share/classes/sun/security/pkcs11/P11Signature.java b/jdk/src/jdk.crypto.pkcs11/share/classes/sun/security/pkcs11/P11Signature.java index e5f498ffc71..7a5dffd9ad7 100644 --- a/jdk/src/jdk.crypto.pkcs11/share/classes/sun/security/pkcs11/P11Signature.java +++ b/jdk/src/jdk.crypto.pkcs11/share/classes/sun/security/pkcs11/P11Signature.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2003, 2014, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2003, 2015, 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 @@ -50,6 +50,8 @@ import sun.security.util.KeyUtil; * . DSA * . NONEwithDSA (RawDSA) * . SHA1withDSA + * . NONEwithDSAinP1363Format (RawDSAinP1363Format) + * . SHA1withDSAinP1363Format * . RSA: * . MD2withRSA * . MD5withRSA @@ -65,6 +67,12 @@ import sun.security.util.KeyUtil; * . SHA256withECDSA * . SHA384withECDSA * . SHA512withECDSA + * . NONEwithECDSAinP1363Format + * . SHA1withECDSAinP1363Format + * . SHA224withECDSAinP1363Format + * . SHA256withECDSAinP1363Format + * . SHA384withECDSAinP1363Format + * . SHA512withECDSAinP1363Format * * Note that the underlying PKCS#11 token may support complete signature * algorithm (e.g. CKM_DSA_SHA1, CKM_MD5_RSA_PKCS), or it may just @@ -117,6 +125,12 @@ final class P11Signature extends SignatureSpi { // total number of bytes processed in current operation private int bytesProcessed; + // The format, to be used for DSA and ECDSA signatures. + // If true, the IEEE P1363 format will be used, the concatenation of + // r and s. If false (default), the signature will be formatted as a + // DER-encoded ASN.1 sequence of r and s. + private boolean p1363Format = false; + // constant for signing mode private final static int M_SIGN = 1; // constant for verification mode @@ -166,10 +180,12 @@ final class P11Signature extends SignatureSpi { break; case (int)CKM_DSA: keyAlgorithm = "DSA"; - if (algorithm.equals("DSA")) { + if (algorithm.equals("DSA") || + algorithm.equals("DSAinP1363Format")) { type = T_DIGEST; md = MessageDigest.getInstance("SHA-1"); - } else if (algorithm.equals("RawDSA")) { + } else if (algorithm.equals("RawDSA") || + algorithm.equals("RawDSAinP1363Format")) { type = T_RAW; buffer = new byte[20]; } else { @@ -178,20 +194,26 @@ final class P11Signature extends SignatureSpi { break; case (int)CKM_ECDSA: keyAlgorithm = "EC"; - if (algorithm.equals("NONEwithECDSA")) { + if (algorithm.equals("NONEwithECDSA") || + algorithm.equals("NONEwithECDSAinP1363Format")) { type = T_RAW; buffer = new byte[RAW_ECDSA_MAX]; } else { String digestAlg; - if (algorithm.equals("SHA1withECDSA")) { + if (algorithm.equals("SHA1withECDSA") || + algorithm.equals("SHA1withECDSAinP1363Format")) { digestAlg = "SHA-1"; - } else if (algorithm.equals("SHA224withECDSA")) { + } else if (algorithm.equals("SHA224withECDSA") || + algorithm.equals("SHA224withECDSAinP1363Format")) { digestAlg = "SHA-224"; - } else if (algorithm.equals("SHA256withECDSA")) { + } else if (algorithm.equals("SHA256withECDSA") || + algorithm.equals("SHA256withECDSAinP1363Format")) { digestAlg = "SHA-256"; - } else if (algorithm.equals("SHA384withECDSA")) { + } else if (algorithm.equals("SHA384withECDSA") || + algorithm.equals("SHA384withECDSAinP1363Format")) { digestAlg = "SHA-384"; - } else if (algorithm.equals("SHA512withECDSA")) { + } else if (algorithm.equals("SHA512withECDSA") || + algorithm.equals("SHA512withECDSAinP1363Format")) { digestAlg = "SHA-512"; } else { throw new ProviderException(algorithm); @@ -235,6 +257,9 @@ final class P11Signature extends SignatureSpi { this.buffer = buffer; this.digestOID = digestOID; this.md = md; + if (algorithm.endsWith("inP1363Format")) { + this.p1363Format = true; + } } private void ensureInitialized() { @@ -582,10 +607,14 @@ final class P11Signature extends SignatureSpi { signature = token.p11.C_Sign(session.id(), data); } } - if (keyAlgorithm.equals("RSA") == false) { - return dsaToASN1(signature); - } else { + if (keyAlgorithm.equals("RSA")) { return signature; + } else { + if (p1363Format) { + return signature; + } else { + return dsaToASN1(signature); + } } } catch (PKCS11Exception e) { throw new ProviderException(e); @@ -599,10 +628,12 @@ final class P11Signature extends SignatureSpi { protected boolean engineVerify(byte[] signature) throws SignatureException { ensureInitialized(); try { - if (keyAlgorithm.equals("DSA")) { - signature = asn1ToDSA(signature); - } else if (keyAlgorithm.equals("EC")) { - signature = asn1ToECDSA(signature); + if (!p1363Format) { + if (keyAlgorithm.equals("DSA")) { + signature = asn1ToDSA(signature); + } else if (keyAlgorithm.equals("EC")) { + signature = asn1ToECDSA(signature); + } } if (type == T_UPDATE) { token.p11.C_VerifyFinal(session.id(), signature); diff --git a/jdk/src/jdk.crypto.pkcs11/share/classes/sun/security/pkcs11/SunPKCS11.java b/jdk/src/jdk.crypto.pkcs11/share/classes/sun/security/pkcs11/SunPKCS11.java index 74e5d1e56af..ec4f231ec37 100644 --- a/jdk/src/jdk.crypto.pkcs11/share/classes/sun/security/pkcs11/SunPKCS11.java +++ b/jdk/src/jdk.crypto.pkcs11/share/classes/sun/security/pkcs11/SunPKCS11.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2003, 2014, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2003, 2015, 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 @@ -680,6 +680,12 @@ public final class SunPKCS11 extends AuthProvider { s("SHA1withDSA", "1.3.14.3.2.13", "1.3.14.3.2.27", "1.2.840.10040.4.3", "OID.1.2.840.10040.4.3"), m(CKM_DSA_SHA1, CKM_DSA)); + d(SIG, "RawDSAinP1363Format", P11Signature, + s("NONEwithDSAinP1363Format"), + m(CKM_DSA)); + d(SIG, "DSAinP1363Format", P11Signature, + s("SHA1withDSAinP1363Format"), + m(CKM_DSA_SHA1, CKM_DSA)); d(SIG, "NONEwithECDSA", P11Signature, m(CKM_ECDSA)); d(SIG, "SHA1withECDSA", P11Signature, @@ -697,6 +703,18 @@ public final class SunPKCS11 extends AuthProvider { d(SIG, "SHA512withECDSA", P11Signature, s("1.2.840.10045.4.3.4", "OID.1.2.840.10045.4.3.4"), m(CKM_ECDSA)); + d(SIG, "NONEwithECDSAinP1363Format", P11Signature, + m(CKM_ECDSA)); + d(SIG, "SHA1withECDSAinP1363Format", P11Signature, + m(CKM_ECDSA_SHA1, CKM_ECDSA)); + d(SIG, "SHA224withECDSAinP1363Format", P11Signature, + m(CKM_ECDSA)); + d(SIG, "SHA256withECDSAinP1363Format", P11Signature, + m(CKM_ECDSA)); + d(SIG, "SHA384withECDSAinP1363Format", P11Signature, + m(CKM_ECDSA)); + d(SIG, "SHA512withECDSAinP1363Format", P11Signature, + m(CKM_ECDSA)); d(SIG, "MD2withRSA", P11Signature, s("1.2.840.113549.1.1.2", "OID.1.2.840.113549.1.1.2"), m(CKM_MD2_RSA_PKCS, CKM_RSA_PKCS, CKM_RSA_X_509)); @@ -1061,7 +1079,7 @@ public final class SunPKCS11 extends AuthProvider { } // EC if (((type == KA) && algorithm.equals("ECDH")) - || ((type == SIG) && algorithm.endsWith("ECDSA"))) { + || ((type == SIG) && algorithm.contains("ECDSA"))) { if (keyAlgorithm.equals("EC") == false) { return false; } @@ -1070,7 +1088,8 @@ public final class SunPKCS11 extends AuthProvider { || (key instanceof ECPublicKey); } // DSA signatures - if ((type == SIG) && algorithm.endsWith("DSA")) { + if ((type == SIG) && algorithm.contains("DSA") && + !algorithm.contains("ECDSA")) { if (keyAlgorithm.equals("DSA") == false) { return false; } diff --git a/jdk/test/sun/security/pkcs11/ec/TestECDSA.java b/jdk/test/sun/security/pkcs11/ec/TestECDSA.java index ad30accadeb..98dd939eaec 100644 --- a/jdk/test/sun/security/pkcs11/ec/TestECDSA.java +++ b/jdk/test/sun/security/pkcs11/ec/TestECDSA.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2006, 2013, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2006, 2015, 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 @@ -23,7 +23,7 @@ /** * @test - * @bug 6405536 + * @bug 6405536 8042967 * @summary basic test of SHA1withECDSA and NONEwithECDSA signing/verifying * @author Andreas Sterbenz * @library .. @@ -176,17 +176,28 @@ public class TestECDSA extends PKCS11Test { verify(provider, "NONEwithECDSA", publicKey, data1SHA, sig, true); verify(provider, "NONEwithECDSA", publicKey, data2SHA, sig, false); - testSigning(provider, privateKey, publicKey); + System.out.println("Testing with default signature format: ASN.1"); + testSigning(provider, privateKey, publicKey, false); + + System.out.println("Testing with IEEE P1363 signature format"); + testSigning(provider, privateKey, publicKey, true); } - private void testSigning(Provider provider, PrivateKey privateKey, - PublicKey publicKey) throws Exception { + private void testSigning(Provider provider, + PrivateKey privateKey, + PublicKey publicKey, + boolean p1363Format) throws Exception { byte[] data = new byte[2048]; new Random().nextBytes(data); // sign random data using SHA1withECDSA and verify using // SHA1withECDSA and NONEwithECDSA - Signature s = Signature.getInstance("SHA1withECDSA", provider); + Signature s; + if (p1363Format) { + s = Signature.getInstance("SHA1withECDSAinP1363Format", provider); + } else { + s = Signature.getInstance("SHA1withECDSA", provider); + } s.initSign(privateKey); s.update(data); byte[] s1 = s.sign(); @@ -197,7 +208,11 @@ public class TestECDSA extends PKCS11Test { throw new Exception("Sign/verify 1 failed"); } - s = Signature.getInstance("NONEwithECDSA", provider); + if (p1363Format) { + s = Signature.getInstance("NONEwithECDSAinP1363Format", provider); + } else { + s = Signature.getInstance("NONEwithECDSA", provider); + } MessageDigest md = MessageDigest.getInstance("SHA-1"); byte[] digest = md.digest(data); s.initVerify(publicKey); @@ -218,7 +233,11 @@ public class TestECDSA extends PKCS11Test { throw new Exception("Sign/verify 3 failed"); } - s = Signature.getInstance("SHA1withECDSA", provider); + if (p1363Format) { + s = Signature.getInstance("SHA1withECDSAinP1363Format", provider); + } else { + s = Signature.getInstance("SHA1withECDSA", provider); + } s.initVerify(publicKey); s.update(data); if (!s.verify(s2)) { diff --git a/jdk/test/sun/security/provider/DSA/TestDSA2.java b/jdk/test/sun/security/provider/DSA/TestDSA2.java index 20e6552f85a..600161d00f7 100644 --- a/jdk/test/sun/security/provider/DSA/TestDSA2.java +++ b/jdk/test/sun/security/provider/DSA/TestDSA2.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2012, 2014, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2012, 2015, 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 @@ -22,9 +22,10 @@ */ /* * @test - * @bug 7044060 + * @bug 7044060 8042967 * @run main/othervm/timeout=250 TestDSA2 - * @summary verify that DSA signature works using SHA and SHA-224 and SHA-256 digests. + * @summary verify that DSA signature works using SHA and SHA-224 and + * SHA-256 digests. */ @@ -40,7 +41,14 @@ public class TestDSA2 { private static final String PROV = "SUN"; private static final String[] SIG_ALGOS = { - "SHA1withDSA", "SHA224withDSA", "SHA256withDSA" + "NONEwithDSA", + "SHA1withDSA", + "SHA224withDSA", + "SHA256withDSA", + "NONEwithDSAinP1363Format", + "SHA1withDSAinP1363Format", + "SHA224withDSAinP1363Format", + "SHA256withDSAinP1363Format" }; private static final int[] KEYSIZES = { @@ -48,15 +56,20 @@ public class TestDSA2 { }; public static void main(String[] args) throws Exception { - boolean[] expectedToPass = { true, true, true }; + boolean[] expectedToPass = { true, true, true, true, + true, true, true, true }; test(1024, expectedToPass); - boolean[] expectedToPass2 = { true, true, true }; + boolean[] expectedToPass2 = { true, true, true, true, + true, true, true, true }; test(2048, expectedToPass2); } private static void test(int keySize, boolean[] testStatus) - throws Exception { - byte[] data = "1234567890".getBytes(); + throws Exception { + // Raw DSA requires the data to be exactly 20 bytes long. Use a + // 20-byte array for these tests so that the NONEwithDSA* algorithms + // don't complain. + byte[] data = "12345678901234567890".getBytes(); System.out.println("Test against key size: " + keySize); KeyPairGenerator keyGen = KeyPairGenerator.getInstance("DSA", PROV); From 3004d4881c09b00fa8baa828f8e51b994a0a51cb Mon Sep 17 00:00:00 2001 From: Brian Burkhalter Date: Tue, 17 Feb 2015 12:02:38 -0800 Subject: [PATCH 106/116] 8073347: javadoc of Formattable messed up by JDK-8019857 Change sample code formatting to the currently blessed idiom. Reviewed-by: martin --- .../java.base/share/classes/java/util/Formattable.java | 10 +++++----- 1 file changed, 5 insertions(+), 5 deletions(-) diff --git a/jdk/src/java.base/share/classes/java/util/Formattable.java b/jdk/src/java.base/share/classes/java/util/Formattable.java index f7e1e509d12..fa87e9c7022 100644 --- a/jdk/src/java.base/share/classes/java/util/Formattable.java +++ b/jdk/src/java.base/share/classes/java/util/Formattable.java @@ -36,14 +36,14 @@ import java.io.IOException; * For example, the following class prints out different representations of a * stock's name depending on the flags and length constraints: * - * {@code + *

 {@code
  *   import java.nio.CharBuffer;
  *   import java.util.Formatter;
  *   import java.util.Formattable;
  *   import java.util.Locale;
  *   import static java.util.FormattableFlags.*;
  *
- *  ...
+ *   ...
  *
  *   public class StockName implements Formattable {
  *       private String symbol, companyName, frenchCompanyName;
@@ -89,12 +89,12 @@ import java.io.IOException;
  *           return String.format("%s - %s", symbol, companyName);
  *       }
  *   }
- * }
+ * }
* *

When used in conjunction with the {@link java.util.Formatter}, the above * class produces the following output for various format strings. * - * {@code + *

 {@code
  *   Formatter fmt = new Formatter();
  *   StockName sn = new StockName("HUGE", "Huge Fruit, Inc.",
  *                                "Fruit Titanesque, Inc.");
@@ -104,7 +104,7 @@ import java.io.IOException;
  *   fmt.format("%-10.8s", sn);              //   -> "HUGE      "
  *   fmt.format("%.12s", sn);                //   -> "Huge Fruit,*"
  *   fmt.format(Locale.FRANCE, "%25s", sn);  //   -> "   Fruit Titanesque, Inc."
- * }
+ * }
* *

Formattables are not necessarily safe for multithreaded access. Thread * safety is optional and may be enforced by classes that extend and implement From 6d4ea4d7da2074f39a2c77492aecd81d94e3cdb6 Mon Sep 17 00:00:00 2001 From: Erik Joelsson Date: Wed, 18 Feb 2015 11:18:00 +0100 Subject: [PATCH 107/116] 8073328: Incremental build of gensrc broken Reviewed-by: alanb, tbell, dfuchs, sherman --- jdk/make/gensrc/Gensrc-jdk.charsets.gmk | 11 ++++++----- jdk/make/gensrc/GensrcCharsetMapping.gmk | 8 +++++--- .../src/classes/build/tools/charsetmapping/Main.java | 2 +- 3 files changed, 12 insertions(+), 9 deletions(-) diff --git a/jdk/make/gensrc/Gensrc-jdk.charsets.gmk b/jdk/make/gensrc/Gensrc-jdk.charsets.gmk index 67e4c3c1f1e..85d67f34c71 100644 --- a/jdk/make/gensrc/Gensrc-jdk.charsets.gmk +++ b/jdk/make/gensrc/Gensrc-jdk.charsets.gmk @@ -40,16 +40,17 @@ CHARSET_TEMPLATES := \ CHARSET_EXTENDED_JAVA_TEMPLATES := \ $(JDK_TOPDIR)/src/jdk.charsets/share/classes/sun/nio/cs/ext/ExtendedCharsets.java.template CHARSET_EXTENDED_JAVA_DIR := $(JDK_TOPDIR)/src/jdk.charsets/share/classes/sun/nio/cs/ext -CHARSET_EXTENDED := extcs CHARSET_STANDARD_OS := stdcs-$(OPENJDK_TARGET_OS) $(CHARSET_DONE_CS)-extcs: $(CHARSET_DATA_DIR)/charsets \ - $(CHARSET_TEMPLATES) $(CHARSET_EXTENDED_DATA) $(BUILD_TOOLS_JDK) + $(wildcard $(CHARSET_DATA_DIR)/$(CHARSET_STANDARD_OS)) \ + $(CHARSET_TEMPLATES) $(CHARSET_EXTENDED_JAVA_TEMPLATES) \ + $(BUILD_TOOLS_JDK) $(MKDIR) -p $(@D) $(TOOL_CHARSETMAPPING) $(CHARSET_DATA_DIR) $(CHARSET_GENSRC_JAVA_DIR_CS) \ - extcs charsets $(CHARSET_STANDARD_OS) \ - $(CHARSET_EXTENDED_JAVA_TEMPLATES) \ - $(CHARSET_EXTENDED_JAVA_DIR) + extcs charsets $(CHARSET_STANDARD_OS) \ + $(CHARSET_EXTENDED_JAVA_TEMPLATES) \ + $(CHARSET_EXTENDED_JAVA_DIR) $(LOG_INFO) $(TOUCH) '$@' $(CHARSET_DONE_CS)-hkscs: $(CHARSET_COPYRIGHT_HEADER)/HKSCS.java \ diff --git a/jdk/make/gensrc/GensrcCharsetMapping.gmk b/jdk/make/gensrc/GensrcCharsetMapping.gmk index e38efd8bf62..e0243a95dcf 100644 --- a/jdk/make/gensrc/GensrcCharsetMapping.gmk +++ b/jdk/make/gensrc/GensrcCharsetMapping.gmk @@ -40,11 +40,13 @@ CHARSET_STANDARD_JAVA_TEMPLATES := \ CHARSET_STANDARD_OS := stdcs-$(OPENJDK_TARGET_OS) $(CHARSET_DONE_BASE)-stdcs: $(CHARSET_DATA_DIR)/charsets \ - $(CHARSET_TEMPLATES) $(BUILD_TOOLS_JDK) + $(wildcard $(CHARSET_DATA_DIR)/$(CHARSET_STANDARD_OS)) \ + $(CHARSET_TEMPLATES) $(CHARSET_STANDARD_JAVA_TEMPLATES) \ + $(BUILD_TOOLS_JDK) $(MKDIR) -p $(@D) $(TOOL_CHARSETMAPPING) $(CHARSET_DATA_DIR) $(CHARSET_GENSRC_JAVA_DIR_BASE) \ - stdcs charsets $(CHARSET_STANDARD_OS) \ - $(CHARSET_STANDARD_JAVA_TEMPLATES) $(CHARSET_EXTSRC_DIR) \ + stdcs charsets $(CHARSET_STANDARD_OS) \ + $(CHARSET_STANDARD_JAVA_TEMPLATES) $(CHARSET_EXTSRC_DIR) $(LOG_INFO) $(TOUCH) '$@' GENSRC_JAVA_BASE += $(CHARSET_DONE_BASE)-stdcs diff --git a/jdk/make/src/classes/build/tools/charsetmapping/Main.java b/jdk/make/src/classes/build/tools/charsetmapping/Main.java index 780ff093b2d..b129288ea26 100644 --- a/jdk/make/src/classes/build/tools/charsetmapping/Main.java +++ b/jdk/make/src/classes/build/tools/charsetmapping/Main.java @@ -206,7 +206,7 @@ public class Main { } static void verbose(Charset cs) { - System.err.printf("%s, %s, %s, %s, %s %b%n", + System.out.printf("%s, %s, %s, %s, %s %b%n", cs.clzName, cs.csName, cs.hisName, cs.pkgName, cs.type, cs.isASCII); } From 7168bf102d5efbdfba34c9a3632dd4d1f4478e4e Mon Sep 17 00:00:00 2001 From: Dmitry Samersoff Date: Wed, 18 Feb 2015 03:16:48 -0800 Subject: [PATCH 108/116] 8072835: sun/tools/jmap/heapconfig/JMapHeapConfigTest.java Key MaxHeapSize doesnt match Make sure that maxheapsize is set explicitly in command line Reviewed-by: sla, ykantser --- .../jmap/heapconfig/JMapHeapConfigTest.java | 16 ++++++++++++++++ 1 file changed, 16 insertions(+) diff --git a/jdk/test/sun/tools/jmap/heapconfig/JMapHeapConfigTest.java b/jdk/test/sun/tools/jmap/heapconfig/JMapHeapConfigTest.java index fe856d736b3..1f9d5f11ffe 100644 --- a/jdk/test/sun/tools/jmap/heapconfig/JMapHeapConfigTest.java +++ b/jdk/test/sun/tools/jmap/heapconfig/JMapHeapConfigTest.java @@ -55,6 +55,8 @@ public class JMapHeapConfigTest { // ignoring MaxMetaspaceSize + static final String desiredMaxHeapSize = "-Xmx128m"; + private static Map parseJMapOutput(List jmapOutput) { Map heapConfigMap = new HashMap(); boolean shouldParse = false; @@ -110,9 +112,23 @@ public class JMapHeapConfigTest { public static void main(String[] args) { System.out.println("Starting JMapHeapConfigTest"); + boolean mx_found = false; + List jvmOptions = Utils.getVmOptions(); + for (String option : jvmOptions) { + if (option.startsWith("-Xmx")) { + System.out.println("INFO: maximum heap size set by JTREG as " + option); + mx_found = true; + break; + } + } + // Forward vm options to LingeredApp ArrayList cmd = new ArrayList(); cmd.addAll(Utils.getVmOptions()); + if (!mx_found) { + cmd.add(desiredMaxHeapSize); + System.out.println("INFO: maximum heap size set explicitly as " + desiredMaxHeapSize); + } cmd.add("-XX:+PrintFlagsFinal"); TmtoolTestScenario tmt = TmtoolTestScenario.create("jmap", "-heap"); From eaa8d1e0f31ceb684d883288ae5a891f5fc9fdc7 Mon Sep 17 00:00:00 2001 From: Dmitry Samersoff Date: Wed, 18 Feb 2015 03:45:06 -0800 Subject: [PATCH 109/116] 8072395: sun/tools/jmap/heapconfig/LingeredAppTest.java and sun/tools/jmap/heapconfig/JMapHeapConfigTest.java fail due to LingeredApp ERROR: java.io.IOException: Lock is too old. Aborting Remove lock age check Reviewed-by: sla, dholmes, kevinw --- .../testlibrary/jdk/testlibrary/Platform.java | 129 +++++++++++++++--- .../jmap/heapconfig/JMapHeapConfigTest.java | 15 +- .../tools/jmap/heapconfig/LingeredApp.java | 47 +++++-- .../jmap/heapconfig/LingeredAppTest.java | 2 - 4 files changed, 164 insertions(+), 29 deletions(-) diff --git a/jdk/test/lib/testlibrary/jdk/testlibrary/Platform.java b/jdk/test/lib/testlibrary/jdk/testlibrary/Platform.java index 6382e01c962..c56697adb1b 100644 --- a/jdk/test/lib/testlibrary/jdk/testlibrary/Platform.java +++ b/jdk/test/lib/testlibrary/jdk/testlibrary/Platform.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2013, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2013, 2015, 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 @@ -22,13 +22,20 @@ */ package jdk.testlibrary; +import java.util.regex.Pattern; +import java.io.RandomAccessFile; +import java.io.FileNotFoundException; +import java.io.IOException; public class Platform { private static final String osName = System.getProperty("os.name"); private static final String dataModel = System.getProperty("sun.arch.data.model"); private static final String vmVersion = System.getProperty("java.vm.version"); + private static final String javaVersion = System.getProperty("java.version"); private static final String osArch = System.getProperty("os.arch"); private static final String vmName = System.getProperty("java.vm.name"); + private static final String userName = System.getProperty("user.name"); + private static final String compiler = System.getProperty("sun.management.compiler"); public static boolean isClient() { return vmName.endsWith(" Client VM"); @@ -38,6 +45,23 @@ public class Platform { return vmName.endsWith(" Server VM"); } + public static boolean isGraal() { + return vmName.endsWith(" Graal VM"); + } + + public static boolean isMinimal() { + return vmName.endsWith(" Minimal VM"); + } + + public static boolean isEmbedded() { + return vmName.contains("Embedded"); + } + + public static boolean isTieredSupported() { + return compiler.contains("Tiered Compilers"); + } + + public static boolean is32bit() { return dataModel.equals("32"); } @@ -46,20 +70,24 @@ public class Platform { return dataModel.equals("64"); } - public static boolean isSolaris() { - return isOs("sunos"); + public static boolean isAix() { + return isOs("aix"); } - public static boolean isWindows() { - return isOs("win"); + public static boolean isLinux() { + return isOs("linux"); } public static boolean isOSX() { return isOs("mac"); } - public static boolean isLinux() { - return isOs("linux"); + public static boolean isSolaris() { + return isOs("sunos"); + } + + public static boolean isWindows() { + return isOs("win"); } private static boolean isOs(String osname) { @@ -71,7 +99,8 @@ public class Platform { } public static boolean isDebugBuild() { - return vmVersion.toLowerCase().contains("debug"); + return (vmVersion.toLowerCase().contains("debug") || + javaVersion.toLowerCase().contains("debug")); } public static String getVMVersion() { @@ -80,33 +109,101 @@ public class Platform { // Returns true for sparc and sparcv9. public static boolean isSparc() { - return isArch("sparc"); + return isArch("sparc.*"); } public static boolean isARM() { - return isArch("arm"); + return isArch("arm.*"); } public static boolean isPPC() { - return isArch("ppc"); + return isArch("ppc.*"); } public static boolean isX86() { - // On Linux it's 'i386', Windows 'x86' - return (isArch("i386") || isArch("x86")); + // On Linux it's 'i386', Windows 'x86' without '_64' suffix. + return isArch("(i386)|(x86(?!_64))"); } public static boolean isX64() { // On OSX it's 'x86_64' and on other (Linux, Windows and Solaris) platforms it's 'amd64' - return (isArch("amd64") || isArch("x86_64")); + return isArch("(amd64)|(x86_64)"); } - private static boolean isArch(String archname) { - return osArch.toLowerCase().startsWith(archname.toLowerCase()); + private static boolean isArch(String archnameRE) { + return Pattern.compile(archnameRE, Pattern.CASE_INSENSITIVE) + .matcher(osArch) + .matches(); } public static String getOsArch() { return osArch; } + /** + * Return a boolean for whether we expect to be able to attach + * the SA to our own processes on this system. + */ + public static boolean shouldSAAttach() + throws IOException { + + if (isAix()) { + return false; // SA not implemented. + } else if (isLinux()) { + return canPtraceAttachLinux(); + } else if (isOSX()) { + return canAttachOSX(); + } else { + // Other platforms expected to work: + return true; + } + } + + /** + * On Linux, first check the SELinux boolean "deny_ptrace" and return false + * as we expect to be denied if that is "1". + */ + public static boolean canPtraceAttachLinux() + throws IOException { + + // SELinux deny_ptrace: + try(RandomAccessFile file = new RandomAccessFile("/sys/fs/selinux/booleans/deny_ptrace", "r")) { + if (file.readByte() != '0') { + return false; + } + } + catch(FileNotFoundException ex) { + // Ignored + } + + // YAMA enhanced security ptrace_scope: + // 0 - a process can PTRACE_ATTACH to any other process running under the same uid + // 1 - restricted ptrace: a process must be a children of the inferior or user is root + // 2 - only processes with CAP_SYS_PTRACE may use ptrace or user is root + // 3 - no attach: no processes may use ptrace with PTRACE_ATTACH + + try(RandomAccessFile file = new RandomAccessFile("/proc/sys/kernel/yama/ptrace_scope", "r")) { + byte yama_scope = file.readByte(); + if (yama_scope == '3') { + return false; + } + + if (!userName.equals("root") && yama_scope != '0') { + return false; + } + } + catch(FileNotFoundException ex) { + // Ignored + } + + // Otherwise expect to be permitted: + return true; + } + + /** + * On OSX, expect permission to attach only if we are root. + */ + public static boolean canAttachOSX() { + return userName.equals("root"); + } } diff --git a/jdk/test/sun/tools/jmap/heapconfig/JMapHeapConfigTest.java b/jdk/test/sun/tools/jmap/heapconfig/JMapHeapConfigTest.java index 1f9d5f11ffe..2db96ea27ed 100644 --- a/jdk/test/sun/tools/jmap/heapconfig/JMapHeapConfigTest.java +++ b/jdk/test/sun/tools/jmap/heapconfig/JMapHeapConfigTest.java @@ -37,6 +37,7 @@ import java.util.HashMap; import java.util.List; import java.util.Map; import jdk.testlibrary.Utils; +import jdk.testlibrary.Platform; public class JMapHeapConfigTest { @@ -109,9 +110,21 @@ public class JMapHeapConfigTest { } } - public static void main(String[] args) { + public static void main(String[] args) throws Exception { System.out.println("Starting JMapHeapConfigTest"); + if (!Platform.shouldSAAttach()) { + // Silently skip the test if we don't have enough permissions to attach + System.err.println("Error! Insufficient permissions to attach."); + return; + } + + if (!LingeredApp.isLastModifiedWorking()) { + // Exact behaviour of the test depends to operating system and the test nature, + // so just print the warning and continue + System.err.println("Warning! Last modified time doesn't work."); + } + boolean mx_found = false; List jvmOptions = Utils.getVmOptions(); for (String option : jvmOptions) { diff --git a/jdk/test/sun/tools/jmap/heapconfig/LingeredApp.java b/jdk/test/sun/tools/jmap/heapconfig/LingeredApp.java index 176f82fc348..1ac1a137088 100644 --- a/jdk/test/sun/tools/jmap/heapconfig/LingeredApp.java +++ b/jdk/test/sun/tools/jmap/heapconfig/LingeredApp.java @@ -362,6 +362,41 @@ public class LingeredApp { } } + /** + * LastModified time might not work correctly in some cases it might + * cause later failures + */ + + public static boolean isLastModifiedWorking() { + boolean sane = true; + try { + long lm = lastModified("."); + if (lm == 0) { + System.err.println("SANITY Warning! The lastModifiedTime() doesn't work on this system, it returns 0"); + sane = false; + } + + long now = epoch(); + if (lm > now) { + System.err.println("SANITY Warning! The Clock is wrong on this system lastModifiedTime() > getTime()"); + sane = false; + } + + setLastModified(".", epoch()); + long lm1 = lastModified("."); + if (lm1 <= lm) { + System.err.println("SANITY Warning! The setLastModified doesn't work on this system"); + sane = false; + } + } + catch(IOException e) { + System.err.println("SANITY Warning! IOException during sanity check " + e); + sane = false; + } + + return sane; + } + /** * This part is the application it self */ @@ -378,16 +413,8 @@ public class LingeredApp { Path path = Paths.get(theLockFileName); while (Files.exists(path)) { - long lm = lastModified(theLockFileName); - long now = epoch(); - - // A bit of paranoja, don't allow test app to run more than an hour - if (now - lm > 3600) { - throw new IOException("Lock is too old. Aborting"); - } - - // Touch lock to indicate our rediness - setLastModified(theLockFileName, now); + // Touch the lock to indicate our readiness + setLastModified(theLockFileName, epoch()); Thread.sleep(spinDelay); } diff --git a/jdk/test/sun/tools/jmap/heapconfig/LingeredAppTest.java b/jdk/test/sun/tools/jmap/heapconfig/LingeredAppTest.java index e492add66c3..f29708db4b5 100644 --- a/jdk/test/sun/tools/jmap/heapconfig/LingeredAppTest.java +++ b/jdk/test/sun/tools/jmap/heapconfig/LingeredAppTest.java @@ -31,8 +31,6 @@ import java.io.IOException; import java.util.ArrayList; import java.util.Arrays; -import java.util.logging.Level; -import java.util.logging.Logger; public class LingeredAppTest { From 3bbf6fb28119efcff46f5f49d08c027ebf881ffb Mon Sep 17 00:00:00 2001 From: Mandy Chung Date: Wed, 18 Feb 2015 08:59:55 -0800 Subject: [PATCH 110/116] 8073373: Remove redundant imports from sun/applet/AppletProps.java Reviewed-by: serb --- jdk/src/java.desktop/share/classes/sun/applet/AppletProps.java | 2 -- 1 file changed, 2 deletions(-) diff --git a/jdk/src/java.desktop/share/classes/sun/applet/AppletProps.java b/jdk/src/java.desktop/share/classes/sun/applet/AppletProps.java index f29a0d010b0..f78e4160209 100644 --- a/jdk/src/java.desktop/share/classes/sun/applet/AppletProps.java +++ b/jdk/src/java.desktop/share/classes/sun/applet/AppletProps.java @@ -28,8 +28,6 @@ package sun.applet; import java.awt.*; import java.io.*; import java.util.Properties; -import sun.net.www.http.HttpClient; -import sun.net.ftp.FtpClient; import java.security.AccessController; import java.security.PrivilegedAction; import java.security.PrivilegedExceptionAction; From db4c1818449f5f3e2beb911b08d4e545ee87fbe4 Mon Sep 17 00:00:00 2001 From: Mandy Chung Date: Wed, 18 Feb 2015 18:14:41 -0800 Subject: [PATCH 111/116] 8072656: test/java/lang/reflect/Proxy/ClassRestrictions.java assumes app class loader be URLClassLoader Reviewed-by: lancea, alanb --- .../java/lang/reflect/Proxy/ClassRestrictions.java | 14 +++++++++++--- 1 file changed, 11 insertions(+), 3 deletions(-) diff --git a/jdk/test/java/lang/reflect/Proxy/ClassRestrictions.java b/jdk/test/java/lang/reflect/Proxy/ClassRestrictions.java index b05ccaec488..ba5b407b99d 100644 --- a/jdk/test/java/lang/reflect/Proxy/ClassRestrictions.java +++ b/jdk/test/java/lang/reflect/Proxy/ClassRestrictions.java @@ -22,7 +22,7 @@ */ /* @test - * @bug 4227192 8004928 + * @bug 4227192 8004928 8072656 * @summary This is a test of the restrictions on the parameters that may * be passed to the Proxy.getProxyClass method. * @author Peter Jones @@ -31,9 +31,12 @@ * @run main ClassRestrictions */ +import java.io.File; import java.lang.reflect.Modifier; import java.lang.reflect.Proxy; import java.net.URLClassLoader; +import java.net.URL; +import java.nio.file.Paths; public class ClassRestrictions { @@ -105,8 +108,13 @@ public class ClassRestrictions { * All of the interfaces types must be visible by name though the * specified class loader. */ - ClassLoader altLoader = new URLClassLoader( - ((URLClassLoader) loader).getURLs(), null); + String[] cpaths = System.getProperty("test.classes", ".") + .split(File.pathSeparator); + URL[] urls = new URL[cpaths.length]; + for (int i=0; i < cpaths.length; i++) { + urls[i] = Paths.get(cpaths[i]).toUri().toURL(); + } + ClassLoader altLoader = new URLClassLoader(urls, null); Class altBarClass; altBarClass = Class.forName(Bar.class.getName(), false, altLoader); try { From 0fafef81473a77cbf863f7b779435be2ce945844 Mon Sep 17 00:00:00 2001 From: David Katleman Date: Thu, 19 Feb 2015 11:23:55 -0800 Subject: [PATCH 112/116] Added tag jdk9-b51 for changeset 5d0c07a90e82 --- .hgtags-top-repo | 1 + 1 file changed, 1 insertion(+) diff --git a/.hgtags-top-repo b/.hgtags-top-repo index 6935eae9e7e..f8935a56868 100644 --- a/.hgtags-top-repo +++ b/.hgtags-top-repo @@ -293,3 +293,4 @@ b6cca3e6175a69f39e5799b7349ddb0176630291 jdk9-b47 0064e246d83f6f9fc245c19b6d05041ecaf4b6d4 jdk9-b48 d91ed1951b948210590ce1394bea5515357246ba jdk9-b49 d1f37d39ff2421f956a6ddf316cf763807bc3363 jdk9-b50 +6207b4b8731ca75c51b031c47daa813ab92ef558 jdk9-b51 From 0efeaabb0a61cf46b7f7c3a3333879106a75545a Mon Sep 17 00:00:00 2001 From: David Katleman Date: Thu, 19 Feb 2015 11:23:57 -0800 Subject: [PATCH 113/116] Added tag jdk9-b51 for changeset 1ede1e98cd63 --- corba/.hgtags | 1 + 1 file changed, 1 insertion(+) diff --git a/corba/.hgtags b/corba/.hgtags index 40d1d16c964..2db5e411ae5 100644 --- a/corba/.hgtags +++ b/corba/.hgtags @@ -293,3 +293,4 @@ ee8447ca632e1d39180b4767c749db101bff7314 jdk9-b47 a13c49c5f2899b702652a460ed7aa73123e671e6 jdk9-b48 9285d14eb7b6b0815679bae98dd936dbc136218d jdk9-b49 224f593393e5b01b3c8f1e591b7f4b1790a3737a jdk9-b50 +2309c02386d1fa4ced5051873ffb9e04874f7a44 jdk9-b51 From cb126fc539b2364aa99dddaf44d5dd405d0f2e00 Mon Sep 17 00:00:00 2001 From: David Katleman Date: Thu, 19 Feb 2015 11:23:58 -0800 Subject: [PATCH 114/116] Added tag jdk9-b51 for changeset 5fb718119516 --- hotspot/.hgtags | 1 + 1 file changed, 1 insertion(+) diff --git a/hotspot/.hgtags b/hotspot/.hgtags index bec0066461f..48d17c8f8ae 100644 --- a/hotspot/.hgtags +++ b/hotspot/.hgtags @@ -453,3 +453,4 @@ a184ee1d717297bd35b7c3e35393e137921a3ed2 jdk9-b46 cc775a4a24c7f5d9e624b4205e9fbd48a17331f6 jdk9-b48 360cd1fc42f10941a9fd17cc32d5b85a22d12a0b jdk9-b49 e0947f58c9c1426aa0d98b98ebb78357b27a7b99 jdk9-b50 +403b9cbadb04d3d1201823591cf931dc93b38e3a jdk9-b51 From 42d9f7489a0a61b3994b544711ef32f76d342c0f Mon Sep 17 00:00:00 2001 From: David Katleman Date: Thu, 19 Feb 2015 11:24:03 -0800 Subject: [PATCH 115/116] Added tag jdk9-b51 for changeset 0584b09d5a1d --- jdk/.hgtags | 1 + 1 file changed, 1 insertion(+) diff --git a/jdk/.hgtags b/jdk/.hgtags index 728bca6d5e6..1eb1a114227 100644 --- a/jdk/.hgtags +++ b/jdk/.hgtags @@ -293,3 +293,4 @@ b641c14730ac05d9ec8b4f66e6fca3dc21adb403 jdk9-b47 ebb2eb7f1aec78eb6d8cc4c96f018afa11093cde jdk9-b48 541a8cef4e0d54c3e4b52a98c6af3c31e2096669 jdk9-b49 f6b8edd397ee463be208fee27517c99101293267 jdk9-b50 +a0dad230aeb3b0d5cfd5b0715029e48d50573f8c jdk9-b51 From 5672ca6e684e9eefcfca866950302dad34ad7243 Mon Sep 17 00:00:00 2001 From: David Katleman Date: Thu, 19 Feb 2015 11:24:08 -0800 Subject: [PATCH 116/116] Added tag jdk9-b51 for changeset db20db37be55 --- nashorn/.hgtags | 1 + 1 file changed, 1 insertion(+) diff --git a/nashorn/.hgtags b/nashorn/.hgtags index e9c26d16a95..fe76f6f80fa 100644 --- a/nashorn/.hgtags +++ b/nashorn/.hgtags @@ -284,3 +284,4 @@ dd7bbdf81a537106cfa9227d1a9a57849cb26b4d jdk9-b37 f08660f30051ba0b38ad00e692979b37d107c9c4 jdk9-b48 2ae58b5f05f803a469f0f6c1ed72c6b5313f4ff0 jdk9-b49 32e48a0d59e186df8a041e1e5f8bfb0b8d2bc4cd jdk9-b50 +10b32cc48ccc2592621b28558a1cf70a0ce22fe5 jdk9-b51