Merge
This commit is contained in:
commit
b532bd21dc
@ -66,7 +66,7 @@ void ImmutableSpace::print() const {
|
|||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
void ImmutableSpace::verify(bool allow_dirty) const {
|
void ImmutableSpace::verify(bool allow_dirty) {
|
||||||
HeapWord* p = bottom();
|
HeapWord* p = bottom();
|
||||||
HeapWord* t = end();
|
HeapWord* t = end();
|
||||||
HeapWord* prev_p = NULL;
|
HeapWord* prev_p = NULL;
|
||||||
|
@ -59,5 +59,5 @@ class ImmutableSpace: public CHeapObj {
|
|||||||
// Debugging
|
// Debugging
|
||||||
virtual void print() const PRODUCT_RETURN;
|
virtual void print() const PRODUCT_RETURN;
|
||||||
virtual void print_short() const PRODUCT_RETURN;
|
virtual void print_short() const PRODUCT_RETURN;
|
||||||
virtual void verify(bool allow_dirty) const;
|
virtual void verify(bool allow_dirty);
|
||||||
};
|
};
|
||||||
|
@ -599,12 +599,28 @@ void MutableNUMASpace::initialize(MemRegion mr, bool clear_space) {
|
|||||||
// Mark the the holes in chunks below the top() as invalid.
|
// Mark the the holes in chunks below the top() as invalid.
|
||||||
void MutableNUMASpace::set_top(HeapWord* value) {
|
void MutableNUMASpace::set_top(HeapWord* value) {
|
||||||
bool found_top = false;
|
bool found_top = false;
|
||||||
for (int i = 0; i < lgrp_spaces()->length(); i++) {
|
for (int i = 0; i < lgrp_spaces()->length();) {
|
||||||
LGRPSpace *ls = lgrp_spaces()->at(i);
|
LGRPSpace *ls = lgrp_spaces()->at(i);
|
||||||
MutableSpace *s = ls->space();
|
MutableSpace *s = ls->space();
|
||||||
HeapWord *top = MAX2((HeapWord*)round_down((intptr_t)s->top(), page_size()), s->bottom());
|
HeapWord *top = MAX2((HeapWord*)round_down((intptr_t)s->top(), page_size()), s->bottom());
|
||||||
|
|
||||||
if (s->contains(value)) {
|
if (s->contains(value)) {
|
||||||
|
// Check if setting the chunk's top to a given value would create a hole less than
|
||||||
|
// a minimal object; assuming that's not the last chunk in which case we don't care.
|
||||||
|
if (i < lgrp_spaces()->length() - 1) {
|
||||||
|
size_t remainder = pointer_delta(s->end(), value);
|
||||||
|
const size_t minimal_object_size = oopDesc::header_size();
|
||||||
|
if (remainder < minimal_object_size && remainder > 0) {
|
||||||
|
// Add a filler object of a minimal size, it will cross the chunk boundary.
|
||||||
|
SharedHeap::fill_region_with_object(MemRegion(value, minimal_object_size));
|
||||||
|
value += minimal_object_size;
|
||||||
|
assert(!s->contains(value), "Should be in the next chunk");
|
||||||
|
// Restart the loop from the same chunk, since the value has moved
|
||||||
|
// to the next one.
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
if (!os::numa_has_static_binding() && top < value && top < s->end()) {
|
if (!os::numa_has_static_binding() && top < value && top < s->end()) {
|
||||||
ls->add_invalid_region(MemRegion(top, value));
|
ls->add_invalid_region(MemRegion(top, value));
|
||||||
}
|
}
|
||||||
@ -620,6 +636,7 @@ void MutableNUMASpace::set_top(HeapWord* value) {
|
|||||||
s->set_top(s->end());
|
s->set_top(s->end());
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
i++;
|
||||||
}
|
}
|
||||||
MutableSpace::set_top(value);
|
MutableSpace::set_top(value);
|
||||||
}
|
}
|
||||||
@ -700,12 +717,14 @@ HeapWord* MutableNUMASpace::cas_allocate(size_t size) {
|
|||||||
MutableSpace *s = lgrp_spaces()->at(i)->space();
|
MutableSpace *s = lgrp_spaces()->at(i)->space();
|
||||||
HeapWord *p = s->cas_allocate(size);
|
HeapWord *p = s->cas_allocate(size);
|
||||||
if (p != NULL) {
|
if (p != NULL) {
|
||||||
size_t remainder = pointer_delta(s->end(), p);
|
size_t remainder = pointer_delta(s->end(), p + size);
|
||||||
if (remainder < (size_t)oopDesc::header_size() && remainder > 0) {
|
if (remainder < (size_t)oopDesc::header_size() && remainder > 0) {
|
||||||
if (s->cas_deallocate(p, size)) {
|
if (s->cas_deallocate(p, size)) {
|
||||||
// We were the last to allocate and created a fragment less than
|
// We were the last to allocate and created a fragment less than
|
||||||
// a minimal object.
|
// a minimal object.
|
||||||
p = NULL;
|
p = NULL;
|
||||||
|
} else {
|
||||||
|
guarantee(false, "Deallocation should always succeed");
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -761,10 +780,12 @@ void MutableNUMASpace::print_on(outputStream* st) const {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
void MutableNUMASpace::verify(bool allow_dirty) const {
|
void MutableNUMASpace::verify(bool allow_dirty) {
|
||||||
for (int i = 0; i < lgrp_spaces()->length(); i++) {
|
// This can be called after setting an arbitary value to the space's top,
|
||||||
lgrp_spaces()->at(i)->space()->verify(allow_dirty);
|
// so an object can cross the chunk boundary. We ensure the parsablity
|
||||||
}
|
// of the space and just walk the objects in linear fashion.
|
||||||
|
ensure_parsability();
|
||||||
|
MutableSpace::verify(allow_dirty);
|
||||||
}
|
}
|
||||||
|
|
||||||
// Scan pages and gather stats about page placement and size.
|
// Scan pages and gather stats about page placement and size.
|
||||||
|
@ -192,7 +192,7 @@ class MutableNUMASpace : public MutableSpace {
|
|||||||
// Debugging
|
// Debugging
|
||||||
virtual void print_on(outputStream* st) const;
|
virtual void print_on(outputStream* st) const;
|
||||||
virtual void print_short_on(outputStream* st) const;
|
virtual void print_short_on(outputStream* st) const;
|
||||||
virtual void verify(bool allow_dirty) const;
|
virtual void verify(bool allow_dirty);
|
||||||
|
|
||||||
virtual void set_top(HeapWord* value);
|
virtual void set_top(HeapWord* value);
|
||||||
};
|
};
|
||||||
|
@ -118,7 +118,7 @@ void MutableSpace::print_on(outputStream* st) const {
|
|||||||
bottom(), top(), end());
|
bottom(), top(), end());
|
||||||
}
|
}
|
||||||
|
|
||||||
void MutableSpace::verify(bool allow_dirty) const {
|
void MutableSpace::verify(bool allow_dirty) {
|
||||||
HeapWord* p = bottom();
|
HeapWord* p = bottom();
|
||||||
HeapWord* t = top();
|
HeapWord* t = top();
|
||||||
HeapWord* prev_p = NULL;
|
HeapWord* prev_p = NULL;
|
||||||
|
@ -98,5 +98,5 @@ class MutableSpace: public ImmutableSpace {
|
|||||||
virtual void print_on(outputStream* st) const;
|
virtual void print_on(outputStream* st) const;
|
||||||
virtual void print_short() const;
|
virtual void print_short() const;
|
||||||
virtual void print_short_on(outputStream* st) const;
|
virtual void print_short_on(outputStream* st) const;
|
||||||
virtual void verify(bool allow_dirty) const;
|
virtual void verify(bool allow_dirty);
|
||||||
};
|
};
|
||||||
|
@ -158,7 +158,6 @@ public:
|
|||||||
assert(ProfileTraps, "used only under +ProfileTraps");
|
assert(ProfileTraps, "used only under +ProfileTraps");
|
||||||
uint old_flags = (_header._struct._flags & flag_mask);
|
uint old_flags = (_header._struct._flags & flag_mask);
|
||||||
_header._struct._flags = (new_state << trap_shift) | old_flags;
|
_header._struct._flags = (new_state << trap_shift) | old_flags;
|
||||||
assert(trap_state() == new_state, "sanity");
|
|
||||||
}
|
}
|
||||||
|
|
||||||
u1 flags() {
|
u1 flags() {
|
||||||
|
Loading…
x
Reference in New Issue
Block a user