Merge
This commit is contained in:
commit
9489b894a1
@ -139,3 +139,4 @@ a6c4c248e8fa350c35014fa94bab5ac1a1ac3299 jdk8-b10
|
|||||||
a4f28069d44a379cda99dd1d921d19f819726d22 jdk8-b15
|
a4f28069d44a379cda99dd1d921d19f819726d22 jdk8-b15
|
||||||
4e06ae613e99549835896720c7a68c29ad5543f5 jdk8-b17
|
4e06ae613e99549835896720c7a68c29ad5543f5 jdk8-b17
|
||||||
4e06ae613e99549835896720c7a68c29ad5543f5 jdk8-b16
|
4e06ae613e99549835896720c7a68c29ad5543f5 jdk8-b16
|
||||||
|
7010bd24cdd07bc7daef80702f39124854dec36c jdk8-b18
|
||||||
|
@ -139,3 +139,4 @@ e59c47de1ad8982ff3b0e843773a6902b36c2337 jdk8-b14
|
|||||||
7da69e7175a7c7564ee6d0e52255cbb8a57ef577 jdk8-b15
|
7da69e7175a7c7564ee6d0e52255cbb8a57ef577 jdk8-b15
|
||||||
82dc033975bb9b553b4ef97b6d483eda8de32e0f jdk8-b17
|
82dc033975bb9b553b4ef97b6d483eda8de32e0f jdk8-b17
|
||||||
82dc033975bb9b553b4ef97b6d483eda8de32e0f jdk8-b16
|
82dc033975bb9b553b4ef97b6d483eda8de32e0f jdk8-b16
|
||||||
|
312cf15d16577ef198b033d2a4cc0a52369b7343 jdk8-b18
|
||||||
|
@ -25,21 +25,21 @@
|
|||||||
|
|
||||||
# Properties for jprt
|
# Properties for jprt
|
||||||
|
|
||||||
# The release to build
|
# Locked down to jdk8
|
||||||
jprt.tools.default.release=jdk8
|
jprt.tools.default.release=jdk8
|
||||||
|
|
||||||
# The different build flavors we want, we override here so we just get these 2
|
# The different build flavors we want, we override here so we just get these 2
|
||||||
jprt.build.flavors=product,fastdebug
|
jprt.build.flavors=product,fastdebug
|
||||||
|
|
||||||
# Standard list of jprt build targets for this source tree
|
# Standard list of jprt build targets for this source tree
|
||||||
jprt.build.targets= \
|
jprt.build.targets= \
|
||||||
solaris_sparc_5.10-{product|fastdebug}, \
|
solaris_sparc_5.10-{product|fastdebug}, \
|
||||||
solaris_sparcv9_5.10-{product|fastdebug}, \
|
solaris_sparcv9_5.10-{product|fastdebug}, \
|
||||||
solaris_i586_5.10-{product|fastdebug}, \
|
solaris_i586_5.10-{product|fastdebug}, \
|
||||||
solaris_x64_5.10-{product|fastdebug}, \
|
solaris_x64_5.10-{product|fastdebug}, \
|
||||||
linux_i586_2.6-{product|fastdebug}, \
|
linux_i586_2.6-{product|fastdebug}, \
|
||||||
linux_x64_2.6-{product|fastdebug}, \
|
linux_x64_2.6-{product|fastdebug}, \
|
||||||
windows_i586_5.1-{product|fastdebug}, \
|
windows_i586_5.1-{product|fastdebug}, \
|
||||||
windows_x64_5.2-{product|fastdebug}
|
windows_x64_5.2-{product|fastdebug}
|
||||||
|
|
||||||
# Directories to be excluded from the source bundles
|
# Directories to be excluded from the source bundles
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
/*
|
/*
|
||||||
* Copyright (c) 2001, 2010, Oracle and/or its affiliates. All rights reserved.
|
* Copyright (c) 2001, 2011, Oracle and/or its affiliates. All rights reserved.
|
||||||
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
||||||
*
|
*
|
||||||
* This code is free software; you can redistribute it and/or modify it
|
* This code is free software; you can redistribute it and/or modify it
|
||||||
@ -113,6 +113,9 @@ import com.sun.corba.se.impl.protocol.giopmsgheaders.ReferenceAddr;
|
|||||||
import com.sun.corba.se.impl.transport.CorbaContactInfoListIteratorImpl;
|
import com.sun.corba.se.impl.transport.CorbaContactInfoListIteratorImpl;
|
||||||
import com.sun.corba.se.impl.util.JDKBridge;
|
import com.sun.corba.se.impl.util.JDKBridge;
|
||||||
|
|
||||||
|
import java.util.concurrent.ConcurrentMap;
|
||||||
|
import java.util.concurrent.ConcurrentHashMap;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* ClientDelegate is the RMI client-side subcontract or representation
|
* ClientDelegate is the RMI client-side subcontract or representation
|
||||||
* It implements RMI delegate as well as our internal ClientRequestDispatcher
|
* It implements RMI delegate as well as our internal ClientRequestDispatcher
|
||||||
@ -122,6 +125,9 @@ public class CorbaClientRequestDispatcherImpl
|
|||||||
implements
|
implements
|
||||||
ClientRequestDispatcher
|
ClientRequestDispatcher
|
||||||
{
|
{
|
||||||
|
private ConcurrentMap<ContactInfo, Object> locks =
|
||||||
|
new ConcurrentHashMap<ContactInfo, Object>();
|
||||||
|
|
||||||
public OutputObject beginRequest(Object self, String opName,
|
public OutputObject beginRequest(Object self, String opName,
|
||||||
boolean isOneWay, ContactInfo contactInfo)
|
boolean isOneWay, ContactInfo contactInfo)
|
||||||
{
|
{
|
||||||
@ -148,8 +154,21 @@ public class CorbaClientRequestDispatcherImpl
|
|||||||
|
|
||||||
// This locking is done so that multiple connections are not created
|
// This locking is done so that multiple connections are not created
|
||||||
// for the same endpoint
|
// for the same endpoint
|
||||||
//6929137 - Synchronized on contactInfo to avoid blocking across multiple endpoints
|
// 7046238 - Synchronization on a single monitor for contactInfo parameters
|
||||||
synchronized (contactInfo) {
|
// with identical hashCode(), so we lock on same monitor for equal parameters
|
||||||
|
// (which can refer to equal (in terms of equals()) but not the same objects)
|
||||||
|
|
||||||
|
Object lock = locks.get(contactInfo);
|
||||||
|
|
||||||
|
if (lock == null) {
|
||||||
|
Object newLock = new Object();
|
||||||
|
lock = locks.putIfAbsent(contactInfo, newLock);
|
||||||
|
if (lock == null) {
|
||||||
|
lock = newLock;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
synchronized (lock) {
|
||||||
if (contactInfo.isConnectionBased()) {
|
if (contactInfo.isConnectionBased()) {
|
||||||
if (contactInfo.shouldCacheConnection()) {
|
if (contactInfo.shouldCacheConnection()) {
|
||||||
connection = (CorbaConnection)
|
connection = (CorbaConnection)
|
||||||
@ -254,7 +273,7 @@ public class CorbaClientRequestDispatcherImpl
|
|||||||
registerWaiter(messageMediator);
|
registerWaiter(messageMediator);
|
||||||
|
|
||||||
// Do connection reclaim now
|
// Do connection reclaim now
|
||||||
synchronized (contactInfo) {
|
synchronized (lock) {
|
||||||
if (contactInfo.isConnectionBased()) {
|
if (contactInfo.isConnectionBased()) {
|
||||||
if (contactInfo.shouldCacheConnection()) {
|
if (contactInfo.shouldCacheConnection()) {
|
||||||
OutboundConnectionCache connectionCache =
|
OutboundConnectionCache connectionCache =
|
||||||
|
@ -205,3 +205,5 @@ d1f29d4e0bc60e8bd7ae961f1306d8ab33290212 jdk8-b17
|
|||||||
d1f29d4e0bc60e8bd7ae961f1306d8ab33290212 jdk8-b16
|
d1f29d4e0bc60e8bd7ae961f1306d8ab33290212 jdk8-b16
|
||||||
6de8c9ba5907e4c5ca05ac4b8d84a8e2cbd92399 hs23-b07
|
6de8c9ba5907e4c5ca05ac4b8d84a8e2cbd92399 hs23-b07
|
||||||
a2fef924d8e6f37dac2a887315e3502876cc8e24 hs23-b08
|
a2fef924d8e6f37dac2a887315e3502876cc8e24 hs23-b08
|
||||||
|
61165f53f1656b9f99e4fb806429bf98b99d59c3 jdk8-b18
|
||||||
|
4bcf61041217f8677dcec18e90e9196acc945bba hs23-b09
|
||||||
|
@ -35,7 +35,7 @@ HOTSPOT_VM_COPYRIGHT=Copyright 2011
|
|||||||
|
|
||||||
HS_MAJOR_VER=23
|
HS_MAJOR_VER=23
|
||||||
HS_MINOR_VER=0
|
HS_MINOR_VER=0
|
||||||
HS_BUILD_NUMBER=08
|
HS_BUILD_NUMBER=09
|
||||||
|
|
||||||
JDK_MAJOR_VER=1
|
JDK_MAJOR_VER=1
|
||||||
JDK_MINOR_VER=8
|
JDK_MINOR_VER=8
|
||||||
|
@ -5968,7 +5968,9 @@ void MacroAssembler::call_VM_base(Register oop_result,
|
|||||||
assert(number_of_arguments >= 0 , "cannot have negative number of arguments");
|
assert(number_of_arguments >= 0 , "cannot have negative number of arguments");
|
||||||
LP64_ONLY(assert(java_thread == r15_thread, "unexpected register"));
|
LP64_ONLY(assert(java_thread == r15_thread, "unexpected register"));
|
||||||
#ifdef ASSERT
|
#ifdef ASSERT
|
||||||
LP64_ONLY(if (UseCompressedOops) verify_heapbase("call_VM_base");)
|
// TraceBytecodes does not use r12 but saves it over the call, so don't verify
|
||||||
|
// r12 is the heapbase.
|
||||||
|
LP64_ONLY(if (UseCompressedOops && !TraceBytecodes) verify_heapbase("call_VM_base");)
|
||||||
#endif // ASSERT
|
#endif // ASSERT
|
||||||
|
|
||||||
assert(java_thread != oop_result , "cannot use the same register for java_thread & oop_result");
|
assert(java_thread != oop_result , "cannot use the same register for java_thread & oop_result");
|
||||||
|
@ -33,7 +33,6 @@
|
|||||||
// All local includes have been commented out.
|
// All local includes have been commented out.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
|
||||||
#ifndef JVM_MD_H
|
#ifndef JVM_MD_H
|
||||||
#define JVM_MD_H
|
#define JVM_MD_H
|
||||||
|
|
||||||
@ -59,6 +58,7 @@
|
|||||||
|
|
||||||
#include <dirent.h> /* For DIR */
|
#include <dirent.h> /* For DIR */
|
||||||
#include <sys/param.h> /* For MAXPATHLEN */
|
#include <sys/param.h> /* For MAXPATHLEN */
|
||||||
|
#include <sys/socket.h> /* For socklen_t */
|
||||||
#include <unistd.h> /* For F_OK, R_OK, W_OK */
|
#include <unistd.h> /* For F_OK, R_OK, W_OK */
|
||||||
|
|
||||||
#define JNI_ONLOAD_SYMBOLS {"JNI_OnLoad"}
|
#define JNI_ONLOAD_SYMBOLS {"JNI_OnLoad"}
|
||||||
@ -128,8 +128,4 @@
|
|||||||
#endif
|
#endif
|
||||||
#endif /* JVM_MD_H */
|
#endif /* JVM_MD_H */
|
||||||
|
|
||||||
// Reconciliation History
|
|
||||||
// jvm_solaris.h 1.6 99/06/22 16:38:47
|
|
||||||
// End
|
|
||||||
|
|
||||||
#endif // OS_BSD_VM_JVM_BSD_H
|
#endif // OS_BSD_VM_JVM_BSD_H
|
||||||
|
@ -150,7 +150,6 @@
|
|||||||
|
|
||||||
// for timer info max values which include all bits
|
// for timer info max values which include all bits
|
||||||
#define ALL_64_BITS CONST64(0xFFFFFFFFFFFFFFFF)
|
#define ALL_64_BITS CONST64(0xFFFFFFFFFFFFFFFF)
|
||||||
#define SEC_IN_NANOSECS 1000000000LL
|
|
||||||
|
|
||||||
#define LARGEPAGES_BIT (1 << 6)
|
#define LARGEPAGES_BIT (1 << 6)
|
||||||
////////////////////////////////////////////////////////////////////////////////
|
////////////////////////////////////////////////////////////////////////////////
|
||||||
@ -3445,8 +3444,6 @@ size_t os::read(int fd, void *buf, unsigned int nBytes) {
|
|||||||
// generates a SIGUSRx signal. Note that SIGUSR1 can interfere with
|
// generates a SIGUSRx signal. Note that SIGUSR1 can interfere with
|
||||||
// SIGSEGV, see 4355769.
|
// SIGSEGV, see 4355769.
|
||||||
|
|
||||||
const int NANOSECS_PER_MILLISECS = 1000000;
|
|
||||||
|
|
||||||
int os::sleep(Thread* thread, jlong millis, bool interruptible) {
|
int os::sleep(Thread* thread, jlong millis, bool interruptible) {
|
||||||
assert(thread == Thread::current(), "thread consistency check");
|
assert(thread == Thread::current(), "thread consistency check");
|
||||||
|
|
||||||
@ -3469,7 +3466,7 @@ int os::sleep(Thread* thread, jlong millis, bool interruptible) {
|
|||||||
// not a guarantee() because JVM should not abort on kernel/glibc bugs
|
// not a guarantee() because JVM should not abort on kernel/glibc bugs
|
||||||
assert(!Bsd::supports_monotonic_clock(), "time moving backwards");
|
assert(!Bsd::supports_monotonic_clock(), "time moving backwards");
|
||||||
} else {
|
} else {
|
||||||
millis -= (newtime - prevtime) / NANOSECS_PER_MILLISECS;
|
millis -= (newtime - prevtime) / NANOSECS_PER_MILLISEC;
|
||||||
}
|
}
|
||||||
|
|
||||||
if(millis <= 0) {
|
if(millis <= 0) {
|
||||||
@ -3508,7 +3505,7 @@ int os::sleep(Thread* thread, jlong millis, bool interruptible) {
|
|||||||
// not a guarantee() because JVM should not abort on kernel/glibc bugs
|
// not a guarantee() because JVM should not abort on kernel/glibc bugs
|
||||||
assert(!Bsd::supports_monotonic_clock(), "time moving backwards");
|
assert(!Bsd::supports_monotonic_clock(), "time moving backwards");
|
||||||
} else {
|
} else {
|
||||||
millis -= (newtime - prevtime) / NANOSECS_PER_MILLISECS;
|
millis -= (newtime - prevtime) / NANOSECS_PER_MILLISEC;
|
||||||
}
|
}
|
||||||
|
|
||||||
if(millis <= 0) break ;
|
if(millis <= 0) break ;
|
||||||
@ -4197,7 +4194,7 @@ jlong os::Bsd::fast_thread_cpu_time(clockid_t clockid) {
|
|||||||
int rc = os::Bsd::clock_gettime(clockid, &tp);
|
int rc = os::Bsd::clock_gettime(clockid, &tp);
|
||||||
assert(rc == 0, "clock_gettime is expected to return 0 code");
|
assert(rc == 0, "clock_gettime is expected to return 0 code");
|
||||||
|
|
||||||
return (tp.tv_sec * SEC_IN_NANOSECS) + tp.tv_nsec;
|
return (tp.tv_sec * NANOSECS_PER_SEC) + tp.tv_nsec;
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
@ -5522,9 +5519,6 @@ void os::PlatformEvent::unpark() {
|
|||||||
* is no need to track notifications.
|
* is no need to track notifications.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
|
||||||
#define NANOSECS_PER_SEC 1000000000
|
|
||||||
#define NANOSECS_PER_MILLISEC 1000000
|
|
||||||
#define MAX_SECS 100000000
|
#define MAX_SECS 100000000
|
||||||
/*
|
/*
|
||||||
* This code is common to bsd and solaris and will be moved to a
|
* This code is common to bsd and solaris and will be moved to a
|
||||||
|
@ -198,15 +198,15 @@ inline int os::socket(int domain, int type, int protocol) {
|
|||||||
return ::socket(domain, type, protocol);
|
return ::socket(domain, type, protocol);
|
||||||
}
|
}
|
||||||
|
|
||||||
inline int os::recv(int fd, char *buf, int nBytes, int flags) {
|
inline int os::recv(int fd, char* buf, size_t nBytes, uint flags) {
|
||||||
RESTARTABLE_RETURN_INT(::recv(fd, buf, nBytes, (unsigned int) flags));
|
RESTARTABLE_RETURN_INT(::recv(fd, buf, nBytes, flags));
|
||||||
}
|
}
|
||||||
|
|
||||||
inline int os::send(int fd, char *buf, int nBytes, int flags) {
|
inline int os::send(int fd, char* buf, size_t nBytes, uint flags) {
|
||||||
RESTARTABLE_RETURN_INT(::send(fd, buf, nBytes, (unsigned int) flags));
|
RESTARTABLE_RETURN_INT(::send(fd, buf, nBytes, flags));
|
||||||
}
|
}
|
||||||
|
|
||||||
inline int os::raw_send(int fd, char *buf, int nBytes, int flags) {
|
inline int os::raw_send(int fd, char* buf, size_t nBytes, uint flags) {
|
||||||
return os::send(fd, buf, nBytes, flags);
|
return os::send(fd, buf, nBytes, flags);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -246,57 +246,52 @@ inline int os::listen(int fd, int count) {
|
|||||||
return ::listen(fd, count);
|
return ::listen(fd, count);
|
||||||
}
|
}
|
||||||
|
|
||||||
inline int os::connect(int fd, struct sockaddr *him, int len) {
|
inline int os::connect(int fd, struct sockaddr* him, socklen_t len) {
|
||||||
RESTARTABLE_RETURN_INT(::connect(fd, him, len));
|
RESTARTABLE_RETURN_INT(::connect(fd, him, len));
|
||||||
}
|
}
|
||||||
|
|
||||||
inline int os::accept(int fd, struct sockaddr *him, int *len) {
|
inline int os::accept(int fd, struct sockaddr* him, socklen_t* len) {
|
||||||
// This cast is from int to unsigned int on bsd. Since we
|
|
||||||
// only pass the parameter "len" around the vm and don't try to
|
|
||||||
// fetch it's value, this cast is safe for now. The java.net group
|
|
||||||
// may need and want to change this interface someday if socklen_t goes
|
|
||||||
// to 64 bits on some platform that we support.
|
|
||||||
|
|
||||||
// At least OpenBSD and FreeBSD can return EINTR from accept.
|
// At least OpenBSD and FreeBSD can return EINTR from accept.
|
||||||
RESTARTABLE_RETURN_INT(::accept(fd, him, (socklen_t *)len));
|
RESTARTABLE_RETURN_INT(::accept(fd, him, len));
|
||||||
}
|
}
|
||||||
|
|
||||||
inline int os::recvfrom(int fd, char *buf, int nBytes, int flags,
|
inline int os::recvfrom(int fd, char* buf, size_t nBytes, uint flags,
|
||||||
sockaddr *from, int *fromlen) {
|
sockaddr* from, socklen_t* fromlen) {
|
||||||
RESTARTABLE_RETURN_INT(::recvfrom(fd, buf, nBytes, (unsigned int) flags, from, (socklen_t *)fromlen));
|
RESTARTABLE_RETURN_INT((int)::recvfrom(fd, buf, nBytes, flags, from, fromlen));
|
||||||
}
|
}
|
||||||
|
|
||||||
inline int os::sendto(int fd, char *buf, int len, int flags,
|
inline int os::sendto(int fd, char* buf, size_t len, uint flags,
|
||||||
struct sockaddr *to, int tolen) {
|
struct sockaddr *to, socklen_t tolen) {
|
||||||
RESTARTABLE_RETURN_INT(::sendto(fd, buf, len, (unsigned int) flags, to, tolen));
|
RESTARTABLE_RETURN_INT((int)::sendto(fd, buf, len, flags, to, tolen));
|
||||||
}
|
}
|
||||||
|
|
||||||
inline int os::socket_shutdown(int fd, int howto){
|
inline int os::socket_shutdown(int fd, int howto) {
|
||||||
return ::shutdown(fd, howto);
|
return ::shutdown(fd, howto);
|
||||||
}
|
}
|
||||||
|
|
||||||
inline int os::bind(int fd, struct sockaddr *him, int len){
|
inline int os::bind(int fd, struct sockaddr* him, socklen_t len) {
|
||||||
return ::bind(fd, him, len);
|
return ::bind(fd, him, len);
|
||||||
}
|
}
|
||||||
|
|
||||||
inline int os::get_sock_name(int fd, struct sockaddr *him, int *len){
|
inline int os::get_sock_name(int fd, struct sockaddr* him, socklen_t* len) {
|
||||||
return ::getsockname(fd, him, (socklen_t *)len);
|
return ::getsockname(fd, him, len);
|
||||||
}
|
}
|
||||||
|
|
||||||
inline int os::get_host_name(char* name, int namelen){
|
inline int os::get_host_name(char* name, int namelen) {
|
||||||
return ::gethostname(name, namelen);
|
return ::gethostname(name, namelen);
|
||||||
}
|
}
|
||||||
|
|
||||||
inline struct hostent* os::get_host_by_name(char* name) {
|
inline struct hostent* os::get_host_by_name(char* name) {
|
||||||
return ::gethostbyname(name);
|
return ::gethostbyname(name);
|
||||||
}
|
}
|
||||||
|
|
||||||
inline int os::get_sock_opt(int fd, int level, int optname,
|
inline int os::get_sock_opt(int fd, int level, int optname,
|
||||||
char *optval, int* optlen){
|
char *optval, socklen_t* optlen) {
|
||||||
return ::getsockopt(fd, level, optname, optval, (socklen_t *)optlen);
|
return ::getsockopt(fd, level, optname, optval, optlen);
|
||||||
}
|
}
|
||||||
|
|
||||||
inline int os::set_sock_opt(int fd, int level, int optname,
|
inline int os::set_sock_opt(int fd, int level, int optname,
|
||||||
const char *optval, int optlen){
|
const char* optval, socklen_t optlen) {
|
||||||
return ::setsockopt(fd, level, optname, optval, optlen);
|
return ::setsockopt(fd, level, optname, optval, optlen);
|
||||||
}
|
}
|
||||||
#endif // OS_BSD_VM_OS_BSD_INLINE_HPP
|
#endif // OS_BSD_VM_OS_BSD_INLINE_HPP
|
||||||
|
@ -33,7 +33,6 @@
|
|||||||
// All local includes have been commented out.
|
// All local includes have been commented out.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
|
||||||
#ifndef JVM_MD_H
|
#ifndef JVM_MD_H
|
||||||
#define JVM_MD_H
|
#define JVM_MD_H
|
||||||
|
|
||||||
@ -44,6 +43,7 @@
|
|||||||
|
|
||||||
#include <dirent.h> /* For DIR */
|
#include <dirent.h> /* For DIR */
|
||||||
#include <sys/param.h> /* For MAXPATHLEN */
|
#include <sys/param.h> /* For MAXPATHLEN */
|
||||||
|
#include <sys/socket.h> /* For socklen_t */
|
||||||
#include <unistd.h> /* For F_OK, R_OK, W_OK */
|
#include <unistd.h> /* For F_OK, R_OK, W_OK */
|
||||||
|
|
||||||
#define JNI_ONLOAD_SYMBOLS {"JNI_OnLoad"}
|
#define JNI_ONLOAD_SYMBOLS {"JNI_OnLoad"}
|
||||||
@ -95,8 +95,4 @@
|
|||||||
|
|
||||||
#endif /* JVM_MD_H */
|
#endif /* JVM_MD_H */
|
||||||
|
|
||||||
// Reconciliation History
|
|
||||||
// jvm_solaris.h 1.6 99/06/22 16:38:47
|
|
||||||
// End
|
|
||||||
|
|
||||||
#endif // OS_LINUX_VM_JVM_LINUX_H
|
#endif // OS_LINUX_VM_JVM_LINUX_H
|
||||||
|
@ -127,7 +127,6 @@
|
|||||||
|
|
||||||
// for timer info max values which include all bits
|
// for timer info max values which include all bits
|
||||||
#define ALL_64_BITS CONST64(0xFFFFFFFFFFFFFFFF)
|
#define ALL_64_BITS CONST64(0xFFFFFFFFFFFFFFFF)
|
||||||
#define SEC_IN_NANOSECS 1000000000LL
|
|
||||||
|
|
||||||
#define LARGEPAGES_BIT (1 << 6)
|
#define LARGEPAGES_BIT (1 << 6)
|
||||||
////////////////////////////////////////////////////////////////////////////////
|
////////////////////////////////////////////////////////////////////////////////
|
||||||
@ -3259,8 +3258,6 @@ size_t os::read(int fd, void *buf, unsigned int nBytes) {
|
|||||||
// generates a SIGUSRx signal. Note that SIGUSR1 can interfere with
|
// generates a SIGUSRx signal. Note that SIGUSR1 can interfere with
|
||||||
// SIGSEGV, see 4355769.
|
// SIGSEGV, see 4355769.
|
||||||
|
|
||||||
const int NANOSECS_PER_MILLISECS = 1000000;
|
|
||||||
|
|
||||||
int os::sleep(Thread* thread, jlong millis, bool interruptible) {
|
int os::sleep(Thread* thread, jlong millis, bool interruptible) {
|
||||||
assert(thread == Thread::current(), "thread consistency check");
|
assert(thread == Thread::current(), "thread consistency check");
|
||||||
|
|
||||||
@ -3283,7 +3280,7 @@ int os::sleep(Thread* thread, jlong millis, bool interruptible) {
|
|||||||
// not a guarantee() because JVM should not abort on kernel/glibc bugs
|
// not a guarantee() because JVM should not abort on kernel/glibc bugs
|
||||||
assert(!Linux::supports_monotonic_clock(), "time moving backwards");
|
assert(!Linux::supports_monotonic_clock(), "time moving backwards");
|
||||||
} else {
|
} else {
|
||||||
millis -= (newtime - prevtime) / NANOSECS_PER_MILLISECS;
|
millis -= (newtime - prevtime) / NANOSECS_PER_MILLISEC;
|
||||||
}
|
}
|
||||||
|
|
||||||
if(millis <= 0) {
|
if(millis <= 0) {
|
||||||
@ -3322,7 +3319,7 @@ int os::sleep(Thread* thread, jlong millis, bool interruptible) {
|
|||||||
// not a guarantee() because JVM should not abort on kernel/glibc bugs
|
// not a guarantee() because JVM should not abort on kernel/glibc bugs
|
||||||
assert(!Linux::supports_monotonic_clock(), "time moving backwards");
|
assert(!Linux::supports_monotonic_clock(), "time moving backwards");
|
||||||
} else {
|
} else {
|
||||||
millis -= (newtime - prevtime) / NANOSECS_PER_MILLISECS;
|
millis -= (newtime - prevtime) / NANOSECS_PER_MILLISEC;
|
||||||
}
|
}
|
||||||
|
|
||||||
if(millis <= 0) break ;
|
if(millis <= 0) break ;
|
||||||
@ -3924,7 +3921,7 @@ jlong os::Linux::fast_thread_cpu_time(clockid_t clockid) {
|
|||||||
int rc = os::Linux::clock_gettime(clockid, &tp);
|
int rc = os::Linux::clock_gettime(clockid, &tp);
|
||||||
assert(rc == 0, "clock_gettime is expected to return 0 code");
|
assert(rc == 0, "clock_gettime is expected to return 0 code");
|
||||||
|
|
||||||
return (tp.tv_sec * SEC_IN_NANOSECS) + tp.tv_nsec;
|
return (tp.tv_sec * NANOSECS_PER_SEC) + tp.tv_nsec;
|
||||||
}
|
}
|
||||||
|
|
||||||
/////
|
/////
|
||||||
@ -5165,9 +5162,6 @@ void os::PlatformEvent::unpark() {
|
|||||||
* is no need to track notifications.
|
* is no need to track notifications.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
|
||||||
#define NANOSECS_PER_SEC 1000000000
|
|
||||||
#define NANOSECS_PER_MILLISEC 1000000
|
|
||||||
#define MAX_SECS 100000000
|
#define MAX_SECS 100000000
|
||||||
/*
|
/*
|
||||||
* This code is common to linux and solaris and will be moved to a
|
* This code is common to linux and solaris and will be moved to a
|
||||||
|
@ -202,15 +202,15 @@ inline int os::socket(int domain, int type, int protocol) {
|
|||||||
return ::socket(domain, type, protocol);
|
return ::socket(domain, type, protocol);
|
||||||
}
|
}
|
||||||
|
|
||||||
inline int os::recv(int fd, char *buf, int nBytes, int flags) {
|
inline int os::recv(int fd, char* buf, size_t nBytes, uint flags) {
|
||||||
RESTARTABLE_RETURN_INT(::recv(fd, buf, nBytes, (unsigned int) flags));
|
RESTARTABLE_RETURN_INT(::recv(fd, buf, nBytes, flags));
|
||||||
}
|
}
|
||||||
|
|
||||||
inline int os::send(int fd, char *buf, int nBytes, int flags) {
|
inline int os::send(int fd, char* buf, size_t nBytes, uint flags) {
|
||||||
RESTARTABLE_RETURN_INT(::send(fd, buf, nBytes, (unsigned int) flags));
|
RESTARTABLE_RETURN_INT(::send(fd, buf, nBytes, flags));
|
||||||
}
|
}
|
||||||
|
|
||||||
inline int os::raw_send(int fd, char *buf, int nBytes, int flags) {
|
inline int os::raw_send(int fd, char* buf, size_t nBytes, uint flags) {
|
||||||
return os::send(fd, buf, nBytes, flags);
|
return os::send(fd, buf, nBytes, flags);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -250,57 +250,53 @@ inline int os::listen(int fd, int count) {
|
|||||||
return ::listen(fd, count);
|
return ::listen(fd, count);
|
||||||
}
|
}
|
||||||
|
|
||||||
inline int os::connect(int fd, struct sockaddr *him, int len) {
|
inline int os::connect(int fd, struct sockaddr* him, socklen_t len) {
|
||||||
RESTARTABLE_RETURN_INT(::connect(fd, him, len));
|
RESTARTABLE_RETURN_INT(::connect(fd, him, len));
|
||||||
}
|
}
|
||||||
|
|
||||||
inline int os::accept(int fd, struct sockaddr *him, int *len) {
|
inline int os::accept(int fd, struct sockaddr* him, socklen_t* len) {
|
||||||
// This cast is from int to unsigned int on linux. Since we
|
// Linux doc says this can't return EINTR, unlike accept() on Solaris.
|
||||||
// only pass the parameter "len" around the vm and don't try to
|
// But see attachListener_linux.cpp, LinuxAttachListener::dequeue().
|
||||||
// fetch it's value, this cast is safe for now. The java.net group
|
return (int)::accept(fd, him, len);
|
||||||
// may need and want to change this interface someday if socklen_t goes
|
|
||||||
// to 64 bits on some platform that we support.
|
|
||||||
// Linux doc says this can't return EINTR, unlike accept() on Solaris
|
|
||||||
|
|
||||||
return ::accept(fd, him, (socklen_t *)len);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
inline int os::recvfrom(int fd, char *buf, int nBytes, int flags,
|
inline int os::recvfrom(int fd, char* buf, size_t nBytes, uint flags,
|
||||||
sockaddr *from, int *fromlen) {
|
sockaddr* from, socklen_t* fromlen) {
|
||||||
RESTARTABLE_RETURN_INT(::recvfrom(fd, buf, nBytes, (unsigned int) flags, from, (socklen_t *)fromlen));
|
RESTARTABLE_RETURN_INT((int)::recvfrom(fd, buf, nBytes, flags, from, fromlen));
|
||||||
}
|
}
|
||||||
|
|
||||||
inline int os::sendto(int fd, char *buf, int len, int flags,
|
inline int os::sendto(int fd, char* buf, size_t len, uint flags,
|
||||||
struct sockaddr *to, int tolen) {
|
struct sockaddr* to, socklen_t tolen) {
|
||||||
RESTARTABLE_RETURN_INT(::sendto(fd, buf, len, (unsigned int) flags, to, tolen));
|
RESTARTABLE_RETURN_INT((int)::sendto(fd, buf, len, flags, to, tolen));
|
||||||
}
|
}
|
||||||
|
|
||||||
inline int os::socket_shutdown(int fd, int howto){
|
inline int os::socket_shutdown(int fd, int howto) {
|
||||||
return ::shutdown(fd, howto);
|
return ::shutdown(fd, howto);
|
||||||
}
|
}
|
||||||
|
|
||||||
inline int os::bind(int fd, struct sockaddr *him, int len){
|
inline int os::bind(int fd, struct sockaddr* him, socklen_t len) {
|
||||||
return ::bind(fd, him, len);
|
return ::bind(fd, him, len);
|
||||||
}
|
}
|
||||||
|
|
||||||
inline int os::get_sock_name(int fd, struct sockaddr *him, int *len){
|
inline int os::get_sock_name(int fd, struct sockaddr* him, socklen_t* len) {
|
||||||
return ::getsockname(fd, him, (socklen_t *)len);
|
return ::getsockname(fd, him, len);
|
||||||
}
|
}
|
||||||
|
|
||||||
inline int os::get_host_name(char* name, int namelen){
|
inline int os::get_host_name(char* name, int namelen) {
|
||||||
return ::gethostname(name, namelen);
|
return ::gethostname(name, namelen);
|
||||||
}
|
}
|
||||||
|
|
||||||
inline struct hostent* os::get_host_by_name(char* name) {
|
inline struct hostent* os::get_host_by_name(char* name) {
|
||||||
return ::gethostbyname(name);
|
return ::gethostbyname(name);
|
||||||
}
|
}
|
||||||
|
|
||||||
inline int os::get_sock_opt(int fd, int level, int optname,
|
inline int os::get_sock_opt(int fd, int level, int optname,
|
||||||
char *optval, int* optlen){
|
char* optval, socklen_t* optlen) {
|
||||||
return ::getsockopt(fd, level, optname, optval, (socklen_t *)optlen);
|
return ::getsockopt(fd, level, optname, optval, optlen);
|
||||||
}
|
}
|
||||||
|
|
||||||
inline int os::set_sock_opt(int fd, int level, int optname,
|
inline int os::set_sock_opt(int fd, int level, int optname,
|
||||||
const char *optval, int optlen){
|
const char* optval, socklen_t optlen) {
|
||||||
return ::setsockopt(fd, level, optname, optval, optlen);
|
return ::setsockopt(fd, level, optname, optval, optlen);
|
||||||
}
|
}
|
||||||
#endif // OS_LINUX_VM_OS_LINUX_INLINE_HPP
|
#endif // OS_LINUX_VM_OS_LINUX_INLINE_HPP
|
||||||
|
@ -33,7 +33,6 @@
|
|||||||
// All local includes have been commented out.
|
// All local includes have been commented out.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
|
||||||
#ifndef JVM_MD_H
|
#ifndef JVM_MD_H
|
||||||
#define JVM_MD_H
|
#define JVM_MD_H
|
||||||
|
|
||||||
@ -44,6 +43,7 @@
|
|||||||
|
|
||||||
#include <dirent.h> /* For DIR */
|
#include <dirent.h> /* For DIR */
|
||||||
#include <sys/param.h> /* For MAXPATHLEN */
|
#include <sys/param.h> /* For MAXPATHLEN */
|
||||||
|
#include <sys/socket.h> /* For socklen_t */
|
||||||
#include <unistd.h> /* For F_OK, R_OK, W_OK */
|
#include <unistd.h> /* For F_OK, R_OK, W_OK */
|
||||||
#include <sys/int_types.h> /* for intptr_t types (64 Bit cleanliness) */
|
#include <sys/int_types.h> /* for intptr_t types (64 Bit cleanliness) */
|
||||||
|
|
||||||
@ -82,7 +82,6 @@
|
|||||||
#define JVM_O_EXCL O_EXCL
|
#define JVM_O_EXCL O_EXCL
|
||||||
#define JVM_O_CREAT O_CREAT
|
#define JVM_O_CREAT O_CREAT
|
||||||
|
|
||||||
|
|
||||||
/* Signal definitions */
|
/* Signal definitions */
|
||||||
|
|
||||||
#define BREAK_SIGNAL SIGQUIT /* Thread dumping support. */
|
#define BREAK_SIGNAL SIGQUIT /* Thread dumping support. */
|
||||||
|
@ -1674,7 +1674,6 @@ void* os::thread_local_storage_at(int index) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
const int NANOSECS_PER_MILLISECS = 1000000;
|
|
||||||
// gethrtime can move backwards if read from one cpu and then a different cpu
|
// gethrtime can move backwards if read from one cpu and then a different cpu
|
||||||
// getTimeNanos is guaranteed to not move backward on Solaris
|
// getTimeNanos is guaranteed to not move backward on Solaris
|
||||||
// local spinloop created as faster for a CAS on an int than
|
// local spinloop created as faster for a CAS on an int than
|
||||||
@ -1803,7 +1802,7 @@ double os::elapsedVTime() {
|
|||||||
// getTimeMillis guaranteed to not move backwards on Solaris
|
// getTimeMillis guaranteed to not move backwards on Solaris
|
||||||
jlong getTimeMillis() {
|
jlong getTimeMillis() {
|
||||||
jlong nanotime = getTimeNanos();
|
jlong nanotime = getTimeNanos();
|
||||||
return (jlong)(nanotime / NANOSECS_PER_MILLISECS);
|
return (jlong)(nanotime / NANOSECS_PER_MILLISEC);
|
||||||
}
|
}
|
||||||
|
|
||||||
// Must return millis since Jan 1 1970 for JVM_CurrentTimeMillis
|
// Must return millis since Jan 1 1970 for JVM_CurrentTimeMillis
|
||||||
@ -6064,10 +6063,7 @@ void os::PlatformEvent::unpark() {
|
|||||||
* is no need to track notifications.
|
* is no need to track notifications.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
#define NANOSECS_PER_SEC 1000000000
|
|
||||||
#define NANOSECS_PER_MILLISEC 1000000
|
|
||||||
#define MAX_SECS 100000000
|
#define MAX_SECS 100000000
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* This code is common to linux and solaris and will be moved to a
|
* This code is common to linux and solaris and will be moved to a
|
||||||
* common place in dolphin.
|
* common place in dolphin.
|
||||||
@ -6363,17 +6359,16 @@ int os::socket_close(int fd) {
|
|||||||
RESTARTABLE_RETURN_INT(::close(fd));
|
RESTARTABLE_RETURN_INT(::close(fd));
|
||||||
}
|
}
|
||||||
|
|
||||||
int os::recv(int fd, char *buf, int nBytes, int flags) {
|
int os::recv(int fd, char* buf, size_t nBytes, uint flags) {
|
||||||
INTERRUPTIBLE_RETURN_INT(::recv(fd, buf, nBytes, flags), os::Solaris::clear_interrupted);
|
INTERRUPTIBLE_RETURN_INT((int)::recv(fd, buf, nBytes, flags), os::Solaris::clear_interrupted);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
int os::send(int fd, char* buf, size_t nBytes, uint flags) {
|
||||||
int os::send(int fd, char *buf, int nBytes, int flags) {
|
INTERRUPTIBLE_RETURN_INT((int)::send(fd, buf, nBytes, flags), os::Solaris::clear_interrupted);
|
||||||
INTERRUPTIBLE_RETURN_INT(::send(fd, buf, nBytes, flags), os::Solaris::clear_interrupted);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
int os::raw_send(int fd, char *buf, int nBytes, int flags) {
|
int os::raw_send(int fd, char* buf, size_t nBytes, uint flags) {
|
||||||
RESTARTABLE_RETURN_INT(::send(fd, buf, nBytes, flags));
|
RESTARTABLE_RETURN_INT((int)::send(fd, buf, nBytes, flags));
|
||||||
}
|
}
|
||||||
|
|
||||||
// As both poll and select can be interrupted by signals, we have to be
|
// As both poll and select can be interrupted by signals, we have to be
|
||||||
@ -6408,19 +6403,19 @@ int os::timeout(int fd, long timeout) {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
int os::connect(int fd, struct sockaddr *him, int len) {
|
int os::connect(int fd, struct sockaddr *him, socklen_t len) {
|
||||||
int _result;
|
int _result;
|
||||||
INTERRUPTIBLE_NORESTART(::connect(fd, him, len), _result,
|
INTERRUPTIBLE_NORESTART(::connect(fd, him, len), _result,\
|
||||||
os::Solaris::clear_interrupted);
|
os::Solaris::clear_interrupted);
|
||||||
|
|
||||||
// Depending on when thread interruption is reset, _result could be
|
// Depending on when thread interruption is reset, _result could be
|
||||||
// one of two values when errno == EINTR
|
// one of two values when errno == EINTR
|
||||||
|
|
||||||
if (((_result == OS_INTRPT) || (_result == OS_ERR))
|
if (((_result == OS_INTRPT) || (_result == OS_ERR))
|
||||||
&& (errno == EINTR)) {
|
&& (errno == EINTR)) {
|
||||||
/* restarting a connect() changes its errno semantics */
|
/* restarting a connect() changes its errno semantics */
|
||||||
INTERRUPTIBLE(::connect(fd, him, len), _result,
|
INTERRUPTIBLE(::connect(fd, him, len), _result,\
|
||||||
os::Solaris::clear_interrupted);
|
os::Solaris::clear_interrupted);
|
||||||
/* undo these changes */
|
/* undo these changes */
|
||||||
if (_result == OS_ERR) {
|
if (_result == OS_ERR) {
|
||||||
if (errno == EALREADY) {
|
if (errno == EALREADY) {
|
||||||
@ -6434,43 +6429,38 @@ int os::connect(int fd, struct sockaddr *him, int len) {
|
|||||||
return _result;
|
return _result;
|
||||||
}
|
}
|
||||||
|
|
||||||
int os::accept(int fd, struct sockaddr *him, int *len) {
|
int os::accept(int fd, struct sockaddr* him, socklen_t* len) {
|
||||||
if (fd < 0)
|
if (fd < 0) {
|
||||||
return OS_ERR;
|
return OS_ERR;
|
||||||
INTERRUPTIBLE_RETURN_INT((int)::accept(fd, him,\
|
}
|
||||||
(socklen_t*) len), os::Solaris::clear_interrupted);
|
INTERRUPTIBLE_RETURN_INT((int)::accept(fd, him, len),\
|
||||||
}
|
os::Solaris::clear_interrupted);
|
||||||
|
|
||||||
int os::recvfrom(int fd, char *buf, int nBytes, int flags,
|
|
||||||
sockaddr *from, int *fromlen) {
|
|
||||||
//%%note jvm_r11
|
|
||||||
INTERRUPTIBLE_RETURN_INT((int)::recvfrom(fd, buf, nBytes,\
|
|
||||||
flags, from, fromlen), os::Solaris::clear_interrupted);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
int os::sendto(int fd, char *buf, int len, int flags,
|
int os::recvfrom(int fd, char* buf, size_t nBytes, uint flags,
|
||||||
struct sockaddr *to, int tolen) {
|
sockaddr* from, socklen_t* fromlen) {
|
||||||
//%%note jvm_r11
|
INTERRUPTIBLE_RETURN_INT((int)::recvfrom(fd, buf, nBytes, flags, from, fromlen),\
|
||||||
INTERRUPTIBLE_RETURN_INT((int)::sendto(fd, buf, len, flags,\
|
os::Solaris::clear_interrupted);
|
||||||
to, tolen), os::Solaris::clear_interrupted);
|
}
|
||||||
|
|
||||||
|
int os::sendto(int fd, char* buf, size_t len, uint flags,
|
||||||
|
struct sockaddr* to, socklen_t tolen) {
|
||||||
|
INTERRUPTIBLE_RETURN_INT((int)::sendto(fd, buf, len, flags, to, tolen),\
|
||||||
|
os::Solaris::clear_interrupted);
|
||||||
}
|
}
|
||||||
|
|
||||||
int os::socket_available(int fd, jint *pbytes) {
|
int os::socket_available(int fd, jint *pbytes) {
|
||||||
if (fd < 0)
|
if (fd < 0) {
|
||||||
return OS_OK;
|
return OS_OK;
|
||||||
|
}
|
||||||
int ret;
|
int ret;
|
||||||
|
RESTARTABLE(::ioctl(fd, FIONREAD, pbytes), ret);
|
||||||
RESTARTABLE(::ioctl(fd, FIONREAD, pbytes), ret);
|
// note: ioctl can return 0 when successful, JVM_SocketAvailable
|
||||||
|
// is expected to return 0 on failure and 1 on success to the jdk.
|
||||||
//%% note ioctl can return 0 when successful, JVM_SocketAvailable
|
return (ret == OS_ERR) ? 0 : 1;
|
||||||
// is expected to return 0 on failure and 1 on success to the jdk.
|
|
||||||
|
|
||||||
return (ret == OS_ERR) ? 0 : 1;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
int os::bind(int fd, struct sockaddr* him, socklen_t len) {
|
||||||
int os::bind(int fd, struct sockaddr *him, int len) {
|
|
||||||
INTERRUPTIBLE_RETURN_INT_NORESTART(::bind(fd, him, len),\
|
INTERRUPTIBLE_RETURN_INT_NORESTART(::bind(fd, him, len),\
|
||||||
os::Solaris::clear_interrupted);
|
os::Solaris::clear_interrupted);
|
||||||
}
|
}
|
||||||
|
@ -243,24 +243,25 @@ inline int os::socket_shutdown(int fd, int howto){
|
|||||||
return ::shutdown(fd, howto);
|
return ::shutdown(fd, howto);
|
||||||
}
|
}
|
||||||
|
|
||||||
inline int os::get_sock_name(int fd, struct sockaddr *him, int *len){
|
inline int os::get_sock_name(int fd, struct sockaddr* him, socklen_t* len){
|
||||||
return ::getsockname(fd, him, (socklen_t*) len);
|
return ::getsockname(fd, him, len);
|
||||||
}
|
}
|
||||||
|
|
||||||
inline int os::get_host_name(char* name, int namelen){
|
inline int os::get_host_name(char* name, int namelen){
|
||||||
return ::gethostname(name, namelen);
|
return ::gethostname(name, namelen);
|
||||||
}
|
}
|
||||||
|
|
||||||
inline struct hostent* os::get_host_by_name(char* name) {
|
inline struct hostent* os::get_host_by_name(char* name) {
|
||||||
return ::gethostbyname(name);
|
return ::gethostbyname(name);
|
||||||
}
|
}
|
||||||
|
|
||||||
inline int os::get_sock_opt(int fd, int level, int optname,
|
inline int os::get_sock_opt(int fd, int level, int optname,
|
||||||
char *optval, int* optlen){
|
char* optval, socklen_t* optlen) {
|
||||||
return ::getsockopt(fd, level, optname, optval, (socklen_t*) optlen);
|
return ::getsockopt(fd, level, optname, optval, optlen);
|
||||||
}
|
}
|
||||||
|
|
||||||
inline int os::set_sock_opt(int fd, int level, int optname,
|
inline int os::set_sock_opt(int fd, int level, int optname,
|
||||||
const char *optval, int optlen){
|
const char *optval, socklen_t optlen) {
|
||||||
return ::setsockopt(fd, level, optname, optval, optlen);
|
return ::setsockopt(fd, level, optname, optval, optlen);
|
||||||
}
|
}
|
||||||
#endif // OS_SOLARIS_VM_OS_SOLARIS_INLINE_HPP
|
#endif // OS_SOLARIS_VM_OS_SOLARIS_INLINE_HPP
|
||||||
|
@ -22,6 +22,9 @@
|
|||||||
*
|
*
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
#ifndef OS_WINDOWS_VM_JVM_WINDOWS_H
|
||||||
|
#define OS_WINDOWS_VM_JVM_WINDOWS_H
|
||||||
|
|
||||||
#ifndef _JAVASOFT_JVM_MD_H_
|
#ifndef _JAVASOFT_JVM_MD_H_
|
||||||
#define _JAVASOFT_JVM_MD_H_
|
#define _JAVASOFT_JVM_MD_H_
|
||||||
|
|
||||||
@ -54,10 +57,10 @@ typedef struct _MODULEINFO {
|
|||||||
#include <Psapi.h>
|
#include <Psapi.h>
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
#include <Tlhelp32.h>
|
#include <Tlhelp32.h>
|
||||||
|
|
||||||
|
typedef unsigned int socklen_t;
|
||||||
|
|
||||||
// #include "jni.h"
|
// #include "jni.h"
|
||||||
|
|
||||||
#define JNI_ONLOAD_SYMBOLS {"_JNI_OnLoad@8", "JNI_OnLoad"}
|
#define JNI_ONLOAD_SYMBOLS {"_JNI_OnLoad@8", "JNI_OnLoad"}
|
||||||
@ -129,3 +132,5 @@ JVM_GetThreadInterruptEvent();
|
|||||||
#define SHUTDOWN2_SIGNAL SIGTERM
|
#define SHUTDOWN2_SIGNAL SIGTERM
|
||||||
|
|
||||||
#endif /* !_JAVASOFT_JVM_MD_H_ */
|
#endif /* !_JAVASOFT_JVM_MD_H_ */
|
||||||
|
|
||||||
|
#endif // OS_WINDOWS_VM_JVM_WINDOWS_H
|
||||||
|
@ -821,17 +821,15 @@ jlong os::javaTimeMillis() {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
#define NANOS_PER_SEC CONST64(1000000000)
|
|
||||||
#define NANOS_PER_MILLISEC 1000000
|
|
||||||
jlong os::javaTimeNanos() {
|
jlong os::javaTimeNanos() {
|
||||||
if (!has_performance_count) {
|
if (!has_performance_count) {
|
||||||
return javaTimeMillis() * NANOS_PER_MILLISEC; // the best we can do.
|
return javaTimeMillis() * NANOSECS_PER_MILLISEC; // the best we can do.
|
||||||
} else {
|
} else {
|
||||||
LARGE_INTEGER current_count;
|
LARGE_INTEGER current_count;
|
||||||
QueryPerformanceCounter(¤t_count);
|
QueryPerformanceCounter(¤t_count);
|
||||||
double current = as_long(current_count);
|
double current = as_long(current_count);
|
||||||
double freq = performance_frequency;
|
double freq = performance_frequency;
|
||||||
jlong time = (jlong)((current/freq) * NANOS_PER_SEC);
|
jlong time = (jlong)((current/freq) * NANOSECS_PER_SEC);
|
||||||
return time;
|
return time;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -847,15 +845,15 @@ void os::javaTimeNanos_info(jvmtiTimerInfo *info_ptr) {
|
|||||||
info_ptr->may_skip_forward = true;
|
info_ptr->may_skip_forward = true;
|
||||||
} else {
|
} else {
|
||||||
jlong freq = performance_frequency;
|
jlong freq = performance_frequency;
|
||||||
if (freq < NANOS_PER_SEC) {
|
if (freq < NANOSECS_PER_SEC) {
|
||||||
// the performance counter is 64 bits and we will
|
// the performance counter is 64 bits and we will
|
||||||
// be multiplying it -- so no wrap in 64 bits
|
// be multiplying it -- so no wrap in 64 bits
|
||||||
info_ptr->max_value = ALL_64_BITS;
|
info_ptr->max_value = ALL_64_BITS;
|
||||||
} else if (freq > NANOS_PER_SEC) {
|
} else if (freq > NANOSECS_PER_SEC) {
|
||||||
// use the max value the counter can reach to
|
// use the max value the counter can reach to
|
||||||
// determine the max value which could be returned
|
// determine the max value which could be returned
|
||||||
julong max_counter = (julong)ALL_64_BITS;
|
julong max_counter = (julong)ALL_64_BITS;
|
||||||
info_ptr->max_value = (jlong)(max_counter / (freq / NANOS_PER_SEC));
|
info_ptr->max_value = (jlong)(max_counter / (freq / NANOSECS_PER_SEC));
|
||||||
} else {
|
} else {
|
||||||
// the performance counter is 64 bits and we will
|
// the performance counter is 64 bits and we will
|
||||||
// be using it directly -- so no wrap in 64 bits
|
// be using it directly -- so no wrap in 64 bits
|
||||||
@ -4851,7 +4849,7 @@ static void initSock() {
|
|||||||
::mutexUnlock(&sockFnTableMutex);
|
::mutexUnlock(&sockFnTableMutex);
|
||||||
}
|
}
|
||||||
|
|
||||||
struct hostent* os::get_host_by_name(char* name) {
|
struct hostent* os::get_host_by_name(char* name) {
|
||||||
if (!sock_initialized) {
|
if (!sock_initialized) {
|
||||||
initSock();
|
initSock();
|
||||||
}
|
}
|
||||||
@ -4882,39 +4880,39 @@ int os::listen(int fd, int count) {
|
|||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
int os::connect(int fd, struct sockaddr *him, int len) {
|
int os::connect(int fd, struct sockaddr* him, socklen_t len) {
|
||||||
ShouldNotReachHere();
|
ShouldNotReachHere();
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
int os::accept(int fd, struct sockaddr *him, int *len) {
|
int os::accept(int fd, struct sockaddr* him, socklen_t* len) {
|
||||||
ShouldNotReachHere();
|
ShouldNotReachHere();
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
int os::sendto(int fd, char *buf, int len, int flags,
|
int os::sendto(int fd, char* buf, size_t len, uint flags,
|
||||||
struct sockaddr *to, int tolen) {
|
struct sockaddr* to, socklen_t tolen) {
|
||||||
ShouldNotReachHere();
|
ShouldNotReachHere();
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
int os::recvfrom(int fd, char *buf, int nBytes, int flags,
|
int os::recvfrom(int fd, char *buf, size_t nBytes, uint flags,
|
||||||
sockaddr *from, int *fromlen) {
|
sockaddr* from, socklen_t* fromlen) {
|
||||||
ShouldNotReachHere();
|
ShouldNotReachHere();
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
int os::recv(int fd, char *buf, int nBytes, int flags) {
|
int os::recv(int fd, char* buf, size_t nBytes, uint flags) {
|
||||||
ShouldNotReachHere();
|
ShouldNotReachHere();
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
int os::send(int fd, char *buf, int nBytes, int flags) {
|
int os::send(int fd, char* buf, size_t nBytes, uint flags) {
|
||||||
ShouldNotReachHere();
|
ShouldNotReachHere();
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
int os::raw_send(int fd, char *buf, int nBytes, int flags) {
|
int os::raw_send(int fd, char* buf, size_t nBytes, uint flags) {
|
||||||
ShouldNotReachHere();
|
ShouldNotReachHere();
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
@ -4934,24 +4932,24 @@ int os::socket_shutdown(int fd, int howto) {
|
|||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
int os::bind(int fd, struct sockaddr *him, int len) {
|
int os::bind(int fd, struct sockaddr* him, socklen_t len) {
|
||||||
ShouldNotReachHere();
|
ShouldNotReachHere();
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
int os::get_sock_name(int fd, struct sockaddr *him, int *len) {
|
int os::get_sock_name(int fd, struct sockaddr* him, socklen_t* len) {
|
||||||
ShouldNotReachHere();
|
ShouldNotReachHere();
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
int os::get_sock_opt(int fd, int level, int optname,
|
int os::get_sock_opt(int fd, int level, int optname,
|
||||||
char *optval, int* optlen) {
|
char* optval, socklen_t* optlen) {
|
||||||
ShouldNotReachHere();
|
ShouldNotReachHere();
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
int os::set_sock_opt(int fd, int level, int optname,
|
int os::set_sock_opt(int fd, int level, int optname,
|
||||||
const char *optval, int optlen) {
|
const char* optval, socklen_t optlen) {
|
||||||
ShouldNotReachHere();
|
ShouldNotReachHere();
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
@ -336,12 +336,6 @@ class CompactibleFreeListSpace: public CompactibleSpace {
|
|||||||
unallocated_block() : end());
|
unallocated_block() : end());
|
||||||
}
|
}
|
||||||
|
|
||||||
// This is needed because the default implementation uses block_start()
|
|
||||||
// which can;t be used at certain times (for example phase 3 of mark-sweep).
|
|
||||||
// A better fix is to change the assertions in phase 3 of mark-sweep to
|
|
||||||
// use is_in_reserved(), but that is deferred since the is_in() assertions
|
|
||||||
// are buried through several layers of callers and are used elsewhere
|
|
||||||
// as well.
|
|
||||||
bool is_in(const void* p) const {
|
bool is_in(const void* p) const {
|
||||||
return used_region().contains(p);
|
return used_region().contains(p);
|
||||||
}
|
}
|
||||||
|
@ -1117,12 +1117,9 @@ public:
|
|||||||
|
|
||||||
// Calculates the number of active workers for a concurrent
|
// Calculates the number of active workers for a concurrent
|
||||||
// phase.
|
// phase.
|
||||||
int ConcurrentMark::calc_parallel_marking_threads() {
|
size_t ConcurrentMark::calc_parallel_marking_threads() {
|
||||||
|
if (G1CollectedHeap::use_parallel_gc_threads()) {
|
||||||
size_t n_conc_workers;
|
size_t n_conc_workers = 0;
|
||||||
if (!G1CollectedHeap::use_parallel_gc_threads()) {
|
|
||||||
n_conc_workers = 1;
|
|
||||||
} else {
|
|
||||||
if (!UseDynamicNumberOfGCThreads ||
|
if (!UseDynamicNumberOfGCThreads ||
|
||||||
(!FLAG_IS_DEFAULT(ConcGCThreads) &&
|
(!FLAG_IS_DEFAULT(ConcGCThreads) &&
|
||||||
!ForceDynamicNumberOfGCThreads)) {
|
!ForceDynamicNumberOfGCThreads)) {
|
||||||
@ -1137,9 +1134,13 @@ int ConcurrentMark::calc_parallel_marking_threads() {
|
|||||||
// Don't scale down "n_conc_workers" by scale_parallel_threads() because
|
// Don't scale down "n_conc_workers" by scale_parallel_threads() because
|
||||||
// that scaling has already gone into "_max_parallel_marking_threads".
|
// that scaling has already gone into "_max_parallel_marking_threads".
|
||||||
}
|
}
|
||||||
|
assert(n_conc_workers > 0, "Always need at least 1");
|
||||||
|
return n_conc_workers;
|
||||||
}
|
}
|
||||||
assert(n_conc_workers > 0, "Always need at least 1");
|
// If we are not running with any parallel GC threads we will not
|
||||||
return (int) MAX2(n_conc_workers, (size_t) 1);
|
// have spawned any marking threads either. Hence the number of
|
||||||
|
// concurrent workers should be 0.
|
||||||
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
void ConcurrentMark::markFromRoots() {
|
void ConcurrentMark::markFromRoots() {
|
||||||
@ -1151,24 +1152,24 @@ void ConcurrentMark::markFromRoots() {
|
|||||||
// stop-the-world GC happens even as we mark in this generation.
|
// stop-the-world GC happens even as we mark in this generation.
|
||||||
|
|
||||||
_restart_for_overflow = false;
|
_restart_for_overflow = false;
|
||||||
|
|
||||||
// Parallel task terminator is set in "set_phase()".
|
|
||||||
force_overflow_conc()->init();
|
force_overflow_conc()->init();
|
||||||
|
|
||||||
// _g1h has _n_par_threads
|
// _g1h has _n_par_threads
|
||||||
|
|
||||||
_parallel_marking_threads = calc_parallel_marking_threads();
|
_parallel_marking_threads = calc_parallel_marking_threads();
|
||||||
assert(parallel_marking_threads() <= max_parallel_marking_threads(),
|
assert(parallel_marking_threads() <= max_parallel_marking_threads(),
|
||||||
"Maximum number of marking threads exceeded");
|
"Maximum number of marking threads exceeded");
|
||||||
_parallel_workers->set_active_workers((int)_parallel_marking_threads);
|
|
||||||
// Don't set _n_par_threads because it affects MT in proceess_strong_roots()
|
|
||||||
// and the decisions on that MT processing is made elsewhere.
|
|
||||||
|
|
||||||
assert( _parallel_workers->active_workers() > 0, "Should have been set");
|
size_t active_workers = MAX2((size_t) 1, parallel_marking_threads());
|
||||||
set_phase(_parallel_workers->active_workers(), true /* concurrent */);
|
|
||||||
|
// Parallel task terminator is set in "set_phase()"
|
||||||
|
set_phase(active_workers, true /* concurrent */);
|
||||||
|
|
||||||
CMConcurrentMarkingTask markingTask(this, cmThread());
|
CMConcurrentMarkingTask markingTask(this, cmThread());
|
||||||
if (parallel_marking_threads() > 0) {
|
if (parallel_marking_threads() > 0) {
|
||||||
|
_parallel_workers->set_active_workers((int)active_workers);
|
||||||
|
// Don't set _n_par_threads because it affects MT in proceess_strong_roots()
|
||||||
|
// and the decisions on that MT processing is made elsewhere.
|
||||||
|
assert(_parallel_workers->active_workers() > 0, "Should have been set");
|
||||||
_parallel_workers->run_task(&markingTask);
|
_parallel_workers->run_task(&markingTask);
|
||||||
} else {
|
} else {
|
||||||
markingTask.work(0);
|
markingTask.work(0);
|
||||||
@ -1765,8 +1766,7 @@ void ConcurrentMark::cleanup() {
|
|||||||
|
|
||||||
HeapRegionRemSet::reset_for_cleanup_tasks();
|
HeapRegionRemSet::reset_for_cleanup_tasks();
|
||||||
|
|
||||||
g1h->set_par_threads();
|
size_t n_workers;
|
||||||
size_t n_workers = g1h->n_par_threads();
|
|
||||||
|
|
||||||
// Do counting once more with the world stopped for good measure.
|
// Do counting once more with the world stopped for good measure.
|
||||||
G1ParFinalCountTask g1_par_count_task(g1h, nextMarkBitMap(),
|
G1ParFinalCountTask g1_par_count_task(g1h, nextMarkBitMap(),
|
||||||
@ -1776,8 +1776,10 @@ void ConcurrentMark::cleanup() {
|
|||||||
HeapRegion::InitialClaimValue),
|
HeapRegion::InitialClaimValue),
|
||||||
"sanity check");
|
"sanity check");
|
||||||
|
|
||||||
|
g1h->set_par_threads();
|
||||||
|
n_workers = g1h->n_par_threads();
|
||||||
assert(g1h->n_par_threads() == (int) n_workers,
|
assert(g1h->n_par_threads() == (int) n_workers,
|
||||||
"Should not have been reset");
|
"Should not have been reset");
|
||||||
g1h->workers()->run_task(&g1_par_count_task);
|
g1h->workers()->run_task(&g1_par_count_task);
|
||||||
// Done with the parallel phase so reset to 0.
|
// Done with the parallel phase so reset to 0.
|
||||||
g1h->set_par_threads(0);
|
g1h->set_par_threads(0);
|
||||||
@ -1786,6 +1788,7 @@ void ConcurrentMark::cleanup() {
|
|||||||
HeapRegion::FinalCountClaimValue),
|
HeapRegion::FinalCountClaimValue),
|
||||||
"sanity check");
|
"sanity check");
|
||||||
} else {
|
} else {
|
||||||
|
n_workers = 1;
|
||||||
g1_par_count_task.work(0);
|
g1_par_count_task.work(0);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -1851,7 +1854,6 @@ void ConcurrentMark::cleanup() {
|
|||||||
(note_end_end - note_end_start)*1000.0);
|
(note_end_end - note_end_start)*1000.0);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
// call below, since it affects the metric by which we sort the heap
|
// call below, since it affects the metric by which we sort the heap
|
||||||
// regions.
|
// regions.
|
||||||
if (G1ScrubRemSets) {
|
if (G1ScrubRemSets) {
|
||||||
@ -2329,9 +2331,9 @@ public:
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
CMRemarkTask(ConcurrentMark* cm) :
|
CMRemarkTask(ConcurrentMark* cm, int active_workers) :
|
||||||
AbstractGangTask("Par Remark"), _cm(cm) {
|
AbstractGangTask("Par Remark"), _cm(cm) {
|
||||||
_cm->terminator()->reset_for_reuse(cm->_g1h->workers()->active_workers());
|
_cm->terminator()->reset_for_reuse(active_workers);
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
@ -2357,7 +2359,7 @@ void ConcurrentMark::checkpointRootsFinalWork() {
|
|||||||
// constructor and pass values of the active workers
|
// constructor and pass values of the active workers
|
||||||
// through the gang in the task.
|
// through the gang in the task.
|
||||||
|
|
||||||
CMRemarkTask remarkTask(this);
|
CMRemarkTask remarkTask(this, active_workers);
|
||||||
g1h->set_par_threads(active_workers);
|
g1h->set_par_threads(active_workers);
|
||||||
g1h->workers()->run_task(&remarkTask);
|
g1h->workers()->run_task(&remarkTask);
|
||||||
g1h->set_par_threads(0);
|
g1h->set_par_threads(0);
|
||||||
@ -2367,7 +2369,7 @@ void ConcurrentMark::checkpointRootsFinalWork() {
|
|||||||
int active_workers = 1;
|
int active_workers = 1;
|
||||||
set_phase(active_workers, false /* concurrent */);
|
set_phase(active_workers, false /* concurrent */);
|
||||||
|
|
||||||
CMRemarkTask remarkTask(this);
|
CMRemarkTask remarkTask(this, active_workers);
|
||||||
// We will start all available threads, even if we decide that the
|
// We will start all available threads, even if we decide that the
|
||||||
// active_workers will be fewer. The extra ones will just bail out
|
// active_workers will be fewer. The extra ones will just bail out
|
||||||
// immediately.
|
// immediately.
|
||||||
@ -3123,13 +3125,12 @@ void ConcurrentMark::complete_marking_in_collection_set() {
|
|||||||
}
|
}
|
||||||
|
|
||||||
double start = os::elapsedTime();
|
double start = os::elapsedTime();
|
||||||
int n_workers = g1h->workers()->total_workers();
|
|
||||||
|
|
||||||
G1ParCompleteMarkInCSetTask complete_mark_task(g1h, this);
|
G1ParCompleteMarkInCSetTask complete_mark_task(g1h, this);
|
||||||
|
|
||||||
assert(g1h->check_cset_heap_region_claim_values(HeapRegion::InitialClaimValue), "sanity");
|
assert(g1h->check_cset_heap_region_claim_values(HeapRegion::InitialClaimValue), "sanity");
|
||||||
|
|
||||||
if (G1CollectedHeap::use_parallel_gc_threads()) {
|
if (G1CollectedHeap::use_parallel_gc_threads()) {
|
||||||
|
int n_workers = g1h->workers()->active_workers();
|
||||||
g1h->set_par_threads(n_workers);
|
g1h->set_par_threads(n_workers);
|
||||||
g1h->workers()->run_task(&complete_mark_task);
|
g1h->workers()->run_task(&complete_mark_task);
|
||||||
g1h->set_par_threads(0);
|
g1h->set_par_threads(0);
|
||||||
|
@ -718,7 +718,7 @@ public:
|
|||||||
size_t scale_parallel_threads(size_t n_par_threads);
|
size_t scale_parallel_threads(size_t n_par_threads);
|
||||||
|
|
||||||
// Calculates the number of GC threads to be used in a concurrent phase.
|
// Calculates the number of GC threads to be used in a concurrent phase.
|
||||||
int calc_parallel_marking_threads();
|
size_t calc_parallel_marking_threads();
|
||||||
|
|
||||||
// The following three are interaction between CM and
|
// The following three are interaction between CM and
|
||||||
// G1CollectedHeap
|
// G1CollectedHeap
|
||||||
|
@ -1294,7 +1294,7 @@ bool G1CollectedHeap::do_collection(bool explicit_gc,
|
|||||||
g1_policy()->stop_incremental_cset_building();
|
g1_policy()->stop_incremental_cset_building();
|
||||||
|
|
||||||
tear_down_region_sets(false /* free_list_only */);
|
tear_down_region_sets(false /* free_list_only */);
|
||||||
g1_policy()->set_full_young_gcs(true);
|
g1_policy()->set_gcs_are_young(true);
|
||||||
|
|
||||||
// See the comments in g1CollectedHeap.hpp and
|
// See the comments in g1CollectedHeap.hpp and
|
||||||
// G1CollectedHeap::ref_processing_init() about
|
// G1CollectedHeap::ref_processing_init() about
|
||||||
@ -1842,7 +1842,9 @@ G1CollectedHeap::G1CollectedHeap(G1CollectorPolicy* policy_) :
|
|||||||
_full_collections_completed(0),
|
_full_collections_completed(0),
|
||||||
_in_cset_fast_test(NULL),
|
_in_cset_fast_test(NULL),
|
||||||
_in_cset_fast_test_base(NULL),
|
_in_cset_fast_test_base(NULL),
|
||||||
_dirty_cards_region_list(NULL) {
|
_dirty_cards_region_list(NULL),
|
||||||
|
_worker_cset_start_region(NULL),
|
||||||
|
_worker_cset_start_region_time_stamp(NULL) {
|
||||||
_g1h = this; // To catch bugs.
|
_g1h = this; // To catch bugs.
|
||||||
if (_process_strong_tasks == NULL || !_process_strong_tasks->valid()) {
|
if (_process_strong_tasks == NULL || !_process_strong_tasks->valid()) {
|
||||||
vm_exit_during_initialization("Failed necessary allocation.");
|
vm_exit_during_initialization("Failed necessary allocation.");
|
||||||
@ -1863,12 +1865,17 @@ G1CollectedHeap::G1CollectedHeap(G1CollectorPolicy* policy_) :
|
|||||||
}
|
}
|
||||||
_rem_set_iterator = iter_arr;
|
_rem_set_iterator = iter_arr;
|
||||||
|
|
||||||
|
_worker_cset_start_region = NEW_C_HEAP_ARRAY(HeapRegion*, n_queues);
|
||||||
|
_worker_cset_start_region_time_stamp = NEW_C_HEAP_ARRAY(unsigned int, n_queues);
|
||||||
|
|
||||||
for (int i = 0; i < n_queues; i++) {
|
for (int i = 0; i < n_queues; i++) {
|
||||||
RefToScanQueue* q = new RefToScanQueue();
|
RefToScanQueue* q = new RefToScanQueue();
|
||||||
q->initialize();
|
q->initialize();
|
||||||
_task_queues->register_queue(i, q);
|
_task_queues->register_queue(i, q);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
clear_cset_start_regions();
|
||||||
|
|
||||||
guarantee(_task_queues != NULL, "task_queues allocation failure.");
|
guarantee(_task_queues != NULL, "task_queues allocation failure.");
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -2411,8 +2418,11 @@ void G1CollectedHeap::collect(GCCause::Cause cause) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
bool G1CollectedHeap::is_in(const void* p) const {
|
bool G1CollectedHeap::is_in(const void* p) const {
|
||||||
HeapRegion* hr = _hrs.addr_to_region((HeapWord*) p);
|
if (_g1_committed.contains(p)) {
|
||||||
if (hr != NULL) {
|
// Given that we know that p is in the committed space,
|
||||||
|
// heap_region_containing_raw() should successfully
|
||||||
|
// return the containing region.
|
||||||
|
HeapRegion* hr = heap_region_containing_raw(p);
|
||||||
return hr->is_in(p);
|
return hr->is_in(p);
|
||||||
} else {
|
} else {
|
||||||
return _perm_gen->as_gen()->is_in(p);
|
return _perm_gen->as_gen()->is_in(p);
|
||||||
@ -2684,25 +2694,80 @@ bool G1CollectedHeap::check_cset_heap_region_claim_values(jint claim_value) {
|
|||||||
}
|
}
|
||||||
#endif // ASSERT
|
#endif // ASSERT
|
||||||
|
|
||||||
// We want the parallel threads to start their collection
|
// Clear the cached CSet starting regions and (more importantly)
|
||||||
// set iteration at different collection set regions to
|
// the time stamps. Called when we reset the GC time stamp.
|
||||||
// avoid contention.
|
void G1CollectedHeap::clear_cset_start_regions() {
|
||||||
// If we have:
|
assert(_worker_cset_start_region != NULL, "sanity");
|
||||||
// n collection set regions
|
assert(_worker_cset_start_region_time_stamp != NULL, "sanity");
|
||||||
// p threads
|
|
||||||
// Then thread t will start at region t * floor (n/p)
|
|
||||||
|
|
||||||
|
int n_queues = MAX2((int)ParallelGCThreads, 1);
|
||||||
|
for (int i = 0; i < n_queues; i++) {
|
||||||
|
_worker_cset_start_region[i] = NULL;
|
||||||
|
_worker_cset_start_region_time_stamp[i] = 0;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
// Given the id of a worker, obtain or calculate a suitable
|
||||||
|
// starting region for iterating over the current collection set.
|
||||||
HeapRegion* G1CollectedHeap::start_cset_region_for_worker(int worker_i) {
|
HeapRegion* G1CollectedHeap::start_cset_region_for_worker(int worker_i) {
|
||||||
HeapRegion* result = g1_policy()->collection_set();
|
assert(get_gc_time_stamp() > 0, "should have been updated by now");
|
||||||
|
|
||||||
|
HeapRegion* result = NULL;
|
||||||
|
unsigned gc_time_stamp = get_gc_time_stamp();
|
||||||
|
|
||||||
|
if (_worker_cset_start_region_time_stamp[worker_i] == gc_time_stamp) {
|
||||||
|
// Cached starting region for current worker was set
|
||||||
|
// during the current pause - so it's valid.
|
||||||
|
// Note: the cached starting heap region may be NULL
|
||||||
|
// (when the collection set is empty).
|
||||||
|
result = _worker_cset_start_region[worker_i];
|
||||||
|
assert(result == NULL || result->in_collection_set(), "sanity");
|
||||||
|
return result;
|
||||||
|
}
|
||||||
|
|
||||||
|
// The cached entry was not valid so let's calculate
|
||||||
|
// a suitable starting heap region for this worker.
|
||||||
|
|
||||||
|
// We want the parallel threads to start their collection
|
||||||
|
// set iteration at different collection set regions to
|
||||||
|
// avoid contention.
|
||||||
|
// If we have:
|
||||||
|
// n collection set regions
|
||||||
|
// p threads
|
||||||
|
// Then thread t will start at region floor ((t * n) / p)
|
||||||
|
|
||||||
|
result = g1_policy()->collection_set();
|
||||||
if (G1CollectedHeap::use_parallel_gc_threads()) {
|
if (G1CollectedHeap::use_parallel_gc_threads()) {
|
||||||
size_t cs_size = g1_policy()->cset_region_length();
|
size_t cs_size = g1_policy()->cset_region_length();
|
||||||
int n_workers = workers()->total_workers();
|
int active_workers = workers()->active_workers();
|
||||||
size_t cs_spans = cs_size / n_workers;
|
assert(UseDynamicNumberOfGCThreads ||
|
||||||
size_t ind = cs_spans * worker_i;
|
active_workers == workers()->total_workers(),
|
||||||
for (size_t i = 0; i < ind; i++) {
|
"Unless dynamic should use total workers");
|
||||||
|
|
||||||
|
size_t end_ind = (cs_size * worker_i) / active_workers;
|
||||||
|
size_t start_ind = 0;
|
||||||
|
|
||||||
|
if (worker_i > 0 &&
|
||||||
|
_worker_cset_start_region_time_stamp[worker_i - 1] == gc_time_stamp) {
|
||||||
|
// Previous workers starting region is valid
|
||||||
|
// so let's iterate from there
|
||||||
|
start_ind = (cs_size * (worker_i - 1)) / active_workers;
|
||||||
|
result = _worker_cset_start_region[worker_i - 1];
|
||||||
|
}
|
||||||
|
|
||||||
|
for (size_t i = start_ind; i < end_ind; i++) {
|
||||||
result = result->next_in_collection_set();
|
result = result->next_in_collection_set();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// Note: the calculated starting heap region may be NULL
|
||||||
|
// (when the collection set is empty).
|
||||||
|
assert(result == NULL || result->in_collection_set(), "sanity");
|
||||||
|
assert(_worker_cset_start_region_time_stamp[worker_i] != gc_time_stamp,
|
||||||
|
"should be updated only once per pause");
|
||||||
|
_worker_cset_start_region[worker_i] = result;
|
||||||
|
OrderAccess::storestore();
|
||||||
|
_worker_cset_start_region_time_stamp[worker_i] = gc_time_stamp;
|
||||||
return result;
|
return result;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -3461,20 +3526,19 @@ G1CollectedHeap::do_collection_pause_at_safepoint(double target_pause_time_ms) {
|
|||||||
// for the duration of this pause.
|
// for the duration of this pause.
|
||||||
g1_policy()->decide_on_conc_mark_initiation();
|
g1_policy()->decide_on_conc_mark_initiation();
|
||||||
|
|
||||||
// We do not allow initial-mark to be piggy-backed on a
|
// We do not allow initial-mark to be piggy-backed on a mixed GC.
|
||||||
// partially-young GC.
|
|
||||||
assert(!g1_policy()->during_initial_mark_pause() ||
|
assert(!g1_policy()->during_initial_mark_pause() ||
|
||||||
g1_policy()->full_young_gcs(), "sanity");
|
g1_policy()->gcs_are_young(), "sanity");
|
||||||
|
|
||||||
// We also do not allow partially-young GCs during marking.
|
// We also do not allow mixed GCs during marking.
|
||||||
assert(!mark_in_progress() || g1_policy()->full_young_gcs(), "sanity");
|
assert(!mark_in_progress() || g1_policy()->gcs_are_young(), "sanity");
|
||||||
|
|
||||||
char verbose_str[128];
|
char verbose_str[128];
|
||||||
sprintf(verbose_str, "GC pause ");
|
sprintf(verbose_str, "GC pause ");
|
||||||
if (g1_policy()->full_young_gcs()) {
|
if (g1_policy()->gcs_are_young()) {
|
||||||
strcat(verbose_str, "(young)");
|
strcat(verbose_str, "(young)");
|
||||||
} else {
|
} else {
|
||||||
strcat(verbose_str, "(partial)");
|
strcat(verbose_str, "(mixed)");
|
||||||
}
|
}
|
||||||
if (g1_policy()->during_initial_mark_pause()) {
|
if (g1_policy()->during_initial_mark_pause()) {
|
||||||
strcat(verbose_str, " (initial-mark)");
|
strcat(verbose_str, " (initial-mark)");
|
||||||
@ -3723,8 +3787,9 @@ G1CollectedHeap::do_collection_pause_at_safepoint(double target_pause_time_ms) {
|
|||||||
double end_time_sec = os::elapsedTime();
|
double end_time_sec = os::elapsedTime();
|
||||||
double pause_time_ms = (end_time_sec - start_time_sec) * MILLIUNITS;
|
double pause_time_ms = (end_time_sec - start_time_sec) * MILLIUNITS;
|
||||||
g1_policy()->record_pause_time_ms(pause_time_ms);
|
g1_policy()->record_pause_time_ms(pause_time_ms);
|
||||||
int active_gc_threads = workers()->active_workers();
|
int active_workers = (G1CollectedHeap::use_parallel_gc_threads() ?
|
||||||
g1_policy()->record_collection_pause_end(active_gc_threads);
|
workers()->active_workers() : 1);
|
||||||
|
g1_policy()->record_collection_pause_end(active_workers);
|
||||||
|
|
||||||
MemoryService::track_memory_usage();
|
MemoryService::track_memory_usage();
|
||||||
|
|
||||||
@ -5248,8 +5313,10 @@ void G1CollectedHeap::process_discovered_references() {
|
|||||||
int active_workers = (G1CollectedHeap::use_parallel_gc_threads() ?
|
int active_workers = (G1CollectedHeap::use_parallel_gc_threads() ?
|
||||||
workers()->active_workers() : 1);
|
workers()->active_workers() : 1);
|
||||||
|
|
||||||
assert(active_workers == workers()->active_workers(),
|
assert(!G1CollectedHeap::use_parallel_gc_threads() ||
|
||||||
"Need to reset active_workers");
|
active_workers == workers()->active_workers(),
|
||||||
|
"Need to reset active_workers");
|
||||||
|
|
||||||
set_par_threads(active_workers);
|
set_par_threads(active_workers);
|
||||||
G1ParPreserveCMReferentsTask keep_cm_referents(this, active_workers, _task_queues);
|
G1ParPreserveCMReferentsTask keep_cm_referents(this, active_workers, _task_queues);
|
||||||
|
|
||||||
@ -5387,13 +5454,13 @@ void G1CollectedHeap::evacuate_collection_set() {
|
|||||||
assert(UseDynamicNumberOfGCThreads ||
|
assert(UseDynamicNumberOfGCThreads ||
|
||||||
n_workers == workers()->total_workers(),
|
n_workers == workers()->total_workers(),
|
||||||
"If not dynamic should be using all the workers");
|
"If not dynamic should be using all the workers");
|
||||||
|
workers()->set_active_workers(n_workers);
|
||||||
set_par_threads(n_workers);
|
set_par_threads(n_workers);
|
||||||
} else {
|
} else {
|
||||||
assert(n_par_threads() == 0,
|
assert(n_par_threads() == 0,
|
||||||
"Should be the original non-parallel value");
|
"Should be the original non-parallel value");
|
||||||
n_workers = 1;
|
n_workers = 1;
|
||||||
}
|
}
|
||||||
workers()->set_active_workers(n_workers);
|
|
||||||
|
|
||||||
G1ParTask g1_par_task(this, _task_queues);
|
G1ParTask g1_par_task(this, _task_queues);
|
||||||
|
|
||||||
@ -5415,6 +5482,7 @@ void G1CollectedHeap::evacuate_collection_set() {
|
|||||||
workers()->run_task(&g1_par_task);
|
workers()->run_task(&g1_par_task);
|
||||||
} else {
|
} else {
|
||||||
StrongRootsScope srs(this);
|
StrongRootsScope srs(this);
|
||||||
|
g1_par_task.set_for_termination(n_workers);
|
||||||
g1_par_task.work(0);
|
g1_par_task.work(0);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -5663,8 +5731,8 @@ void G1CollectedHeap::cleanUpCardTable() {
|
|||||||
// Iterate over the dirty cards region list.
|
// Iterate over the dirty cards region list.
|
||||||
G1ParCleanupCTTask cleanup_task(ct_bs, this);
|
G1ParCleanupCTTask cleanup_task(ct_bs, this);
|
||||||
|
|
||||||
if (ParallelGCThreads > 0) {
|
if (G1CollectedHeap::use_parallel_gc_threads()) {
|
||||||
set_par_threads(workers()->total_workers());
|
set_par_threads();
|
||||||
workers()->run_task(&cleanup_task);
|
workers()->run_task(&cleanup_task);
|
||||||
set_par_threads(0);
|
set_par_threads(0);
|
||||||
} else {
|
} else {
|
||||||
@ -6072,8 +6140,9 @@ HeapRegion* MutatorAllocRegion::allocate_new_region(size_t word_size,
|
|||||||
void G1CollectedHeap::set_par_threads() {
|
void G1CollectedHeap::set_par_threads() {
|
||||||
// Don't change the number of workers. Use the value previously set
|
// Don't change the number of workers. Use the value previously set
|
||||||
// in the workgroup.
|
// in the workgroup.
|
||||||
|
assert(G1CollectedHeap::use_parallel_gc_threads(), "shouldn't be here otherwise");
|
||||||
int n_workers = workers()->active_workers();
|
int n_workers = workers()->active_workers();
|
||||||
assert(UseDynamicNumberOfGCThreads ||
|
assert(UseDynamicNumberOfGCThreads ||
|
||||||
n_workers == workers()->total_workers(),
|
n_workers == workers()->total_workers(),
|
||||||
"Otherwise should be using the total number of workers");
|
"Otherwise should be using the total number of workers");
|
||||||
if (n_workers == 0) {
|
if (n_workers == 0) {
|
||||||
|
@ -943,6 +943,16 @@ protected:
|
|||||||
// discovery.
|
// discovery.
|
||||||
G1CMIsAliveClosure _is_alive_closure_cm;
|
G1CMIsAliveClosure _is_alive_closure_cm;
|
||||||
|
|
||||||
|
// Cache used by G1CollectedHeap::start_cset_region_for_worker().
|
||||||
|
HeapRegion** _worker_cset_start_region;
|
||||||
|
|
||||||
|
// Time stamp to validate the regions recorded in the cache
|
||||||
|
// used by G1CollectedHeap::start_cset_region_for_worker().
|
||||||
|
// The heap region entry for a given worker is valid iff
|
||||||
|
// the associated time stamp value matches the current value
|
||||||
|
// of G1CollectedHeap::_gc_time_stamp.
|
||||||
|
unsigned int* _worker_cset_start_region_time_stamp;
|
||||||
|
|
||||||
enum G1H_process_strong_roots_tasks {
|
enum G1H_process_strong_roots_tasks {
|
||||||
G1H_PS_mark_stack_oops_do,
|
G1H_PS_mark_stack_oops_do,
|
||||||
G1H_PS_refProcessor_oops_do,
|
G1H_PS_refProcessor_oops_do,
|
||||||
@ -1030,6 +1040,9 @@ public:
|
|||||||
void reset_gc_time_stamp() {
|
void reset_gc_time_stamp() {
|
||||||
_gc_time_stamp = 0;
|
_gc_time_stamp = 0;
|
||||||
OrderAccess::fence();
|
OrderAccess::fence();
|
||||||
|
// Clear the cached CSet starting regions and time stamps.
|
||||||
|
// Their validity is dependent on the GC timestamp.
|
||||||
|
clear_cset_start_regions();
|
||||||
}
|
}
|
||||||
|
|
||||||
void increment_gc_time_stamp() {
|
void increment_gc_time_stamp() {
|
||||||
@ -1196,7 +1209,7 @@ public:
|
|||||||
HumongousRegionSet* humongous_proxy_set,
|
HumongousRegionSet* humongous_proxy_set,
|
||||||
bool par);
|
bool par);
|
||||||
|
|
||||||
// Returns "TRUE" iff "p" points into the allocated area of the heap.
|
// Returns "TRUE" iff "p" points into the committed areas of the heap.
|
||||||
virtual bool is_in(const void* p) const;
|
virtual bool is_in(const void* p) const;
|
||||||
|
|
||||||
// Return "TRUE" iff the given object address is within the collection
|
// Return "TRUE" iff the given object address is within the collection
|
||||||
@ -1300,9 +1313,12 @@ public:
|
|||||||
bool check_cset_heap_region_claim_values(jint claim_value);
|
bool check_cset_heap_region_claim_values(jint claim_value);
|
||||||
#endif // ASSERT
|
#endif // ASSERT
|
||||||
|
|
||||||
// Given the id of a worker, calculate a suitable
|
// Clear the cached cset start regions and (more importantly)
|
||||||
// starting region for iterating over the current
|
// the time stamps. Called when we reset the GC time stamp.
|
||||||
// collection set.
|
void clear_cset_start_regions();
|
||||||
|
|
||||||
|
// Given the id of a worker, obtain or calculate a suitable
|
||||||
|
// starting region for iterating over the current collection set.
|
||||||
HeapRegion* start_cset_region_for_worker(int worker_i);
|
HeapRegion* start_cset_region_for_worker(int worker_i);
|
||||||
|
|
||||||
// Iterate over the regions (if any) in the current collection set.
|
// Iterate over the regions (if any) in the current collection set.
|
||||||
|
@ -50,7 +50,7 @@ static double cost_per_card_ms_defaults[] = {
|
|||||||
};
|
};
|
||||||
|
|
||||||
// all the same
|
// all the same
|
||||||
static double fully_young_cards_per_entry_ratio_defaults[] = {
|
static double young_cards_per_entry_ratio_defaults[] = {
|
||||||
1.0, 1.0, 1.0, 1.0, 1.0, 1.0, 1.0, 1.0
|
1.0, 1.0, 1.0, 1.0, 1.0, 1.0, 1.0, 1.0
|
||||||
};
|
};
|
||||||
|
|
||||||
@ -168,11 +168,10 @@ G1CollectorPolicy::G1CollectorPolicy() :
|
|||||||
_pending_card_diff_seq(new TruncatedSeq(TruncatedSeqLength)),
|
_pending_card_diff_seq(new TruncatedSeq(TruncatedSeqLength)),
|
||||||
_rs_length_diff_seq(new TruncatedSeq(TruncatedSeqLength)),
|
_rs_length_diff_seq(new TruncatedSeq(TruncatedSeqLength)),
|
||||||
_cost_per_card_ms_seq(new TruncatedSeq(TruncatedSeqLength)),
|
_cost_per_card_ms_seq(new TruncatedSeq(TruncatedSeqLength)),
|
||||||
_fully_young_cards_per_entry_ratio_seq(new TruncatedSeq(TruncatedSeqLength)),
|
_young_cards_per_entry_ratio_seq(new TruncatedSeq(TruncatedSeqLength)),
|
||||||
_partially_young_cards_per_entry_ratio_seq(
|
_mixed_cards_per_entry_ratio_seq(new TruncatedSeq(TruncatedSeqLength)),
|
||||||
new TruncatedSeq(TruncatedSeqLength)),
|
|
||||||
_cost_per_entry_ms_seq(new TruncatedSeq(TruncatedSeqLength)),
|
_cost_per_entry_ms_seq(new TruncatedSeq(TruncatedSeqLength)),
|
||||||
_partially_young_cost_per_entry_ms_seq(new TruncatedSeq(TruncatedSeqLength)),
|
_mixed_cost_per_entry_ms_seq(new TruncatedSeq(TruncatedSeqLength)),
|
||||||
_cost_per_byte_ms_seq(new TruncatedSeq(TruncatedSeqLength)),
|
_cost_per_byte_ms_seq(new TruncatedSeq(TruncatedSeqLength)),
|
||||||
_cost_per_byte_ms_during_cm_seq(new TruncatedSeq(TruncatedSeqLength)),
|
_cost_per_byte_ms_during_cm_seq(new TruncatedSeq(TruncatedSeqLength)),
|
||||||
_constant_other_time_ms_seq(new TruncatedSeq(TruncatedSeqLength)),
|
_constant_other_time_ms_seq(new TruncatedSeq(TruncatedSeqLength)),
|
||||||
@ -185,9 +184,9 @@ G1CollectorPolicy::G1CollectorPolicy() :
|
|||||||
|
|
||||||
_pause_time_target_ms((double) MaxGCPauseMillis),
|
_pause_time_target_ms((double) MaxGCPauseMillis),
|
||||||
|
|
||||||
_full_young_gcs(true),
|
_gcs_are_young(true),
|
||||||
_full_young_pause_num(0),
|
_young_pause_num(0),
|
||||||
_partial_young_pause_num(0),
|
_mixed_pause_num(0),
|
||||||
|
|
||||||
_during_marking(false),
|
_during_marking(false),
|
||||||
_in_marking_window(false),
|
_in_marking_window(false),
|
||||||
@ -198,7 +197,8 @@ G1CollectorPolicy::G1CollectorPolicy() :
|
|||||||
|
|
||||||
_young_gc_eff_seq(new TruncatedSeq(TruncatedSeqLength)),
|
_young_gc_eff_seq(new TruncatedSeq(TruncatedSeqLength)),
|
||||||
|
|
||||||
_recent_prev_end_times_for_all_gcs_sec(new TruncatedSeq(NumPrevPausesForHeuristics)),
|
_recent_prev_end_times_for_all_gcs_sec(
|
||||||
|
new TruncatedSeq(NumPrevPausesForHeuristics)),
|
||||||
|
|
||||||
_recent_avg_pause_time_ratio(0.0),
|
_recent_avg_pause_time_ratio(0.0),
|
||||||
|
|
||||||
@ -206,8 +206,9 @@ G1CollectorPolicy::G1CollectorPolicy() :
|
|||||||
|
|
||||||
_initiate_conc_mark_if_possible(false),
|
_initiate_conc_mark_if_possible(false),
|
||||||
_during_initial_mark_pause(false),
|
_during_initial_mark_pause(false),
|
||||||
_should_revert_to_full_young_gcs(false),
|
_should_revert_to_young_gcs(false),
|
||||||
_last_full_young_gc(false),
|
_last_young_gc(false),
|
||||||
|
_last_gc_was_young(false),
|
||||||
|
|
||||||
_eden_bytes_before_gc(0),
|
_eden_bytes_before_gc(0),
|
||||||
_survivor_bytes_before_gc(0),
|
_survivor_bytes_before_gc(0),
|
||||||
@ -308,8 +309,8 @@ G1CollectorPolicy::G1CollectorPolicy() :
|
|||||||
_pending_card_diff_seq->add(0.0);
|
_pending_card_diff_seq->add(0.0);
|
||||||
_rs_length_diff_seq->add(rs_length_diff_defaults[index]);
|
_rs_length_diff_seq->add(rs_length_diff_defaults[index]);
|
||||||
_cost_per_card_ms_seq->add(cost_per_card_ms_defaults[index]);
|
_cost_per_card_ms_seq->add(cost_per_card_ms_defaults[index]);
|
||||||
_fully_young_cards_per_entry_ratio_seq->add(
|
_young_cards_per_entry_ratio_seq->add(
|
||||||
fully_young_cards_per_entry_ratio_defaults[index]);
|
young_cards_per_entry_ratio_defaults[index]);
|
||||||
_cost_per_entry_ms_seq->add(cost_per_entry_ms_defaults[index]);
|
_cost_per_entry_ms_seq->add(cost_per_entry_ms_defaults[index]);
|
||||||
_cost_per_byte_ms_seq->add(cost_per_byte_ms_defaults[index]);
|
_cost_per_byte_ms_seq->add(cost_per_byte_ms_defaults[index]);
|
||||||
_constant_other_time_ms_seq->add(constant_other_time_ms_defaults[index]);
|
_constant_other_time_ms_seq->add(constant_other_time_ms_defaults[index]);
|
||||||
@ -606,7 +607,7 @@ void G1CollectorPolicy::update_young_list_target_length(size_t rs_lengths) {
|
|||||||
|
|
||||||
size_t young_list_target_length = 0;
|
size_t young_list_target_length = 0;
|
||||||
if (adaptive_young_list_length()) {
|
if (adaptive_young_list_length()) {
|
||||||
if (full_young_gcs()) {
|
if (gcs_are_young()) {
|
||||||
young_list_target_length =
|
young_list_target_length =
|
||||||
calculate_young_list_target_length(rs_lengths,
|
calculate_young_list_target_length(rs_lengths,
|
||||||
base_min_length,
|
base_min_length,
|
||||||
@ -619,10 +620,10 @@ void G1CollectorPolicy::update_young_list_target_length(size_t rs_lengths) {
|
|||||||
// possible to maximize how many old regions we can add to it.
|
// possible to maximize how many old regions we can add to it.
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
if (full_young_gcs()) {
|
if (gcs_are_young()) {
|
||||||
young_list_target_length = _young_list_fixed_length;
|
young_list_target_length = _young_list_fixed_length;
|
||||||
} else {
|
} else {
|
||||||
// A bit arbitrary: during partially-young GCs we allocate half
|
// A bit arbitrary: during mixed GCs we allocate half
|
||||||
// the young regions to try to add old regions to the CSet.
|
// the young regions to try to add old regions to the CSet.
|
||||||
young_list_target_length = _young_list_fixed_length / 2;
|
young_list_target_length = _young_list_fixed_length / 2;
|
||||||
// We choose to accept that we might go under the desired min
|
// We choose to accept that we might go under the desired min
|
||||||
@ -655,7 +656,7 @@ G1CollectorPolicy::calculate_young_list_target_length(size_t rs_lengths,
|
|||||||
size_t desired_min_length,
|
size_t desired_min_length,
|
||||||
size_t desired_max_length) {
|
size_t desired_max_length) {
|
||||||
assert(adaptive_young_list_length(), "pre-condition");
|
assert(adaptive_young_list_length(), "pre-condition");
|
||||||
assert(full_young_gcs(), "only call this for fully-young GCs");
|
assert(gcs_are_young(), "only call this for young GCs");
|
||||||
|
|
||||||
// In case some edge-condition makes the desired max length too small...
|
// In case some edge-condition makes the desired max length too small...
|
||||||
if (desired_max_length <= desired_min_length) {
|
if (desired_max_length <= desired_min_length) {
|
||||||
@ -858,12 +859,11 @@ void G1CollectorPolicy::record_full_collection_end() {
|
|||||||
|
|
||||||
_g1->clear_full_collection();
|
_g1->clear_full_collection();
|
||||||
|
|
||||||
// "Nuke" the heuristics that control the fully/partially young GC
|
// "Nuke" the heuristics that control the young/mixed GC
|
||||||
// transitions and make sure we start with fully young GCs after the
|
// transitions and make sure we start with young GCs after the Full GC.
|
||||||
// Full GC.
|
set_gcs_are_young(true);
|
||||||
set_full_young_gcs(true);
|
_last_young_gc = false;
|
||||||
_last_full_young_gc = false;
|
_should_revert_to_young_gcs = false;
|
||||||
_should_revert_to_full_young_gcs = false;
|
|
||||||
clear_initiate_conc_mark_if_possible();
|
clear_initiate_conc_mark_if_possible();
|
||||||
clear_during_initial_mark_pause();
|
clear_during_initial_mark_pause();
|
||||||
_known_garbage_bytes = 0;
|
_known_garbage_bytes = 0;
|
||||||
@ -892,7 +892,7 @@ void G1CollectorPolicy::record_collection_pause_start(double start_time_sec,
|
|||||||
if (PrintGCDetails) {
|
if (PrintGCDetails) {
|
||||||
gclog_or_tty->stamp(PrintGCTimeStamps);
|
gclog_or_tty->stamp(PrintGCTimeStamps);
|
||||||
gclog_or_tty->print("[GC pause");
|
gclog_or_tty->print("[GC pause");
|
||||||
gclog_or_tty->print(" (%s)", full_young_gcs() ? "young" : "partial");
|
gclog_or_tty->print(" (%s)", gcs_are_young() ? "young" : "mixed");
|
||||||
}
|
}
|
||||||
|
|
||||||
// We only need to do this here as the policy will only be applied
|
// We only need to do this here as the policy will only be applied
|
||||||
@ -951,7 +951,7 @@ void G1CollectorPolicy::record_collection_pause_start(double start_time_sec,
|
|||||||
// the evacuation pause if marking is in progress.
|
// the evacuation pause if marking is in progress.
|
||||||
_cur_satb_drain_time_ms = 0.0;
|
_cur_satb_drain_time_ms = 0.0;
|
||||||
|
|
||||||
_last_young_gc_full = false;
|
_last_gc_was_young = false;
|
||||||
|
|
||||||
// do that for any other surv rate groups
|
// do that for any other surv rate groups
|
||||||
_short_lived_surv_rate_group->stop_adding_regions();
|
_short_lived_surv_rate_group->stop_adding_regions();
|
||||||
@ -988,8 +988,8 @@ void G1CollectorPolicy::record_concurrent_mark_cleanup_start() {
|
|||||||
}
|
}
|
||||||
|
|
||||||
void G1CollectorPolicy::record_concurrent_mark_cleanup_completed() {
|
void G1CollectorPolicy::record_concurrent_mark_cleanup_completed() {
|
||||||
_should_revert_to_full_young_gcs = false;
|
_should_revert_to_young_gcs = false;
|
||||||
_last_full_young_gc = true;
|
_last_young_gc = true;
|
||||||
_in_marking_window = false;
|
_in_marking_window = false;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -1153,7 +1153,7 @@ void G1CollectorPolicy::record_collection_pause_end(int no_of_gc_threads) {
|
|||||||
size_t marking_initiating_used_threshold =
|
size_t marking_initiating_used_threshold =
|
||||||
(_g1->capacity() / 100) * InitiatingHeapOccupancyPercent;
|
(_g1->capacity() / 100) * InitiatingHeapOccupancyPercent;
|
||||||
|
|
||||||
if (!_g1->mark_in_progress() && !_last_full_young_gc) {
|
if (!_g1->mark_in_progress() && !_last_young_gc) {
|
||||||
assert(!last_pause_included_initial_mark, "invariant");
|
assert(!last_pause_included_initial_mark, "invariant");
|
||||||
if (cur_used_bytes > marking_initiating_used_threshold) {
|
if (cur_used_bytes > marking_initiating_used_threshold) {
|
||||||
if (cur_used_bytes > _prev_collection_pause_used_at_end_bytes) {
|
if (cur_used_bytes > _prev_collection_pause_used_at_end_bytes) {
|
||||||
@ -1458,57 +1458,57 @@ void G1CollectorPolicy::record_collection_pause_end(int no_of_gc_threads) {
|
|||||||
new_in_marking_window_im = true;
|
new_in_marking_window_im = true;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (_last_full_young_gc) {
|
if (_last_young_gc) {
|
||||||
if (!last_pause_included_initial_mark) {
|
if (!last_pause_included_initial_mark) {
|
||||||
ergo_verbose2(ErgoPartiallyYoungGCs,
|
ergo_verbose2(ErgoMixedGCs,
|
||||||
"start partially-young GCs",
|
"start mixed GCs",
|
||||||
ergo_format_byte_perc("known garbage"),
|
ergo_format_byte_perc("known garbage"),
|
||||||
_known_garbage_bytes, _known_garbage_ratio * 100.0);
|
_known_garbage_bytes, _known_garbage_ratio * 100.0);
|
||||||
set_full_young_gcs(false);
|
set_gcs_are_young(false);
|
||||||
} else {
|
} else {
|
||||||
ergo_verbose0(ErgoPartiallyYoungGCs,
|
ergo_verbose0(ErgoMixedGCs,
|
||||||
"do not start partially-young GCs",
|
"do not start mixed GCs",
|
||||||
ergo_format_reason("concurrent cycle is about to start"));
|
ergo_format_reason("concurrent cycle is about to start"));
|
||||||
}
|
}
|
||||||
_last_full_young_gc = false;
|
_last_young_gc = false;
|
||||||
}
|
}
|
||||||
|
|
||||||
if ( !_last_young_gc_full ) {
|
if (!_last_gc_was_young) {
|
||||||
if (_should_revert_to_full_young_gcs) {
|
if (_should_revert_to_young_gcs) {
|
||||||
ergo_verbose2(ErgoPartiallyYoungGCs,
|
ergo_verbose2(ErgoMixedGCs,
|
||||||
"end partially-young GCs",
|
"end mixed GCs",
|
||||||
ergo_format_reason("partially-young GCs end requested")
|
ergo_format_reason("mixed GCs end requested")
|
||||||
ergo_format_byte_perc("known garbage"),
|
ergo_format_byte_perc("known garbage"),
|
||||||
_known_garbage_bytes, _known_garbage_ratio * 100.0);
|
_known_garbage_bytes, _known_garbage_ratio * 100.0);
|
||||||
set_full_young_gcs(true);
|
set_gcs_are_young(true);
|
||||||
} else if (_known_garbage_ratio < 0.05) {
|
} else if (_known_garbage_ratio < 0.05) {
|
||||||
ergo_verbose3(ErgoPartiallyYoungGCs,
|
ergo_verbose3(ErgoMixedGCs,
|
||||||
"end partially-young GCs",
|
"end mixed GCs",
|
||||||
ergo_format_reason("known garbage percent lower than threshold")
|
ergo_format_reason("known garbage percent lower than threshold")
|
||||||
ergo_format_byte_perc("known garbage")
|
ergo_format_byte_perc("known garbage")
|
||||||
ergo_format_perc("threshold"),
|
ergo_format_perc("threshold"),
|
||||||
_known_garbage_bytes, _known_garbage_ratio * 100.0,
|
_known_garbage_bytes, _known_garbage_ratio * 100.0,
|
||||||
0.05 * 100.0);
|
0.05 * 100.0);
|
||||||
set_full_young_gcs(true);
|
set_gcs_are_young(true);
|
||||||
} else if (adaptive_young_list_length() &&
|
} else if (adaptive_young_list_length() &&
|
||||||
(get_gc_eff_factor() * cur_efficiency < predict_young_gc_eff())) {
|
(get_gc_eff_factor() * cur_efficiency < predict_young_gc_eff())) {
|
||||||
ergo_verbose5(ErgoPartiallyYoungGCs,
|
ergo_verbose5(ErgoMixedGCs,
|
||||||
"end partially-young GCs",
|
"end mixed GCs",
|
||||||
ergo_format_reason("current GC efficiency lower than "
|
ergo_format_reason("current GC efficiency lower than "
|
||||||
"predicted fully-young GC efficiency")
|
"predicted young GC efficiency")
|
||||||
ergo_format_double("GC efficiency factor")
|
ergo_format_double("GC efficiency factor")
|
||||||
ergo_format_double("current GC efficiency")
|
ergo_format_double("current GC efficiency")
|
||||||
ergo_format_double("predicted fully-young GC efficiency")
|
ergo_format_double("predicted young GC efficiency")
|
||||||
ergo_format_byte_perc("known garbage"),
|
ergo_format_byte_perc("known garbage"),
|
||||||
get_gc_eff_factor(), cur_efficiency,
|
get_gc_eff_factor(), cur_efficiency,
|
||||||
predict_young_gc_eff(),
|
predict_young_gc_eff(),
|
||||||
_known_garbage_bytes, _known_garbage_ratio * 100.0);
|
_known_garbage_bytes, _known_garbage_ratio * 100.0);
|
||||||
set_full_young_gcs(true);
|
set_gcs_are_young(true);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
_should_revert_to_full_young_gcs = false;
|
_should_revert_to_young_gcs = false;
|
||||||
|
|
||||||
if (_last_young_gc_full && !_during_marking) {
|
if (_last_gc_was_young && !_during_marking) {
|
||||||
_young_gc_eff_seq->add(cur_efficiency);
|
_young_gc_eff_seq->add(cur_efficiency);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -1534,19 +1534,21 @@ void G1CollectorPolicy::record_collection_pause_end(int no_of_gc_threads) {
|
|||||||
double cost_per_entry_ms = 0.0;
|
double cost_per_entry_ms = 0.0;
|
||||||
if (cards_scanned > 10) {
|
if (cards_scanned > 10) {
|
||||||
cost_per_entry_ms = scan_rs_time / (double) cards_scanned;
|
cost_per_entry_ms = scan_rs_time / (double) cards_scanned;
|
||||||
if (_last_young_gc_full)
|
if (_last_gc_was_young) {
|
||||||
_cost_per_entry_ms_seq->add(cost_per_entry_ms);
|
_cost_per_entry_ms_seq->add(cost_per_entry_ms);
|
||||||
else
|
} else {
|
||||||
_partially_young_cost_per_entry_ms_seq->add(cost_per_entry_ms);
|
_mixed_cost_per_entry_ms_seq->add(cost_per_entry_ms);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if (_max_rs_lengths > 0) {
|
if (_max_rs_lengths > 0) {
|
||||||
double cards_per_entry_ratio =
|
double cards_per_entry_ratio =
|
||||||
(double) cards_scanned / (double) _max_rs_lengths;
|
(double) cards_scanned / (double) _max_rs_lengths;
|
||||||
if (_last_young_gc_full)
|
if (_last_gc_was_young) {
|
||||||
_fully_young_cards_per_entry_ratio_seq->add(cards_per_entry_ratio);
|
_young_cards_per_entry_ratio_seq->add(cards_per_entry_ratio);
|
||||||
else
|
} else {
|
||||||
_partially_young_cards_per_entry_ratio_seq->add(cards_per_entry_ratio);
|
_mixed_cards_per_entry_ratio_seq->add(cards_per_entry_ratio);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
// It turns out that, sometimes, _max_rs_lengths can get smaller
|
// It turns out that, sometimes, _max_rs_lengths can get smaller
|
||||||
@ -1563,10 +1565,11 @@ void G1CollectorPolicy::record_collection_pause_end(int no_of_gc_threads) {
|
|||||||
double cost_per_byte_ms = 0.0;
|
double cost_per_byte_ms = 0.0;
|
||||||
if (copied_bytes > 0) {
|
if (copied_bytes > 0) {
|
||||||
cost_per_byte_ms = obj_copy_time / (double) copied_bytes;
|
cost_per_byte_ms = obj_copy_time / (double) copied_bytes;
|
||||||
if (_in_marking_window)
|
if (_in_marking_window) {
|
||||||
_cost_per_byte_ms_during_cm_seq->add(cost_per_byte_ms);
|
_cost_per_byte_ms_during_cm_seq->add(cost_per_byte_ms);
|
||||||
else
|
} else {
|
||||||
_cost_per_byte_ms_seq->add(cost_per_byte_ms);
|
_cost_per_byte_ms_seq->add(cost_per_byte_ms);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
double all_other_time_ms = pause_time_ms -
|
double all_other_time_ms = pause_time_ms -
|
||||||
@ -1722,10 +1725,11 @@ predict_young_collection_elapsed_time_ms(size_t adjustment) {
|
|||||||
size_t rs_lengths = g1h->young_list()->sampled_rs_lengths() +
|
size_t rs_lengths = g1h->young_list()->sampled_rs_lengths() +
|
||||||
predict_rs_length_diff();
|
predict_rs_length_diff();
|
||||||
size_t card_num;
|
size_t card_num;
|
||||||
if (full_young_gcs())
|
if (gcs_are_young()) {
|
||||||
card_num = predict_young_card_num(rs_lengths);
|
card_num = predict_young_card_num(rs_lengths);
|
||||||
else
|
} else {
|
||||||
card_num = predict_non_young_card_num(rs_lengths);
|
card_num = predict_non_young_card_num(rs_lengths);
|
||||||
|
}
|
||||||
size_t young_byte_size = young_num * HeapRegion::GrainBytes;
|
size_t young_byte_size = young_num * HeapRegion::GrainBytes;
|
||||||
double accum_yg_surv_rate =
|
double accum_yg_surv_rate =
|
||||||
_short_lived_surv_rate_group->accum_surv_rate(adjustment);
|
_short_lived_surv_rate_group->accum_surv_rate(adjustment);
|
||||||
@ -1745,10 +1749,11 @@ double
|
|||||||
G1CollectorPolicy::predict_base_elapsed_time_ms(size_t pending_cards) {
|
G1CollectorPolicy::predict_base_elapsed_time_ms(size_t pending_cards) {
|
||||||
size_t rs_length = predict_rs_length_diff();
|
size_t rs_length = predict_rs_length_diff();
|
||||||
size_t card_num;
|
size_t card_num;
|
||||||
if (full_young_gcs())
|
if (gcs_are_young()) {
|
||||||
card_num = predict_young_card_num(rs_length);
|
card_num = predict_young_card_num(rs_length);
|
||||||
else
|
} else {
|
||||||
card_num = predict_non_young_card_num(rs_length);
|
card_num = predict_non_young_card_num(rs_length);
|
||||||
|
}
|
||||||
return predict_base_elapsed_time_ms(pending_cards, card_num);
|
return predict_base_elapsed_time_ms(pending_cards, card_num);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -1766,10 +1771,11 @@ G1CollectorPolicy::predict_region_elapsed_time_ms(HeapRegion* hr,
|
|||||||
bool young) {
|
bool young) {
|
||||||
size_t rs_length = hr->rem_set()->occupied();
|
size_t rs_length = hr->rem_set()->occupied();
|
||||||
size_t card_num;
|
size_t card_num;
|
||||||
if (full_young_gcs())
|
if (gcs_are_young()) {
|
||||||
card_num = predict_young_card_num(rs_length);
|
card_num = predict_young_card_num(rs_length);
|
||||||
else
|
} else {
|
||||||
card_num = predict_non_young_card_num(rs_length);
|
card_num = predict_non_young_card_num(rs_length);
|
||||||
|
}
|
||||||
size_t bytes_to_copy = predict_bytes_to_copy(hr);
|
size_t bytes_to_copy = predict_bytes_to_copy(hr);
|
||||||
|
|
||||||
double region_elapsed_time_ms =
|
double region_elapsed_time_ms =
|
||||||
@ -1817,14 +1823,14 @@ void G1CollectorPolicy::check_if_region_is_too_expensive(double
|
|||||||
// I don't think we need to do this when in young GC mode since
|
// I don't think we need to do this when in young GC mode since
|
||||||
// marking will be initiated next time we hit the soft limit anyway...
|
// marking will be initiated next time we hit the soft limit anyway...
|
||||||
if (predicted_time_ms > _expensive_region_limit_ms) {
|
if (predicted_time_ms > _expensive_region_limit_ms) {
|
||||||
ergo_verbose2(ErgoPartiallyYoungGCs,
|
ergo_verbose2(ErgoMixedGCs,
|
||||||
"request partially-young GCs end",
|
"request mixed GCs end",
|
||||||
ergo_format_reason("predicted region time higher than threshold")
|
ergo_format_reason("predicted region time higher than threshold")
|
||||||
ergo_format_ms("predicted region time")
|
ergo_format_ms("predicted region time")
|
||||||
ergo_format_ms("threshold"),
|
ergo_format_ms("threshold"),
|
||||||
predicted_time_ms, _expensive_region_limit_ms);
|
predicted_time_ms, _expensive_region_limit_ms);
|
||||||
// no point in doing another partial one
|
// no point in doing another mixed GC
|
||||||
_should_revert_to_full_young_gcs = true;
|
_should_revert_to_young_gcs = true;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -2033,8 +2039,8 @@ void G1CollectorPolicy::print_tracing_info() const {
|
|||||||
print_summary_sd(0, "Total", _all_pause_times_ms);
|
print_summary_sd(0, "Total", _all_pause_times_ms);
|
||||||
gclog_or_tty->print_cr("");
|
gclog_or_tty->print_cr("");
|
||||||
gclog_or_tty->print_cr("");
|
gclog_or_tty->print_cr("");
|
||||||
gclog_or_tty->print_cr(" Full Young GC Pauses: %8d", _full_young_pause_num);
|
gclog_or_tty->print_cr(" Young GC Pauses: %8d", _young_pause_num);
|
||||||
gclog_or_tty->print_cr(" Partial Young GC Pauses: %8d", _partial_young_pause_num);
|
gclog_or_tty->print_cr(" Mixed GC Pauses: %8d", _mixed_pause_num);
|
||||||
gclog_or_tty->print_cr("");
|
gclog_or_tty->print_cr("");
|
||||||
|
|
||||||
gclog_or_tty->print_cr("EVACUATION PAUSES");
|
gclog_or_tty->print_cr("EVACUATION PAUSES");
|
||||||
@ -2188,11 +2194,11 @@ G1CollectorPolicy::decide_on_conc_mark_initiation() {
|
|||||||
// initiate a new cycle.
|
// initiate a new cycle.
|
||||||
|
|
||||||
set_during_initial_mark_pause();
|
set_during_initial_mark_pause();
|
||||||
// We do not allow non-full young GCs during marking.
|
// We do not allow mixed GCs during marking.
|
||||||
if (!full_young_gcs()) {
|
if (!gcs_are_young()) {
|
||||||
set_full_young_gcs(true);
|
set_gcs_are_young(true);
|
||||||
ergo_verbose0(ErgoPartiallyYoungGCs,
|
ergo_verbose0(ErgoMixedGCs,
|
||||||
"end partially-young GCs",
|
"end mixed GCs",
|
||||||
ergo_format_reason("concurrent cycle is about to start"));
|
ergo_format_reason("concurrent cycle is about to start"));
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -2623,12 +2629,12 @@ void G1CollectorPolicy::choose_collection_set(double target_pause_time_ms) {
|
|||||||
double young_start_time_sec = os::elapsedTime();
|
double young_start_time_sec = os::elapsedTime();
|
||||||
|
|
||||||
_collection_set_bytes_used_before = 0;
|
_collection_set_bytes_used_before = 0;
|
||||||
_last_young_gc_full = full_young_gcs() ? true : false;
|
_last_gc_was_young = gcs_are_young() ? true : false;
|
||||||
|
|
||||||
if (_last_young_gc_full) {
|
if (_last_gc_was_young) {
|
||||||
++_full_young_pause_num;
|
++_young_pause_num;
|
||||||
} else {
|
} else {
|
||||||
++_partial_young_pause_num;
|
++_mixed_pause_num;
|
||||||
}
|
}
|
||||||
|
|
||||||
// The young list is laid with the survivor regions from the previous
|
// The young list is laid with the survivor regions from the previous
|
||||||
@ -2675,7 +2681,7 @@ void G1CollectorPolicy::choose_collection_set(double target_pause_time_ms) {
|
|||||||
// We are doing young collections so reset this.
|
// We are doing young collections so reset this.
|
||||||
non_young_start_time_sec = young_end_time_sec;
|
non_young_start_time_sec = young_end_time_sec;
|
||||||
|
|
||||||
if (!full_young_gcs()) {
|
if (!gcs_are_young()) {
|
||||||
bool should_continue = true;
|
bool should_continue = true;
|
||||||
NumberSeq seq;
|
NumberSeq seq;
|
||||||
double avg_prediction = 100000000000000000.0; // something very large
|
double avg_prediction = 100000000000000000.0; // something very large
|
||||||
@ -2732,14 +2738,14 @@ void G1CollectorPolicy::choose_collection_set(double target_pause_time_ms) {
|
|||||||
} while (should_continue);
|
} while (should_continue);
|
||||||
|
|
||||||
if (!adaptive_young_list_length() &&
|
if (!adaptive_young_list_length() &&
|
||||||
cset_region_length() < _young_list_fixed_length) {
|
cset_region_length() < _young_list_fixed_length) {
|
||||||
ergo_verbose2(ErgoCSetConstruction,
|
ergo_verbose2(ErgoCSetConstruction,
|
||||||
"request partially-young GCs end",
|
"request mixed GCs end",
|
||||||
ergo_format_reason("CSet length lower than target")
|
ergo_format_reason("CSet length lower than target")
|
||||||
ergo_format_region("CSet")
|
ergo_format_region("CSet")
|
||||||
ergo_format_region("young target"),
|
ergo_format_region("young target"),
|
||||||
cset_region_length(), _young_list_fixed_length);
|
cset_region_length(), _young_list_fixed_length);
|
||||||
_should_revert_to_full_young_gcs = true;
|
_should_revert_to_young_gcs = true;
|
||||||
}
|
}
|
||||||
|
|
||||||
ergo_verbose2(ErgoCSetConstruction | ErgoHigh,
|
ergo_verbose2(ErgoCSetConstruction | ErgoHigh,
|
||||||
|
@ -164,8 +164,8 @@ private:
|
|||||||
// times for a given worker thread.
|
// times for a given worker thread.
|
||||||
double* _par_last_gc_worker_other_times_ms;
|
double* _par_last_gc_worker_other_times_ms;
|
||||||
|
|
||||||
// indicates whether we are in full young or partially young GC mode
|
// indicates whether we are in young or mixed GC mode
|
||||||
bool _full_young_gcs;
|
bool _gcs_are_young;
|
||||||
|
|
||||||
// if true, then it tries to dynamically adjust the length of the
|
// if true, then it tries to dynamically adjust the length of the
|
||||||
// young list
|
// young list
|
||||||
@ -178,10 +178,10 @@ private:
|
|||||||
// locker is active. This should be >= _young_list_target_length;
|
// locker is active. This should be >= _young_list_target_length;
|
||||||
size_t _young_list_max_length;
|
size_t _young_list_max_length;
|
||||||
|
|
||||||
bool _last_young_gc_full;
|
bool _last_gc_was_young;
|
||||||
|
|
||||||
unsigned _full_young_pause_num;
|
unsigned _young_pause_num;
|
||||||
unsigned _partial_young_pause_num;
|
unsigned _mixed_pause_num;
|
||||||
|
|
||||||
bool _during_marking;
|
bool _during_marking;
|
||||||
bool _in_marking_window;
|
bool _in_marking_window;
|
||||||
@ -211,10 +211,10 @@ private:
|
|||||||
TruncatedSeq* _pending_card_diff_seq;
|
TruncatedSeq* _pending_card_diff_seq;
|
||||||
TruncatedSeq* _rs_length_diff_seq;
|
TruncatedSeq* _rs_length_diff_seq;
|
||||||
TruncatedSeq* _cost_per_card_ms_seq;
|
TruncatedSeq* _cost_per_card_ms_seq;
|
||||||
TruncatedSeq* _fully_young_cards_per_entry_ratio_seq;
|
TruncatedSeq* _young_cards_per_entry_ratio_seq;
|
||||||
TruncatedSeq* _partially_young_cards_per_entry_ratio_seq;
|
TruncatedSeq* _mixed_cards_per_entry_ratio_seq;
|
||||||
TruncatedSeq* _cost_per_entry_ms_seq;
|
TruncatedSeq* _cost_per_entry_ms_seq;
|
||||||
TruncatedSeq* _partially_young_cost_per_entry_ms_seq;
|
TruncatedSeq* _mixed_cost_per_entry_ms_seq;
|
||||||
TruncatedSeq* _cost_per_byte_ms_seq;
|
TruncatedSeq* _cost_per_byte_ms_seq;
|
||||||
TruncatedSeq* _constant_other_time_ms_seq;
|
TruncatedSeq* _constant_other_time_ms_seq;
|
||||||
TruncatedSeq* _young_other_cost_per_region_ms_seq;
|
TruncatedSeq* _young_other_cost_per_region_ms_seq;
|
||||||
@ -322,20 +322,22 @@ public:
|
|||||||
|
|
||||||
size_t predict_pending_card_diff() {
|
size_t predict_pending_card_diff() {
|
||||||
double prediction = get_new_neg_prediction(_pending_card_diff_seq);
|
double prediction = get_new_neg_prediction(_pending_card_diff_seq);
|
||||||
if (prediction < 0.00001)
|
if (prediction < 0.00001) {
|
||||||
return 0;
|
return 0;
|
||||||
else
|
} else {
|
||||||
return (size_t) prediction;
|
return (size_t) prediction;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
size_t predict_pending_cards() {
|
size_t predict_pending_cards() {
|
||||||
size_t max_pending_card_num = _g1->max_pending_card_num();
|
size_t max_pending_card_num = _g1->max_pending_card_num();
|
||||||
size_t diff = predict_pending_card_diff();
|
size_t diff = predict_pending_card_diff();
|
||||||
size_t prediction;
|
size_t prediction;
|
||||||
if (diff > max_pending_card_num)
|
if (diff > max_pending_card_num) {
|
||||||
prediction = max_pending_card_num;
|
prediction = max_pending_card_num;
|
||||||
else
|
} else {
|
||||||
prediction = max_pending_card_num - diff;
|
prediction = max_pending_card_num - diff;
|
||||||
|
}
|
||||||
|
|
||||||
return prediction;
|
return prediction;
|
||||||
}
|
}
|
||||||
@ -356,57 +358,62 @@ public:
|
|||||||
return (double) pending_cards * predict_cost_per_card_ms();
|
return (double) pending_cards * predict_cost_per_card_ms();
|
||||||
}
|
}
|
||||||
|
|
||||||
double predict_fully_young_cards_per_entry_ratio() {
|
double predict_young_cards_per_entry_ratio() {
|
||||||
return get_new_prediction(_fully_young_cards_per_entry_ratio_seq);
|
return get_new_prediction(_young_cards_per_entry_ratio_seq);
|
||||||
}
|
}
|
||||||
|
|
||||||
double predict_partially_young_cards_per_entry_ratio() {
|
double predict_mixed_cards_per_entry_ratio() {
|
||||||
if (_partially_young_cards_per_entry_ratio_seq->num() < 2)
|
if (_mixed_cards_per_entry_ratio_seq->num() < 2) {
|
||||||
return predict_fully_young_cards_per_entry_ratio();
|
return predict_young_cards_per_entry_ratio();
|
||||||
else
|
} else {
|
||||||
return get_new_prediction(_partially_young_cards_per_entry_ratio_seq);
|
return get_new_prediction(_mixed_cards_per_entry_ratio_seq);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
size_t predict_young_card_num(size_t rs_length) {
|
size_t predict_young_card_num(size_t rs_length) {
|
||||||
return (size_t) ((double) rs_length *
|
return (size_t) ((double) rs_length *
|
||||||
predict_fully_young_cards_per_entry_ratio());
|
predict_young_cards_per_entry_ratio());
|
||||||
}
|
}
|
||||||
|
|
||||||
size_t predict_non_young_card_num(size_t rs_length) {
|
size_t predict_non_young_card_num(size_t rs_length) {
|
||||||
return (size_t) ((double) rs_length *
|
return (size_t) ((double) rs_length *
|
||||||
predict_partially_young_cards_per_entry_ratio());
|
predict_mixed_cards_per_entry_ratio());
|
||||||
}
|
}
|
||||||
|
|
||||||
double predict_rs_scan_time_ms(size_t card_num) {
|
double predict_rs_scan_time_ms(size_t card_num) {
|
||||||
if (full_young_gcs())
|
if (gcs_are_young()) {
|
||||||
return (double) card_num * get_new_prediction(_cost_per_entry_ms_seq);
|
return (double) card_num * get_new_prediction(_cost_per_entry_ms_seq);
|
||||||
else
|
} else {
|
||||||
return predict_partially_young_rs_scan_time_ms(card_num);
|
return predict_mixed_rs_scan_time_ms(card_num);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
double predict_partially_young_rs_scan_time_ms(size_t card_num) {
|
double predict_mixed_rs_scan_time_ms(size_t card_num) {
|
||||||
if (_partially_young_cost_per_entry_ms_seq->num() < 3)
|
if (_mixed_cost_per_entry_ms_seq->num() < 3) {
|
||||||
return (double) card_num * get_new_prediction(_cost_per_entry_ms_seq);
|
return (double) card_num * get_new_prediction(_cost_per_entry_ms_seq);
|
||||||
else
|
} else {
|
||||||
return (double) card_num *
|
return (double) (card_num *
|
||||||
get_new_prediction(_partially_young_cost_per_entry_ms_seq);
|
get_new_prediction(_mixed_cost_per_entry_ms_seq));
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
double predict_object_copy_time_ms_during_cm(size_t bytes_to_copy) {
|
double predict_object_copy_time_ms_during_cm(size_t bytes_to_copy) {
|
||||||
if (_cost_per_byte_ms_during_cm_seq->num() < 3)
|
if (_cost_per_byte_ms_during_cm_seq->num() < 3) {
|
||||||
return 1.1 * (double) bytes_to_copy *
|
return (1.1 * (double) bytes_to_copy) *
|
||||||
get_new_prediction(_cost_per_byte_ms_seq);
|
get_new_prediction(_cost_per_byte_ms_seq);
|
||||||
else
|
} else {
|
||||||
return (double) bytes_to_copy *
|
return (double) bytes_to_copy *
|
||||||
get_new_prediction(_cost_per_byte_ms_during_cm_seq);
|
get_new_prediction(_cost_per_byte_ms_during_cm_seq);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
double predict_object_copy_time_ms(size_t bytes_to_copy) {
|
double predict_object_copy_time_ms(size_t bytes_to_copy) {
|
||||||
if (_in_marking_window && !_in_marking_window_im)
|
if (_in_marking_window && !_in_marking_window_im) {
|
||||||
return predict_object_copy_time_ms_during_cm(bytes_to_copy);
|
return predict_object_copy_time_ms_during_cm(bytes_to_copy);
|
||||||
else
|
} else {
|
||||||
return (double) bytes_to_copy *
|
return (double) bytes_to_copy *
|
||||||
get_new_prediction(_cost_per_byte_ms_seq);
|
get_new_prediction(_cost_per_byte_ms_seq);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
double predict_constant_other_time_ms() {
|
double predict_constant_other_time_ms() {
|
||||||
@ -414,15 +421,13 @@ public:
|
|||||||
}
|
}
|
||||||
|
|
||||||
double predict_young_other_time_ms(size_t young_num) {
|
double predict_young_other_time_ms(size_t young_num) {
|
||||||
return
|
return (double) young_num *
|
||||||
(double) young_num *
|
get_new_prediction(_young_other_cost_per_region_ms_seq);
|
||||||
get_new_prediction(_young_other_cost_per_region_ms_seq);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
double predict_non_young_other_time_ms(size_t non_young_num) {
|
double predict_non_young_other_time_ms(size_t non_young_num) {
|
||||||
return
|
return (double) non_young_num *
|
||||||
(double) non_young_num *
|
get_new_prediction(_non_young_other_cost_per_region_ms_seq);
|
||||||
get_new_prediction(_non_young_other_cost_per_region_ms_seq);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void check_if_region_is_too_expensive(double predicted_time_ms);
|
void check_if_region_is_too_expensive(double predicted_time_ms);
|
||||||
@ -456,7 +461,7 @@ public:
|
|||||||
double predict_survivor_regions_evac_time();
|
double predict_survivor_regions_evac_time();
|
||||||
|
|
||||||
void cset_regions_freed() {
|
void cset_regions_freed() {
|
||||||
bool propagate = _last_young_gc_full && !_in_marking_window;
|
bool propagate = _last_gc_was_young && !_in_marking_window;
|
||||||
_short_lived_surv_rate_group->all_surviving_words_recorded(propagate);
|
_short_lived_surv_rate_group->all_surviving_words_recorded(propagate);
|
||||||
_survivor_surv_rate_group->all_surviving_words_recorded(propagate);
|
_survivor_surv_rate_group->all_surviving_words_recorded(propagate);
|
||||||
// also call it on any more surv rate groups
|
// also call it on any more surv rate groups
|
||||||
@ -628,8 +633,8 @@ private:
|
|||||||
// initial-mark work.
|
// initial-mark work.
|
||||||
volatile bool _during_initial_mark_pause;
|
volatile bool _during_initial_mark_pause;
|
||||||
|
|
||||||
bool _should_revert_to_full_young_gcs;
|
bool _should_revert_to_young_gcs;
|
||||||
bool _last_full_young_gc;
|
bool _last_young_gc;
|
||||||
|
|
||||||
// This set of variables tracks the collector efficiency, in order to
|
// This set of variables tracks the collector efficiency, in order to
|
||||||
// determine whether we should initiate a new marking.
|
// determine whether we should initiate a new marking.
|
||||||
@ -985,11 +990,11 @@ public:
|
|||||||
return _young_list_max_length;
|
return _young_list_max_length;
|
||||||
}
|
}
|
||||||
|
|
||||||
bool full_young_gcs() {
|
bool gcs_are_young() {
|
||||||
return _full_young_gcs;
|
return _gcs_are_young;
|
||||||
}
|
}
|
||||||
void set_full_young_gcs(bool full_young_gcs) {
|
void set_gcs_are_young(bool gcs_are_young) {
|
||||||
_full_young_gcs = full_young_gcs;
|
_gcs_are_young = gcs_are_young;
|
||||||
}
|
}
|
||||||
|
|
||||||
bool adaptive_young_list_length() {
|
bool adaptive_young_list_length() {
|
||||||
|
@ -52,14 +52,13 @@ void G1ErgoVerbose::set_enabled(bool enabled) {
|
|||||||
const char* G1ErgoVerbose::to_string(int tag) {
|
const char* G1ErgoVerbose::to_string(int tag) {
|
||||||
ErgoHeuristic n = extract_heuristic(tag);
|
ErgoHeuristic n = extract_heuristic(tag);
|
||||||
switch (n) {
|
switch (n) {
|
||||||
case ErgoHeapSizing: return "Heap Sizing";
|
case ErgoHeapSizing: return "Heap Sizing";
|
||||||
case ErgoCSetConstruction: return "CSet Construction";
|
case ErgoCSetConstruction: return "CSet Construction";
|
||||||
case ErgoConcCycles: return "Concurrent Cycles";
|
case ErgoConcCycles: return "Concurrent Cycles";
|
||||||
case ErgoPartiallyYoungGCs: return "Partially-Young GCs";
|
case ErgoMixedGCs: return "Mixed GCs";
|
||||||
default:
|
default:
|
||||||
ShouldNotReachHere();
|
ShouldNotReachHere();
|
||||||
// Keep the Windows compiler happy
|
// Keep the Windows compiler happy
|
||||||
return NULL;
|
return NULL;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -69,7 +69,7 @@ typedef enum {
|
|||||||
ErgoHeapSizing = 0,
|
ErgoHeapSizing = 0,
|
||||||
ErgoCSetConstruction,
|
ErgoCSetConstruction,
|
||||||
ErgoConcCycles,
|
ErgoConcCycles,
|
||||||
ErgoPartiallyYoungGCs,
|
ErgoMixedGCs,
|
||||||
|
|
||||||
ErgoHeuristicNum
|
ErgoHeuristicNum
|
||||||
} ErgoHeuristic;
|
} ErgoHeuristic;
|
||||||
|
@ -119,7 +119,7 @@ class G1MonitoringSupport : public CHeapObj {
|
|||||||
G1CollectedHeap* _g1h;
|
G1CollectedHeap* _g1h;
|
||||||
|
|
||||||
// jstat performance counters
|
// jstat performance counters
|
||||||
// incremental collections both fully and partially young
|
// incremental collections both young and mixed
|
||||||
CollectorCounters* _incremental_collection_counters;
|
CollectorCounters* _incremental_collection_counters;
|
||||||
// full stop-the-world collections
|
// full stop-the-world collections
|
||||||
CollectorCounters* _full_collection_counters;
|
CollectorCounters* _full_collection_counters;
|
||||||
|
@ -672,15 +672,20 @@ void PSMarkSweep::mark_sweep_phase4() {
|
|||||||
}
|
}
|
||||||
|
|
||||||
jlong PSMarkSweep::millis_since_last_gc() {
|
jlong PSMarkSweep::millis_since_last_gc() {
|
||||||
jlong ret_val = os::javaTimeMillis() - _time_of_last_gc;
|
// We need a monotonically non-deccreasing time in ms but
|
||||||
|
// os::javaTimeMillis() does not guarantee monotonicity.
|
||||||
|
jlong now = os::javaTimeNanos() / NANOSECS_PER_MILLISEC;
|
||||||
|
jlong ret_val = now - _time_of_last_gc;
|
||||||
// XXX See note in genCollectedHeap::millis_since_last_gc().
|
// XXX See note in genCollectedHeap::millis_since_last_gc().
|
||||||
if (ret_val < 0) {
|
if (ret_val < 0) {
|
||||||
NOT_PRODUCT(warning("time warp: %d", ret_val);)
|
NOT_PRODUCT(warning("time warp: "INT64_FORMAT, ret_val);)
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
return ret_val;
|
return ret_val;
|
||||||
}
|
}
|
||||||
|
|
||||||
void PSMarkSweep::reset_millis_since_last_gc() {
|
void PSMarkSweep::reset_millis_since_last_gc() {
|
||||||
_time_of_last_gc = os::javaTimeMillis();
|
// We need a monotonically non-deccreasing time in ms but
|
||||||
|
// os::javaTimeMillis() does not guarantee monotonicity.
|
||||||
|
_time_of_last_gc = os::javaTimeNanos() / NANOSECS_PER_MILLISEC;
|
||||||
}
|
}
|
||||||
|
@ -3398,17 +3398,22 @@ PSParallelCompact::move_and_update(ParCompactionManager* cm, SpaceId space_id) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
jlong PSParallelCompact::millis_since_last_gc() {
|
jlong PSParallelCompact::millis_since_last_gc() {
|
||||||
jlong ret_val = os::javaTimeMillis() - _time_of_last_gc;
|
// We need a monotonically non-deccreasing time in ms but
|
||||||
|
// os::javaTimeMillis() does not guarantee monotonicity.
|
||||||
|
jlong now = os::javaTimeNanos() / NANOSECS_PER_MILLISEC;
|
||||||
|
jlong ret_val = now - _time_of_last_gc;
|
||||||
// XXX See note in genCollectedHeap::millis_since_last_gc().
|
// XXX See note in genCollectedHeap::millis_since_last_gc().
|
||||||
if (ret_val < 0) {
|
if (ret_val < 0) {
|
||||||
NOT_PRODUCT(warning("time warp: %d", ret_val);)
|
NOT_PRODUCT(warning("time warp: "INT64_FORMAT, ret_val);)
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
return ret_val;
|
return ret_val;
|
||||||
}
|
}
|
||||||
|
|
||||||
void PSParallelCompact::reset_millis_since_last_gc() {
|
void PSParallelCompact::reset_millis_since_last_gc() {
|
||||||
_time_of_last_gc = os::javaTimeMillis();
|
// We need a monotonically non-deccreasing time in ms but
|
||||||
|
// os::javaTimeMillis() does not guarantee monotonicity.
|
||||||
|
_time_of_last_gc = os::javaTimeNanos() / NANOSECS_PER_MILLISEC;
|
||||||
}
|
}
|
||||||
|
|
||||||
ParMarkBitMap::IterationStatus MoveAndUpdateClosure::copy_until_full()
|
ParMarkBitMap::IterationStatus MoveAndUpdateClosure::copy_until_full()
|
||||||
|
@ -471,3 +471,26 @@ oop CollectedHeap::Class_obj_allocate(KlassHandle klass, int size, KlassHandle r
|
|||||||
|
|
||||||
return mirror;
|
return mirror;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/////////////// Unit tests ///////////////
|
||||||
|
|
||||||
|
#ifndef PRODUCT
|
||||||
|
void CollectedHeap::test_is_in() {
|
||||||
|
CollectedHeap* heap = Universe::heap();
|
||||||
|
|
||||||
|
// Test that NULL is not in the heap.
|
||||||
|
assert(!heap->is_in(NULL), "NULL is unexpectedly in the heap");
|
||||||
|
|
||||||
|
// Test that a pointer to before the heap start is reported as outside the heap.
|
||||||
|
assert(heap->_reserved.start() >= (void*)MinObjAlignment, "sanity");
|
||||||
|
void* before_heap = (void*)((intptr_t)heap->_reserved.start() - MinObjAlignment);
|
||||||
|
assert(!heap->is_in(before_heap),
|
||||||
|
err_msg("before_heap: " PTR_FORMAT " is unexpectedly in the heap", before_heap));
|
||||||
|
|
||||||
|
// Test that a pointer to after the heap end is reported as outside the heap.
|
||||||
|
assert(heap->_reserved.end() <= (void*)(uintptr_t(-1) - (uint)MinObjAlignment), "sanity");
|
||||||
|
void* after_heap = (void*)((intptr_t)heap->_reserved.end() + MinObjAlignment);
|
||||||
|
assert(!heap->is_in(after_heap),
|
||||||
|
err_msg("after_heap: " PTR_FORMAT " is unexpectedly in the heap", after_heap));
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
@ -217,8 +217,8 @@ class CollectedHeap : public CHeapObj {
|
|||||||
return p == NULL || is_in_reserved(p);
|
return p == NULL || is_in_reserved(p);
|
||||||
}
|
}
|
||||||
|
|
||||||
// Returns "TRUE" if "p" points to the head of an allocated object in the
|
// Returns "TRUE" iff "p" points into the committed areas of the heap.
|
||||||
// heap. Since this method can be expensive in general, we restrict its
|
// Since this method can be expensive in general, we restrict its
|
||||||
// use to assertion checking only.
|
// use to assertion checking only.
|
||||||
virtual bool is_in(const void* p) const = 0;
|
virtual bool is_in(const void* p) const = 0;
|
||||||
|
|
||||||
@ -648,6 +648,10 @@ class CollectedHeap : public CHeapObj {
|
|||||||
// reduce the occurrence of ParallelGCThreads to uses where the
|
// reduce the occurrence of ParallelGCThreads to uses where the
|
||||||
// actual number may be germane.
|
// actual number may be germane.
|
||||||
static bool use_parallel_gc_threads() { return ParallelGCThreads > 0; }
|
static bool use_parallel_gc_threads() { return ParallelGCThreads > 0; }
|
||||||
|
|
||||||
|
/////////////// Unit tests ///////////////
|
||||||
|
|
||||||
|
NOT_PRODUCT(static void test_is_in();)
|
||||||
};
|
};
|
||||||
|
|
||||||
// Class to set and reset the GC cause for a CollectedHeap.
|
// Class to set and reset the GC cause for a CollectedHeap.
|
||||||
|
@ -957,7 +957,7 @@ bool GenCollectedHeap::is_in_young(oop p) {
|
|||||||
return result;
|
return result;
|
||||||
}
|
}
|
||||||
|
|
||||||
// Returns "TRUE" iff "p" points into the allocated area of the heap.
|
// Returns "TRUE" iff "p" points into the committed areas of the heap.
|
||||||
bool GenCollectedHeap::is_in(const void* p) const {
|
bool GenCollectedHeap::is_in(const void* p) const {
|
||||||
#ifndef ASSERT
|
#ifndef ASSERT
|
||||||
guarantee(VerifyBeforeGC ||
|
guarantee(VerifyBeforeGC ||
|
||||||
@ -1460,26 +1460,22 @@ class GenTimeOfLastGCClosure: public GenCollectedHeap::GenClosure {
|
|||||||
};
|
};
|
||||||
|
|
||||||
jlong GenCollectedHeap::millis_since_last_gc() {
|
jlong GenCollectedHeap::millis_since_last_gc() {
|
||||||
jlong now = os::javaTimeMillis();
|
// We need a monotonically non-deccreasing time in ms but
|
||||||
|
// os::javaTimeMillis() does not guarantee monotonicity.
|
||||||
|
jlong now = os::javaTimeNanos() / NANOSECS_PER_MILLISEC;
|
||||||
GenTimeOfLastGCClosure tolgc_cl(now);
|
GenTimeOfLastGCClosure tolgc_cl(now);
|
||||||
// iterate over generations getting the oldest
|
// iterate over generations getting the oldest
|
||||||
// time that a generation was collected
|
// time that a generation was collected
|
||||||
generation_iterate(&tolgc_cl, false);
|
generation_iterate(&tolgc_cl, false);
|
||||||
tolgc_cl.do_generation(perm_gen());
|
tolgc_cl.do_generation(perm_gen());
|
||||||
// XXX Despite the assert above, since javaTimeMillis()
|
|
||||||
// doesnot guarantee monotonically increasing return
|
// javaTimeNanos() is guaranteed to be monotonically non-decreasing
|
||||||
// values (note, i didn't say "strictly monotonic"),
|
// provided the underlying platform provides such a time source
|
||||||
// we need to guard against getting back a time
|
// (and it is bug free). So we still have to guard against getting
|
||||||
// later than now. This should be fixed by basing
|
// back a time later than 'now'.
|
||||||
// on someting like gethrtime() which guarantees
|
|
||||||
// monotonicity. Note that cond_wait() is susceptible
|
|
||||||
// to a similar problem, because its interface is
|
|
||||||
// based on absolute time in the form of the
|
|
||||||
// system time's notion of UCT. See also 4506635
|
|
||||||
// for yet another problem of similar nature. XXX
|
|
||||||
jlong retVal = now - tolgc_cl.time();
|
jlong retVal = now - tolgc_cl.time();
|
||||||
if (retVal < 0) {
|
if (retVal < 0) {
|
||||||
NOT_PRODUCT(warning("time warp: %d", retVal);)
|
NOT_PRODUCT(warning("time warp: "INT64_FORMAT, retVal);)
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
return retVal;
|
return retVal;
|
||||||
|
@ -198,7 +198,7 @@ public:
|
|||||||
// Mostly used for testing purposes. Caller does not hold the Heap_lock on entry.
|
// Mostly used for testing purposes. Caller does not hold the Heap_lock on entry.
|
||||||
void collect(GCCause::Cause cause, int max_level);
|
void collect(GCCause::Cause cause, int max_level);
|
||||||
|
|
||||||
// Returns "TRUE" iff "p" points into the allocated area of the heap.
|
// Returns "TRUE" iff "p" points into the committed areas of the heap.
|
||||||
// The methods is_in(), is_in_closed_subset() and is_in_youngest() may
|
// The methods is_in(), is_in_closed_subset() and is_in_youngest() may
|
||||||
// be expensive to compute in general, so, to prevent
|
// be expensive to compute in general, so, to prevent
|
||||||
// their inadvertent use in product jvm's, we restrict their use to
|
// their inadvertent use in product jvm's, we restrict their use to
|
||||||
|
@ -220,7 +220,7 @@ class Generation: public CHeapObj {
|
|||||||
MemRegion prev_used_region() const { return _prev_used_region; }
|
MemRegion prev_used_region() const { return _prev_used_region; }
|
||||||
virtual void save_used_region() { _prev_used_region = used_region(); }
|
virtual void save_used_region() { _prev_used_region = used_region(); }
|
||||||
|
|
||||||
// Returns "TRUE" iff "p" points into an allocated object in the generation.
|
// Returns "TRUE" iff "p" points into the committed areas in the generation.
|
||||||
// For some kinds of generations, this may be an expensive operation.
|
// For some kinds of generations, this may be an expensive operation.
|
||||||
// To avoid performance problems stemming from its inadvertent use in
|
// To avoid performance problems stemming from its inadvertent use in
|
||||||
// product jvm's, we restrict its use to assertion checking or
|
// product jvm's, we restrict its use to assertion checking or
|
||||||
@ -413,10 +413,13 @@ class Generation: public CHeapObj {
|
|||||||
// Time (in ms) when we were last collected or now if a collection is
|
// Time (in ms) when we were last collected or now if a collection is
|
||||||
// in progress.
|
// in progress.
|
||||||
virtual jlong time_of_last_gc(jlong now) {
|
virtual jlong time_of_last_gc(jlong now) {
|
||||||
// XXX See note in genCollectedHeap::millis_since_last_gc()
|
// Both _time_of_last_gc and now are set using a time source
|
||||||
|
// that guarantees monotonically non-decreasing values provided
|
||||||
|
// the underlying platform provides such a source. So we still
|
||||||
|
// have to guard against non-monotonicity.
|
||||||
NOT_PRODUCT(
|
NOT_PRODUCT(
|
||||||
if (now < _time_of_last_gc) {
|
if (now < _time_of_last_gc) {
|
||||||
warning("time warp: %d to %d", _time_of_last_gc, now);
|
warning("time warp: "INT64_FORMAT" to "INT64_FORMAT, _time_of_last_gc, now);
|
||||||
}
|
}
|
||||||
)
|
)
|
||||||
return _time_of_last_gc;
|
return _time_of_last_gc;
|
||||||
|
@ -43,7 +43,9 @@ void referenceProcessor_init() {
|
|||||||
}
|
}
|
||||||
|
|
||||||
void ReferenceProcessor::init_statics() {
|
void ReferenceProcessor::init_statics() {
|
||||||
jlong now = os::javaTimeMillis();
|
// We need a monotonically non-deccreasing time in ms but
|
||||||
|
// os::javaTimeMillis() does not guarantee monotonicity.
|
||||||
|
jlong now = os::javaTimeNanos() / NANOSECS_PER_MILLISEC;
|
||||||
|
|
||||||
// Initialize the soft ref timestamp clock.
|
// Initialize the soft ref timestamp clock.
|
||||||
_soft_ref_timestamp_clock = now;
|
_soft_ref_timestamp_clock = now;
|
||||||
@ -151,7 +153,10 @@ void ReferenceProcessor::weak_oops_do(OopClosure* f) {
|
|||||||
void ReferenceProcessor::update_soft_ref_master_clock() {
|
void ReferenceProcessor::update_soft_ref_master_clock() {
|
||||||
// Update (advance) the soft ref master clock field. This must be done
|
// Update (advance) the soft ref master clock field. This must be done
|
||||||
// after processing the soft ref list.
|
// after processing the soft ref list.
|
||||||
jlong now = os::javaTimeMillis();
|
|
||||||
|
// We need a monotonically non-deccreasing time in ms but
|
||||||
|
// os::javaTimeMillis() does not guarantee monotonicity.
|
||||||
|
jlong now = os::javaTimeNanos() / NANOSECS_PER_MILLISEC;
|
||||||
jlong soft_ref_clock = java_lang_ref_SoftReference::clock();
|
jlong soft_ref_clock = java_lang_ref_SoftReference::clock();
|
||||||
assert(soft_ref_clock == _soft_ref_timestamp_clock, "soft ref clocks out of sync");
|
assert(soft_ref_clock == _soft_ref_timestamp_clock, "soft ref clocks out of sync");
|
||||||
|
|
||||||
@ -161,10 +166,11 @@ void ReferenceProcessor::update_soft_ref_master_clock() {
|
|||||||
_soft_ref_timestamp_clock, now);
|
_soft_ref_timestamp_clock, now);
|
||||||
}
|
}
|
||||||
)
|
)
|
||||||
// In product mode, protect ourselves from system time being adjusted
|
// The values of now and _soft_ref_timestamp_clock are set using
|
||||||
// externally and going backward; see note in the implementation of
|
// javaTimeNanos(), which is guaranteed to be monotonically
|
||||||
// GenCollectedHeap::time_since_last_gc() for the right way to fix
|
// non-decreasing provided the underlying platform provides such
|
||||||
// this uniformly throughout the VM; see bug-id 4741166. XXX
|
// a time source (and it is bug free).
|
||||||
|
// In product mode, however, protect ourselves from non-monotonicty.
|
||||||
if (now > _soft_ref_timestamp_clock) {
|
if (now > _soft_ref_timestamp_clock) {
|
||||||
_soft_ref_timestamp_clock = now;
|
_soft_ref_timestamp_clock = now;
|
||||||
java_lang_ref_SoftReference::set_clock(now);
|
java_lang_ref_SoftReference::set_clock(now);
|
||||||
|
@ -304,11 +304,6 @@ void ContiguousSpace::clear(bool mangle_space) {
|
|||||||
CompactibleSpace::clear(mangle_space);
|
CompactibleSpace::clear(mangle_space);
|
||||||
}
|
}
|
||||||
|
|
||||||
bool Space::is_in(const void* p) const {
|
|
||||||
HeapWord* b = block_start_const(p);
|
|
||||||
return b != NULL && block_is_obj(b);
|
|
||||||
}
|
|
||||||
|
|
||||||
bool ContiguousSpace::is_in(const void* p) const {
|
bool ContiguousSpace::is_in(const void* p) const {
|
||||||
return _bottom <= p && p < _top;
|
return _bottom <= p && p < _top;
|
||||||
}
|
}
|
||||||
|
@ -187,7 +187,7 @@ class Space: public CHeapObj {
|
|||||||
// expensive operation. To prevent performance problems
|
// expensive operation. To prevent performance problems
|
||||||
// on account of its inadvertent use in product jvm's,
|
// on account of its inadvertent use in product jvm's,
|
||||||
// we restrict its use to assertion checks only.
|
// we restrict its use to assertion checks only.
|
||||||
virtual bool is_in(const void* p) const;
|
virtual bool is_in(const void* p) const = 0;
|
||||||
|
|
||||||
// Returns true iff the given reserved memory of the space contains the
|
// Returns true iff the given reserved memory of the space contains the
|
||||||
// given address.
|
// given address.
|
||||||
|
@ -38,9 +38,7 @@ bool arrayOopDesc::check_max_length_overflow(BasicType type) {
|
|||||||
return (julong)(size_t)bytes == bytes;
|
return (julong)(size_t)bytes == bytes;
|
||||||
}
|
}
|
||||||
|
|
||||||
bool arrayOopDesc::test_max_array_length() {
|
void arrayOopDesc::test_max_array_length() {
|
||||||
tty->print_cr("test_max_array_length");
|
|
||||||
|
|
||||||
assert(check_max_length_overflow(T_BOOLEAN), "size_t overflow for boolean array");
|
assert(check_max_length_overflow(T_BOOLEAN), "size_t overflow for boolean array");
|
||||||
assert(check_max_length_overflow(T_CHAR), "size_t overflow for char array");
|
assert(check_max_length_overflow(T_CHAR), "size_t overflow for char array");
|
||||||
assert(check_max_length_overflow(T_FLOAT), "size_t overflow for float array");
|
assert(check_max_length_overflow(T_FLOAT), "size_t overflow for float array");
|
||||||
@ -54,8 +52,6 @@ bool arrayOopDesc::test_max_array_length() {
|
|||||||
assert(check_max_length_overflow(T_NARROWOOP), "size_t overflow for narrowOop array");
|
assert(check_max_length_overflow(T_NARROWOOP), "size_t overflow for narrowOop array");
|
||||||
|
|
||||||
// T_VOID and T_ADDRESS are not supported by max_array_length()
|
// T_VOID and T_ADDRESS are not supported by max_array_length()
|
||||||
|
|
||||||
return true;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
@ -128,7 +128,7 @@ class arrayOopDesc : public oopDesc {
|
|||||||
#ifndef PRODUCT
|
#ifndef PRODUCT
|
||||||
static bool check_max_length_overflow(BasicType type);
|
static bool check_max_length_overflow(BasicType type);
|
||||||
static int32_t old_max_array_length(BasicType type);
|
static int32_t old_max_array_length(BasicType type);
|
||||||
static bool test_max_array_length();
|
static void test_max_array_length();
|
||||||
#endif
|
#endif
|
||||||
};
|
};
|
||||||
|
|
||||||
|
@ -5037,16 +5037,25 @@ _JNI_IMPORT_OR_EXPORT_ jint JNICALL JNI_GetDefaultJavaVMInitArgs(void *args_) {
|
|||||||
|
|
||||||
#ifndef PRODUCT
|
#ifndef PRODUCT
|
||||||
|
|
||||||
|
#include "gc_interface/collectedHeap.hpp"
|
||||||
#include "utilities/quickSort.hpp"
|
#include "utilities/quickSort.hpp"
|
||||||
|
|
||||||
|
#define run_unit_test(unit_test_function_call) \
|
||||||
|
tty->print_cr("Running test: " #unit_test_function_call); \
|
||||||
|
unit_test_function_call
|
||||||
|
|
||||||
void execute_internal_vm_tests() {
|
void execute_internal_vm_tests() {
|
||||||
if (ExecuteInternalVMTests) {
|
if (ExecuteInternalVMTests) {
|
||||||
assert(QuickSort::test_quick_sort(), "test_quick_sort failed");
|
tty->print_cr("Running internal VM tests");
|
||||||
assert(arrayOopDesc::test_max_array_length(), "test_max_array_length failed");
|
run_unit_test(arrayOopDesc::test_max_array_length());
|
||||||
|
run_unit_test(CollectedHeap::test_is_in());
|
||||||
|
run_unit_test(QuickSort::test_quick_sort());
|
||||||
tty->print_cr("All internal VM tests passed");
|
tty->print_cr("All internal VM tests passed");
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#undef run_unit_test
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#ifndef USDT2
|
#ifndef USDT2
|
||||||
|
@ -3515,14 +3515,14 @@ JVM_END
|
|||||||
JVM_LEAF(jint, JVM_Recv(jint fd, char *buf, jint nBytes, jint flags))
|
JVM_LEAF(jint, JVM_Recv(jint fd, char *buf, jint nBytes, jint flags))
|
||||||
JVMWrapper2("JVM_Recv (0x%x)", fd);
|
JVMWrapper2("JVM_Recv (0x%x)", fd);
|
||||||
//%note jvm_r6
|
//%note jvm_r6
|
||||||
return os::recv(fd, buf, nBytes, flags);
|
return os::recv(fd, buf, (size_t)nBytes, (uint)flags);
|
||||||
JVM_END
|
JVM_END
|
||||||
|
|
||||||
|
|
||||||
JVM_LEAF(jint, JVM_Send(jint fd, char *buf, jint nBytes, jint flags))
|
JVM_LEAF(jint, JVM_Send(jint fd, char *buf, jint nBytes, jint flags))
|
||||||
JVMWrapper2("JVM_Send (0x%x)", fd);
|
JVMWrapper2("JVM_Send (0x%x)", fd);
|
||||||
//%note jvm_r6
|
//%note jvm_r6
|
||||||
return os::send(fd, buf, nBytes, flags);
|
return os::send(fd, buf, (size_t)nBytes, (uint)flags);
|
||||||
JVM_END
|
JVM_END
|
||||||
|
|
||||||
|
|
||||||
@ -3543,42 +3543,51 @@ JVM_END
|
|||||||
JVM_LEAF(jint, JVM_Connect(jint fd, struct sockaddr *him, jint len))
|
JVM_LEAF(jint, JVM_Connect(jint fd, struct sockaddr *him, jint len))
|
||||||
JVMWrapper2("JVM_Connect (0x%x)", fd);
|
JVMWrapper2("JVM_Connect (0x%x)", fd);
|
||||||
//%note jvm_r6
|
//%note jvm_r6
|
||||||
return os::connect(fd, him, len);
|
return os::connect(fd, him, (socklen_t)len);
|
||||||
JVM_END
|
JVM_END
|
||||||
|
|
||||||
|
|
||||||
JVM_LEAF(jint, JVM_Bind(jint fd, struct sockaddr *him, jint len))
|
JVM_LEAF(jint, JVM_Bind(jint fd, struct sockaddr *him, jint len))
|
||||||
JVMWrapper2("JVM_Bind (0x%x)", fd);
|
JVMWrapper2("JVM_Bind (0x%x)", fd);
|
||||||
//%note jvm_r6
|
//%note jvm_r6
|
||||||
return os::bind(fd, him, len);
|
return os::bind(fd, him, (socklen_t)len);
|
||||||
JVM_END
|
JVM_END
|
||||||
|
|
||||||
|
|
||||||
JVM_LEAF(jint, JVM_Accept(jint fd, struct sockaddr *him, jint *len))
|
JVM_LEAF(jint, JVM_Accept(jint fd, struct sockaddr *him, jint *len))
|
||||||
JVMWrapper2("JVM_Accept (0x%x)", fd);
|
JVMWrapper2("JVM_Accept (0x%x)", fd);
|
||||||
//%note jvm_r6
|
//%note jvm_r6
|
||||||
return os::accept(fd, him, (int *)len);
|
socklen_t socklen = (socklen_t)(*len);
|
||||||
|
jint result = os::accept(fd, him, &socklen);
|
||||||
|
*len = (jint)socklen;
|
||||||
|
return result;
|
||||||
JVM_END
|
JVM_END
|
||||||
|
|
||||||
|
|
||||||
JVM_LEAF(jint, JVM_RecvFrom(jint fd, char *buf, int nBytes, int flags, struct sockaddr *from, int *fromlen))
|
JVM_LEAF(jint, JVM_RecvFrom(jint fd, char *buf, int nBytes, int flags, struct sockaddr *from, int *fromlen))
|
||||||
JVMWrapper2("JVM_RecvFrom (0x%x)", fd);
|
JVMWrapper2("JVM_RecvFrom (0x%x)", fd);
|
||||||
//%note jvm_r6
|
//%note jvm_r6
|
||||||
return os::recvfrom(fd, buf, nBytes, flags, from, fromlen);
|
socklen_t socklen = (socklen_t)(*fromlen);
|
||||||
|
jint result = os::recvfrom(fd, buf, (size_t)nBytes, (uint)flags, from, &socklen);
|
||||||
|
*fromlen = (int)socklen;
|
||||||
|
return result;
|
||||||
JVM_END
|
JVM_END
|
||||||
|
|
||||||
|
|
||||||
JVM_LEAF(jint, JVM_GetSockName(jint fd, struct sockaddr *him, int *len))
|
JVM_LEAF(jint, JVM_GetSockName(jint fd, struct sockaddr *him, int *len))
|
||||||
JVMWrapper2("JVM_GetSockName (0x%x)", fd);
|
JVMWrapper2("JVM_GetSockName (0x%x)", fd);
|
||||||
//%note jvm_r6
|
//%note jvm_r6
|
||||||
return os::get_sock_name(fd, him, len);
|
socklen_t socklen = (socklen_t)(*len);
|
||||||
|
jint result = os::get_sock_name(fd, him, &socklen);
|
||||||
|
*len = (int)socklen;
|
||||||
|
return result;
|
||||||
JVM_END
|
JVM_END
|
||||||
|
|
||||||
|
|
||||||
JVM_LEAF(jint, JVM_SendTo(jint fd, char *buf, int len, int flags, struct sockaddr *to, int tolen))
|
JVM_LEAF(jint, JVM_SendTo(jint fd, char *buf, int len, int flags, struct sockaddr *to, int tolen))
|
||||||
JVMWrapper2("JVM_SendTo (0x%x)", fd);
|
JVMWrapper2("JVM_SendTo (0x%x)", fd);
|
||||||
//%note jvm_r6
|
//%note jvm_r6
|
||||||
return os::sendto(fd, buf, len, flags, to, tolen);
|
return os::sendto(fd, buf, (size_t)len, (uint)flags, to, (socklen_t)tolen);
|
||||||
JVM_END
|
JVM_END
|
||||||
|
|
||||||
|
|
||||||
@ -3592,21 +3601,26 @@ JVM_END
|
|||||||
JVM_LEAF(jint, JVM_GetSockOpt(jint fd, int level, int optname, char *optval, int *optlen))
|
JVM_LEAF(jint, JVM_GetSockOpt(jint fd, int level, int optname, char *optval, int *optlen))
|
||||||
JVMWrapper2("JVM_GetSockOpt (0x%x)", fd);
|
JVMWrapper2("JVM_GetSockOpt (0x%x)", fd);
|
||||||
//%note jvm_r6
|
//%note jvm_r6
|
||||||
return os::get_sock_opt(fd, level, optname, optval, optlen);
|
socklen_t socklen = (socklen_t)(*optlen);
|
||||||
|
jint result = os::get_sock_opt(fd, level, optname, optval, &socklen);
|
||||||
|
*optlen = (int)socklen;
|
||||||
|
return result;
|
||||||
JVM_END
|
JVM_END
|
||||||
|
|
||||||
|
|
||||||
JVM_LEAF(jint, JVM_SetSockOpt(jint fd, int level, int optname, const char *optval, int optlen))
|
JVM_LEAF(jint, JVM_SetSockOpt(jint fd, int level, int optname, const char *optval, int optlen))
|
||||||
JVMWrapper2("JVM_GetSockOpt (0x%x)", fd);
|
JVMWrapper2("JVM_GetSockOpt (0x%x)", fd);
|
||||||
//%note jvm_r6
|
//%note jvm_r6
|
||||||
return os::set_sock_opt(fd, level, optname, optval, optlen);
|
return os::set_sock_opt(fd, level, optname, optval, (socklen_t)optlen);
|
||||||
JVM_END
|
JVM_END
|
||||||
|
|
||||||
|
|
||||||
JVM_LEAF(int, JVM_GetHostName(char* name, int namelen))
|
JVM_LEAF(int, JVM_GetHostName(char* name, int namelen))
|
||||||
JVMWrapper("JVM_GetHostName");
|
JVMWrapper("JVM_GetHostName");
|
||||||
return os::get_host_name(name, namelen);
|
return os::get_host_name(name, namelen);
|
||||||
JVM_END
|
JVM_END
|
||||||
|
|
||||||
|
|
||||||
// Library support ///////////////////////////////////////////////////////////////////////////
|
// Library support ///////////////////////////////////////////////////////////////////////////
|
||||||
|
|
||||||
JVM_ENTRY_NO_ENV(void*, JVM_LoadLibrary(const char* name))
|
JVM_ENTRY_NO_ENV(void*, JVM_LoadLibrary(const char* name))
|
||||||
@ -3647,6 +3661,7 @@ JVM_LEAF(void*, JVM_FindLibraryEntry(void* handle, const char* name))
|
|||||||
return os::dll_lookup(handle, name);
|
return os::dll_lookup(handle, name);
|
||||||
JVM_END
|
JVM_END
|
||||||
|
|
||||||
|
|
||||||
// Floating point support ////////////////////////////////////////////////////////////////////
|
// Floating point support ////////////////////////////////////////////////////////////////////
|
||||||
|
|
||||||
JVM_LEAF(jboolean, JVM_IsNaN(jdouble a))
|
JVM_LEAF(jboolean, JVM_IsNaN(jdouble a))
|
||||||
@ -3655,7 +3670,6 @@ JVM_LEAF(jboolean, JVM_IsNaN(jdouble a))
|
|||||||
JVM_END
|
JVM_END
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
// JNI version ///////////////////////////////////////////////////////////////////////////////
|
// JNI version ///////////////////////////////////////////////////////////////////////////////
|
||||||
|
|
||||||
JVM_LEAF(jboolean, JVM_IsSupportedJNIVersion(jint version))
|
JVM_LEAF(jboolean, JVM_IsSupportedJNIVersion(jint version))
|
||||||
|
@ -43,7 +43,7 @@
|
|||||||
#ifdef TARGET_ARCH_ppc
|
#ifdef TARGET_ARCH_ppc
|
||||||
# include "bytes_ppc.hpp"
|
# include "bytes_ppc.hpp"
|
||||||
#endif
|
#endif
|
||||||
// FIXME: add Deprecated, LVT, LVTT attributes
|
// FIXME: add Deprecated, LVTT attributes
|
||||||
// FIXME: fix Synthetic attribute
|
// FIXME: fix Synthetic attribute
|
||||||
// FIXME: per Serguei, add error return handling for constantPoolOopDesc::copy_cpool_bytes()
|
// FIXME: per Serguei, add error return handling for constantPoolOopDesc::copy_cpool_bytes()
|
||||||
|
|
||||||
@ -136,8 +136,9 @@ void JvmtiClassFileReconstituter::write_code_attribute(methodHandle method) {
|
|||||||
constMethodHandle const_method(thread(), method->constMethod());
|
constMethodHandle const_method(thread(), method->constMethod());
|
||||||
u2 line_num_cnt = 0;
|
u2 line_num_cnt = 0;
|
||||||
int stackmap_len = 0;
|
int stackmap_len = 0;
|
||||||
|
int local_variable_table_length = 0;
|
||||||
|
|
||||||
// compute number and length of attributes -- FIXME: for now no LVT
|
// compute number and length of attributes
|
||||||
int attr_count = 0;
|
int attr_count = 0;
|
||||||
int attr_size = 0;
|
int attr_size = 0;
|
||||||
if (const_method->has_linenumber_table()) {
|
if (const_method->has_linenumber_table()) {
|
||||||
@ -170,6 +171,25 @@ void JvmtiClassFileReconstituter::write_code_attribute(methodHandle method) {
|
|||||||
attr_size += 2 + 4 + stackmap_len;
|
attr_size += 2 + 4 + stackmap_len;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
if (method->has_localvariable_table()) {
|
||||||
|
local_variable_table_length = method->localvariable_table_length();
|
||||||
|
++attr_count;
|
||||||
|
if (local_variable_table_length != 0) {
|
||||||
|
// Compute the size of the local variable table attribute (VM stores raw):
|
||||||
|
// LocalVariableTable_attribute {
|
||||||
|
// u2 attribute_name_index;
|
||||||
|
// u4 attribute_length;
|
||||||
|
// u2 local_variable_table_length;
|
||||||
|
// {
|
||||||
|
// u2 start_pc;
|
||||||
|
// u2 length;
|
||||||
|
// u2 name_index;
|
||||||
|
// u2 descriptor_index;
|
||||||
|
// u2 index;
|
||||||
|
// }
|
||||||
|
attr_size += 2 + 4 + 2 + local_variable_table_length * (2 + 2 + 2 + 2 + 2);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
typeArrayHandle exception_table(thread(), const_method->exception_table());
|
typeArrayHandle exception_table(thread(), const_method->exception_table());
|
||||||
int exception_table_length = exception_table->length();
|
int exception_table_length = exception_table->length();
|
||||||
@ -203,8 +223,9 @@ void JvmtiClassFileReconstituter::write_code_attribute(methodHandle method) {
|
|||||||
if (stackmap_len != 0) {
|
if (stackmap_len != 0) {
|
||||||
write_stackmap_table_attribute(method, stackmap_len);
|
write_stackmap_table_attribute(method, stackmap_len);
|
||||||
}
|
}
|
||||||
|
if (local_variable_table_length != 0) {
|
||||||
// FIXME: write LVT attribute
|
write_local_variable_table_attribute(method, local_variable_table_length);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
// Write Exceptions attribute
|
// Write Exceptions attribute
|
||||||
@ -371,6 +392,36 @@ void JvmtiClassFileReconstituter::write_line_number_table_attribute(methodHandle
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// Write LineNumberTable attribute
|
||||||
|
// JVMSpec| LocalVariableTable_attribute {
|
||||||
|
// JVMSpec| u2 attribute_name_index;
|
||||||
|
// JVMSpec| u4 attribute_length;
|
||||||
|
// JVMSpec| u2 local_variable_table_length;
|
||||||
|
// JVMSpec| { u2 start_pc;
|
||||||
|
// JVMSpec| u2 length;
|
||||||
|
// JVMSpec| u2 name_index;
|
||||||
|
// JVMSpec| u2 descriptor_index;
|
||||||
|
// JVMSpec| u2 index;
|
||||||
|
// JVMSpec| } local_variable_table[local_variable_table_length];
|
||||||
|
// JVMSpec| }
|
||||||
|
void JvmtiClassFileReconstituter::write_local_variable_table_attribute(methodHandle method, u2 num_entries) {
|
||||||
|
write_attribute_name_index("LocalVariableTable");
|
||||||
|
write_u4(2 + num_entries * (2 + 2 + 2 + 2 + 2));
|
||||||
|
write_u2(num_entries);
|
||||||
|
|
||||||
|
assert(method->localvariable_table_length() == num_entries, "just checking");
|
||||||
|
|
||||||
|
LocalVariableTableElement *elem = method->localvariable_table_start();
|
||||||
|
for (int j=0; j<method->localvariable_table_length(); j++) {
|
||||||
|
write_u2(elem->start_bci);
|
||||||
|
write_u2(elem->length);
|
||||||
|
write_u2(elem->name_cp_index);
|
||||||
|
write_u2(elem->descriptor_cp_index);
|
||||||
|
write_u2(elem->slot);
|
||||||
|
elem++;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
// Write stack map table attribute
|
// Write stack map table attribute
|
||||||
// JSR-202| StackMapTable_attribute {
|
// JSR-202| StackMapTable_attribute {
|
||||||
// JSR-202| u2 attribute_name_index;
|
// JSR-202| u2 attribute_name_index;
|
||||||
|
@ -119,6 +119,7 @@ class JvmtiClassFileReconstituter : public JvmtiConstantPoolReconstituter {
|
|||||||
void write_source_debug_extension_attribute();
|
void write_source_debug_extension_attribute();
|
||||||
u2 line_number_table_entries(methodHandle method);
|
u2 line_number_table_entries(methodHandle method);
|
||||||
void write_line_number_table_attribute(methodHandle method, u2 num_entries);
|
void write_line_number_table_attribute(methodHandle method, u2 num_entries);
|
||||||
|
void write_local_variable_table_attribute(methodHandle method, u2 num_entries);
|
||||||
void write_stackmap_table_attribute(methodHandle method, int stackmap_table_len);
|
void write_stackmap_table_attribute(methodHandle method, int stackmap_table_len);
|
||||||
u2 inner_classes_attribute_length();
|
u2 inner_classes_attribute_length();
|
||||||
void write_inner_classes_attribute(int length);
|
void write_inner_classes_attribute(int length);
|
||||||
|
@ -82,16 +82,19 @@ bool Flag::is_unlocked() const {
|
|||||||
}
|
}
|
||||||
|
|
||||||
bool Flag::is_writeable() const {
|
bool Flag::is_writeable() const {
|
||||||
return (strcmp(kind, "{manageable}") == 0 || strcmp(kind, "{product rw}") == 0);
|
return strcmp(kind, "{manageable}") == 0 ||
|
||||||
|
strcmp(kind, "{product rw}") == 0 ||
|
||||||
|
is_writeable_ext();
|
||||||
}
|
}
|
||||||
|
|
||||||
// All flags except "manageable" are assumed internal flags.
|
// All flags except "manageable" are assumed to be internal flags.
|
||||||
// Long term, we need to define a mechanism to specify which flags
|
// Long term, we need to define a mechanism to specify which flags
|
||||||
// are external/stable and change this function accordingly.
|
// are external/stable and change this function accordingly.
|
||||||
bool Flag::is_external() const {
|
bool Flag::is_external() const {
|
||||||
return (strcmp(kind, "{manageable}") == 0);
|
return strcmp(kind, "{manageable}") == 0 || is_external_ext();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
// Length of format string (e.g. "%.1234s") for printing ccstr below
|
// Length of format string (e.g. "%.1234s") for printing ccstr below
|
||||||
#define FORMAT_BUFFER_LEN 16
|
#define FORMAT_BUFFER_LEN 16
|
||||||
|
|
||||||
|
@ -245,6 +245,8 @@ struct Flag {
|
|||||||
|
|
||||||
bool is_unlocker_ext() const;
|
bool is_unlocker_ext() const;
|
||||||
bool is_unlocked_ext() const;
|
bool is_unlocked_ext() const;
|
||||||
|
bool is_writeable_ext() const;
|
||||||
|
bool is_external_ext() const;
|
||||||
|
|
||||||
void print_on(outputStream* st, bool withComments = false );
|
void print_on(outputStream* st, bool withComments = false );
|
||||||
void print_as_flag(outputStream* st);
|
void print_as_flag(outputStream* st);
|
||||||
|
@ -53,4 +53,12 @@ inline bool Flag::is_unlocked_ext() const {
|
|||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
inline bool Flag::is_writeable_ext() const {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
inline bool Flag::is_external_ext() const {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
#endif // SHARE_VM_RUNTIME_GLOBALS_EXT_HPP
|
#endif // SHARE_VM_RUNTIME_GLOBALS_EXT_HPP
|
||||||
|
@ -584,28 +584,28 @@ class os: AllStatic {
|
|||||||
static int socket(int domain, int type, int protocol);
|
static int socket(int domain, int type, int protocol);
|
||||||
static int socket_close(int fd);
|
static int socket_close(int fd);
|
||||||
static int socket_shutdown(int fd, int howto);
|
static int socket_shutdown(int fd, int howto);
|
||||||
static int recv(int fd, char *buf, int nBytes, int flags);
|
static int recv(int fd, char* buf, size_t nBytes, uint flags);
|
||||||
static int send(int fd, char *buf, int nBytes, int flags);
|
static int send(int fd, char* buf, size_t nBytes, uint flags);
|
||||||
static int raw_send(int fd, char *buf, int nBytes, int flags);
|
static int raw_send(int fd, char* buf, size_t nBytes, uint flags);
|
||||||
static int timeout(int fd, long timeout);
|
static int timeout(int fd, long timeout);
|
||||||
static int listen(int fd, int count);
|
static int listen(int fd, int count);
|
||||||
static int connect(int fd, struct sockaddr *him, int len);
|
static int connect(int fd, struct sockaddr* him, socklen_t len);
|
||||||
static int bind(int fd, struct sockaddr *him, int len);
|
static int bind(int fd, struct sockaddr* him, socklen_t len);
|
||||||
static int accept(int fd, struct sockaddr *him, int *len);
|
static int accept(int fd, struct sockaddr* him, socklen_t* len);
|
||||||
static int recvfrom(int fd, char *buf, int nbytes, int flags,
|
static int recvfrom(int fd, char* buf, size_t nbytes, uint flags,
|
||||||
struct sockaddr *from, int *fromlen);
|
struct sockaddr* from, socklen_t* fromlen);
|
||||||
static int get_sock_name(int fd, struct sockaddr *him, int *len);
|
static int get_sock_name(int fd, struct sockaddr* him, socklen_t* len);
|
||||||
static int sendto(int fd, char *buf, int len, int flags,
|
static int sendto(int fd, char* buf, size_t len, uint flags,
|
||||||
struct sockaddr *to, int tolen);
|
struct sockaddr* to, socklen_t tolen);
|
||||||
static int socket_available(int fd, jint *pbytes);
|
static int socket_available(int fd, jint* pbytes);
|
||||||
|
|
||||||
static int get_sock_opt(int fd, int level, int optname,
|
static int get_sock_opt(int fd, int level, int optname,
|
||||||
char *optval, int* optlen);
|
char* optval, socklen_t* optlen);
|
||||||
static int set_sock_opt(int fd, int level, int optname,
|
static int set_sock_opt(int fd, int level, int optname,
|
||||||
const char *optval, int optlen);
|
const char* optval, socklen_t optlen);
|
||||||
static int get_host_name(char* name, int namelen);
|
static int get_host_name(char* name, int namelen);
|
||||||
|
|
||||||
static struct hostent* get_host_by_name(char* name);
|
static struct hostent* get_host_by_name(char* name);
|
||||||
|
|
||||||
// Printing 64 bit integers
|
// Printing 64 bit integers
|
||||||
static const char* jlong_format_specifier();
|
static const char* jlong_format_specifier();
|
||||||
@ -715,7 +715,6 @@ class os: AllStatic {
|
|||||||
# include "os_bsd_zero.hpp"
|
# include "os_bsd_zero.hpp"
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
|
||||||
// debugging support (mostly used by debug.cpp but also fatal error handler)
|
// debugging support (mostly used by debug.cpp but also fatal error handler)
|
||||||
static bool find(address pc, outputStream* st = tty); // OS specific function to make sense out of an address
|
static bool find(address pc, outputStream* st = tty); // OS specific function to make sense out of an address
|
||||||
|
|
||||||
|
@ -33,6 +33,7 @@
|
|||||||
#include "oops/objArrayKlass.hpp"
|
#include "oops/objArrayKlass.hpp"
|
||||||
#include "oops/oop.inline.hpp"
|
#include "oops/oop.inline.hpp"
|
||||||
#include "runtime/arguments.hpp"
|
#include "runtime/arguments.hpp"
|
||||||
|
#include "runtime/globals.hpp"
|
||||||
#include "runtime/handles.inline.hpp"
|
#include "runtime/handles.inline.hpp"
|
||||||
#include "runtime/interfaceSupport.hpp"
|
#include "runtime/interfaceSupport.hpp"
|
||||||
#include "runtime/javaCalls.hpp"
|
#include "runtime/javaCalls.hpp"
|
||||||
|
@ -175,6 +175,9 @@ const int MILLIUNITS = 1000; // milli units per base unit
|
|||||||
const int MICROUNITS = 1000000; // micro units per base unit
|
const int MICROUNITS = 1000000; // micro units per base unit
|
||||||
const int NANOUNITS = 1000000000; // nano units per base unit
|
const int NANOUNITS = 1000000000; // nano units per base unit
|
||||||
|
|
||||||
|
const jlong NANOSECS_PER_SEC = CONST64(1000000000);
|
||||||
|
const jint NANOSECS_PER_MILLISEC = 1000000;
|
||||||
|
|
||||||
inline const char* proper_unit_for_byte_size(size_t s) {
|
inline const char* proper_unit_for_byte_size(size_t s) {
|
||||||
if (s >= 10*M) {
|
if (s >= 10*M) {
|
||||||
return "M";
|
return "M";
|
||||||
|
@ -1021,7 +1021,7 @@ int networkStream::read(char *buf, size_t len) {
|
|||||||
|
|
||||||
void networkStream::flush() {
|
void networkStream::flush() {
|
||||||
if (size() != 0) {
|
if (size() != 0) {
|
||||||
int result = os::raw_send(_socket, (char *)base(), (int)size(), 0);
|
int result = os::raw_send(_socket, (char *)base(), size(), 0);
|
||||||
assert(result != -1, "connection error");
|
assert(result != -1, "connection error");
|
||||||
assert(result == (int)size(), "didn't send enough data");
|
assert(result == (int)size(), "didn't send enough data");
|
||||||
}
|
}
|
||||||
|
@ -93,8 +93,7 @@ bool QuickSort::sort_and_compare(int* arrayToSort, int* expectedResult, int leng
|
|||||||
return compare_arrays(arrayToSort, expectedResult, length);
|
return compare_arrays(arrayToSort, expectedResult, length);
|
||||||
}
|
}
|
||||||
|
|
||||||
bool QuickSort::test_quick_sort() {
|
void QuickSort::test_quick_sort() {
|
||||||
tty->print_cr("test_quick_sort");
|
|
||||||
{
|
{
|
||||||
int* test_array = NULL;
|
int* test_array = NULL;
|
||||||
int* expected_array = NULL;
|
int* expected_array = NULL;
|
||||||
@ -214,7 +213,6 @@ bool QuickSort::test_quick_sort() {
|
|||||||
delete[] test_array;
|
delete[] test_array;
|
||||||
delete[] expected_array;
|
delete[] expected_array;
|
||||||
}
|
}
|
||||||
return true;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
@ -130,7 +130,7 @@ class QuickSort : AllStatic {
|
|||||||
static void print_array(const char* prefix, int* array, int length);
|
static void print_array(const char* prefix, int* array, int length);
|
||||||
static bool compare_arrays(int* actual, int* expected, int length);
|
static bool compare_arrays(int* actual, int* expected, int length);
|
||||||
template <class C> static bool sort_and_compare(int* arrayToSort, int* expectedResult, int length, C comparator, bool idempotent = false);
|
template <class C> static bool sort_and_compare(int* arrayToSort, int* expectedResult, int length, C comparator, bool idempotent = false);
|
||||||
static bool test_quick_sort();
|
static void test_quick_sort();
|
||||||
#endif
|
#endif
|
||||||
};
|
};
|
||||||
|
|
||||||
|
@ -139,3 +139,4 @@ bcc739229f6384786c7ac0b52c1822c85674dcf1 jdk8-b13
|
|||||||
804f666d6d44e33caac12ad8da3d2780ac44ef72 jdk8-b15
|
804f666d6d44e33caac12ad8da3d2780ac44ef72 jdk8-b15
|
||||||
09eb517404b059607aca30cdd1af83ffc57eafeb jdk8-b17
|
09eb517404b059607aca30cdd1af83ffc57eafeb jdk8-b17
|
||||||
09eb517404b059607aca30cdd1af83ffc57eafeb jdk8-b16
|
09eb517404b059607aca30cdd1af83ffc57eafeb jdk8-b16
|
||||||
|
ebec6a7e8d4e481d205a2109ddeea8121d76db7f jdk8-b18
|
||||||
|
@ -43,14 +43,6 @@
|
|||||||
Run 'make help' for help using the Makefile.
|
Run 'make help' for help using the Makefile.
|
||||||
</description>
|
</description>
|
||||||
|
|
||||||
<!-- Mac is special, need to downgrade these before build.properties. -->
|
|
||||||
<condition property="javac.source" value="1.5">
|
|
||||||
<os family="mac"/>
|
|
||||||
</condition>
|
|
||||||
<condition property="javac.target" value="1.5">
|
|
||||||
<os family="mac"/>
|
|
||||||
</condition>
|
|
||||||
|
|
||||||
<!-- Project build properties. -->
|
<!-- Project build properties. -->
|
||||||
<property file="build.properties"/>
|
<property file="build.properties"/>
|
||||||
|
|
||||||
|
@ -25,21 +25,21 @@
|
|||||||
|
|
||||||
# Properties for jprt
|
# Properties for jprt
|
||||||
|
|
||||||
# The release to build
|
# Locked down to jdk8
|
||||||
jprt.tools.default.release=jdk8
|
jprt.tools.default.release=jdk8
|
||||||
|
|
||||||
# The different build flavors we want, we override here so we just get these 2
|
# The different build flavors we want, we override here so we just get these 2
|
||||||
jprt.build.flavors=product,fastdebug
|
jprt.build.flavors=product,fastdebug
|
||||||
|
|
||||||
# Standard list of jprt build targets for this source tree
|
# Standard list of jprt build targets for this source tree
|
||||||
jprt.build.targets= \
|
jprt.build.targets= \
|
||||||
solaris_sparc_5.10-{product|fastdebug}, \
|
solaris_sparc_5.10-{product|fastdebug}, \
|
||||||
solaris_sparcv9_5.10-{product|fastdebug}, \
|
solaris_sparcv9_5.10-{product|fastdebug}, \
|
||||||
solaris_i586_5.10-{product|fastdebug}, \
|
solaris_i586_5.10-{product|fastdebug}, \
|
||||||
solaris_x64_5.10-{product|fastdebug}, \
|
solaris_x64_5.10-{product|fastdebug}, \
|
||||||
linux_i586_2.6-{product|fastdebug}, \
|
linux_i586_2.6-{product|fastdebug}, \
|
||||||
linux_x64_2.6-{product|fastdebug}, \
|
linux_x64_2.6-{product|fastdebug}, \
|
||||||
windows_i586_5.1-{product|fastdebug}, \
|
windows_i586_5.1-{product|fastdebug}, \
|
||||||
windows_x64_5.2-{product|fastdebug}
|
windows_x64_5.2-{product|fastdebug}
|
||||||
|
|
||||||
# Directories to be excluded from the source bundles
|
# Directories to be excluded from the source bundles
|
||||||
|
@ -139,3 +139,4 @@ adf2a6b5fde14090beb9ebc40c4114132ddee731 jdk8-b13
|
|||||||
c9ab96ff23d52d85d5dcce1f9c0fd7a3de418c74 jdk8-b15
|
c9ab96ff23d52d85d5dcce1f9c0fd7a3de418c74 jdk8-b15
|
||||||
3d45ab79643d5b4cc7e050ae2d9c08b4d89d665e jdk8-b17
|
3d45ab79643d5b4cc7e050ae2d9c08b4d89d665e jdk8-b17
|
||||||
3d45ab79643d5b4cc7e050ae2d9c08b4d89d665e jdk8-b16
|
3d45ab79643d5b4cc7e050ae2d9c08b4d89d665e jdk8-b16
|
||||||
|
54928c8850f5498670dd43d6c9299f36de1a6746 jdk8-b18
|
||||||
|
@ -43,14 +43,6 @@
|
|||||||
Run 'make help' for help using the Makefile.
|
Run 'make help' for help using the Makefile.
|
||||||
</description>
|
</description>
|
||||||
|
|
||||||
<!-- Mac is special, need to downgrade these before build.properties. -->
|
|
||||||
<condition property="javac.source" value="1.5">
|
|
||||||
<os family="mac"/>
|
|
||||||
</condition>
|
|
||||||
<condition property="javac.target" value="1.5">
|
|
||||||
<os family="mac"/>
|
|
||||||
</condition>
|
|
||||||
|
|
||||||
<!-- Project build properties. -->
|
<!-- Project build properties. -->
|
||||||
<property file="build.properties"/>
|
<property file="build.properties"/>
|
||||||
|
|
||||||
|
@ -25,21 +25,21 @@
|
|||||||
|
|
||||||
# Properties for jprt
|
# Properties for jprt
|
||||||
|
|
||||||
# The release to build
|
# Locked down to jdk8
|
||||||
jprt.tools.default.release=jdk8
|
jprt.tools.default.release=jdk8
|
||||||
|
|
||||||
# The different build flavors we want, we override here so we just get these 2
|
# The different build flavors we want, we override here so we just get these 2
|
||||||
jprt.build.flavors=product,fastdebug
|
jprt.build.flavors=product,fastdebug
|
||||||
|
|
||||||
# Standard list of jprt build targets for this source tree
|
# Standard list of jprt build targets for this source tree
|
||||||
jprt.build.targets= \
|
jprt.build.targets= \
|
||||||
solaris_sparc_5.10-{product|fastdebug}, \
|
solaris_sparc_5.10-{product|fastdebug}, \
|
||||||
solaris_sparcv9_5.10-{product|fastdebug}, \
|
solaris_sparcv9_5.10-{product|fastdebug}, \
|
||||||
solaris_i586_5.10-{product|fastdebug}, \
|
solaris_i586_5.10-{product|fastdebug}, \
|
||||||
solaris_x64_5.10-{product|fastdebug}, \
|
solaris_x64_5.10-{product|fastdebug}, \
|
||||||
linux_i586_2.6-{product|fastdebug}, \
|
linux_i586_2.6-{product|fastdebug}, \
|
||||||
linux_x64_2.6-{product|fastdebug}, \
|
linux_x64_2.6-{product|fastdebug}, \
|
||||||
windows_i586_5.1-{product|fastdebug}, \
|
windows_i586_5.1-{product|fastdebug}, \
|
||||||
windows_x64_5.2-{product|fastdebug}
|
windows_x64_5.2-{product|fastdebug}
|
||||||
|
|
||||||
# Directories to be excluded from the source bundles
|
# Directories to be excluded from the source bundles
|
||||||
|
@ -139,3 +139,4 @@ f1ec21b8142168ff40f3278d2f6b5fe4bd5f3b26 jdk8-b09
|
|||||||
3c248d0e2c486624cc0d7aba1e4df45ae5774ff7 jdk8-b15
|
3c248d0e2c486624cc0d7aba1e4df45ae5774ff7 jdk8-b15
|
||||||
b71d1acfae5240d8c1359443cd02b5ddb587231c jdk8-b17
|
b71d1acfae5240d8c1359443cd02b5ddb587231c jdk8-b17
|
||||||
929597c6e777f742ad252660045ebaa4a3ea4772 jdk8-b16
|
929597c6e777f742ad252660045ebaa4a3ea4772 jdk8-b16
|
||||||
|
334bd51fb3f321cd6777416ae7bafac71a84140a jdk8-b18
|
||||||
|
@ -239,7 +239,7 @@ classes : $(CLASSES_INIT) .delete.classlist .compile.classlist
|
|||||||
$(CAT) $<.filtered; \
|
$(CAT) $<.filtered; \
|
||||||
$(ECHO) "# Running javac: $$numfiles files; in $(CURDIR)"; \
|
$(ECHO) "# Running javac: $$numfiles files; in $(CURDIR)"; \
|
||||||
$(ECHO) $(JAVAC_CMD) -sourcepath "$(SOURCEPATH)" -d $(CLASSDESTDIR) @$<.filtered; \
|
$(ECHO) $(JAVAC_CMD) -sourcepath "$(SOURCEPATH)" -d $(CLASSDESTDIR) @$<.filtered; \
|
||||||
$(JAVAC_CMD) -sourcepath "$(SOURCEPATH)" -d $(CLASSDESTDIR) @$<.filtered; \
|
$(JAVAC_CMD) -sourcepath "$(SOURCEPATH)" -d $(CLASSDESTDIR) @$<.filtered && \
|
||||||
$(ECHO) "# javac finished"; \
|
$(ECHO) "# javac finished"; \
|
||||||
fi
|
fi
|
||||||
@$(java-vm-cleanup)
|
@$(java-vm-cleanup)
|
||||||
|
@ -25,15 +25,15 @@
|
|||||||
|
|
||||||
# Properties for jprt
|
# Properties for jprt
|
||||||
|
|
||||||
# Release to build for
|
# Locked down to jdk8
|
||||||
jprt.tools.default.release=jdk8
|
jprt.tools.default.release=jdk8
|
||||||
|
|
||||||
# The different build flavors we want, we override here so we just get these 2
|
# The different build flavors we want, we override here so we just get these 2
|
||||||
jprt.build.flavors=product,fastdebug
|
jprt.build.flavors=product,fastdebug
|
||||||
|
|
||||||
# Standard list of jprt build targets for this source tree
|
# Standard list of jprt build targets for this source tree
|
||||||
jprt.build.targets= \
|
jprt.build.targets= \
|
||||||
solaris_sparc_5.10-{product|fastdebug}, \
|
solaris_sparc_5.10-{product|fastdebug}, \
|
||||||
solaris_sparcv9_5.10-{product|fastdebug}, \
|
solaris_sparcv9_5.10-{product|fastdebug}, \
|
||||||
solaris_i586_5.10-{product|fastdebug}, \
|
solaris_i586_5.10-{product|fastdebug}, \
|
||||||
solaris_x64_5.10-{product|fastdebug}, \
|
solaris_x64_5.10-{product|fastdebug}, \
|
||||||
@ -45,247 +45,59 @@ jprt.build.targets= \
|
|||||||
# User can select the test set with jprt submit "-testset name" option
|
# User can select the test set with jprt submit "-testset name" option
|
||||||
jprt.my.test.set=${jprt.test.set}
|
jprt.my.test.set=${jprt.test.set}
|
||||||
|
|
||||||
# Standard vm test target
|
# Test target list (no fastdebug & limited c2 testing)
|
||||||
|
jprt.my.test.target.set= \
|
||||||
|
solaris_sparc_5.10-product-c1-TESTNAME, \
|
||||||
|
solaris_sparcv9_5.10-product-c2-TESTNAME, \
|
||||||
|
solaris_i586_5.10-product-c1-TESTNAME, \
|
||||||
|
solaris_x64_5.10-product-c2-TESTNAME, \
|
||||||
|
linux_i586_2.6-product-{c1|c2}-TESTNAME, \
|
||||||
|
linux_x64_2.6-product-c2-TESTNAME, \
|
||||||
|
windows_i586_5.1-product-c1-TESTNAME, \
|
||||||
|
windows_x64_5.2-product-c2-TESTNAME
|
||||||
|
|
||||||
|
# Default vm test targets (testset=default)
|
||||||
jprt.vm.default.test.targets= \
|
jprt.vm.default.test.targets= \
|
||||||
solaris_sparc_5.10-product-c1-jvm98, \
|
${jprt.my.test.target.set:TESTNAME=jvm98}
|
||||||
solaris_sparcv9_5.10-product-c2-jvm98, \
|
|
||||||
solaris_i586_5.10-product-c1-jvm98, \
|
|
||||||
solaris_x64_5.10-product-c2-jvm98, \
|
|
||||||
linux_i586_2.6-product-{c1|c2}-jvm98, \
|
|
||||||
linux_x64_2.6-product-c2-jvm98, \
|
|
||||||
windows_i586_5.1-product-c1-jvm98, \
|
|
||||||
windows_x64_5.2-product-c2-jvm98
|
|
||||||
|
|
||||||
# Select vm testlist to use (allow for testset to be empty too)
|
# Default jdk test targets (testset=default)
|
||||||
jprt.vm.all.test.targets=${jprt.vm.default.test.targets}
|
|
||||||
jprt.vm..test.targets=${jprt.vm.default.test.targets}
|
|
||||||
jprt.test.targets=${jprt.vm.${jprt.my.test.set}.test.targets}
|
|
||||||
|
|
||||||
# Default jdk test targets in test/Makefile (no fastdebug & limited c2)
|
|
||||||
jprt.make.rule.default.test.targets= \
|
jprt.make.rule.default.test.targets= \
|
||||||
\
|
${jprt.my.test.target.set:TESTNAME=jdk_beans1}, \
|
||||||
solaris_sparc_5.10-product-c1-jdk_beans1, \
|
${jprt.my.test.target.set:TESTNAME=jdk_io}, \
|
||||||
solaris_sparcv9_5.10-product-c2-jdk_beans1, \
|
${jprt.my.test.target.set:TESTNAME=jdk_lang}, \
|
||||||
solaris_i586_5.10-product-c1-jdk_beans1, \
|
${jprt.my.test.target.set:TESTNAME=jdk_math}, \
|
||||||
solaris_x64_5.10-product-c2-jdk_beans1, \
|
${jprt.my.test.target.set:TESTNAME=jdk_misc}, \
|
||||||
linux_i586_2.6-product-{c1|c2}-jdk_beans1, \
|
${jprt.my.test.target.set:TESTNAME=jdk_net}, \
|
||||||
linux_x64_2.6-product-c2-jdk_beans1, \
|
${jprt.my.test.target.set:TESTNAME=jdk_nio1}, \
|
||||||
windows_i586_5.1-product-c1-jdk_beans1, \
|
${jprt.my.test.target.set:TESTNAME=jdk_nio2}, \
|
||||||
windows_x64_5.2-product-c2-jdk_beans1, \
|
${jprt.my.test.target.set:TESTNAME=jdk_nio3}, \
|
||||||
\
|
${jprt.my.test.target.set:TESTNAME=jdk_security1}, \
|
||||||
solaris_sparc_5.10-product-c1-jdk_io, \
|
${jprt.my.test.target.set:TESTNAME=jdk_text}, \
|
||||||
solaris_sparcv9_5.10-product-c2-jdk_io, \
|
${jprt.my.test.target.set:TESTNAME=jdk_util}
|
||||||
solaris_i586_5.10-product-c1-jdk_io, \
|
|
||||||
solaris_x64_5.10-product-c2-jdk_io, \
|
|
||||||
linux_i586_2.6-product-{c1|c2}-jdk_io, \
|
|
||||||
linux_x64_2.6-product-c2-jdk_io, \
|
|
||||||
windows_i586_5.1-product-c1-jdk_io, \
|
|
||||||
windows_x64_5.2-product-c2-jdk_io, \
|
|
||||||
\
|
|
||||||
solaris_sparc_5.10-product-c1-jdk_lang, \
|
|
||||||
solaris_sparcv9_5.10-product-c2-jdk_lang, \
|
|
||||||
solaris_i586_5.10-product-c1-jdk_lang, \
|
|
||||||
solaris_x64_5.10-product-c2-jdk_lang, \
|
|
||||||
linux_i586_2.6-product-{c1|c2}-jdk_lang, \
|
|
||||||
linux_x64_2.6-product-c2-jdk_lang, \
|
|
||||||
windows_i586_5.1-product-c1-jdk_lang, \
|
|
||||||
windows_x64_5.2-product-c2-jdk_lang, \
|
|
||||||
\
|
|
||||||
solaris_sparc_5.10-product-c1-jdk_math, \
|
|
||||||
solaris_sparcv9_5.10-product-c2-jdk_math, \
|
|
||||||
solaris_i586_5.10-product-c1-jdk_math, \
|
|
||||||
solaris_x64_5.10-product-c2-jdk_math, \
|
|
||||||
linux_i586_2.6-product-{c1|c2}-jdk_math, \
|
|
||||||
linux_x64_2.6-product-c2-jdk_math, \
|
|
||||||
windows_i586_5.1-product-c1-jdk_math, \
|
|
||||||
windows_x64_5.2-product-c2-jdk_math, \
|
|
||||||
\
|
|
||||||
solaris_sparc_5.10-product-c1-jdk_misc, \
|
|
||||||
solaris_sparcv9_5.10-product-c2-jdk_misc, \
|
|
||||||
solaris_i586_5.10-product-c1-jdk_misc, \
|
|
||||||
solaris_x64_5.10-product-c2-jdk_misc, \
|
|
||||||
linux_i586_2.6-product-{c1|c2}-jdk_misc, \
|
|
||||||
linux_x64_2.6-product-c2-jdk_misc, \
|
|
||||||
windows_i586_5.1-product-c1-jdk_misc, \
|
|
||||||
windows_x64_5.2-product-c2-jdk_misc, \
|
|
||||||
\
|
|
||||||
solaris_sparc_5.10-product-c1-jdk_net, \
|
|
||||||
solaris_sparcv9_5.10-product-c2-jdk_net, \
|
|
||||||
solaris_i586_5.10-product-c1-jdk_net, \
|
|
||||||
solaris_x64_5.10-product-c2-jdk_net, \
|
|
||||||
linux_i586_2.6-product-{c1|c2}-jdk_net, \
|
|
||||||
linux_x64_2.6-product-c2-jdk_net, \
|
|
||||||
windows_i586_5.1-product-c1-jdk_net, \
|
|
||||||
windows_x64_5.2-product-c2-jdk_net, \
|
|
||||||
\
|
|
||||||
solaris_sparc_5.10-product-c1-jdk_nio1, \
|
|
||||||
solaris_sparcv9_5.10-product-c2-jdk_nio1, \
|
|
||||||
solaris_i586_5.10-product-c1-jdk_nio1, \
|
|
||||||
solaris_x64_5.10-product-c2-jdk_nio1, \
|
|
||||||
linux_i586_2.6-product-{c1|c2}-jdk_nio1, \
|
|
||||||
linux_x64_2.6-product-c2-jdk_nio1, \
|
|
||||||
windows_i586_5.1-product-c1-jdk_nio1, \
|
|
||||||
windows_x64_5.2-product-c2-jdk_nio1, \
|
|
||||||
\
|
|
||||||
solaris_sparc_5.10-product-c1-jdk_nio2, \
|
|
||||||
solaris_sparcv9_5.10-product-c2-jdk_nio2, \
|
|
||||||
solaris_i586_5.10-product-c1-jdk_nio2, \
|
|
||||||
solaris_x64_5.10-product-c2-jdk_nio2, \
|
|
||||||
linux_i586_2.6-product-{c1|c2}-jdk_nio2, \
|
|
||||||
linux_x64_2.6-product-c2-jdk_nio2, \
|
|
||||||
windows_i586_5.1-product-c1-jdk_nio2, \
|
|
||||||
windows_x64_5.2-product-c2-jdk_nio2, \
|
|
||||||
\
|
|
||||||
solaris_sparc_5.10-product-c1-jdk_nio3, \
|
|
||||||
solaris_sparcv9_5.10-product-c2-jdk_nio3, \
|
|
||||||
solaris_i586_5.10-product-c1-jdk_nio3, \
|
|
||||||
solaris_x64_5.10-product-c2-jdk_nio3, \
|
|
||||||
linux_i586_2.6-product-{c1|c2}-jdk_nio3, \
|
|
||||||
linux_x64_2.6-product-c2-jdk_nio3, \
|
|
||||||
windows_i586_5.1-product-c1-jdk_nio3, \
|
|
||||||
windows_x64_5.2-product-c2-jdk_nio3, \
|
|
||||||
\
|
|
||||||
solaris_sparc_5.10-product-c1-jdk_security1, \
|
|
||||||
solaris_sparcv9_5.10-product-c2-jdk_security1, \
|
|
||||||
solaris_i586_5.10-product-c1-jdk_security1, \
|
|
||||||
solaris_x64_5.10-product-c2-jdk_security1, \
|
|
||||||
linux_i586_2.6-product-{c1|c2}-jdk_security1, \
|
|
||||||
linux_x64_2.6-product-c2-jdk_security1, \
|
|
||||||
windows_i586_5.1-product-c1-jdk_security1, \
|
|
||||||
windows_x64_5.2-product-c2-jdk_security1, \
|
|
||||||
\
|
|
||||||
solaris_sparc_5.10-product-c1-jdk_text, \
|
|
||||||
solaris_sparcv9_5.10-product-c2-jdk_text, \
|
|
||||||
solaris_i586_5.10-product-c1-jdk_text, \
|
|
||||||
solaris_x64_5.10-product-c2-jdk_text, \
|
|
||||||
linux_i586_2.6-product-{c1|c2}-jdk_text, \
|
|
||||||
linux_x64_2.6-product-c2-jdk_text, \
|
|
||||||
windows_i586_5.1-product-c1-jdk_text, \
|
|
||||||
windows_x64_5.2-product-c2-jdk_text, \
|
|
||||||
\
|
|
||||||
solaris_sparc_5.10-product-c1-jdk_tools1, \
|
|
||||||
solaris_sparcv9_5.10-product-c2-jdk_tools1, \
|
|
||||||
solaris_i586_5.10-product-c1-jdk_tools1, \
|
|
||||||
solaris_x64_5.10-product-c2-jdk_tools1, \
|
|
||||||
linux_i586_2.6-product-{c1|c2}-jdk_tools1, \
|
|
||||||
linux_x64_2.6-product-c2-jdk_tools1, \
|
|
||||||
windows_i586_5.1-product-c1-jdk_tools1, \
|
|
||||||
windows_x64_5.2-product-c2-jdk_tools1, \
|
|
||||||
\
|
|
||||||
solaris_sparc_5.10-product-c1-jdk_util, \
|
|
||||||
solaris_sparcv9_5.10-product-c2-jdk_util, \
|
|
||||||
solaris_i586_5.10-product-c1-jdk_util, \
|
|
||||||
solaris_x64_5.10-product-c2-jdk_util, \
|
|
||||||
linux_i586_2.6-product-{c1|c2}-jdk_util, \
|
|
||||||
linux_x64_2.6-product-c2-jdk_util, \
|
|
||||||
windows_i586_5.1-product-c1-jdk_util, \
|
|
||||||
windows_x64_5.2-product-c2-jdk_util
|
|
||||||
|
|
||||||
# All jdk test targets in test/Makefile (still no fastdebug & limited c2)
|
# All vm test targets (testset=all)
|
||||||
|
jprt.vm.all.test.targets= \
|
||||||
|
${jprt.vm.default.test.targets}, \
|
||||||
|
${jprt.my.test.target.set:TESTNAME=runThese}, \
|
||||||
|
${jprt.my.test.target.set:TESTNAME=jbb_default}
|
||||||
|
|
||||||
|
# All jdk test targets (testset=all)
|
||||||
jprt.make.rule.all.test.targets= \
|
jprt.make.rule.all.test.targets= \
|
||||||
\
|
${jprt.make.rule.default.test.targets}, \
|
||||||
${jprt.make.rule.default.test.targets}, \
|
${jprt.my.test.target.set:TESTNAME=jdk_awt}, \
|
||||||
\
|
${jprt.my.test.target.set:TESTNAME=jdk_beans2}, \
|
||||||
solaris_sparc_5.10-product-c1-jdk_awt, \
|
${jprt.my.test.target.set:TESTNAME=jdk_beans3}, \
|
||||||
solaris_sparcv9_5.10-product-c2-jdk_awt, \
|
${jprt.my.test.target.set:TESTNAME=jdk_management1}, \
|
||||||
solaris_i586_5.10-product-c1-jdk_awt, \
|
${jprt.my.test.target.set:TESTNAME=jdk_management2}, \
|
||||||
solaris_x64_5.10-product-c2-jdk_awt, \
|
${jprt.my.test.target.set:TESTNAME=jdk_rmi}, \
|
||||||
linux_i586_2.6-product-{c1|c2}-jdk_awt, \
|
${jprt.my.test.target.set:TESTNAME=jdk_security2}, \
|
||||||
linux_x64_2.6-product-c2-jdk_awt, \
|
${jprt.my.test.target.set:TESTNAME=jdk_security3}, \
|
||||||
windows_i586_5.1-product-c1-jdk_awt, \
|
${jprt.my.test.target.set:TESTNAME=jdk_sound}, \
|
||||||
windows_x64_5.2-product-c2-jdk_awt, \
|
${jprt.my.test.target.set:TESTNAME=jdk_swing}, \
|
||||||
\
|
${jprt.my.test.target.set:TESTNAME=jdk_tools1}, \
|
||||||
solaris_sparc_5.10-product-c1-jdk_beans2, \
|
${jprt.my.test.target.set:TESTNAME=jdk_tools2}
|
||||||
solaris_sparcv9_5.10-product-c2-jdk_beans2, \
|
|
||||||
solaris_i586_5.10-product-c1-jdk_beans2, \
|
|
||||||
solaris_x64_5.10-product-c2-jdk_beans2, \
|
|
||||||
linux_i586_2.6-product-{c1|c2}-jdk_beans2, \
|
|
||||||
linux_x64_2.6-product-c2-jdk_beans2, \
|
|
||||||
windows_i586_5.1-product-c1-jdk_beans2, \
|
|
||||||
windows_x64_5.2-product-c2-jdk_beans2, \
|
|
||||||
\
|
|
||||||
solaris_sparc_5.10-product-c1-jdk_beans3, \
|
|
||||||
solaris_sparcv9_5.10-product-c2-jdk_beans3, \
|
|
||||||
solaris_i586_5.10-product-c1-jdk_beans3, \
|
|
||||||
solaris_x64_5.10-product-c2-jdk_beans3, \
|
|
||||||
linux_i586_2.6-product-{c1|c2}-jdk_beans3, \
|
|
||||||
linux_x64_2.6-product-c2-jdk_beans3, \
|
|
||||||
windows_i586_5.1-product-c1-jdk_beans3, \
|
|
||||||
windows_x64_5.2-product-c2-jdk_beans3, \
|
|
||||||
\
|
|
||||||
solaris_sparc_5.10-product-c1-jdk_management1, \
|
|
||||||
solaris_sparcv9_5.10-product-c2-jdk_management1, \
|
|
||||||
solaris_i586_5.10-product-c1-jdk_management1, \
|
|
||||||
solaris_x64_5.10-product-c2-jdk_management1, \
|
|
||||||
linux_i586_2.6-product-{c1|c2}-jdk_management1, \
|
|
||||||
linux_x64_2.6-product-c2-jdk_management1, \
|
|
||||||
windows_i586_5.1-product-c1-jdk_management1, \
|
|
||||||
windows_x64_5.2-product-c2-jdk_management1, \
|
|
||||||
\
|
|
||||||
solaris_sparc_5.10-product-c1-jdk_management2, \
|
|
||||||
solaris_sparcv9_5.10-product-c2-jdk_management2, \
|
|
||||||
solaris_i586_5.10-product-c1-jdk_management2, \
|
|
||||||
solaris_x64_5.10-product-c2-jdk_management2, \
|
|
||||||
linux_i586_2.6-product-{c1|c2}-jdk_management2, \
|
|
||||||
linux_x64_2.6-product-c2-jdk_management2, \
|
|
||||||
windows_i586_5.1-product-c1-jdk_management2, \
|
|
||||||
windows_x64_5.2-product-c2-jdk_management2, \
|
|
||||||
\
|
|
||||||
solaris_sparc_5.10-product-c1-jdk_rmi, \
|
|
||||||
solaris_sparcv9_5.10-product-c2-jdk_rmi, \
|
|
||||||
solaris_i586_5.10-product-c1-jdk_rmi, \
|
|
||||||
solaris_x64_5.10-product-c2-jdk_rmi, \
|
|
||||||
linux_i586_2.6-product-{c1|c2}-jdk_rmi, \
|
|
||||||
linux_x64_2.6-product-c2-jdk_rmi, \
|
|
||||||
windows_i586_5.1-product-c1-jdk_rmi, \
|
|
||||||
windows_x64_5.2-product-c2-jdk_rmi, \
|
|
||||||
\
|
|
||||||
solaris_sparc_5.10-product-c1-jdk_security2, \
|
|
||||||
solaris_sparcv9_5.10-product-c2-jdk_security2, \
|
|
||||||
solaris_i586_5.10-product-c1-jdk_security2, \
|
|
||||||
solaris_x64_5.10-product-c2-jdk_security2, \
|
|
||||||
linux_i586_2.6-product-{c1|c2}-jdk_security2, \
|
|
||||||
linux_x64_2.6-product-c2-jdk_security2, \
|
|
||||||
windows_i586_5.1-product-c1-jdk_security2, \
|
|
||||||
windows_x64_5.2-product-c2-jdk_security2, \
|
|
||||||
\
|
|
||||||
solaris_sparc_5.10-product-c1-jdk_security3, \
|
|
||||||
solaris_sparcv9_5.10-product-c2-jdk_security3, \
|
|
||||||
solaris_i586_5.10-product-c1-jdk_security3, \
|
|
||||||
solaris_x64_5.10-product-c2-jdk_security3, \
|
|
||||||
linux_i586_2.6-product-{c1|c2}-jdk_security3, \
|
|
||||||
linux_x64_2.6-product-c2-jdk_security3, \
|
|
||||||
windows_i586_5.1-product-c1-jdk_security3, \
|
|
||||||
windows_x64_5.2-product-c2-jdk_security3, \
|
|
||||||
\
|
|
||||||
solaris_sparc_5.10-product-c1-jdk_sound, \
|
|
||||||
solaris_sparcv9_5.10-product-c2-jdk_sound, \
|
|
||||||
solaris_i586_5.10-product-c1-jdk_sound, \
|
|
||||||
solaris_x64_5.10-product-c2-jdk_sound, \
|
|
||||||
linux_i586_2.6-product-{c1|c2}-jdk_sound, \
|
|
||||||
linux_x64_2.6-product-c2-jdk_sound, \
|
|
||||||
windows_i586_5.1-product-c1-jdk_sound, \
|
|
||||||
windows_x64_5.2-product-c2-jdk_sound, \
|
|
||||||
\
|
|
||||||
solaris_sparc_5.10-product-c1-jdk_swing, \
|
|
||||||
solaris_sparcv9_5.10-product-c2-jdk_swing, \
|
|
||||||
solaris_i586_5.10-product-c1-jdk_swing, \
|
|
||||||
solaris_x64_5.10-product-c2-jdk_swing, \
|
|
||||||
linux_i586_2.6-product-{c1|c2}-jdk_swing, \
|
|
||||||
linux_x64_2.6-product-c2-jdk_swing, \
|
|
||||||
windows_i586_5.1-product-c1-jdk_swing, \
|
|
||||||
windows_x64_5.2-product-c2-jdk_swing, \
|
|
||||||
\
|
|
||||||
solaris_sparc_5.10-product-c1-jdk_tools2, \
|
|
||||||
solaris_sparcv9_5.10-product-c2-jdk_tools2, \
|
|
||||||
solaris_i586_5.10-product-c1-jdk_tools2, \
|
|
||||||
solaris_x64_5.10-product-c2-jdk_tools2, \
|
|
||||||
linux_i586_2.6-product-{c1|c2}-jdk_tools2, \
|
|
||||||
linux_x64_2.6-product-c2-jdk_tools2, \
|
|
||||||
windows_i586_5.1-product-c1-jdk_tools2, \
|
|
||||||
windows_x64_5.2-product-c2-jdk_tools2
|
|
||||||
|
|
||||||
# JCK test targets in test/Makefile (no fastdebug & limited c2, windows broken)
|
# JCK test targets in test/Makefile (no windows)
|
||||||
jprt.my.jck.test.target.set= \
|
jprt.my.jck.test.target.set= \
|
||||||
solaris_sparc_5.10-product-c1-JCK7TESTRULE, \
|
solaris_sparc_5.10-product-c1-JCK7TESTRULE, \
|
||||||
solaris_sparcv9_5.10-product-c2-JCK7TESTRULE, \
|
solaris_sparcv9_5.10-product-c2-JCK7TESTRULE, \
|
||||||
@ -303,6 +115,8 @@ jprt.make.rule.jck.test.targets= \
|
|||||||
# Select list to use (allow for testset to be empty too)
|
# Select list to use (allow for testset to be empty too)
|
||||||
jprt.make.rule..test.targets=${jprt.make.rule.default.test.targets}
|
jprt.make.rule..test.targets=${jprt.make.rule.default.test.targets}
|
||||||
jprt.make.rule.test.targets=${jprt.make.rule.${jprt.my.test.set}.test.targets}
|
jprt.make.rule.test.targets=${jprt.make.rule.${jprt.my.test.set}.test.targets}
|
||||||
|
jprt.vm..test.targets=${jprt.vm.default.test.targets}
|
||||||
|
jprt.test.targets=${jprt.vm.${jprt.my.test.set}.test.targets}
|
||||||
|
|
||||||
# Directories to be excluded from the source bundles
|
# Directories to be excluded from the source bundles
|
||||||
jprt.bundle.exclude.src.dirs=build dist webrev
|
jprt.bundle.exclude.src.dirs=build dist webrev
|
||||||
|
@ -35,7 +35,7 @@ class ArrayRegionTypeNode extends AbstractSimpleTypeNode {
|
|||||||
}
|
}
|
||||||
|
|
||||||
String javaType() {
|
String javaType() {
|
||||||
return "List";
|
return "List<?>";
|
||||||
}
|
}
|
||||||
|
|
||||||
public void genJavaWrite(PrintWriter writer, int depth,
|
public void genJavaWrite(PrintWriter writer, int depth,
|
||||||
|
@ -89,7 +89,7 @@ class OutNode extends AbstractTypeListNode {
|
|||||||
if (Main.genDebug) {
|
if (Main.genDebug) {
|
||||||
indent(writer, depth+1);
|
indent(writer, depth+1);
|
||||||
writer.println(
|
writer.println(
|
||||||
"if ((vm.traceFlags & vm.TRACE_SENDS) != 0) {");
|
"if ((vm.traceFlags & VirtualMachineImpl.TRACE_SENDS) != 0) {");
|
||||||
indent(writer, depth+2);
|
indent(writer, depth+2);
|
||||||
writer.print(
|
writer.print(
|
||||||
"vm.printTrace(\"Sending Command(id=\" + ps.pkt.id + \") ");
|
"vm.printTrace(\"Sending Command(id=\" + ps.pkt.id + \") ");
|
||||||
|
@ -29,5 +29,5 @@ package com.sun.java.swing;
|
|||||||
*
|
*
|
||||||
* @deprecated Use {@link javax.swing.Painter} instead.
|
* @deprecated Use {@link javax.swing.Painter} instead.
|
||||||
*/
|
*/
|
||||||
public interface Painter<T> extends javax.swing.Painter {
|
public interface Painter<T> extends javax.swing.Painter<T> {
|
||||||
}
|
}
|
||||||
|
@ -33,6 +33,7 @@ package com.sun.jdi;
|
|||||||
*/
|
*/
|
||||||
public class AbsentInformationException extends Exception
|
public class AbsentInformationException extends Exception
|
||||||
{
|
{
|
||||||
|
private static final long serialVersionUID = 4988939309582416373L;
|
||||||
public AbsentInformationException()
|
public AbsentInformationException()
|
||||||
{
|
{
|
||||||
super();
|
super();
|
||||||
|
@ -69,6 +69,7 @@ package com.sun.jdi;
|
|||||||
*/
|
*/
|
||||||
public class ClassNotLoadedException extends Exception
|
public class ClassNotLoadedException extends Exception
|
||||||
{
|
{
|
||||||
|
private static final long serialVersionUID = -6242978768444298722L;
|
||||||
private String className;
|
private String className;
|
||||||
|
|
||||||
public ClassNotLoadedException(String className) {
|
public ClassNotLoadedException(String className) {
|
||||||
|
@ -33,6 +33,7 @@ package com.sun.jdi;
|
|||||||
* @since 1.3
|
* @since 1.3
|
||||||
*/
|
*/
|
||||||
public class ClassNotPreparedException extends RuntimeException {
|
public class ClassNotPreparedException extends RuntimeException {
|
||||||
|
private static final long serialVersionUID = -6120698967144079642L;
|
||||||
public ClassNotPreparedException()
|
public ClassNotPreparedException()
|
||||||
{
|
{
|
||||||
super();
|
super();
|
||||||
|
@ -34,6 +34,7 @@ package com.sun.jdi;
|
|||||||
*/
|
*/
|
||||||
public class IncompatibleThreadStateException extends Exception
|
public class IncompatibleThreadStateException extends Exception
|
||||||
{
|
{
|
||||||
|
private static final long serialVersionUID = 6199174323414551389L;
|
||||||
public IncompatibleThreadStateException()
|
public IncompatibleThreadStateException()
|
||||||
{
|
{
|
||||||
super();
|
super();
|
||||||
|
@ -35,6 +35,7 @@ package com.sun.jdi;
|
|||||||
* @since 1.3
|
* @since 1.3
|
||||||
*/
|
*/
|
||||||
public class InconsistentDebugInfoException extends RuntimeException {
|
public class InconsistentDebugInfoException extends RuntimeException {
|
||||||
|
private static final long serialVersionUID = 7964236415376861808L;
|
||||||
public InconsistentDebugInfoException() {
|
public InconsistentDebugInfoException() {
|
||||||
super();
|
super();
|
||||||
}
|
}
|
||||||
|
@ -33,6 +33,7 @@ package com.sun.jdi;
|
|||||||
* @since 1.3
|
* @since 1.3
|
||||||
*/
|
*/
|
||||||
public class InternalException extends RuntimeException {
|
public class InternalException extends RuntimeException {
|
||||||
|
private static final long serialVersionUID = -9171606393104480607L;
|
||||||
private int errorCode;
|
private int errorCode;
|
||||||
|
|
||||||
public InternalException() {
|
public InternalException() {
|
||||||
|
@ -36,6 +36,7 @@ package com.sun.jdi;
|
|||||||
*/
|
*/
|
||||||
@Deprecated
|
@Deprecated
|
||||||
public class InvalidCodeIndexException extends RuntimeException {
|
public class InvalidCodeIndexException extends RuntimeException {
|
||||||
|
private static final long serialVersionUID = 7416010225133747805L;
|
||||||
public InvalidCodeIndexException() {
|
public InvalidCodeIndexException() {
|
||||||
super();
|
super();
|
||||||
}
|
}
|
||||||
|
@ -36,6 +36,7 @@ package com.sun.jdi;
|
|||||||
*/
|
*/
|
||||||
@Deprecated
|
@Deprecated
|
||||||
public class InvalidLineNumberException extends RuntimeException {
|
public class InvalidLineNumberException extends RuntimeException {
|
||||||
|
private static final long serialVersionUID = 4048709912372692875L;
|
||||||
public InvalidLineNumberException() {
|
public InvalidLineNumberException() {
|
||||||
super();
|
super();
|
||||||
}
|
}
|
||||||
|
@ -33,6 +33,7 @@ package com.sun.jdi;
|
|||||||
* @since 1.3
|
* @since 1.3
|
||||||
*/
|
*/
|
||||||
public class InvalidStackFrameException extends RuntimeException {
|
public class InvalidStackFrameException extends RuntimeException {
|
||||||
|
private static final long serialVersionUID = -1919378296505827922L;
|
||||||
public InvalidStackFrameException() {
|
public InvalidStackFrameException() {
|
||||||
super();
|
super();
|
||||||
}
|
}
|
||||||
|
@ -34,6 +34,7 @@ package com.sun.jdi;
|
|||||||
*/
|
*/
|
||||||
public class InvalidTypeException extends Exception
|
public class InvalidTypeException extends Exception
|
||||||
{
|
{
|
||||||
|
private static final long serialVersionUID = 2256667231949650806L;
|
||||||
public InvalidTypeException()
|
public InvalidTypeException()
|
||||||
{
|
{
|
||||||
super();
|
super();
|
||||||
|
@ -34,6 +34,7 @@ package com.sun.jdi;
|
|||||||
*/
|
*/
|
||||||
public class InvocationException extends Exception
|
public class InvocationException extends Exception
|
||||||
{
|
{
|
||||||
|
private static final long serialVersionUID = 6066780907971918568L;
|
||||||
ObjectReference exception;
|
ObjectReference exception;
|
||||||
|
|
||||||
public InvocationException(ObjectReference exception)
|
public InvocationException(ObjectReference exception)
|
||||||
|
@ -79,7 +79,7 @@ package com.sun.jdi;
|
|||||||
*/
|
*/
|
||||||
|
|
||||||
public final class JDIPermission extends java.security.BasicPermission {
|
public final class JDIPermission extends java.security.BasicPermission {
|
||||||
|
private static final long serialVersionUID = -6988461416938786271L;
|
||||||
/**
|
/**
|
||||||
* The <code>JDIPermission</code> class represents access rights to the
|
* The <code>JDIPermission</code> class represents access rights to the
|
||||||
* <code>VirtualMachineManager</code>
|
* <code>VirtualMachineManager</code>
|
||||||
|
@ -34,6 +34,7 @@ package com.sun.jdi;
|
|||||||
*/
|
*/
|
||||||
public class NativeMethodException extends RuntimeException {
|
public class NativeMethodException extends RuntimeException {
|
||||||
|
|
||||||
|
private static final long serialVersionUID = 3924951669039469992L;
|
||||||
public NativeMethodException() {
|
public NativeMethodException() {
|
||||||
super();
|
super();
|
||||||
}
|
}
|
||||||
|
@ -33,6 +33,7 @@ package com.sun.jdi;
|
|||||||
* @since 1.3
|
* @since 1.3
|
||||||
*/
|
*/
|
||||||
public class ObjectCollectedException extends RuntimeException {
|
public class ObjectCollectedException extends RuntimeException {
|
||||||
|
private static final long serialVersionUID = -1928428056197269588L;
|
||||||
public ObjectCollectedException() {
|
public ObjectCollectedException() {
|
||||||
super();
|
super();
|
||||||
}
|
}
|
||||||
|
@ -33,6 +33,7 @@ package com.sun.jdi;
|
|||||||
* @since 1.5
|
* @since 1.5
|
||||||
*/
|
*/
|
||||||
public class VMCannotBeModifiedException extends UnsupportedOperationException {
|
public class VMCannotBeModifiedException extends UnsupportedOperationException {
|
||||||
|
private static final long serialVersionUID = -4063879815130164009L;
|
||||||
public VMCannotBeModifiedException() {
|
public VMCannotBeModifiedException() {
|
||||||
super();
|
super();
|
||||||
}
|
}
|
||||||
|
@ -35,6 +35,7 @@ package com.sun.jdi;
|
|||||||
*/
|
*/
|
||||||
public class VMDisconnectedException extends RuntimeException {
|
public class VMDisconnectedException extends RuntimeException {
|
||||||
|
|
||||||
|
private static final long serialVersionUID = 2892975269768351637L;
|
||||||
public VMDisconnectedException() {
|
public VMDisconnectedException() {
|
||||||
super();
|
super();
|
||||||
}
|
}
|
||||||
|
@ -34,6 +34,7 @@ package com.sun.jdi;
|
|||||||
* @since 1.3
|
* @since 1.3
|
||||||
*/
|
*/
|
||||||
public class VMMismatchException extends RuntimeException {
|
public class VMMismatchException extends RuntimeException {
|
||||||
|
private static final long serialVersionUID = 289169358790459564L;
|
||||||
public VMMismatchException() {
|
public VMMismatchException() {
|
||||||
super();
|
super();
|
||||||
}
|
}
|
||||||
|
@ -33,6 +33,7 @@ package com.sun.jdi;
|
|||||||
* @since 1.3
|
* @since 1.3
|
||||||
*/
|
*/
|
||||||
public class VMOutOfMemoryException extends RuntimeException {
|
public class VMOutOfMemoryException extends RuntimeException {
|
||||||
|
private static final long serialVersionUID = 71504228548910686L;
|
||||||
public VMOutOfMemoryException() {
|
public VMOutOfMemoryException() {
|
||||||
super();
|
super();
|
||||||
}
|
}
|
||||||
|
@ -38,6 +38,7 @@ import java.util.Collections;
|
|||||||
*/
|
*/
|
||||||
public class IllegalConnectorArgumentsException extends Exception
|
public class IllegalConnectorArgumentsException extends Exception
|
||||||
{
|
{
|
||||||
|
private static final long serialVersionUID = -3042212603611350941L;
|
||||||
List<String> names;
|
List<String> names;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -55,7 +55,7 @@ package com.sun.jdi.connect;
|
|||||||
* @since 1.5
|
* @since 1.5
|
||||||
*/
|
*/
|
||||||
public class TransportTimeoutException extends java.io.IOException {
|
public class TransportTimeoutException extends java.io.IOException {
|
||||||
|
private static final long serialVersionUID = 4107035242623365074L;
|
||||||
/**
|
/**
|
||||||
* Constructs a <tt>TransportTimeoutException</tt> with no detail
|
* Constructs a <tt>TransportTimeoutException</tt> with no detail
|
||||||
* message.
|
* message.
|
||||||
|
@ -36,6 +36,7 @@ package com.sun.jdi.connect;
|
|||||||
*/
|
*/
|
||||||
public class VMStartException extends Exception
|
public class VMStartException extends Exception
|
||||||
{
|
{
|
||||||
|
private static final long serialVersionUID = 6408644824640801020L;
|
||||||
Process process;
|
Process process;
|
||||||
|
|
||||||
public VMStartException(Process process) {
|
public VMStartException(Process process) {
|
||||||
|
@ -46,7 +46,7 @@ package com.sun.jdi.connect.spi;
|
|||||||
* @since 1.5
|
* @since 1.5
|
||||||
*/
|
*/
|
||||||
public class ClosedConnectionException extends java.io.IOException {
|
public class ClosedConnectionException extends java.io.IOException {
|
||||||
|
private static final long serialVersionUID = 3877032124297204774L;
|
||||||
/**
|
/**
|
||||||
* Constructs a <tt>ClosedConnectionException</tt> with no detail
|
* Constructs a <tt>ClosedConnectionException</tt> with no detail
|
||||||
* message.
|
* message.
|
||||||
|
@ -33,6 +33,7 @@ package com.sun.jdi.request;
|
|||||||
*/
|
*/
|
||||||
public class DuplicateRequestException extends RuntimeException
|
public class DuplicateRequestException extends RuntimeException
|
||||||
{
|
{
|
||||||
|
private static final long serialVersionUID = -3719784920313411060L;
|
||||||
public DuplicateRequestException()
|
public DuplicateRequestException()
|
||||||
{
|
{
|
||||||
super();
|
super();
|
||||||
|
@ -36,6 +36,7 @@ package com.sun.jdi.request;
|
|||||||
* @since 1.3
|
* @since 1.3
|
||||||
*/
|
*/
|
||||||
public class InvalidRequestStateException extends RuntimeException {
|
public class InvalidRequestStateException extends RuntimeException {
|
||||||
|
private static final long serialVersionUID = -3774632428543322148L;
|
||||||
public InvalidRequestStateException()
|
public InvalidRequestStateException()
|
||||||
{
|
{
|
||||||
super();
|
super();
|
||||||
|
@ -70,8 +70,8 @@ public class ArrayReferenceImpl extends ObjectReferenceImpl
|
|||||||
}
|
}
|
||||||
|
|
||||||
public Value getValue(int index) {
|
public Value getValue(int index) {
|
||||||
List list = getValues(index, 1);
|
List<Value> list = getValues(index, 1);
|
||||||
return (Value)list.get(0);
|
return list.get(0);
|
||||||
}
|
}
|
||||||
|
|
||||||
public List<Value> getValues() {
|
public List<Value> getValues() {
|
||||||
|
@ -61,7 +61,7 @@ public class ArrayTypeImpl extends ReferenceTypeImpl
|
|||||||
return findType(componentSignature());
|
return findType(componentSignature());
|
||||||
}
|
}
|
||||||
|
|
||||||
void addVisibleMethods(Map map) {
|
void addVisibleMethods(Map<String, Method> map) {
|
||||||
// arrays don't have methods
|
// arrays don't have methods
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -83,10 +83,10 @@ public class ArrayTypeImpl extends ReferenceTypeImpl
|
|||||||
if (PacketStream.isObjectTag(tag)) {
|
if (PacketStream.isObjectTag(tag)) {
|
||||||
// It's a reference type
|
// It's a reference type
|
||||||
JNITypeParser parser = new JNITypeParser(componentSignature());
|
JNITypeParser parser = new JNITypeParser(componentSignature());
|
||||||
List list = vm.classesByName(parser.typeName());
|
List<ReferenceType> list = vm.classesByName(parser.typeName());
|
||||||
Iterator iter = list.iterator();
|
Iterator<ReferenceType> iter = list.iterator();
|
||||||
while (iter.hasNext()) {
|
while (iter.hasNext()) {
|
||||||
ReferenceType type = (ReferenceType)iter.next();
|
ReferenceType type = iter.next();
|
||||||
ClassLoaderReference cl = type.classLoader();
|
ClassLoaderReference cl = type.classLoader();
|
||||||
if ((cl == null)?
|
if ((cl == null)?
|
||||||
(classLoader() == null) :
|
(classLoader() == null) :
|
||||||
|
@ -78,7 +78,7 @@ public class BooleanValueImpl extends PrimitiveValueImpl
|
|||||||
}
|
}
|
||||||
|
|
||||||
public int intValue() {
|
public int intValue() {
|
||||||
return(int)((value)?1:0);
|
return (value)?1:0;
|
||||||
}
|
}
|
||||||
|
|
||||||
public long longValue() {
|
public long longValue() {
|
||||||
@ -90,7 +90,7 @@ public class BooleanValueImpl extends PrimitiveValueImpl
|
|||||||
}
|
}
|
||||||
|
|
||||||
public double doubleValue() {
|
public double doubleValue() {
|
||||||
return(double)((value)?1.0:0.0);
|
return (value)?1.0:0.0;
|
||||||
}
|
}
|
||||||
|
|
||||||
public String toString() {
|
public String toString() {
|
||||||
|
@ -75,7 +75,7 @@ public class CharValueImpl extends PrimitiveValueImpl
|
|||||||
}
|
}
|
||||||
|
|
||||||
public char charValue() {
|
public char charValue() {
|
||||||
return(char)value;
|
return value;
|
||||||
}
|
}
|
||||||
|
|
||||||
public short shortValue() {
|
public short shortValue() {
|
||||||
|
@ -80,7 +80,7 @@ public class ClassLoaderReferenceImpl extends ObjectReferenceImpl
|
|||||||
classes = Collections.unmodifiableList(classes);
|
classes = Collections.unmodifiableList(classes);
|
||||||
if (local != null) {
|
if (local != null) {
|
||||||
local.visibleClasses = classes;
|
local.visibleClasses = classes;
|
||||||
if ((vm.traceFlags & vm.TRACE_OBJREFS) != 0) {
|
if ((vm.traceFlags & VirtualMachine.TRACE_OBJREFS) != 0) {
|
||||||
vm.printTrace(description() +
|
vm.printTrace(description() +
|
||||||
" temporarily caching visible classes (count = " +
|
" temporarily caching visible classes (count = " +
|
||||||
classes.size() + ")");
|
classes.size() + ")");
|
||||||
@ -95,9 +95,9 @@ public class ClassLoaderReferenceImpl extends ObjectReferenceImpl
|
|||||||
|
|
||||||
Type findType(String signature) throws ClassNotLoadedException {
|
Type findType(String signature) throws ClassNotLoadedException {
|
||||||
List<ReferenceType> types = visibleClasses();
|
List<ReferenceType> types = visibleClasses();
|
||||||
Iterator iter = types.iterator();
|
Iterator<ReferenceType> iter = types.iterator();
|
||||||
while (iter.hasNext()) {
|
while (iter.hasNext()) {
|
||||||
ReferenceType type = (ReferenceType)iter.next();
|
ReferenceType type = iter.next();
|
||||||
if (type.signature().equals(signature)) {
|
if (type.signature().equals(signature)) {
|
||||||
return type;
|
return type;
|
||||||
}
|
}
|
||||||
|
@ -76,7 +76,7 @@ public class ClassTypeImpl extends ReferenceTypeImpl
|
|||||||
List<InterfaceType> immediate = interfaces();
|
List<InterfaceType> immediate = interfaces();
|
||||||
list.addAll(interfaces());
|
list.addAll(interfaces());
|
||||||
|
|
||||||
Iterator iter = immediate.iterator();
|
Iterator<InterfaceType> iter = immediate.iterator();
|
||||||
while (iter.hasNext()) {
|
while (iter.hasNext()) {
|
||||||
InterfaceTypeImpl interfaze = (InterfaceTypeImpl)iter.next();
|
InterfaceTypeImpl interfaze = (InterfaceTypeImpl)iter.next();
|
||||||
interfaze.addSuperinterfaces(list);
|
interfaze.addSuperinterfaces(list);
|
||||||
@ -389,7 +389,7 @@ public class ClassTypeImpl extends ReferenceTypeImpl
|
|||||||
* overwrite them in the hash table
|
* overwrite them in the hash table
|
||||||
*/
|
*/
|
||||||
|
|
||||||
Iterator iter = interfaces().iterator();
|
Iterator<InterfaceType> iter = interfaces().iterator();
|
||||||
while (iter.hasNext()) {
|
while (iter.hasNext()) {
|
||||||
InterfaceTypeImpl interfaze = (InterfaceTypeImpl)iter.next();
|
InterfaceTypeImpl interfaze = (InterfaceTypeImpl)iter.next();
|
||||||
interfaze.addVisibleMethods(methodMap);
|
interfaze.addVisibleMethods(methodMap);
|
||||||
@ -411,7 +411,7 @@ public class ClassTypeImpl extends ReferenceTypeImpl
|
|||||||
return true;
|
return true;
|
||||||
} else {
|
} else {
|
||||||
List<InterfaceType> interfaces = interfaces();
|
List<InterfaceType> interfaces = interfaces();
|
||||||
Iterator iter = interfaces.iterator();
|
Iterator<InterfaceType> iter = interfaces.iterator();
|
||||||
while (iter.hasNext()) {
|
while (iter.hasNext()) {
|
||||||
InterfaceTypeImpl interfaze = (InterfaceTypeImpl)iter.next();
|
InterfaceTypeImpl interfaze = (InterfaceTypeImpl)iter.next();
|
||||||
if (interfaze.isAssignableTo(type)) {
|
if (interfaze.isAssignableTo(type)) {
|
||||||
|
@ -192,7 +192,7 @@ public class ConcreteMethodImpl extends MethodImpl {
|
|||||||
return super.codeIndexToLineInfo(stratum, codeIndex);
|
return super.codeIndexToLineInfo(stratum, codeIndex);
|
||||||
}
|
}
|
||||||
|
|
||||||
Iterator iter = lineLocations.iterator();
|
Iterator<Location> iter = lineLocations.iterator();
|
||||||
/*
|
/*
|
||||||
* Treat code before the beginning of the first line table
|
* Treat code before the beginning of the first line table
|
||||||
* entry as part of the first line. javac will generate
|
* entry as part of the first line. javac will generate
|
||||||
@ -221,9 +221,9 @@ public class ConcreteMethodImpl extends MethodImpl {
|
|||||||
List<LocalVariable> variables = getVariables();
|
List<LocalVariable> variables = getVariables();
|
||||||
|
|
||||||
List<LocalVariable> retList = new ArrayList<LocalVariable>(2);
|
List<LocalVariable> retList = new ArrayList<LocalVariable>(2);
|
||||||
Iterator iter = variables.iterator();
|
Iterator<LocalVariable> iter = variables.iterator();
|
||||||
while(iter.hasNext()) {
|
while(iter.hasNext()) {
|
||||||
LocalVariable variable = (LocalVariable)iter.next();
|
LocalVariable variable = iter.next();
|
||||||
if (variable.name().equals(name)) {
|
if (variable.name().equals(name)) {
|
||||||
retList.add(variable);
|
retList.add(variable);
|
||||||
}
|
}
|
||||||
@ -235,9 +235,9 @@ public class ConcreteMethodImpl extends MethodImpl {
|
|||||||
List<LocalVariable> variables = getVariables();
|
List<LocalVariable> variables = getVariables();
|
||||||
|
|
||||||
List<LocalVariable> retList = new ArrayList<LocalVariable>(variables.size());
|
List<LocalVariable> retList = new ArrayList<LocalVariable>(variables.size());
|
||||||
Iterator iter = variables.iterator();
|
Iterator<LocalVariable> iter = variables.iterator();
|
||||||
while(iter.hasNext()) {
|
while(iter.hasNext()) {
|
||||||
LocalVariable variable = (LocalVariable)iter.next();
|
LocalVariable variable = iter.next();
|
||||||
if (variable.isArgument()) {
|
if (variable.isArgument()) {
|
||||||
retList.add(variable);
|
retList.add(variable);
|
||||||
}
|
}
|
||||||
@ -291,7 +291,7 @@ public class ConcreteMethodImpl extends MethodImpl {
|
|||||||
SDE.LineStratum lastLineStratum = null;
|
SDE.LineStratum lastLineStratum = null;
|
||||||
SDE.Stratum baseStratum =
|
SDE.Stratum baseStratum =
|
||||||
declaringType.stratum(SDE.BASE_STRATUM_NAME);
|
declaringType.stratum(SDE.BASE_STRATUM_NAME);
|
||||||
Iterator it = getBaseLocations().lineLocations.iterator();
|
Iterator<Location> it = getBaseLocations().lineLocations.iterator();
|
||||||
while(it.hasNext()) {
|
while(it.hasNext()) {
|
||||||
LocationImpl loc = (LocationImpl)it.next();
|
LocationImpl loc = (LocationImpl)it.next();
|
||||||
int baseLineNumber = loc.lineNumber(baseStratum);
|
int baseLineNumber = loc.lineNumber(baseStratum);
|
||||||
|
@ -47,9 +47,9 @@ abstract class ConnectorImpl implements Connector {
|
|||||||
|
|
||||||
public Map<String,Argument> defaultArguments() {
|
public Map<String,Argument> defaultArguments() {
|
||||||
Map<String,Argument> defaults = new java.util.LinkedHashMap<String,Argument>();
|
Map<String,Argument> defaults = new java.util.LinkedHashMap<String,Argument>();
|
||||||
Collection values = defaultArguments.values();
|
Collection<Argument> values = defaultArguments.values();
|
||||||
|
|
||||||
Iterator iter = values.iterator();
|
Iterator<Argument> iter = values.iterator();
|
||||||
while (iter.hasNext()) {
|
while (iter.hasNext()) {
|
||||||
ArgumentImpl argument = (ArgumentImpl)iter.next();
|
ArgumentImpl argument = (ArgumentImpl)iter.next();
|
||||||
defaults.put(argument.name(), (Argument)argument.clone());
|
defaults.put(argument.name(), (Argument)argument.clone());
|
||||||
@ -96,7 +96,7 @@ abstract class ConnectorImpl implements Connector {
|
|||||||
mustSpecify, list));
|
mustSpecify, list));
|
||||||
}
|
}
|
||||||
|
|
||||||
ArgumentImpl argument(String name, Map arguments)
|
ArgumentImpl argument(String name, Map<String, ? extends Argument> arguments)
|
||||||
throws IllegalConnectorArgumentsException {
|
throws IllegalConnectorArgumentsException {
|
||||||
|
|
||||||
ArgumentImpl argument = (ArgumentImpl)arguments.get(name);
|
ArgumentImpl argument = (ArgumentImpl)arguments.get(name);
|
||||||
@ -130,7 +130,7 @@ abstract class ConnectorImpl implements Connector {
|
|||||||
|
|
||||||
public String toString() {
|
public String toString() {
|
||||||
String string = name() + " (defaults: ";
|
String string = name() + " (defaults: ";
|
||||||
Iterator iter = defaultArguments().values().iterator();
|
Iterator<Argument> iter = defaultArguments().values().iterator();
|
||||||
boolean first = true;
|
boolean first = true;
|
||||||
while (iter.hasNext()) {
|
while (iter.hasNext()) {
|
||||||
ArgumentImpl argument = (ArgumentImpl)iter.next();
|
ArgumentImpl argument = (ArgumentImpl)iter.next();
|
||||||
@ -222,7 +222,7 @@ abstract class ConnectorImpl implements Connector {
|
|||||||
|
|
||||||
class BooleanArgumentImpl extends ConnectorImpl.ArgumentImpl
|
class BooleanArgumentImpl extends ConnectorImpl.ArgumentImpl
|
||||||
implements Connector.BooleanArgument {
|
implements Connector.BooleanArgument {
|
||||||
|
private static final long serialVersionUID = 1624542968639361316L;
|
||||||
BooleanArgumentImpl(String name, String label, String description,
|
BooleanArgumentImpl(String name, String label, String description,
|
||||||
boolean value,
|
boolean value,
|
||||||
boolean mustSpecify) {
|
boolean mustSpecify) {
|
||||||
@ -277,7 +277,7 @@ abstract class ConnectorImpl implements Connector {
|
|||||||
|
|
||||||
class IntegerArgumentImpl extends ConnectorImpl.ArgumentImpl
|
class IntegerArgumentImpl extends ConnectorImpl.ArgumentImpl
|
||||||
implements Connector.IntegerArgument {
|
implements Connector.IntegerArgument {
|
||||||
|
private static final long serialVersionUID = 763286081923797770L;
|
||||||
private final int min;
|
private final int min;
|
||||||
private final int max;
|
private final int max;
|
||||||
|
|
||||||
@ -378,7 +378,7 @@ abstract class ConnectorImpl implements Connector {
|
|||||||
|
|
||||||
class StringArgumentImpl extends ConnectorImpl.ArgumentImpl
|
class StringArgumentImpl extends ConnectorImpl.ArgumentImpl
|
||||||
implements Connector.StringArgument {
|
implements Connector.StringArgument {
|
||||||
|
private static final long serialVersionUID = 7500484902692107464L;
|
||||||
StringArgumentImpl(String name, String label, String description,
|
StringArgumentImpl(String name, String label, String description,
|
||||||
String value,
|
String value,
|
||||||
boolean mustSpecify) {
|
boolean mustSpecify) {
|
||||||
@ -396,7 +396,7 @@ abstract class ConnectorImpl implements Connector {
|
|||||||
|
|
||||||
class SelectedArgumentImpl extends ConnectorImpl.ArgumentImpl
|
class SelectedArgumentImpl extends ConnectorImpl.ArgumentImpl
|
||||||
implements Connector.SelectedArgument {
|
implements Connector.SelectedArgument {
|
||||||
|
private static final long serialVersionUID = -5689584530908382517L;
|
||||||
private final List<String> choices;
|
private final List<String> choices;
|
||||||
|
|
||||||
SelectedArgumentImpl(String name, String label, String description,
|
SelectedArgumentImpl(String name, String label, String description,
|
||||||
|
@ -101,7 +101,7 @@ public class DoubleValueImpl extends PrimitiveValueImpl
|
|||||||
}
|
}
|
||||||
|
|
||||||
public double doubleValue() {
|
public double doubleValue() {
|
||||||
return(double)value;
|
return value;
|
||||||
}
|
}
|
||||||
|
|
||||||
byte checkedByteValue() throws InvalidTypeException {
|
byte checkedByteValue() throws InvalidTypeException {
|
||||||
|
@ -43,7 +43,7 @@ import java.util.*;
|
|||||||
class EventRequestManagerImpl extends MirrorImpl
|
class EventRequestManagerImpl extends MirrorImpl
|
||||||
implements EventRequestManager
|
implements EventRequestManager
|
||||||
{
|
{
|
||||||
List[] requestLists;
|
List<? extends EventRequest>[] requestLists;
|
||||||
private static int methodExitEventCmd = 0;
|
private static int methodExitEventCmd = 0;
|
||||||
|
|
||||||
static int JDWPtoJDISuspendPolicy(byte jdwpPolicy) {
|
static int JDWPtoJDISuspendPolicy(byte jdwpPolicy) {
|
||||||
@ -91,7 +91,7 @@ class EventRequestManagerImpl extends MirrorImpl
|
|||||||
* access/modification should be protected by synchronizing on
|
* access/modification should be protected by synchronizing on
|
||||||
* the enclosing instance of EventRequestImpl.
|
* the enclosing instance of EventRequestImpl.
|
||||||
*/
|
*/
|
||||||
List filters = new ArrayList();
|
List<Object> filters = new ArrayList<>();
|
||||||
|
|
||||||
boolean isEnabled = false;
|
boolean isEnabled = false;
|
||||||
boolean deleted = false;
|
boolean deleted = false;
|
||||||
@ -195,7 +195,6 @@ class EventRequestManagerImpl extends MirrorImpl
|
|||||||
*/
|
*/
|
||||||
synchronized void set() {
|
synchronized void set() {
|
||||||
JDWP.EventRequest.Set.Modifier[] mods =
|
JDWP.EventRequest.Set.Modifier[] mods =
|
||||||
(JDWP.EventRequest.Set.Modifier[])
|
|
||||||
filters.toArray(
|
filters.toArray(
|
||||||
new JDWP.EventRequest.Set.Modifier[filters.size()]);
|
new JDWP.EventRequest.Set.Modifier[filters.size()]);
|
||||||
try {
|
try {
|
||||||
@ -582,10 +581,10 @@ class EventRequestManagerImpl extends MirrorImpl
|
|||||||
/*
|
/*
|
||||||
* Make sure this isn't a duplicate
|
* Make sure this isn't a duplicate
|
||||||
*/
|
*/
|
||||||
List requests = stepRequests();
|
List<StepRequest> requests = stepRequests();
|
||||||
Iterator iter = requests.iterator();
|
Iterator<StepRequest> iter = requests.iterator();
|
||||||
while (iter.hasNext()) {
|
while (iter.hasNext()) {
|
||||||
StepRequest request = (StepRequest)iter.next();
|
StepRequest request = iter.next();
|
||||||
if ((request != this) &&
|
if ((request != this) &&
|
||||||
request.isEnabled() &&
|
request.isEnabled() &&
|
||||||
request.thread().equals(thread)) {
|
request.thread().equals(thread)) {
|
||||||
@ -735,7 +734,7 @@ class EventRequestManagerImpl extends MirrorImpl
|
|||||||
}
|
}
|
||||||
requestLists = new List[highest+1];
|
requestLists = new List[highest+1];
|
||||||
for (int i=0; i <= highest; i++) {
|
for (int i=0; i <= highest; i++) {
|
||||||
requestLists[i] = new ArrayList();
|
requestLists[i] = new ArrayList<>();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -852,7 +851,7 @@ class EventRequestManagerImpl extends MirrorImpl
|
|||||||
public void deleteEventRequests(List<? extends EventRequest> eventRequests) {
|
public void deleteEventRequests(List<? extends EventRequest> eventRequests) {
|
||||||
validateMirrors(eventRequests);
|
validateMirrors(eventRequests);
|
||||||
// copy the eventRequests to avoid ConcurrentModificationException
|
// copy the eventRequests to avoid ConcurrentModificationException
|
||||||
Iterator iter = (new ArrayList(eventRequests)).iterator();
|
Iterator<? extends EventRequest> iter = (new ArrayList<>(eventRequests)).iterator();
|
||||||
while (iter.hasNext()) {
|
while (iter.hasNext()) {
|
||||||
((EventRequestImpl)iter.next()).delete();
|
((EventRequestImpl)iter.next()).delete();
|
||||||
}
|
}
|
||||||
@ -869,76 +868,76 @@ class EventRequestManagerImpl extends MirrorImpl
|
|||||||
}
|
}
|
||||||
|
|
||||||
public List<StepRequest> stepRequests() {
|
public List<StepRequest> stepRequests() {
|
||||||
return unmodifiableRequestList(JDWP.EventKind.SINGLE_STEP);
|
return (List<StepRequest>)unmodifiableRequestList(JDWP.EventKind.SINGLE_STEP);
|
||||||
}
|
}
|
||||||
|
|
||||||
public List<ClassPrepareRequest> classPrepareRequests() {
|
public List<ClassPrepareRequest> classPrepareRequests() {
|
||||||
return unmodifiableRequestList(JDWP.EventKind.CLASS_PREPARE);
|
return (List<ClassPrepareRequest>)unmodifiableRequestList(JDWP.EventKind.CLASS_PREPARE);
|
||||||
}
|
}
|
||||||
|
|
||||||
public List<ClassUnloadRequest> classUnloadRequests() {
|
public List<ClassUnloadRequest> classUnloadRequests() {
|
||||||
return unmodifiableRequestList(JDWP.EventKind.CLASS_UNLOAD);
|
return (List<ClassUnloadRequest>)unmodifiableRequestList(JDWP.EventKind.CLASS_UNLOAD);
|
||||||
}
|
}
|
||||||
|
|
||||||
public List<ThreadStartRequest> threadStartRequests() {
|
public List<ThreadStartRequest> threadStartRequests() {
|
||||||
return unmodifiableRequestList(JDWP.EventKind.THREAD_START);
|
return (List<ThreadStartRequest>)unmodifiableRequestList(JDWP.EventKind.THREAD_START);
|
||||||
}
|
}
|
||||||
|
|
||||||
public List<ThreadDeathRequest> threadDeathRequests() {
|
public List<ThreadDeathRequest> threadDeathRequests() {
|
||||||
return unmodifiableRequestList(JDWP.EventKind.THREAD_DEATH);
|
return (List<ThreadDeathRequest>)unmodifiableRequestList(JDWP.EventKind.THREAD_DEATH);
|
||||||
}
|
}
|
||||||
|
|
||||||
public List<ExceptionRequest> exceptionRequests() {
|
public List<ExceptionRequest> exceptionRequests() {
|
||||||
return unmodifiableRequestList(JDWP.EventKind.EXCEPTION);
|
return (List<ExceptionRequest>)unmodifiableRequestList(JDWP.EventKind.EXCEPTION);
|
||||||
}
|
}
|
||||||
|
|
||||||
public List<BreakpointRequest> breakpointRequests() {
|
public List<BreakpointRequest> breakpointRequests() {
|
||||||
return unmodifiableRequestList(JDWP.EventKind.BREAKPOINT);
|
return (List<BreakpointRequest>)unmodifiableRequestList(JDWP.EventKind.BREAKPOINT);
|
||||||
}
|
}
|
||||||
|
|
||||||
public List<AccessWatchpointRequest> accessWatchpointRequests() {
|
public List<AccessWatchpointRequest> accessWatchpointRequests() {
|
||||||
return unmodifiableRequestList(JDWP.EventKind.FIELD_ACCESS);
|
return (List<AccessWatchpointRequest>)unmodifiableRequestList(JDWP.EventKind.FIELD_ACCESS);
|
||||||
}
|
}
|
||||||
|
|
||||||
public List<ModificationWatchpointRequest> modificationWatchpointRequests() {
|
public List<ModificationWatchpointRequest> modificationWatchpointRequests() {
|
||||||
return unmodifiableRequestList(JDWP.EventKind.FIELD_MODIFICATION);
|
return (List<ModificationWatchpointRequest>)unmodifiableRequestList(JDWP.EventKind.FIELD_MODIFICATION);
|
||||||
}
|
}
|
||||||
|
|
||||||
public List<MethodEntryRequest> methodEntryRequests() {
|
public List<MethodEntryRequest> methodEntryRequests() {
|
||||||
return unmodifiableRequestList(JDWP.EventKind.METHOD_ENTRY);
|
return (List<MethodEntryRequest>)unmodifiableRequestList(JDWP.EventKind.METHOD_ENTRY);
|
||||||
}
|
}
|
||||||
|
|
||||||
public List<MethodExitRequest> methodExitRequests() {
|
public List<MethodExitRequest> methodExitRequests() {
|
||||||
return unmodifiableRequestList(
|
return (List<MethodExitRequest>)unmodifiableRequestList(
|
||||||
EventRequestManagerImpl.methodExitEventCmd);
|
EventRequestManagerImpl.methodExitEventCmd);
|
||||||
}
|
}
|
||||||
|
|
||||||
public List<MonitorContendedEnterRequest> monitorContendedEnterRequests() {
|
public List<MonitorContendedEnterRequest> monitorContendedEnterRequests() {
|
||||||
return unmodifiableRequestList(JDWP.EventKind.MONITOR_CONTENDED_ENTER);
|
return (List<MonitorContendedEnterRequest>)unmodifiableRequestList(JDWP.EventKind.MONITOR_CONTENDED_ENTER);
|
||||||
}
|
}
|
||||||
|
|
||||||
public List<MonitorContendedEnteredRequest> monitorContendedEnteredRequests() {
|
public List<MonitorContendedEnteredRequest> monitorContendedEnteredRequests() {
|
||||||
return unmodifiableRequestList(JDWP.EventKind.MONITOR_CONTENDED_ENTERED);
|
return (List<MonitorContendedEnteredRequest>)unmodifiableRequestList(JDWP.EventKind.MONITOR_CONTENDED_ENTERED);
|
||||||
}
|
}
|
||||||
|
|
||||||
public List<MonitorWaitRequest> monitorWaitRequests() {
|
public List<MonitorWaitRequest> monitorWaitRequests() {
|
||||||
return unmodifiableRequestList(JDWP.EventKind.MONITOR_WAIT);
|
return (List<MonitorWaitRequest>)unmodifiableRequestList(JDWP.EventKind.MONITOR_WAIT);
|
||||||
}
|
}
|
||||||
|
|
||||||
public List<MonitorWaitedRequest> monitorWaitedRequests() {
|
public List<MonitorWaitedRequest> monitorWaitedRequests() {
|
||||||
return unmodifiableRequestList(JDWP.EventKind.MONITOR_WAITED);
|
return (List<MonitorWaitedRequest>)unmodifiableRequestList(JDWP.EventKind.MONITOR_WAITED);
|
||||||
}
|
}
|
||||||
|
|
||||||
public List<VMDeathRequest> vmDeathRequests() {
|
public List<VMDeathRequest> vmDeathRequests() {
|
||||||
return unmodifiableRequestList(JDWP.EventKind.VM_DEATH);
|
return (List<VMDeathRequest>)unmodifiableRequestList(JDWP.EventKind.VM_DEATH);
|
||||||
}
|
}
|
||||||
|
|
||||||
List unmodifiableRequestList(int eventCmd) {
|
List<? extends EventRequest> unmodifiableRequestList(int eventCmd) {
|
||||||
return Collections.unmodifiableList(requestList(eventCmd));
|
return Collections.unmodifiableList(requestList(eventCmd));
|
||||||
}
|
}
|
||||||
|
|
||||||
EventRequest request(int eventCmd, int requestId) {
|
EventRequest request(int eventCmd, int requestId) {
|
||||||
List rl = requestList(eventCmd);
|
List<? extends EventRequest> rl = requestList(eventCmd);
|
||||||
for (int i = rl.size() - 1; i >= 0; i--) {
|
for (int i = rl.size() - 1; i >= 0; i--) {
|
||||||
EventRequestImpl er = (EventRequestImpl)rl.get(i);
|
EventRequestImpl er = (EventRequestImpl)rl.get(i);
|
||||||
if (er.id == requestId) {
|
if (er.id == requestId) {
|
||||||
|
@ -47,7 +47,7 @@ enum EventDestination {UNKNOWN_EVENT, INTERNAL_EVENT, CLIENT_EVENT};
|
|||||||
* that is on the queues are all for client requests.
|
* that is on the queues are all for client requests.
|
||||||
*/
|
*/
|
||||||
public class EventSetImpl extends ArrayList<Event> implements EventSet {
|
public class EventSetImpl extends ArrayList<Event> implements EventSet {
|
||||||
|
private static final long serialVersionUID = -4857338819787924570L;
|
||||||
private VirtualMachineImpl vm; // we implement Mirror
|
private VirtualMachineImpl vm; // we implement Mirror
|
||||||
private Packet pkt;
|
private Packet pkt;
|
||||||
private byte suspendPolicy;
|
private byte suspendPolicy;
|
||||||
@ -607,7 +607,7 @@ public class EventSetImpl extends ArrayList<Event> implements EventSet {
|
|||||||
PacketStream ps = new PacketStream(vm, pkt);
|
PacketStream ps = new PacketStream(vm, pkt);
|
||||||
JDWP.Event.Composite compEvt = new JDWP.Event.Composite(vm, ps);
|
JDWP.Event.Composite compEvt = new JDWP.Event.Composite(vm, ps);
|
||||||
suspendPolicy = compEvt.suspendPolicy;
|
suspendPolicy = compEvt.suspendPolicy;
|
||||||
if ((vm.traceFlags & vm.TRACE_EVENTS) != 0) {
|
if ((vm.traceFlags & VirtualMachine.TRACE_EVENTS) != 0) {
|
||||||
switch(suspendPolicy) {
|
switch(suspendPolicy) {
|
||||||
case JDWP.SuspendPolicy.ALL:
|
case JDWP.SuspendPolicy.ALL:
|
||||||
vm.printTrace("EventSet: SUSPEND_ALL");
|
vm.printTrace("EventSet: SUSPEND_ALL");
|
||||||
@ -626,7 +626,7 @@ public class EventSetImpl extends ArrayList<Event> implements EventSet {
|
|||||||
ThreadReference fix6485605 = null;
|
ThreadReference fix6485605 = null;
|
||||||
for (int i = 0; i < compEvt.events.length; i++) {
|
for (int i = 0; i < compEvt.events.length; i++) {
|
||||||
EventImpl evt = createEvent(compEvt.events[i]);
|
EventImpl evt = createEvent(compEvt.events[i]);
|
||||||
if ((vm.traceFlags & vm.TRACE_EVENTS) != 0) {
|
if ((vm.traceFlags & VirtualMachine.TRACE_EVENTS) != 0) {
|
||||||
try {
|
try {
|
||||||
vm.printTrace("Event: " + evt);
|
vm.printTrace("Event: " + evt);
|
||||||
} catch (VMDisconnectedException ee) {
|
} catch (VMDisconnectedException ee) {
|
||||||
|
Some files were not shown because too many files have changed in this diff Show More
Loading…
x
Reference in New Issue
Block a user