Merge
This commit is contained in:
commit
b7e6e0d9a7
@ -159,3 +159,4 @@ cc771d92284f71765eca14d6d08703c4af254c04 jdk8-b21
|
|||||||
5285317ebb4e8e4f6d8d52b5616fa801e2ea844d jdk8-b35
|
5285317ebb4e8e4f6d8d52b5616fa801e2ea844d jdk8-b35
|
||||||
6a6ba0a07f33d37a2f97b1107e60c6a9a69ec84d jdk8-b36
|
6a6ba0a07f33d37a2f97b1107e60c6a9a69ec84d jdk8-b36
|
||||||
b2972095a4b1e2a97409b7c3df61f3b263a5ce14 jdk8-b37
|
b2972095a4b1e2a97409b7c3df61f3b263a5ce14 jdk8-b37
|
||||||
|
d939bd0ab13c16647ffa38cc4b64fb31b7d44e10 jdk8-b38
|
||||||
|
@ -159,3 +159,4 @@ e24c5cc8b0f7cc48374eef0f995838fb4823e0eb jdk8-b34
|
|||||||
e3d735914edd0a621b16bb85417423f8e6af5d51 jdk8-b35
|
e3d735914edd0a621b16bb85417423f8e6af5d51 jdk8-b35
|
||||||
a5a61f259961a7f46b002e5cc50b4a9bf86927b6 jdk8-b36
|
a5a61f259961a7f46b002e5cc50b4a9bf86927b6 jdk8-b36
|
||||||
83fac66442cf680bb59ec9e3a71cc4729322b595 jdk8-b37
|
83fac66442cf680bb59ec9e3a71cc4729322b595 jdk8-b37
|
||||||
|
b8cbfb31139f820e5e094ba71449e58159fbe22e jdk8-b38
|
||||||
|
@ -1,7 +1,7 @@
|
|||||||
#!/bin/sh
|
#!/bin/sh
|
||||||
|
|
||||||
#
|
#
|
||||||
# Copyright (c) 2010, Oracle and/or its affiliates. All rights reserved.
|
# Copyright (c) 2010, 2012, 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
|
||||||
@ -26,7 +26,7 @@
|
|||||||
#
|
#
|
||||||
|
|
||||||
# Get clones of all nested repositories
|
# Get clones of all nested repositories
|
||||||
sh ./make/scripts/hgforest.sh clone
|
sh ./make/scripts/hgforest.sh clone $*
|
||||||
|
|
||||||
# Update all existing repositories to the latest sources
|
# Update all existing repositories to the latest sources
|
||||||
sh ./make/scripts/hgforest.sh pull -u
|
sh ./make/scripts/hgforest.sh pull -u
|
||||||
|
@ -244,3 +244,5 @@ dff6e3459210f8dd0430b9b03ccc99280560da30 hs24-b08
|
|||||||
50b4400ca1ecb2ac2fde35f5e53ec8f04b86be7f jdk8-b36
|
50b4400ca1ecb2ac2fde35f5e53ec8f04b86be7f jdk8-b36
|
||||||
bfcf92bfefb82da00f7fdbf0d9273feaa0a9456d jdk8-b37
|
bfcf92bfefb82da00f7fdbf0d9273feaa0a9456d jdk8-b37
|
||||||
7d5ec8bf38d1b12e0e09ec381f10976b8beede3b hs24-b09
|
7d5ec8bf38d1b12e0e09ec381f10976b8beede3b hs24-b09
|
||||||
|
637c3f5f068f88fb9ec9c5867341cf59fd5ebedc jdk8-b38
|
||||||
|
73147e6c48813b5fee904aa33f79a77103250ff4 hs24-b10
|
||||||
|
@ -35,7 +35,7 @@ HOTSPOT_VM_COPYRIGHT=Copyright 2011
|
|||||||
|
|
||||||
HS_MAJOR_VER=24
|
HS_MAJOR_VER=24
|
||||||
HS_MINOR_VER=0
|
HS_MINOR_VER=0
|
||||||
HS_BUILD_NUMBER=09
|
HS_BUILD_NUMBER=10
|
||||||
|
|
||||||
JDK_MAJOR_VER=1
|
JDK_MAJOR_VER=1
|
||||||
JDK_MINOR_VER=8
|
JDK_MINOR_VER=8
|
||||||
|
@ -1462,7 +1462,11 @@ void LIR_Assembler::emit_opConvert(LIR_OpConvert* op) {
|
|||||||
break;
|
break;
|
||||||
|
|
||||||
case Bytecodes::_l2i:
|
case Bytecodes::_l2i:
|
||||||
|
#ifdef _LP64
|
||||||
|
__ movl(dest->as_register(), src->as_register_lo());
|
||||||
|
#else
|
||||||
move_regs(src->as_register_lo(), dest->as_register());
|
move_regs(src->as_register_lo(), dest->as_register());
|
||||||
|
#endif
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case Bytecodes::_i2b:
|
case Bytecodes::_i2b:
|
||||||
|
@ -59,7 +59,7 @@ typedef struct _MODULEINFO {
|
|||||||
|
|
||||||
#include <Tlhelp32.h>
|
#include <Tlhelp32.h>
|
||||||
|
|
||||||
typedef unsigned int socklen_t;
|
typedef int socklen_t;
|
||||||
|
|
||||||
// #include "jni.h"
|
// #include "jni.h"
|
||||||
|
|
||||||
|
@ -4820,99 +4820,92 @@ struct hostent* os::get_host_by_name(char* name) {
|
|||||||
return (struct hostent*)os::WinSock2Dll::gethostbyname(name);
|
return (struct hostent*)os::WinSock2Dll::gethostbyname(name);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
int os::socket_close(int fd) {
|
int os::socket_close(int fd) {
|
||||||
ShouldNotReachHere();
|
return ::closesocket(fd);
|
||||||
return 0;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
int os::socket_available(int fd, jint *pbytes) {
|
int os::socket_available(int fd, jint *pbytes) {
|
||||||
ShouldNotReachHere();
|
int ret = ::ioctlsocket(fd, FIONREAD, (u_long*)pbytes);
|
||||||
return 0;
|
return (ret < 0) ? 0 : 1;
|
||||||
}
|
}
|
||||||
|
|
||||||
int os::socket(int domain, int type, int protocol) {
|
int os::socket(int domain, int type, int protocol) {
|
||||||
ShouldNotReachHere();
|
return ::socket(domain, type, protocol);
|
||||||
return 0;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
int os::listen(int fd, int count) {
|
int os::listen(int fd, int count) {
|
||||||
ShouldNotReachHere();
|
return ::listen(fd, count);
|
||||||
return 0;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
int os::connect(int fd, struct sockaddr* him, socklen_t len) {
|
int os::connect(int fd, struct sockaddr* him, socklen_t len) {
|
||||||
ShouldNotReachHere();
|
return ::connect(fd, him, len);
|
||||||
return 0;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
int os::accept(int fd, struct sockaddr* him, socklen_t* len) {
|
int os::accept(int fd, struct sockaddr* him, socklen_t* len) {
|
||||||
ShouldNotReachHere();
|
return ::accept(fd, him, len);
|
||||||
return 0;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
int os::sendto(int fd, char* buf, size_t len, uint flags,
|
int os::sendto(int fd, char* buf, size_t len, uint flags,
|
||||||
struct sockaddr* to, socklen_t tolen) {
|
struct sockaddr* to, socklen_t tolen) {
|
||||||
ShouldNotReachHere();
|
|
||||||
return 0;
|
return ::sendto(fd, buf, (int)len, flags, to, tolen);
|
||||||
}
|
}
|
||||||
|
|
||||||
int os::recvfrom(int fd, char *buf, size_t nBytes, uint flags,
|
int os::recvfrom(int fd, char *buf, size_t nBytes, uint flags,
|
||||||
sockaddr* from, socklen_t* fromlen) {
|
sockaddr* from, socklen_t* fromlen) {
|
||||||
ShouldNotReachHere();
|
|
||||||
return 0;
|
return ::recvfrom(fd, buf, (int)nBytes, flags, from, fromlen);
|
||||||
}
|
}
|
||||||
|
|
||||||
int os::recv(int fd, char* buf, size_t nBytes, uint flags) {
|
int os::recv(int fd, char* buf, size_t nBytes, uint flags) {
|
||||||
ShouldNotReachHere();
|
return ::recv(fd, buf, (int)nBytes, flags);
|
||||||
return 0;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
int os::send(int fd, char* buf, size_t nBytes, uint flags) {
|
int os::send(int fd, char* buf, size_t nBytes, uint flags) {
|
||||||
ShouldNotReachHere();
|
return ::send(fd, buf, (int)nBytes, flags);
|
||||||
return 0;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
int os::raw_send(int fd, char* buf, size_t nBytes, uint flags) {
|
int os::raw_send(int fd, char* buf, size_t nBytes, uint flags) {
|
||||||
ShouldNotReachHere();
|
return ::send(fd, buf, (int)nBytes, flags);
|
||||||
return 0;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
int os::timeout(int fd, long timeout) {
|
int os::timeout(int fd, long timeout) {
|
||||||
ShouldNotReachHere();
|
fd_set tbl;
|
||||||
return 0;
|
struct timeval t;
|
||||||
|
|
||||||
|
t.tv_sec = timeout / 1000;
|
||||||
|
t.tv_usec = (timeout % 1000) * 1000;
|
||||||
|
|
||||||
|
tbl.fd_count = 1;
|
||||||
|
tbl.fd_array[0] = fd;
|
||||||
|
|
||||||
|
return ::select(1, &tbl, 0, 0, &t);
|
||||||
}
|
}
|
||||||
|
|
||||||
int os::get_host_name(char* name, int namelen) {
|
int os::get_host_name(char* name, int namelen) {
|
||||||
ShouldNotReachHere();
|
return ::gethostname(name, namelen);
|
||||||
return 0;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
int os::socket_shutdown(int fd, int howto) {
|
int os::socket_shutdown(int fd, int howto) {
|
||||||
ShouldNotReachHere();
|
return ::shutdown(fd, howto);
|
||||||
return 0;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
int os::bind(int fd, struct sockaddr* him, socklen_t len) {
|
int os::bind(int fd, struct sockaddr* him, socklen_t len) {
|
||||||
ShouldNotReachHere();
|
return ::bind(fd, him, len);
|
||||||
return 0;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
int os::get_sock_name(int fd, struct sockaddr* him, socklen_t* len) {
|
int os::get_sock_name(int fd, struct sockaddr* him, socklen_t* len) {
|
||||||
ShouldNotReachHere();
|
return ::getsockname(fd, him, len);
|
||||||
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, socklen_t* optlen) {
|
char* optval, socklen_t* optlen) {
|
||||||
ShouldNotReachHere();
|
return ::getsockopt(fd, level, optname, optval, optlen);
|
||||||
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, socklen_t optlen) {
|
const char* optval, socklen_t optlen) {
|
||||||
ShouldNotReachHere();
|
return ::setsockopt(fd, level, optname, optval, optlen);
|
||||||
return 0;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
@ -3355,7 +3355,8 @@ instanceKlassHandle ClassFileParser::parseClassFile(Symbol* name,
|
|||||||
static_field_size,
|
static_field_size,
|
||||||
total_oop_map_count,
|
total_oop_map_count,
|
||||||
access_flags,
|
access_flags,
|
||||||
rt, CHECK_(nullHandle));
|
rt, host_klass,
|
||||||
|
CHECK_(nullHandle));
|
||||||
instanceKlassHandle this_klass (THREAD, ik);
|
instanceKlassHandle this_klass (THREAD, ik);
|
||||||
|
|
||||||
assert(this_klass->static_field_size() == static_field_size, "sanity");
|
assert(this_klass->static_field_size() == static_field_size, "sanity");
|
||||||
|
@ -128,11 +128,12 @@ klassOop oopFactory::new_instanceKlass(Symbol* name, int vtable_len, int itable_
|
|||||||
int static_field_size,
|
int static_field_size,
|
||||||
unsigned int nonstatic_oop_map_count,
|
unsigned int nonstatic_oop_map_count,
|
||||||
AccessFlags access_flags,
|
AccessFlags access_flags,
|
||||||
ReferenceType rt, TRAPS) {
|
ReferenceType rt,
|
||||||
|
KlassHandle host_klass, TRAPS) {
|
||||||
instanceKlassKlass* ikk = instanceKlassKlass::cast(Universe::instanceKlassKlassObj());
|
instanceKlassKlass* ikk = instanceKlassKlass::cast(Universe::instanceKlassKlassObj());
|
||||||
return ikk->allocate_instance_klass(name, vtable_len, itable_len,
|
return ikk->allocate_instance_klass(name, vtable_len, itable_len,
|
||||||
static_field_size, nonstatic_oop_map_count,
|
static_field_size, nonstatic_oop_map_count,
|
||||||
access_flags, rt, CHECK_NULL);
|
access_flags, rt, host_klass, CHECK_NULL);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
@ -78,7 +78,8 @@ class oopFactory: AllStatic {
|
|||||||
int static_field_size,
|
int static_field_size,
|
||||||
unsigned int nonstatic_oop_map_count,
|
unsigned int nonstatic_oop_map_count,
|
||||||
AccessFlags access_flags,
|
AccessFlags access_flags,
|
||||||
ReferenceType rt, TRAPS);
|
ReferenceType rt,
|
||||||
|
KlassHandle host_klass, TRAPS);
|
||||||
|
|
||||||
// Methods
|
// Methods
|
||||||
private:
|
private:
|
||||||
|
@ -880,10 +880,17 @@ class ContiguousSpace: public CompactibleSpace {
|
|||||||
void object_iterate_mem(MemRegion mr, UpwardsObjectClosure* cl);
|
void object_iterate_mem(MemRegion mr, UpwardsObjectClosure* cl);
|
||||||
// iterates on objects up to the safe limit
|
// iterates on objects up to the safe limit
|
||||||
HeapWord* object_iterate_careful(ObjectClosureCareful* cl);
|
HeapWord* object_iterate_careful(ObjectClosureCareful* cl);
|
||||||
inline HeapWord* concurrent_iteration_safe_limit();
|
HeapWord* concurrent_iteration_safe_limit() {
|
||||||
|
assert(_concurrent_iteration_safe_limit <= top(),
|
||||||
|
"_concurrent_iteration_safe_limit update missed");
|
||||||
|
return _concurrent_iteration_safe_limit;
|
||||||
|
}
|
||||||
// changes the safe limit, all objects from bottom() to the new
|
// changes the safe limit, all objects from bottom() to the new
|
||||||
// limit should be properly initialized
|
// limit should be properly initialized
|
||||||
inline void set_concurrent_iteration_safe_limit(HeapWord* new_limit);
|
void set_concurrent_iteration_safe_limit(HeapWord* new_limit) {
|
||||||
|
assert(new_limit <= top(), "uninitialized objects in the safe range");
|
||||||
|
_concurrent_iteration_safe_limit = new_limit;
|
||||||
|
}
|
||||||
|
|
||||||
#ifndef SERIALGC
|
#ifndef SERIALGC
|
||||||
// In support of parallel oop_iterate.
|
// In support of parallel oop_iterate.
|
||||||
|
@ -67,17 +67,4 @@ OffsetTableContigSpace::block_start_const(const void* p) const {
|
|||||||
return _offsets.block_start(p);
|
return _offsets.block_start(p);
|
||||||
}
|
}
|
||||||
|
|
||||||
inline HeapWord* ContiguousSpace::concurrent_iteration_safe_limit()
|
|
||||||
{
|
|
||||||
assert(_concurrent_iteration_safe_limit <= top(),
|
|
||||||
"_concurrent_iteration_safe_limit update missed");
|
|
||||||
return _concurrent_iteration_safe_limit;
|
|
||||||
}
|
|
||||||
|
|
||||||
inline void ContiguousSpace::set_concurrent_iteration_safe_limit(HeapWord* new_limit)
|
|
||||||
{
|
|
||||||
assert(new_limit <= top(), "uninitialized objects in the safe range");
|
|
||||||
_concurrent_iteration_safe_limit = new_limit;
|
|
||||||
}
|
|
||||||
|
|
||||||
#endif // SHARE_VM_MEMORY_SPACE_INLINE_HPP
|
#endif // SHARE_VM_MEMORY_SPACE_INLINE_HPP
|
||||||
|
@ -1862,7 +1862,7 @@ void instanceKlass::follow_weak_klass_links(
|
|||||||
if (impl != NULL) {
|
if (impl != NULL) {
|
||||||
if (!is_alive->do_object_b(impl)) {
|
if (!is_alive->do_object_b(impl)) {
|
||||||
// remove this guy
|
// remove this guy
|
||||||
*start_of_implementor() = NULL;
|
*adr_implementor() = NULL;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
|
@ -78,6 +78,7 @@
|
|||||||
// The embedded nonstatic oop-map blocks are short pairs (offset, length)
|
// The embedded nonstatic oop-map blocks are short pairs (offset, length)
|
||||||
// indicating where oops are located in instances of this klass.
|
// indicating where oops are located in instances of this klass.
|
||||||
// [EMBEDDED implementor of the interface] only exist for interface
|
// [EMBEDDED implementor of the interface] only exist for interface
|
||||||
|
// [EMBEDDED host klass ] only exist for an anonymous class (JSR 292 enabled)
|
||||||
|
|
||||||
|
|
||||||
// forward declaration for class -- see below for definition
|
// forward declaration for class -- see below for definition
|
||||||
@ -176,10 +177,6 @@ class instanceKlass: public Klass {
|
|||||||
oop _class_loader;
|
oop _class_loader;
|
||||||
// Protection domain.
|
// Protection domain.
|
||||||
oop _protection_domain;
|
oop _protection_domain;
|
||||||
// Host class, which grants its access privileges to this class also.
|
|
||||||
// This is only non-null for an anonymous class (JSR 292 enabled).
|
|
||||||
// The host class is either named, or a previously loaded anonymous class.
|
|
||||||
klassOop _host_klass;
|
|
||||||
// Class signers.
|
// Class signers.
|
||||||
objArrayOop _signers;
|
objArrayOop _signers;
|
||||||
// The InnerClasses attribute and EnclosingMethod attribute. The
|
// The InnerClasses attribute and EnclosingMethod attribute. The
|
||||||
@ -234,9 +231,13 @@ class instanceKlass: public Klass {
|
|||||||
int _nonstatic_oop_map_size;// size in words of nonstatic oop map blocks
|
int _nonstatic_oop_map_size;// size in words of nonstatic oop map blocks
|
||||||
|
|
||||||
bool _is_marked_dependent; // used for marking during flushing and deoptimization
|
bool _is_marked_dependent; // used for marking during flushing and deoptimization
|
||||||
bool _rewritten; // methods rewritten.
|
enum {
|
||||||
bool _has_nonstatic_fields; // for sizing with UseCompressedOops
|
_misc_rewritten = 1 << 0, // methods rewritten.
|
||||||
bool _should_verify_class; // allow caching of preverification
|
_misc_has_nonstatic_fields = 1 << 1, // for sizing with UseCompressedOops
|
||||||
|
_misc_should_verify_class = 1 << 2, // allow caching of preverification
|
||||||
|
_misc_is_anonymous = 1 << 3 // has embedded _inner_classes field
|
||||||
|
};
|
||||||
|
u2 _misc_flags;
|
||||||
u2 _minor_version; // minor version number of class file
|
u2 _minor_version; // minor version number of class file
|
||||||
u2 _major_version; // major version number of class file
|
u2 _major_version; // major version number of class file
|
||||||
Thread* _init_thread; // Pointer to current thread doing initialization (to handle recusive initialization)
|
Thread* _init_thread; // Pointer to current thread doing initialization (to handle recusive initialization)
|
||||||
@ -276,13 +277,29 @@ class instanceKlass: public Klass {
|
|||||||
// NULL: no implementor.
|
// NULL: no implementor.
|
||||||
// A klassOop that's not itself: one implementor.
|
// A klassOop that's not itself: one implementor.
|
||||||
// Itsef: more than one implementors.
|
// Itsef: more than one implementors.
|
||||||
|
// embedded host klass follows here
|
||||||
|
// The embedded host klass only exists in an anonymous class for
|
||||||
|
// dynamic language support (JSR 292 enabled). The host class grants
|
||||||
|
// its access privileges to this class also. The host class is either
|
||||||
|
// named, or a previously loaded anonymous class. A non-anonymous class
|
||||||
|
// or an anonymous class loaded through normal classloading does not
|
||||||
|
// have this embedded field.
|
||||||
|
//
|
||||||
|
|
||||||
friend class instanceKlassKlass;
|
friend class instanceKlassKlass;
|
||||||
friend class SystemDictionary;
|
friend class SystemDictionary;
|
||||||
|
|
||||||
public:
|
public:
|
||||||
bool has_nonstatic_fields() const { return _has_nonstatic_fields; }
|
bool has_nonstatic_fields() const {
|
||||||
void set_has_nonstatic_fields(bool b) { _has_nonstatic_fields = b; }
|
return (_misc_flags & _misc_has_nonstatic_fields) != 0;
|
||||||
|
}
|
||||||
|
void set_has_nonstatic_fields(bool b) {
|
||||||
|
if (b) {
|
||||||
|
_misc_flags |= _misc_has_nonstatic_fields;
|
||||||
|
} else {
|
||||||
|
_misc_flags &= ~_misc_has_nonstatic_fields;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
// field sizes
|
// field sizes
|
||||||
int nonstatic_field_size() const { return _nonstatic_field_size; }
|
int nonstatic_field_size() const { return _nonstatic_field_size; }
|
||||||
@ -335,7 +352,7 @@ class instanceKlass: public Klass {
|
|||||||
int java_fields_count() const { return (int)_java_fields_count; }
|
int java_fields_count() const { return (int)_java_fields_count; }
|
||||||
|
|
||||||
// Number of fields including any injected fields
|
// Number of fields including any injected fields
|
||||||
int all_fields_count() const { return _fields->length() / sizeof(FieldInfo::field_slots); }
|
int all_fields_count() const { return _fields->length() / FieldInfo::field_slots; }
|
||||||
|
|
||||||
typeArrayOop fields() const { return _fields; }
|
typeArrayOop fields() const { return _fields; }
|
||||||
|
|
||||||
@ -396,11 +413,19 @@ class instanceKlass: public Klass {
|
|||||||
bool is_in_error_state() const { return _init_state == initialization_error; }
|
bool is_in_error_state() const { return _init_state == initialization_error; }
|
||||||
bool is_reentrant_initialization(Thread *thread) { return thread == _init_thread; }
|
bool is_reentrant_initialization(Thread *thread) { return thread == _init_thread; }
|
||||||
ClassState init_state() { return (ClassState)_init_state; }
|
ClassState init_state() { return (ClassState)_init_state; }
|
||||||
bool is_rewritten() const { return _rewritten; }
|
bool is_rewritten() const { return (_misc_flags & _misc_rewritten) != 0; }
|
||||||
|
|
||||||
// defineClass specified verification
|
// defineClass specified verification
|
||||||
bool should_verify_class() const { return _should_verify_class; }
|
bool should_verify_class() const {
|
||||||
void set_should_verify_class(bool value) { _should_verify_class = value; }
|
return (_misc_flags & _misc_should_verify_class) != 0;
|
||||||
|
}
|
||||||
|
void set_should_verify_class(bool value) {
|
||||||
|
if (value) {
|
||||||
|
_misc_flags |= _misc_should_verify_class;
|
||||||
|
} else {
|
||||||
|
_misc_flags &= ~_misc_should_verify_class;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
// marking
|
// marking
|
||||||
bool is_marked_dependent() const { return _is_marked_dependent; }
|
bool is_marked_dependent() const { return _is_marked_dependent; }
|
||||||
@ -469,9 +494,30 @@ class instanceKlass: public Klass {
|
|||||||
void set_protection_domain(oop pd) { oop_store((oop*) &_protection_domain, pd); }
|
void set_protection_domain(oop pd) { oop_store((oop*) &_protection_domain, pd); }
|
||||||
|
|
||||||
// host class
|
// host class
|
||||||
oop host_klass() const { return _host_klass; }
|
oop host_klass() const {
|
||||||
void set_host_klass(oop host) { oop_store((oop*) &_host_klass, host); }
|
oop* hk = adr_host_klass();
|
||||||
bool is_anonymous() const { return _host_klass != NULL; }
|
if (hk == NULL) {
|
||||||
|
return NULL;
|
||||||
|
} else {
|
||||||
|
return *hk;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
void set_host_klass(oop host) {
|
||||||
|
assert(is_anonymous(), "not anonymous");
|
||||||
|
oop* addr = adr_host_klass();
|
||||||
|
assert(addr != NULL, "no reversed space");
|
||||||
|
oop_store(addr, host);
|
||||||
|
}
|
||||||
|
bool is_anonymous() const {
|
||||||
|
return (_misc_flags & _misc_is_anonymous) != 0;
|
||||||
|
}
|
||||||
|
void set_is_anonymous(bool value) {
|
||||||
|
if (value) {
|
||||||
|
_misc_flags |= _misc_is_anonymous;
|
||||||
|
} else {
|
||||||
|
_misc_flags &= ~_misc_is_anonymous;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
// signers
|
// signers
|
||||||
objArrayOop signers() const { return _signers; }
|
objArrayOop signers() const { return _signers; }
|
||||||
@ -651,7 +697,7 @@ class instanceKlass: public Klass {
|
|||||||
// Access to the implementor of an interface.
|
// Access to the implementor of an interface.
|
||||||
klassOop implementor() const
|
klassOop implementor() const
|
||||||
{
|
{
|
||||||
klassOop* k = start_of_implementor();
|
klassOop* k = (klassOop*)adr_implementor();
|
||||||
if (k == NULL) {
|
if (k == NULL) {
|
||||||
return NULL;
|
return NULL;
|
||||||
} else {
|
} else {
|
||||||
@ -661,7 +707,7 @@ class instanceKlass: public Klass {
|
|||||||
|
|
||||||
void set_implementor(klassOop k) {
|
void set_implementor(klassOop k) {
|
||||||
assert(is_interface(), "not interface");
|
assert(is_interface(), "not interface");
|
||||||
oop* addr = (oop*)start_of_implementor();
|
oop* addr = adr_implementor();
|
||||||
oop_store_without_check(addr, k);
|
oop_store_without_check(addr, k);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -717,9 +763,11 @@ class instanceKlass: public Klass {
|
|||||||
{
|
{
|
||||||
return object_size(align_object_offset(vtable_length()) +
|
return object_size(align_object_offset(vtable_length()) +
|
||||||
align_object_offset(itable_length()) +
|
align_object_offset(itable_length()) +
|
||||||
(is_interface() ?
|
((is_interface() || is_anonymous()) ?
|
||||||
(align_object_offset(nonstatic_oop_map_size()) + (int)sizeof(klassOop)/HeapWordSize) :
|
align_object_offset(nonstatic_oop_map_size()) :
|
||||||
nonstatic_oop_map_size()));
|
nonstatic_oop_map_size()) +
|
||||||
|
(is_interface() ? (int)sizeof(klassOop)/HeapWordSize : 0) +
|
||||||
|
(is_anonymous() ? (int)sizeof(klassOop)/HeapWordSize : 0));
|
||||||
}
|
}
|
||||||
static int vtable_start_offset() { return header_size(); }
|
static int vtable_start_offset() { return header_size(); }
|
||||||
static int vtable_length_offset() { return oopDesc::header_size() + offset_of(instanceKlass, _vtable_len) / HeapWordSize; }
|
static int vtable_length_offset() { return oopDesc::header_size() + offset_of(instanceKlass, _vtable_len) / HeapWordSize; }
|
||||||
@ -737,15 +785,29 @@ class instanceKlass: public Klass {
|
|||||||
return (OopMapBlock*)(start_of_itable() + align_object_offset(itable_length()));
|
return (OopMapBlock*)(start_of_itable() + align_object_offset(itable_length()));
|
||||||
}
|
}
|
||||||
|
|
||||||
klassOop* start_of_implementor() const {
|
oop* adr_implementor() const {
|
||||||
if (is_interface()) {
|
if (is_interface()) {
|
||||||
return (klassOop*)(start_of_nonstatic_oop_maps() +
|
return (oop*)(start_of_nonstatic_oop_maps() +
|
||||||
nonstatic_oop_map_count());
|
nonstatic_oop_map_count());
|
||||||
} else {
|
} else {
|
||||||
return NULL;
|
return NULL;
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
|
oop* adr_host_klass() const {
|
||||||
|
if (is_anonymous()) {
|
||||||
|
oop* adr_impl = adr_implementor();
|
||||||
|
if (adr_impl != NULL) {
|
||||||
|
return adr_impl + 1;
|
||||||
|
} else {
|
||||||
|
return (oop*)(start_of_nonstatic_oop_maps() +
|
||||||
|
nonstatic_oop_map_count());
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
return NULL;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
// Allocation profiling support
|
// Allocation profiling support
|
||||||
juint alloc_size() const { return _alloc_count * size_helper(); }
|
juint alloc_size() const { return _alloc_count * size_helper(); }
|
||||||
void set_alloc_size(juint n) {}
|
void set_alloc_size(juint n) {}
|
||||||
@ -819,7 +881,7 @@ private:
|
|||||||
#else
|
#else
|
||||||
void set_init_state(ClassState state) { _init_state = (u1)state; }
|
void set_init_state(ClassState state) { _init_state = (u1)state; }
|
||||||
#endif
|
#endif
|
||||||
void set_rewritten() { _rewritten = true; }
|
void set_rewritten() { _misc_flags |= _misc_rewritten; }
|
||||||
void set_init_thread(Thread *thread) { _init_thread = thread; }
|
void set_init_thread(Thread *thread) { _init_thread = thread; }
|
||||||
|
|
||||||
u2 idnum_allocated_count() const { return _idnum_allocated_count; }
|
u2 idnum_allocated_count() const { return _idnum_allocated_count; }
|
||||||
@ -852,10 +914,8 @@ private:
|
|||||||
oop* adr_constants() const { return (oop*)&this->_constants;}
|
oop* adr_constants() const { return (oop*)&this->_constants;}
|
||||||
oop* adr_class_loader() const { return (oop*)&this->_class_loader;}
|
oop* adr_class_loader() const { return (oop*)&this->_class_loader;}
|
||||||
oop* adr_protection_domain() const { return (oop*)&this->_protection_domain;}
|
oop* adr_protection_domain() const { return (oop*)&this->_protection_domain;}
|
||||||
oop* adr_host_klass() const { return (oop*)&this->_host_klass;}
|
|
||||||
oop* adr_signers() const { return (oop*)&this->_signers;}
|
oop* adr_signers() const { return (oop*)&this->_signers;}
|
||||||
oop* adr_inner_classes() const { return (oop*)&this->_inner_classes;}
|
oop* adr_inner_classes() const { return (oop*)&this->_inner_classes;}
|
||||||
oop* adr_implementor() const { return (oop*)start_of_implementor(); }
|
|
||||||
oop* adr_methods_jmethod_ids() const { return (oop*)&this->_methods_jmethod_ids;}
|
oop* adr_methods_jmethod_ids() const { return (oop*)&this->_methods_jmethod_ids;}
|
||||||
oop* adr_methods_cached_itable_indices() const { return (oop*)&this->_methods_cached_itable_indices;}
|
oop* adr_methods_cached_itable_indices() const { return (oop*)&this->_methods_cached_itable_indices;}
|
||||||
oop* adr_class_annotations() const { return (oop*)&this->_class_annotations;}
|
oop* adr_class_annotations() const { return (oop*)&this->_class_annotations;}
|
||||||
|
@ -103,7 +103,9 @@ void instanceKlassKlass::oop_follow_contents(oop obj) {
|
|||||||
MarkSweep::mark_and_push(ik->adr_class_loader());
|
MarkSweep::mark_and_push(ik->adr_class_loader());
|
||||||
MarkSweep::mark_and_push(ik->adr_inner_classes());
|
MarkSweep::mark_and_push(ik->adr_inner_classes());
|
||||||
MarkSweep::mark_and_push(ik->adr_protection_domain());
|
MarkSweep::mark_and_push(ik->adr_protection_domain());
|
||||||
|
if (ik->adr_host_klass() != NULL) {
|
||||||
MarkSweep::mark_and_push(ik->adr_host_klass());
|
MarkSweep::mark_and_push(ik->adr_host_klass());
|
||||||
|
}
|
||||||
MarkSweep::mark_and_push(ik->adr_signers());
|
MarkSweep::mark_and_push(ik->adr_signers());
|
||||||
MarkSweep::mark_and_push(ik->adr_class_annotations());
|
MarkSweep::mark_and_push(ik->adr_class_annotations());
|
||||||
MarkSweep::mark_and_push(ik->adr_fields_annotations());
|
MarkSweep::mark_and_push(ik->adr_fields_annotations());
|
||||||
@ -139,7 +141,9 @@ void instanceKlassKlass::oop_follow_contents(ParCompactionManager* cm,
|
|||||||
PSParallelCompact::mark_and_push(cm, ik->adr_class_loader());
|
PSParallelCompact::mark_and_push(cm, ik->adr_class_loader());
|
||||||
PSParallelCompact::mark_and_push(cm, ik->adr_inner_classes());
|
PSParallelCompact::mark_and_push(cm, ik->adr_inner_classes());
|
||||||
PSParallelCompact::mark_and_push(cm, ik->adr_protection_domain());
|
PSParallelCompact::mark_and_push(cm, ik->adr_protection_domain());
|
||||||
|
if (ik->adr_host_klass() != NULL) {
|
||||||
PSParallelCompact::mark_and_push(cm, ik->adr_host_klass());
|
PSParallelCompact::mark_and_push(cm, ik->adr_host_klass());
|
||||||
|
}
|
||||||
PSParallelCompact::mark_and_push(cm, ik->adr_signers());
|
PSParallelCompact::mark_and_push(cm, ik->adr_signers());
|
||||||
PSParallelCompact::mark_and_push(cm, ik->adr_class_annotations());
|
PSParallelCompact::mark_and_push(cm, ik->adr_class_annotations());
|
||||||
PSParallelCompact::mark_and_push(cm, ik->adr_fields_annotations());
|
PSParallelCompact::mark_and_push(cm, ik->adr_fields_annotations());
|
||||||
@ -177,10 +181,12 @@ int instanceKlassKlass::oop_oop_iterate(oop obj, OopClosure* blk) {
|
|||||||
blk->do_oop(ik->adr_constants());
|
blk->do_oop(ik->adr_constants());
|
||||||
blk->do_oop(ik->adr_class_loader());
|
blk->do_oop(ik->adr_class_loader());
|
||||||
blk->do_oop(ik->adr_protection_domain());
|
blk->do_oop(ik->adr_protection_domain());
|
||||||
|
if (ik->adr_host_klass() != NULL) {
|
||||||
blk->do_oop(ik->adr_host_klass());
|
blk->do_oop(ik->adr_host_klass());
|
||||||
|
}
|
||||||
blk->do_oop(ik->adr_signers());
|
blk->do_oop(ik->adr_signers());
|
||||||
blk->do_oop(ik->adr_inner_classes());
|
blk->do_oop(ik->adr_inner_classes());
|
||||||
if (ik->is_interface()) {
|
if (ik->adr_implementor() != NULL) {
|
||||||
blk->do_oop(ik->adr_implementor());
|
blk->do_oop(ik->adr_implementor());
|
||||||
}
|
}
|
||||||
blk->do_oop(ik->adr_class_annotations());
|
blk->do_oop(ik->adr_class_annotations());
|
||||||
@ -227,15 +233,13 @@ int instanceKlassKlass::oop_oop_iterate_m(oop obj, OopClosure* blk,
|
|||||||
adr = ik->adr_protection_domain();
|
adr = ik->adr_protection_domain();
|
||||||
if (mr.contains(adr)) blk->do_oop(adr);
|
if (mr.contains(adr)) blk->do_oop(adr);
|
||||||
adr = ik->adr_host_klass();
|
adr = ik->adr_host_klass();
|
||||||
if (mr.contains(adr)) blk->do_oop(adr);
|
if (adr != NULL && mr.contains(adr)) blk->do_oop(adr);
|
||||||
adr = ik->adr_signers();
|
adr = ik->adr_signers();
|
||||||
if (mr.contains(adr)) blk->do_oop(adr);
|
if (mr.contains(adr)) blk->do_oop(adr);
|
||||||
adr = ik->adr_inner_classes();
|
adr = ik->adr_inner_classes();
|
||||||
if (mr.contains(adr)) blk->do_oop(adr);
|
if (mr.contains(adr)) blk->do_oop(adr);
|
||||||
if (ik->is_interface()) {
|
|
||||||
adr = ik->adr_implementor();
|
adr = ik->adr_implementor();
|
||||||
if (mr.contains(adr)) blk->do_oop(adr);
|
if (adr != NULL && mr.contains(adr)) blk->do_oop(adr);
|
||||||
}
|
|
||||||
adr = ik->adr_class_annotations();
|
adr = ik->adr_class_annotations();
|
||||||
if (mr.contains(adr)) blk->do_oop(adr);
|
if (mr.contains(adr)) blk->do_oop(adr);
|
||||||
adr = ik->adr_fields_annotations();
|
adr = ik->adr_fields_annotations();
|
||||||
@ -270,10 +274,12 @@ int instanceKlassKlass::oop_adjust_pointers(oop obj) {
|
|||||||
MarkSweep::adjust_pointer(ik->adr_constants());
|
MarkSweep::adjust_pointer(ik->adr_constants());
|
||||||
MarkSweep::adjust_pointer(ik->adr_class_loader());
|
MarkSweep::adjust_pointer(ik->adr_class_loader());
|
||||||
MarkSweep::adjust_pointer(ik->adr_protection_domain());
|
MarkSweep::adjust_pointer(ik->adr_protection_domain());
|
||||||
|
if (ik->adr_host_klass() != NULL) {
|
||||||
MarkSweep::adjust_pointer(ik->adr_host_klass());
|
MarkSweep::adjust_pointer(ik->adr_host_klass());
|
||||||
|
}
|
||||||
MarkSweep::adjust_pointer(ik->adr_signers());
|
MarkSweep::adjust_pointer(ik->adr_signers());
|
||||||
MarkSweep::adjust_pointer(ik->adr_inner_classes());
|
MarkSweep::adjust_pointer(ik->adr_inner_classes());
|
||||||
if (ik->is_interface()) {
|
if (ik->adr_implementor() != NULL) {
|
||||||
MarkSweep::adjust_pointer(ik->adr_implementor());
|
MarkSweep::adjust_pointer(ik->adr_implementor());
|
||||||
}
|
}
|
||||||
MarkSweep::adjust_pointer(ik->adr_class_annotations());
|
MarkSweep::adjust_pointer(ik->adr_class_annotations());
|
||||||
@ -302,7 +308,7 @@ void instanceKlassKlass::oop_push_contents(PSPromotionManager* pm, oop obj) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
oop* hk_addr = ik->adr_host_klass();
|
oop* hk_addr = ik->adr_host_klass();
|
||||||
if (PSScavenge::should_scavenge(hk_addr)) {
|
if (hk_addr != NULL && PSScavenge::should_scavenge(hk_addr)) {
|
||||||
pm->claim_or_forward_depth(hk_addr);
|
pm->claim_or_forward_depth(hk_addr);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -328,9 +334,13 @@ int instanceKlassKlass::oop_update_pointers(ParCompactionManager* cm, oop obj) {
|
|||||||
for (oop* cur_oop = beg_oop; cur_oop < end_oop; ++cur_oop) {
|
for (oop* cur_oop = beg_oop; cur_oop < end_oop; ++cur_oop) {
|
||||||
PSParallelCompact::adjust_pointer(cur_oop);
|
PSParallelCompact::adjust_pointer(cur_oop);
|
||||||
}
|
}
|
||||||
if (ik->is_interface()) {
|
// embedded oops
|
||||||
|
if (ik->adr_implementor() != NULL) {
|
||||||
PSParallelCompact::adjust_pointer(ik->adr_implementor());
|
PSParallelCompact::adjust_pointer(ik->adr_implementor());
|
||||||
}
|
}
|
||||||
|
if (ik->adr_host_klass() != NULL) {
|
||||||
|
PSParallelCompact::adjust_pointer(ik->adr_host_klass());
|
||||||
|
}
|
||||||
|
|
||||||
OopClosure* closure = PSParallelCompact::adjust_root_pointer_closure();
|
OopClosure* closure = PSParallelCompact::adjust_root_pointer_closure();
|
||||||
iterate_c_heap_oops(ik, closure);
|
iterate_c_heap_oops(ik, closure);
|
||||||
@ -346,16 +356,23 @@ instanceKlassKlass::allocate_instance_klass(Symbol* name, int vtable_len, int it
|
|||||||
int static_field_size,
|
int static_field_size,
|
||||||
unsigned nonstatic_oop_map_count,
|
unsigned nonstatic_oop_map_count,
|
||||||
AccessFlags access_flags,
|
AccessFlags access_flags,
|
||||||
ReferenceType rt, TRAPS) {
|
ReferenceType rt,
|
||||||
|
KlassHandle host_klass, TRAPS) {
|
||||||
|
|
||||||
const int nonstatic_oop_map_size =
|
const int nonstatic_oop_map_size =
|
||||||
instanceKlass::nonstatic_oop_map_size(nonstatic_oop_map_count);
|
instanceKlass::nonstatic_oop_map_size(nonstatic_oop_map_count);
|
||||||
int size = align_object_offset(vtable_len) + align_object_offset(itable_len);
|
int size = align_object_offset(vtable_len) + align_object_offset(itable_len);
|
||||||
if (access_flags.is_interface()) {
|
if (access_flags.is_interface() || !host_klass.is_null()) {
|
||||||
size += align_object_offset(nonstatic_oop_map_size) + (int)sizeof(klassOop)/HeapWordSize;
|
size += align_object_offset(nonstatic_oop_map_size);
|
||||||
} else {
|
} else {
|
||||||
size += nonstatic_oop_map_size;
|
size += nonstatic_oop_map_size;
|
||||||
}
|
}
|
||||||
|
if (access_flags.is_interface()) {
|
||||||
|
size += (int)sizeof(klassOop)/HeapWordSize;
|
||||||
|
}
|
||||||
|
if (!host_klass.is_null()) {
|
||||||
|
size += (int)sizeof(klassOop)/HeapWordSize;
|
||||||
|
}
|
||||||
size = instanceKlass::object_size(size);
|
size = instanceKlass::object_size(size);
|
||||||
|
|
||||||
// Allocation
|
// Allocation
|
||||||
@ -389,6 +406,7 @@ instanceKlassKlass::allocate_instance_klass(Symbol* name, int vtable_len, int it
|
|||||||
ik->set_static_field_size(static_field_size);
|
ik->set_static_field_size(static_field_size);
|
||||||
ik->set_nonstatic_oop_map_size(nonstatic_oop_map_size);
|
ik->set_nonstatic_oop_map_size(nonstatic_oop_map_size);
|
||||||
ik->set_access_flags(access_flags);
|
ik->set_access_flags(access_flags);
|
||||||
|
ik->set_is_anonymous(!host_klass.is_null());
|
||||||
assert(k()->size() == size, "wrong size for object");
|
assert(k()->size() == size, "wrong size for object");
|
||||||
|
|
||||||
ik->set_array_klasses(NULL);
|
ik->set_array_klasses(NULL);
|
||||||
@ -401,7 +419,6 @@ instanceKlassKlass::allocate_instance_klass(Symbol* name, int vtable_len, int it
|
|||||||
ik->set_constants(NULL);
|
ik->set_constants(NULL);
|
||||||
ik->set_class_loader(NULL);
|
ik->set_class_loader(NULL);
|
||||||
ik->set_protection_domain(NULL);
|
ik->set_protection_domain(NULL);
|
||||||
ik->set_host_klass(NULL);
|
|
||||||
ik->set_signers(NULL);
|
ik->set_signers(NULL);
|
||||||
ik->set_source_file_name(NULL);
|
ik->set_source_file_name(NULL);
|
||||||
ik->set_source_debug_extension(NULL);
|
ik->set_source_debug_extension(NULL);
|
||||||
@ -503,7 +520,9 @@ void instanceKlassKlass::oop_print_on(oop obj, outputStream* st) {
|
|||||||
st->print(BULLET"constants: "); ik->constants()->print_value_on(st); st->cr();
|
st->print(BULLET"constants: "); ik->constants()->print_value_on(st); st->cr();
|
||||||
st->print(BULLET"class loader: "); ik->class_loader()->print_value_on(st); st->cr();
|
st->print(BULLET"class loader: "); ik->class_loader()->print_value_on(st); st->cr();
|
||||||
st->print(BULLET"protection domain: "); ik->protection_domain()->print_value_on(st); st->cr();
|
st->print(BULLET"protection domain: "); ik->protection_domain()->print_value_on(st); st->cr();
|
||||||
|
if (ik->host_klass() != NULL) {
|
||||||
st->print(BULLET"host class: "); ik->host_klass()->print_value_on(st); st->cr();
|
st->print(BULLET"host class: "); ik->host_klass()->print_value_on(st); st->cr();
|
||||||
|
}
|
||||||
st->print(BULLET"signers: "); ik->signers()->print_value_on(st); st->cr();
|
st->print(BULLET"signers: "); ik->signers()->print_value_on(st); st->cr();
|
||||||
if (ik->source_file_name() != NULL) {
|
if (ik->source_file_name() != NULL) {
|
||||||
st->print(BULLET"source file: ");
|
st->print(BULLET"source file: ");
|
||||||
|
@ -48,6 +48,7 @@ class instanceKlassKlass : public klassKlass {
|
|||||||
unsigned int nonstatic_oop_map_count,
|
unsigned int nonstatic_oop_map_count,
|
||||||
AccessFlags access_flags,
|
AccessFlags access_flags,
|
||||||
ReferenceType rt,
|
ReferenceType rt,
|
||||||
|
KlassHandle host_klass,
|
||||||
TRAPS);
|
TRAPS);
|
||||||
|
|
||||||
// Casting from klassOop
|
// Casting from klassOop
|
||||||
|
@ -137,6 +137,7 @@ JVMState* DirectCallGenerator::generate(JVMState* jvms) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
CallStaticJavaNode *call = new (kit.C, tf()->domain()->cnt()) CallStaticJavaNode(tf(), target, method(), kit.bci());
|
CallStaticJavaNode *call = new (kit.C, tf()->domain()->cnt()) CallStaticJavaNode(tf(), target, method(), kit.bci());
|
||||||
|
_call_node = call; // Save the call node in case we need it later
|
||||||
if (!is_static) {
|
if (!is_static) {
|
||||||
// Make an explicit receiver null_check as part of this call.
|
// Make an explicit receiver null_check as part of this call.
|
||||||
// Since we share a map with the caller, his JVMS gets adjusted.
|
// Since we share a map with the caller, his JVMS gets adjusted.
|
||||||
@ -155,7 +156,6 @@ JVMState* DirectCallGenerator::generate(JVMState* jvms) {
|
|||||||
kit.set_edges_for_java_call(call, false, _separate_io_proj);
|
kit.set_edges_for_java_call(call, false, _separate_io_proj);
|
||||||
Node* ret = kit.set_results_for_java_call(call, _separate_io_proj);
|
Node* ret = kit.set_results_for_java_call(call, _separate_io_proj);
|
||||||
kit.push_node(method()->return_type()->basic_type(), ret);
|
kit.push_node(method()->return_type()->basic_type(), ret);
|
||||||
_call_node = call; // Save the call node in case we need it later
|
|
||||||
return kit.transfer_exceptions_into_jvms();
|
return kit.transfer_exceptions_into_jvms();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -897,8 +897,8 @@ bool StringConcat::validate_control_flow() {
|
|||||||
}
|
}
|
||||||
|
|
||||||
Node* PhaseStringOpts::fetch_static_field(GraphKit& kit, ciField* field) {
|
Node* PhaseStringOpts::fetch_static_field(GraphKit& kit, ciField* field) {
|
||||||
const TypeKlassPtr* klass_type = TypeKlassPtr::make(field->holder());
|
const TypeInstPtr* mirror_type = TypeInstPtr::make(field->holder()->java_mirror());
|
||||||
Node* klass_node = __ makecon(klass_type);
|
Node* klass_node = __ makecon(mirror_type);
|
||||||
BasicType bt = field->layout_type();
|
BasicType bt = field->layout_type();
|
||||||
ciType* field_klass = field->type();
|
ciType* field_klass = field->type();
|
||||||
|
|
||||||
@ -913,6 +913,7 @@ Node* PhaseStringOpts::fetch_static_field(GraphKit& kit, ciField* field) {
|
|||||||
// and may yield a vacuous result if the field is of interface type.
|
// and may yield a vacuous result if the field is of interface type.
|
||||||
type = TypeOopPtr::make_from_constant(con, true)->isa_oopptr();
|
type = TypeOopPtr::make_from_constant(con, true)->isa_oopptr();
|
||||||
assert(type != NULL, "field singleton type must be consistent");
|
assert(type != NULL, "field singleton type must be consistent");
|
||||||
|
return __ makecon(type);
|
||||||
} else {
|
} else {
|
||||||
type = TypeOopPtr::make_from_klass(field_klass->as_klass());
|
type = TypeOopPtr::make_from_klass(field_klass->as_klass());
|
||||||
}
|
}
|
||||||
@ -922,7 +923,7 @@ Node* PhaseStringOpts::fetch_static_field(GraphKit& kit, ciField* field) {
|
|||||||
|
|
||||||
return kit.make_load(NULL, kit.basic_plus_adr(klass_node, field->offset_in_bytes()),
|
return kit.make_load(NULL, kit.basic_plus_adr(klass_node, field->offset_in_bytes()),
|
||||||
type, T_OBJECT,
|
type, T_OBJECT,
|
||||||
C->get_alias_index(klass_type->add_offset(field->offset_in_bytes())));
|
C->get_alias_index(mirror_type->add_offset(field->offset_in_bytes())));
|
||||||
}
|
}
|
||||||
|
|
||||||
Node* PhaseStringOpts::int_stringSize(GraphKit& kit, Node* arg) {
|
Node* PhaseStringOpts::int_stringSize(GraphKit& kit, Node* arg) {
|
||||||
|
@ -1221,12 +1221,11 @@ Node* SuperWord::vector_opd(Node_List* p, int opd_idx) {
|
|||||||
return opd; // input is matching vector
|
return opd; // input is matching vector
|
||||||
}
|
}
|
||||||
assert(!opd->is_VectorStore(), "such vector is not expected here");
|
assert(!opd->is_VectorStore(), "such vector is not expected here");
|
||||||
// Convert scalar input to vector. Use p0's type because it's container
|
// Convert scalar input to vector with the same number of elements as
|
||||||
// maybe smaller than the operand's container.
|
// p0's vector. Use p0's type because size of operand's container in
|
||||||
const Type* opd_t = velt_type(!in_bb(opd) ? p0 : opd);
|
// vector should match p0's size regardless operand's size.
|
||||||
const Type* p0_t = velt_type(p0);
|
const Type* p0_t = velt_type(p0);
|
||||||
if (p0_t->higher_equal(opd_t)) opd_t = p0_t;
|
VectorNode* vn = VectorNode::scalar2vector(_phase->C, opd, vlen, p0_t);
|
||||||
VectorNode* vn = VectorNode::scalar2vector(_phase->C, opd, vlen, opd_t);
|
|
||||||
|
|
||||||
_phase->_igvn.register_new_node_with_optimizer(vn);
|
_phase->_igvn.register_new_node_with_optimizer(vn);
|
||||||
_phase->set_ctrl(vn, _phase->get_ctrl(opd));
|
_phase->set_ctrl(vn, _phase->get_ctrl(opd));
|
||||||
@ -1234,14 +1233,15 @@ Node* SuperWord::vector_opd(Node_List* p, int opd_idx) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
// Insert pack operation
|
// Insert pack operation
|
||||||
const Type* opd_t = velt_type(!in_bb(opd) ? p0 : opd);
|
const Type* p0_t = velt_type(p0);
|
||||||
PackNode* pk = PackNode::make(_phase->C, opd, opd_t);
|
PackNode* pk = PackNode::make(_phase->C, opd, p0_t);
|
||||||
|
DEBUG_ONLY( const BasicType opd_bt = opd->bottom_type()->basic_type(); )
|
||||||
|
|
||||||
for (uint i = 1; i < vlen; i++) {
|
for (uint i = 1; i < vlen; i++) {
|
||||||
Node* pi = p->at(i);
|
Node* pi = p->at(i);
|
||||||
Node* in = pi->in(opd_idx);
|
Node* in = pi->in(opd_idx);
|
||||||
assert(my_pack(in) == NULL, "Should already have been unpacked");
|
assert(my_pack(in) == NULL, "Should already have been unpacked");
|
||||||
assert(opd_t == velt_type(!in_bb(in) ? pi : in), "all same type");
|
assert(opd_bt == in->bottom_type()->basic_type(), "all same type");
|
||||||
pk->add_opd(in);
|
pk->add_opd(in);
|
||||||
}
|
}
|
||||||
_phase->_igvn.register_new_node_with_optimizer(pk);
|
_phase->_igvn.register_new_node_with_optimizer(pk);
|
||||||
|
@ -148,6 +148,8 @@ void Flag::print_as_flag(outputStream* st) {
|
|||||||
st->print("-XX:%s=" UINTX_FORMAT, name, get_uintx());
|
st->print("-XX:%s=" UINTX_FORMAT, name, get_uintx());
|
||||||
} else if (is_uint64_t()) {
|
} else if (is_uint64_t()) {
|
||||||
st->print("-XX:%s=" UINT64_FORMAT, name, get_uint64_t());
|
st->print("-XX:%s=" UINT64_FORMAT, name, get_uint64_t());
|
||||||
|
} else if (is_double()) {
|
||||||
|
st->print("-XX:%s=%f", name, get_double());
|
||||||
} else if (is_ccstr()) {
|
} else if (is_ccstr()) {
|
||||||
st->print("-XX:%s=", name);
|
st->print("-XX:%s=", name);
|
||||||
const char* cp = get_ccstr();
|
const char* cp = get_ccstr();
|
||||||
|
@ -13,7 +13,18 @@
|
|||||||
Porter, 1980, An algorithm for suffix stripping, Program, Vol. 14,
|
Porter, 1980, An algorithm for suffix stripping, Program, Vol. 14,
|
||||||
no. 3, pp 130-137,
|
no. 3, pp 130-137,
|
||||||
|
|
||||||
See also http://www.tartarus.org/~martin/PorterStemmer
|
http://www.tartarus.org/~martin/PorterStemmer
|
||||||
|
|
||||||
|
The software is completely free for any purpose, unless notes at the head
|
||||||
|
of the program text indicates otherwise (which is rare). In any case,
|
||||||
|
the notes about licensing are never more restrictive than the BSD License.
|
||||||
|
|
||||||
|
In every case where the software is not written by me (Martin Porter),
|
||||||
|
this licensing arrangement has been endorsed by the contributor, and it is
|
||||||
|
therefore unnecessary to ask the contributor again to confirm it.
|
||||||
|
|
||||||
|
I have not asked any contributors (or their employers, if they have them)
|
||||||
|
for proofs that they have the right to distribute their software in this way.
|
||||||
|
|
||||||
History:
|
History:
|
||||||
|
|
||||||
|
71
hotspot/test/compiler/7160610/Test7160610.java
Normal file
71
hotspot/test/compiler/7160610/Test7160610.java
Normal file
@ -0,0 +1,71 @@
|
|||||||
|
/*
|
||||||
|
* Copyright (c) 2012, Oracle and/or its affiliates. All rights reserved.
|
||||||
|
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
||||||
|
*
|
||||||
|
* This code is free software; you can redistribute it and/or modify it
|
||||||
|
* under the terms of the GNU General Public License version 2 only, as
|
||||||
|
* published by the Free Software Foundation.
|
||||||
|
*
|
||||||
|
* This code is distributed in the hope that it will be useful, but WITHOUT
|
||||||
|
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
|
||||||
|
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
|
||||||
|
* version 2 for more details (a copy is included in the LICENSE file that
|
||||||
|
* accompanied this code).
|
||||||
|
*
|
||||||
|
* You should have received a copy of the GNU General Public License version
|
||||||
|
* 2 along with this work; if not, write to the Free Software Foundation,
|
||||||
|
* Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
|
||||||
|
*
|
||||||
|
* Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
|
||||||
|
* or visit www.oracle.com if you need additional information or have any
|
||||||
|
* questions.
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @test
|
||||||
|
* @bug 7160610
|
||||||
|
* @summary Unknown Native Code compilation issue.
|
||||||
|
*
|
||||||
|
* @run main/othervm -XX:+IgnoreUnrecognizedVMOptions -XX:-OptimizeFill Test7160610
|
||||||
|
*/
|
||||||
|
|
||||||
|
public class Test7160610 {
|
||||||
|
private static final byte[] BYTE_ARRAY = new byte[7];
|
||||||
|
private static int[] anIntArray1190 = new int[32768];
|
||||||
|
private static int[] anIntArray1191 = new int[32768];
|
||||||
|
|
||||||
|
public static void main(String arg[]) {
|
||||||
|
int i = 256;
|
||||||
|
for(int j = BYTE_ARRAY[2]; j < anIntArray1190.length; j++) {
|
||||||
|
anIntArray1190[j] = BYTE_ARRAY[2];
|
||||||
|
}
|
||||||
|
|
||||||
|
for(int k = BYTE_ARRAY[2]; (k ^ BYTE_ARRAY[1]) > -5001; k++) {
|
||||||
|
int i1 = (int)(Math.random() * 128D * (double)i);
|
||||||
|
anIntArray1190[i1] = (int)(Math.random() * 256D);
|
||||||
|
}
|
||||||
|
|
||||||
|
for(int l = BYTE_ARRAY[2]; (l ^ BYTE_ARRAY[1]) > -21; l++) {
|
||||||
|
for(int j1 = BYTE_ARRAY[0]; j1 < i + -BYTE_ARRAY[0]; j1++) {
|
||||||
|
for(int k1 = BYTE_ARRAY[0]; (k1 ^ BYTE_ARRAY[1]) > -128; k1++) {
|
||||||
|
int l1 = k1 - -(j1 << 0x26cb6487);
|
||||||
|
anIntArray1191[l1] = (anIntArray1190[l1 + -BYTE_ARRAY[0]] - -anIntArray1190[l1 - -BYTE_ARRAY[0]] - -anIntArray1190[-128 + l1] - -anIntArray1190[128 + l1]) / BYTE_ARRAY[6];
|
||||||
|
}
|
||||||
|
}
|
||||||
|
int ai[] = anIntArray1190;
|
||||||
|
anIntArray1190 = anIntArray1191;
|
||||||
|
anIntArray1191 = ai;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
static {
|
||||||
|
BYTE_ARRAY[6] = 4;
|
||||||
|
BYTE_ARRAY[5] = 5;
|
||||||
|
BYTE_ARRAY[4] = 3;
|
||||||
|
BYTE_ARRAY[3] = 2;
|
||||||
|
BYTE_ARRAY[2] = 0;
|
||||||
|
BYTE_ARRAY[1] = -1;
|
||||||
|
BYTE_ARRAY[0] = 1;
|
||||||
|
}
|
||||||
|
}
|
38
hotspot/test/runtime/7167069/PrintAsFlag.java
Normal file
38
hotspot/test/runtime/7167069/PrintAsFlag.java
Normal file
@ -0,0 +1,38 @@
|
|||||||
|
/*
|
||||||
|
* Copyright (c) 2012, Oracle and/or its affiliates. All rights reserved.
|
||||||
|
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
||||||
|
*
|
||||||
|
* This code is free software; you can redistribute it and/or modify it
|
||||||
|
* under the terms of the GNU General Public License version 2 only, as
|
||||||
|
* published by the Free Software Foundation.
|
||||||
|
*
|
||||||
|
* This code is distributed in the hope that it will be useful, but WITHOUT
|
||||||
|
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
|
||||||
|
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
|
||||||
|
* version 2 for more details (a copy is included in the LICENSE file that
|
||||||
|
* accompanied this code).
|
||||||
|
*
|
||||||
|
* You should have received a copy of the GNU General Public License version
|
||||||
|
* 2 along with this work; if not, write to the Free Software Foundation,
|
||||||
|
* Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
|
||||||
|
*
|
||||||
|
* Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
|
||||||
|
* or visit www.oracle.com if you need additional information or have any
|
||||||
|
* questions.
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Note that in the run command below the only important flag is PrintCommandLineFlags.
|
||||||
|
* The others are just flags of all types; bool, intx, uintx, uint64_t, double and ccstr.
|
||||||
|
*
|
||||||
|
* @test PrintAsFlag
|
||||||
|
* @summary verify that Flag::print_as_flag() works correctly. This is used by "jinfo -flag" and -XX:+PrintCommandLineFlags.
|
||||||
|
* @run main/othervm -XX:+PrintCommandLineFlags -XX:-ShowMessageBoxOnError -XX:BiasedLockingStartupDelay=4000 -XX:ParallelGCThreads=4 -XX:MaxRAM=1G -XX:CMSSmallCoalSurplusPercent=1.05 -XX:ErrorFile="file" PrintAsFlag
|
||||||
|
*/
|
||||||
|
|
||||||
|
public class PrintAsFlag {
|
||||||
|
public static void main(String... args) {
|
||||||
|
System.out.printf("Done");
|
||||||
|
}
|
||||||
|
}
|
@ -159,3 +159,4 @@ ddfe5562f61f54ed2121ac0c73b688b94f3e66b5 jdk8-b32
|
|||||||
2e3e1356ffbddb2ae95c08da72830ba9ab8b3181 jdk8-b35
|
2e3e1356ffbddb2ae95c08da72830ba9ab8b3181 jdk8-b35
|
||||||
45da9cb055ee258dc09e69c1718e27eadea38e45 jdk8-b36
|
45da9cb055ee258dc09e69c1718e27eadea38e45 jdk8-b36
|
||||||
9e82ac15ab80370d6e021aea7b98c7c9626adb5e jdk8-b37
|
9e82ac15ab80370d6e021aea7b98c7c9626adb5e jdk8-b37
|
||||||
|
c45f3509a70796c54b48f32910d1caf435763416 jdk8-b38
|
||||||
|
@ -156,6 +156,7 @@ JDK_MAN_PAGES = \
|
|||||||
jstack.1 \
|
jstack.1 \
|
||||||
jstat.1 \
|
jstat.1 \
|
||||||
jstatd.1 \
|
jstatd.1 \
|
||||||
|
jvisualvm.1 \
|
||||||
native2ascii.1 \
|
native2ascii.1 \
|
||||||
rmic.1 \
|
rmic.1 \
|
||||||
schemagen.1 \
|
schemagen.1 \
|
||||||
@ -1311,8 +1312,8 @@ $(TEMP_PREV_JDK_COMPARISON): install-previous-jdk $(DIRDIFF_JARFILE)
|
|||||||
@$(java-vm-cleanup)
|
@$(java-vm-cleanup)
|
||||||
|
|
||||||
# Clean up names in the messages printed out
|
# Clean up names in the messages printed out
|
||||||
CAT_FILTER = $(SED) -e "s@$(JDK_IMAGE_DIR)@JDK_IMAGE@g" \
|
CAT_FILTER = $(SED) -e "s|$(JDK_IMAGE_DIR)|JDK_IMAGE|g" \
|
||||||
-e "s@$(JRE_IMAGE_DIR)@JRE_IMAGE@g"
|
-e "s|$(JRE_IMAGE_DIR)|JRE_IMAGE|g"
|
||||||
|
|
||||||
# Report on the jre image comparison
|
# Report on the jre image comparison
|
||||||
compare-image-jre: $(TEMP_PREV_JRE_COMPARISON)
|
compare-image-jre: $(TEMP_PREV_JRE_COMPARISON)
|
||||||
|
@ -1,7 +1,7 @@
|
|||||||
#!/bin/sh
|
#!/bin/sh
|
||||||
|
|
||||||
#
|
#
|
||||||
# Copyright (c) 2009, 2010, Oracle and/or its affiliates. All rights reserved.
|
# Copyright (c) 2009, 2012, 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
|
||||||
@ -24,6 +24,8 @@
|
|||||||
#
|
#
|
||||||
|
|
||||||
# Shell script for a fast parallel forest command
|
# Shell script for a fast parallel forest command
|
||||||
|
command="$1"
|
||||||
|
pull_extra_base="$2"
|
||||||
|
|
||||||
tmp=/tmp/forest.$$
|
tmp=/tmp/forest.$$
|
||||||
rm -f -r ${tmp}
|
rm -f -r ${tmp}
|
||||||
@ -35,40 +37,58 @@ trap 'rm -f -r ${tmp}' EXIT
|
|||||||
|
|
||||||
# Only look in specific locations for possible forests (avoids long searches)
|
# Only look in specific locations for possible forests (avoids long searches)
|
||||||
pull_default=""
|
pull_default=""
|
||||||
if [ "$1" = "clone" -o "$1" = "fclone" ] ; then
|
repos=""
|
||||||
|
repos_extra=""
|
||||||
|
if [ "${command}" = "clone" -o "${command}" = "fclone" ] ; then
|
||||||
subrepos="corba jaxp jaxws langtools jdk hotspot"
|
subrepos="corba jaxp jaxws langtools jdk hotspot"
|
||||||
if [ -f .hg/hgrc ] ; then
|
if [ -f .hg/hgrc ] ; then
|
||||||
pull_default=`hg paths default`
|
pull_default=`hg paths default`
|
||||||
fi
|
|
||||||
if [ "${pull_default}" = "" ] ; then
|
if [ "${pull_default}" = "" ] ; then
|
||||||
echo "ERROR: Need initial clone with 'hg paths default' defined"
|
echo "ERROR: Need initial clone with 'hg paths default' defined"
|
||||||
exit 1
|
exit 1
|
||||||
fi
|
fi
|
||||||
repos=""
|
fi
|
||||||
|
if [ "${pull_default}" = "" ] ; then
|
||||||
|
echo "ERROR: Need initial repository to use this script"
|
||||||
|
exit 1
|
||||||
|
fi
|
||||||
for i in ${subrepos} ; do
|
for i in ${subrepos} ; do
|
||||||
if [ ! -f ${i}/.hg/hgrc ] ; then
|
if [ ! -f ${i}/.hg/hgrc ] ; then
|
||||||
repos="${repos} ${i}"
|
repos="${repos} ${i}"
|
||||||
fi
|
fi
|
||||||
done
|
done
|
||||||
|
if [ "${pull_extra_base}" != "" ] ; then
|
||||||
|
subrepos_extra="jdk/src/closed jdk/make/closed jdk/test/closed hotspot/src/closed hotspot/test/closed deploy install sponsors pubs"
|
||||||
|
pull_default_tail=`echo ${pull_default} | sed -e 's@^.*://[^/]*/\(.*\)@\1@'`
|
||||||
|
pull_extra="${pull_extra_base}/${pull_default_tail}"
|
||||||
|
for i in ${subrepos_extra} ; do
|
||||||
|
if [ ! -f ${i}/.hg/hgrc ] ; then
|
||||||
|
repos_extra="${repos_extra} ${i}"
|
||||||
|
fi
|
||||||
|
done
|
||||||
|
fi
|
||||||
at_a_time=2
|
at_a_time=2
|
||||||
|
# Any repos to deal with?
|
||||||
|
if [ "${repos}" = "" -a "${repos_extra}" = "" ] ; then
|
||||||
|
echo "No repositories to clone."
|
||||||
|
exit
|
||||||
|
fi
|
||||||
else
|
else
|
||||||
hgdirs=`ls -d ./.hg ./*/.hg ./*/*/.hg ./*/*/*/.hg ./*/*/*/*/.hg 2>/dev/null`
|
hgdirs=`ls -d ./.hg ./*/.hg ./*/*/.hg ./*/*/*/.hg ./*/*/*/*/.hg 2>/dev/null`
|
||||||
# Derive repository names from the .hg directory locations
|
# Derive repository names from the .hg directory locations
|
||||||
repos=""
|
|
||||||
for i in ${hgdirs} ; do
|
for i in ${hgdirs} ; do
|
||||||
repos="${repos} `echo ${i} | sed -e 's@/.hg$@@'`"
|
repos="${repos} `echo ${i} | sed -e 's@/.hg$@@'`"
|
||||||
done
|
done
|
||||||
at_a_time=8
|
at_a_time=8
|
||||||
fi
|
|
||||||
|
|
||||||
# Any repos to deal with?
|
# Any repos to deal with?
|
||||||
if [ "${repos}" = "" ] ; then
|
if [ "${repos}" = "" ] ; then
|
||||||
echo "No repositories to process."
|
echo "No repositories to process."
|
||||||
exit
|
exit
|
||||||
fi
|
fi
|
||||||
|
fi
|
||||||
|
|
||||||
# Echo out what repositories we will process
|
# Echo out what repositories we will clone
|
||||||
echo "# Repos: ${repos}"
|
echo "# Repos: ${repos} ${repos_extra}"
|
||||||
|
|
||||||
# Run the supplied command on all repos in parallel, save output until end
|
# Run the supplied command on all repos in parallel, save output until end
|
||||||
n=0
|
n=0
|
||||||
@ -77,8 +97,8 @@ for i in ${repos} ; do
|
|||||||
n=`expr ${n} '+' 1`
|
n=`expr ${n} '+' 1`
|
||||||
(
|
(
|
||||||
(
|
(
|
||||||
if [ "$1" = "clone" -o "$1" = "fclone" ] ; then
|
if [ "${command}" = "clone" -o "${command}" = "fclone" ] ; then
|
||||||
cline="hg $* ${pull_default}/${i} ${i}"
|
cline="hg clone ${pull_default}/${i} ${i}"
|
||||||
echo "# ${cline}"
|
echo "# ${cline}"
|
||||||
( eval "${cline}" )
|
( eval "${cline}" )
|
||||||
else
|
else
|
||||||
@ -92,6 +112,22 @@ for i in ${repos} ; do
|
|||||||
sleep 5
|
sleep 5
|
||||||
fi
|
fi
|
||||||
done
|
done
|
||||||
|
if [ "${repos_extra}" != "" ] ; then
|
||||||
|
for i in ${repos_extra} ; do
|
||||||
|
echo "Starting on ${i}"
|
||||||
|
n=`expr ${n} '+' 1`
|
||||||
|
(
|
||||||
|
(
|
||||||
|
cline="hg clone ${pull_extra}/${i} ${i}"
|
||||||
|
echo "# ${cline}"
|
||||||
|
( eval "${cline}" )
|
||||||
|
echo "# exit code $?"
|
||||||
|
) > ${tmp}/repo.${n} 2>&1 ; cat ${tmp}/repo.${n} ) &
|
||||||
|
if [ `expr ${n} '%' ${at_a_time}` -eq 0 ] ; then
|
||||||
|
sleep 5
|
||||||
|
fi
|
||||||
|
done
|
||||||
|
fi
|
||||||
|
|
||||||
# Wait for all hg commands to complete
|
# Wait for all hg commands to complete
|
||||||
wait
|
wait
|
||||||
|
Loading…
x
Reference in New Issue
Block a user