8253639: Change os::attempt_reserve_memory_at parameter order

Reviewed-by: tschatzl, iklam
This commit is contained in:
Stefan Karlsson 2020-09-28 07:12:48 +00:00
parent fed3636f12
commit ca1ed16292
10 changed files with 27 additions and 27 deletions

View File

@ -2532,7 +2532,7 @@ bool os::can_execute_large_page_memory() {
return false; return false;
} }
char* os::pd_attempt_reserve_memory_at(size_t bytes, char* requested_addr, int file_desc) { char* os::pd_attempt_reserve_memory_at(char* requested_addr, size_t bytes, int file_desc) {
assert(file_desc >= 0, "file_desc is not valid"); assert(file_desc >= 0, "file_desc is not valid");
char* result = NULL; char* result = NULL;
@ -2550,7 +2550,7 @@ char* os::pd_attempt_reserve_memory_at(size_t bytes, char* requested_addr, int f
// Reserve memory at an arbitrary address, only if that area is // Reserve memory at an arbitrary address, only if that area is
// available (and not reserved for something else). // available (and not reserved for something else).
char* os::pd_attempt_reserve_memory_at(size_t bytes, char* requested_addr) { char* os::pd_attempt_reserve_memory_at(char* requested_addr, size_t bytes) {
char* addr = NULL; char* addr = NULL;
// Always round to os::vm_page_size(), which may be larger than 4K. // Always round to os::vm_page_size(), which may be larger than 4K.

View File

@ -2115,9 +2115,9 @@ bool os::can_execute_large_page_memory() {
return false; return false;
} }
char* os::pd_attempt_reserve_memory_at(size_t bytes, char* requested_addr, int file_desc) { char* os::pd_attempt_reserve_memory_at(char* requested_addr, size_t bytes, int file_desc) {
assert(file_desc >= 0, "file_desc is not valid"); assert(file_desc >= 0, "file_desc is not valid");
char* result = pd_attempt_reserve_memory_at(bytes, requested_addr); char* result = pd_attempt_reserve_memory_at(requested_addr, bytes);
if (result != NULL) { if (result != NULL) {
if (replace_existing_mapping_with_file_mapping(result, bytes, file_desc) == NULL) { if (replace_existing_mapping_with_file_mapping(result, bytes, file_desc) == NULL) {
vm_exit_during_initialization(err_msg("Error in mapping Java heap at the given filesystem directory")); vm_exit_during_initialization(err_msg("Error in mapping Java heap at the given filesystem directory"));
@ -2129,7 +2129,7 @@ char* os::pd_attempt_reserve_memory_at(size_t bytes, char* requested_addr, int f
// Reserve memory at an arbitrary address, only if that area is // Reserve memory at an arbitrary address, only if that area is
// available (and not reserved for something else). // available (and not reserved for something else).
char* os::pd_attempt_reserve_memory_at(size_t bytes, char* requested_addr) { char* os::pd_attempt_reserve_memory_at(char* requested_addr, size_t bytes) {
// Assert only that the size is a multiple of the page size, since // Assert only that the size is a multiple of the page size, since
// that's all that mmap requires, and since that's all we really know // that's all that mmap requires, and since that's all we really know
// about at this low abstraction level. If we need higher alignment, // about at this low abstraction level. If we need higher alignment,

View File

@ -4376,9 +4376,9 @@ bool os::can_execute_large_page_memory() {
return UseTransparentHugePages || UseHugeTLBFS; return UseTransparentHugePages || UseHugeTLBFS;
} }
char* os::pd_attempt_reserve_memory_at(size_t bytes, char* requested_addr, int file_desc) { char* os::pd_attempt_reserve_memory_at(char* requested_addr, size_t bytes, int file_desc) {
assert(file_desc >= 0, "file_desc is not valid"); assert(file_desc >= 0, "file_desc is not valid");
char* result = pd_attempt_reserve_memory_at(bytes, requested_addr); char* result = pd_attempt_reserve_memory_at(requested_addr, bytes);
if (result != NULL) { if (result != NULL) {
if (replace_existing_mapping_with_file_mapping(result, bytes, file_desc) == NULL) { if (replace_existing_mapping_with_file_mapping(result, bytes, file_desc) == NULL) {
vm_exit_during_initialization(err_msg("Error in mapping Java heap at the given filesystem directory")); vm_exit_during_initialization(err_msg("Error in mapping Java heap at the given filesystem directory"));
@ -4390,7 +4390,7 @@ char* os::pd_attempt_reserve_memory_at(size_t bytes, char* requested_addr, int f
// Reserve memory at an arbitrary address, only if that area is // Reserve memory at an arbitrary address, only if that area is
// available (and not reserved for something else). // available (and not reserved for something else).
char* os::pd_attempt_reserve_memory_at(size_t bytes, char* requested_addr) { char* os::pd_attempt_reserve_memory_at(char* requested_addr, size_t bytes) {
// Assert only that the size is a multiple of the page size, since // Assert only that the size is a multiple of the page size, since
// that's all that mmap requires, and since that's all we really know // that's all that mmap requires, and since that's all we really know
// about at this low abstraction level. If we need higher alignment, // about at this low abstraction level. If we need higher alignment,

View File

@ -3063,8 +3063,8 @@ void os::split_reserved_memory(char *base, size_t size, size_t split) {
assert(is_aligned(split_address, os::vm_allocation_granularity()), "Sanity"); assert(is_aligned(split_address, os::vm_allocation_granularity()), "Sanity");
release_memory(base, size); release_memory(base, size);
attempt_reserve_memory_at(split, base); attempt_reserve_memory_at(base, split);
attempt_reserve_memory_at(size - split, split_address); attempt_reserve_memory_at(split_address, size - split);
// NMT: nothing to do here. Since Windows implements the split by // NMT: nothing to do here. Since Windows implements the split by
// releasing and re-reserving memory, the parts are already registered // releasing and re-reserving memory, the parts are already registered
@ -3099,7 +3099,7 @@ char* os::reserve_memory_aligned(size_t size, size_t alignment, int file_desc) {
os::release_memory(extra_base, extra_size); os::release_memory(extra_base, extra_size);
} }
aligned_base = os::attempt_reserve_memory_at(size, aligned_base, file_desc); aligned_base = os::attempt_reserve_memory_at(aligned_base, size, file_desc);
} while (aligned_base == NULL); } while (aligned_base == NULL);
@ -3108,12 +3108,12 @@ char* os::reserve_memory_aligned(size_t size, size_t alignment, int file_desc) {
char* os::pd_reserve_memory(size_t bytes, size_t alignment_hint) { char* os::pd_reserve_memory(size_t bytes, size_t alignment_hint) {
// Ignores alignment hint // Ignores alignment hint
return pd_attempt_reserve_memory_at(bytes, NULL /* addr */); return pd_attempt_reserve_memory_at(NULL /* addr */, bytes);
} }
// Reserve memory at an arbitrary address, only if that area is // Reserve memory at an arbitrary address, only if that area is
// available (and not reserved for something else). // available (and not reserved for something else).
char* os::pd_attempt_reserve_memory_at(size_t bytes, char* addr) { char* os::pd_attempt_reserve_memory_at(char* addr, size_t bytes) {
assert((size_t)addr % os::vm_allocation_granularity() == 0, assert((size_t)addr % os::vm_allocation_granularity() == 0,
"reserve alignment"); "reserve alignment");
assert(bytes % os::vm_page_size() == 0, "reserve page size"); assert(bytes % os::vm_page_size() == 0, "reserve page size");
@ -3144,7 +3144,7 @@ char* os::pd_attempt_reserve_memory_at(size_t bytes, char* addr) {
return res; return res;
} }
char* os::pd_attempt_reserve_memory_at(size_t bytes, char* requested_addr, int file_desc) { char* os::pd_attempt_reserve_memory_at(char* requested_addr, size_t bytes, int file_desc) {
assert(file_desc >= 0, "file_desc is not valid"); assert(file_desc >= 0, "file_desc is not valid");
return map_memory_to_file(requested_addr, bytes, file_desc); return map_memory_to_file(requested_addr, bytes, file_desc);
} }

View File

@ -859,7 +859,7 @@ void os::workaround_expand_exec_shield_cs_limit() {
*/ */
char* hint = (char*)(Linux::initial_thread_stack_bottom() - char* hint = (char*)(Linux::initial_thread_stack_bottom() -
(JavaThread::stack_guard_zone_size() + page_size)); (JavaThread::stack_guard_zone_size() + page_size));
char* codebuf = os::attempt_reserve_memory_at(page_size, hint); char* codebuf = os::attempt_reserve_memory_at(hint, page_size);
if (codebuf == NULL) { if (codebuf == NULL) {
// JDK-8197429: There may be a stack gap of one megabyte between // JDK-8197429: There may be a stack gap of one megabyte between
@ -867,7 +867,7 @@ void os::workaround_expand_exec_shield_cs_limit() {
// Linux kernel workaround for CVE-2017-1000364. If we failed to // Linux kernel workaround for CVE-2017-1000364. If we failed to
// map our codebuf, try again at an address one megabyte lower. // map our codebuf, try again at an address one megabyte lower.
hint -= 1 * M; hint -= 1 * M;
codebuf = os::attempt_reserve_memory_at(page_size, hint); codebuf = os::attempt_reserve_memory_at(hint, page_size);
} }
if ((codebuf == NULL) || (!os::commit_memory(codebuf, page_size, true))) { if ((codebuf == NULL) || (!os::commit_memory(codebuf, page_size, true))) {

View File

@ -220,7 +220,7 @@ static bool map_nvdimm_space(ReservedSpace rs) {
return false; return false;
} }
// commit this memory in nv-dimm // commit this memory in nv-dimm
char* ret = os::attempt_reserve_memory_at(rs.size(), rs.base(), _backing_fd); char* ret = os::attempt_reserve_memory_at(rs.base(), rs.size(), _backing_fd);
if (ret != rs.base()) { if (ret != rs.base()) {
if (ret != NULL) { if (ret != NULL) {
@ -267,7 +267,7 @@ bool G1RegionToHeteroSpaceMapper::initialize() {
assert(rs_dram.size() == rs_nvdimm.size() && rs_nvdimm.size() == MaxHeapSize, "They all should be same"); assert(rs_dram.size() == rs_nvdimm.size() && rs_nvdimm.size() == MaxHeapSize, "They all should be same");
// Reserve dram memory // Reserve dram memory
char* base = os::attempt_reserve_memory_at(rs_dram.size(), rs_dram.base()); char* base = os::attempt_reserve_memory_at(rs_dram.base(), rs_dram.size());
if (base != rs_dram.base()) { if (base != rs_dram.base()) {
if (base != NULL) { if (base != NULL) {
os::release_memory(base, rs_dram.size()); os::release_memory(base, rs_dram.size());

View File

@ -188,7 +188,7 @@ void ReservedSpace::initialize(size_t size, size_t alignment, bool large,
// important. If available space is not detected, return NULL. // important. If available space is not detected, return NULL.
if (requested_address != 0) { if (requested_address != 0) {
base = os::attempt_reserve_memory_at(size, requested_address, _fd_for_heap); base = os::attempt_reserve_memory_at(requested_address, size, _fd_for_heap);
if (failed_to_reserve_as_requested(base, requested_address, size, false, _fd_for_heap != -1)) { if (failed_to_reserve_as_requested(base, requested_address, size, false, _fd_for_heap != -1)) {
// OS ignored requested address. Try different address. // OS ignored requested address. Try different address.
base = NULL; base = NULL;
@ -380,7 +380,7 @@ void ReservedHeapSpace::try_reserve_heap(size_t size,
// important. If available space is not detected, return NULL. // important. If available space is not detected, return NULL.
if (requested_address != 0) { if (requested_address != 0) {
base = os::attempt_reserve_memory_at(size, requested_address, _fd_for_heap); base = os::attempt_reserve_memory_at(requested_address, size, _fd_for_heap);
} else { } else {
base = os::reserve_memory_with_fd(size, alignment, _fd_for_heap); base = os::reserve_memory_with_fd(size, alignment, _fd_for_heap);
} }

View File

@ -762,7 +762,7 @@ WB_ENTRY(jlong, WB_NMTReserveMemory(JNIEnv* env, jobject o, jlong size))
WB_END WB_END
WB_ENTRY(jlong, WB_NMTAttemptReserveMemoryAt(JNIEnv* env, jobject o, jlong addr, jlong size)) WB_ENTRY(jlong, WB_NMTAttemptReserveMemoryAt(JNIEnv* env, jobject o, jlong addr, jlong size))
addr = (jlong)(uintptr_t)os::attempt_reserve_memory_at((size_t)size, (char*)(uintptr_t)addr); addr = (jlong)(uintptr_t)os::attempt_reserve_memory_at((char*)(uintptr_t)addr, (size_t)size);
MemTracker::record_virtual_memory_type((address)addr, mtTest); MemTracker::record_virtual_memory_type((address)addr, mtTest);
return addr; return addr;

View File

@ -1684,15 +1684,15 @@ char* os::reserve_memory_with_fd(size_t bytes, size_t alignment_hint, int file_d
return result; return result;
} }
char* os::attempt_reserve_memory_at(size_t bytes, char* addr, int file_desc) { char* os::attempt_reserve_memory_at(char* addr, size_t bytes, int file_desc) {
char* result = NULL; char* result = NULL;
if (file_desc != -1) { if (file_desc != -1) {
result = pd_attempt_reserve_memory_at(bytes, addr, file_desc); result = pd_attempt_reserve_memory_at(addr, bytes, file_desc);
if (result != NULL) { if (result != NULL) {
MemTracker::record_virtual_memory_reserve_and_commit((address)result, bytes, CALLER_PC); MemTracker::record_virtual_memory_reserve_and_commit((address)result, bytes, CALLER_PC);
} }
} else { } else {
result = pd_attempt_reserve_memory_at(bytes, addr); result = pd_attempt_reserve_memory_at(addr, bytes);
if (result != NULL) { if (result != NULL) {
MemTracker::record_virtual_memory_reserve((address)result, bytes, CALLER_PC); MemTracker::record_virtual_memory_reserve((address)result, bytes, CALLER_PC);
} }

View File

@ -115,8 +115,8 @@ class os: AllStatic {
static char* pd_reserve_memory(size_t bytes, size_t alignment_hint); static char* pd_reserve_memory(size_t bytes, size_t alignment_hint);
static char* pd_attempt_reserve_memory_at(size_t bytes, char* addr); static char* pd_attempt_reserve_memory_at(char* addr, size_t bytes);
static char* pd_attempt_reserve_memory_at(size_t bytes, char* addr, int file_desc); static char* pd_attempt_reserve_memory_at(char* addr, size_t bytes, int file_desc);
static bool pd_commit_memory(char* addr, size_t bytes, bool executable); static bool pd_commit_memory(char* addr, size_t bytes, bool executable);
static bool pd_commit_memory(char* addr, size_t size, size_t alignment_hint, static bool pd_commit_memory(char* addr, size_t size, size_t alignment_hint,
@ -325,7 +325,7 @@ class os: AllStatic {
// Attempts to reserve the virtual memory at [addr, addr + bytes). // Attempts to reserve the virtual memory at [addr, addr + bytes).
// Does not overwrite existing mappings. // Does not overwrite existing mappings.
static char* attempt_reserve_memory_at(size_t bytes, char* addr, int file_desc = -1); static char* attempt_reserve_memory_at(char* addr, size_t bytes, int file_desc = -1);
// Split a reserved memory region [base, base+size) into two regions [base, base+split) and // Split a reserved memory region [base, base+size) into two regions [base, base+split) and
// [base+split, base+size). // [base+split, base+size).