8212205: VM asserts after CDS archive has been unmapped

Reviewed-by: dholmes, jiangli, hseigel, stuefe
This commit is contained in:
Ioi Lam 2018-10-25 11:23:43 -07:00
parent 37ef084d73
commit 9a06fc3ea7
4 changed files with 11 additions and 4 deletions

View file

@ -244,7 +244,6 @@ class ClassLoaderData;
class MetaspaceClosure;
class MetaspaceObj {
friend class MetaspaceShared;
// When CDS is enabled, all shared metaspace objects are mapped
// into a single contiguous memory block, so we can use these
// two pointers to quickly determine if something is in the
@ -263,6 +262,13 @@ class MetaspaceObj {
}
void print_address_on(outputStream* st) const; // nonvirtual address printing
static void set_shared_metaspace_range(void* base, void* top) {
_shared_metaspace_base = base;
_shared_metaspace_top = top;
}
static void* shared_metaspace_base() { return _shared_metaspace_base; }
static void* shared_metaspace_top() { return _shared_metaspace_top; }
#define METASPACE_OBJ_TYPES_DO(f) \
f(Class) \
f(Symbol) \

View file

@ -1355,6 +1355,8 @@ bool FileMapInfo::is_in_shared_region(const void* p, int idx) {
// Unmap mapped regions of shared space.
void FileMapInfo::stop_sharing_and_unmap(const char* msg) {
MetaspaceObj::set_shared_metaspace_range(NULL, NULL);
FileMapInfo *map_info = FileMapInfo::current_info();
if (map_info) {
map_info->fail_continue("%s", msg);

View file

@ -1957,8 +1957,7 @@ bool MetaspaceShared::map_shared_spaces(FileMapInfo* mapinfo) {
assert(ro_top == md_base, "must be");
assert(md_top == od_base, "must be");
MetaspaceObj::_shared_metaspace_base = (void*)mc_base;
MetaspaceObj::_shared_metaspace_top = (void*)od_top;
MetaspaceObj::set_shared_metaspace_range((void*)mc_base, (void*)od_top);
return true;
} else {
// If there was a failure in mapping any of the spaces, unmap the ones

View file

@ -125,7 +125,7 @@ class MetaspaceShared : AllStatic {
static bool is_in_shared_metaspace(const void* p) {
// If no shared metaspace regions are mapped, MetaspceObj::_shared_metaspace_{base,top} will
// both be NULL and all values of p will be rejected quickly.
return (p < MetaspaceObj::_shared_metaspace_top && p >= MetaspaceObj::_shared_metaspace_base);
return (p < MetaspaceObj::shared_metaspace_top() && p >= MetaspaceObj::shared_metaspace_base());
}
// Return true if given address is in the shared region corresponding to the idx