From 4991c87ad45ac91273a0f4674369d1a29479fd15 Mon Sep 17 00:00:00 2001 From: "Keith W. Campbell" Date: Wed, 18 Jul 2018 16:16:53 -0400 Subject: [PATCH] Fix ranges used by findAvailableMemoryBlockNoMalloc The caller provides start and end addresses that constrain a non-null address that can be returned by the function. Internally, however, the function operates on ranges which are inclusive of the space requested by the caller: the allowed range must be initialized taking this difference into account by adding the requested block size to the end address. Signed-off-by: Keith W. Campbell --- port/linux/omrvmem.c | 10 +++++++++- port/ztpf/omrvmem.c | 15 +++++++++++---- 2 files changed, 20 insertions(+), 5 deletions(-) diff --git a/port/linux/omrvmem.c b/port/linux/omrvmem.c index 7ef451be6b2..dc23aca843d 100644 --- a/port/linux/omrvmem.c +++ b/port/linux/omrvmem.c @@ -344,8 +344,16 @@ findAvailableMemoryBlockNoMalloc(struct OMRPortLibrary *portLibrary, ADDRESS sta BOOLEAN dataCorrupt = FALSE; BOOLEAN matchFound = FALSE; + /* + * The caller provides start and end addresses that constrain a non-null + * address that can be returned by this function. Internally, however, + * this function operates on ranges which are inclusive of the space + * requested by the caller: the allowed range must be initialized taking + * this difference into account by adding the requested block size to the + * end address. + */ AddressRange allowedRange; - addressRange_Init(&allowedRange, start, end); + addressRange_Init(&allowedRange, start, end + byteAmount); AddressRange lastAvailableRange; addressRange_Init(&lastAvailableRange, NULL, NULL); diff --git a/port/ztpf/omrvmem.c b/port/ztpf/omrvmem.c index d76745fc78e..111800df77a 100644 --- a/port/ztpf/omrvmem.c +++ b/port/ztpf/omrvmem.c @@ -1,5 +1,5 @@ /******************************************************************************* - * Copyright (c) 1991, 2017 IBM Corp. and others + * Copyright (c) 1991, 2018 IBM Corp. and others * * This program and the accompanying materials are made available under * the terms of the Eclipse Public License 2.0 which accompanies this @@ -32,7 +32,6 @@ #define _GNU_SOURCE #endif - #include "omrport.h" #include "omrportpriv.h" #include "omrportpg.h" @@ -350,7 +349,7 @@ addressRange_Width(AddressRange* range) * @param ADDRESS start [in] The start address allowed, see also @param end * @param ADDRESS end [in] The end address allowed, see also @param start. * The returned memory address should be within the range defined by the @param start and the @param end. - * @param uintptr_t byteAmount [in] The block size required. + * @param uintptr_t byteAmount [in] The block size required. * @param BOOLEAN reverse [in] Returns the first available memory block when this param equals FALSE, returns the last available memory block when this param equals TRUE * * returns the address available. @@ -362,8 +361,16 @@ findAvailableMemoryBlockNoMalloc(struct OMRPortLibrary *portLibrary, BOOLEAN dataCorrupt = FALSE; BOOLEAN matchFound = FALSE; + /* + * The caller provides start and end addresses that constrain a non-null + * address that can be returned by this function. Internally, however, + * this function operates on ranges which are inclusive of the space + * requested by the caller: the allowed range must be initialized taking + * this difference into account by adding the requested block size to the + * end address. + */ AddressRange allowedRange; - addressRange_Init(&allowedRange, start, end); + addressRange_Init(&allowedRange, start, end + byteAmount); AddressRange lastAvailableRange; addressRange_Init(&lastAvailableRange, NULL, NULL);