diff --git a/hotspot/src/share/vm/memory/heap.cpp b/hotspot/src/share/vm/memory/heap.cpp index 5ba099e78e8..5501700312e 100644 --- a/hotspot/src/share/vm/memory/heap.cpp +++ b/hotspot/src/share/vm/memory/heap.cpp @@ -279,10 +279,12 @@ size_t CodeHeap::alignment_offset() const { return sizeof(HeapBlock) & (_segment_size - 1); } -// Finds the next free heapblock. If the current one is free, that it returned -void* CodeHeap::next_free(HeapBlock* b) const { - // Since free blocks are merged, there is max. on free block - // between two used ones +// Returns the current block if available and used. +// If not, it returns the subsequent block (if available), NULL otherwise. +// Free blocks are merged, therefore there is at most one free block +// between two used ones. As a result, the subsequent block (if available) is +// guaranteed to be used. +void* CodeHeap::next_used(HeapBlock* b) const { if (b != NULL && b->free()) b = next_block(b); assert(b == NULL || !b->free(), "must be in use or at end of heap"); return (b == NULL) ? NULL : b->allocated_space(); diff --git a/hotspot/src/share/vm/memory/heap.hpp b/hotspot/src/share/vm/memory/heap.hpp index 4fdbeabbfc3..45b43ce06c1 100644 --- a/hotspot/src/share/vm/memory/heap.hpp +++ b/hotspot/src/share/vm/memory/heap.hpp @@ -123,7 +123,7 @@ class CodeHeap : public CHeapObj { FreeBlock* search_freelist(size_t length); // Iteration helpers - void* next_free(HeapBlock* b) const; + void* next_used(HeapBlock* b) const; HeapBlock* first_block() const; HeapBlock* next_block(HeapBlock* b) const; HeapBlock* block_start(void* p) const; @@ -158,9 +158,9 @@ class CodeHeap : public CHeapObj { int freelist_length() const { return _freelist_length; } // number of elements in the freelist // returns the first block or NULL - void* first() const { return next_free(first_block()); } + void* first() const { return next_used(first_block()); } // returns the next block given a block p or NULL - void* next(void* p) const { return next_free(next_block(block_start(p))); } + void* next(void* p) const { return next_used(next_block(block_start(p))); } // Statistics size_t capacity() const;