Merge "Remove bogus extra alignment from sbrk."
This commit is contained in:
commit
d7ff139fec
@ -151,7 +151,6 @@ libc_common_src_files := \
|
|||||||
bionic/atoll.c \
|
bionic/atoll.c \
|
||||||
bionic/bindresvport.c \
|
bionic/bindresvport.c \
|
||||||
bionic/bionic_clone.c \
|
bionic/bionic_clone.c \
|
||||||
bionic/brk.c \
|
|
||||||
bionic/clearenv.c \
|
bionic/clearenv.c \
|
||||||
bionic/cpuacct.c \
|
bionic/cpuacct.c \
|
||||||
bionic/daemon.c \
|
bionic/daemon.c \
|
||||||
@ -201,7 +200,6 @@ libc_common_src_files := \
|
|||||||
bionic/realpath.c \
|
bionic/realpath.c \
|
||||||
bionic/reboot.c \
|
bionic/reboot.c \
|
||||||
bionic/recv.c \
|
bionic/recv.c \
|
||||||
bionic/sbrk.c \
|
|
||||||
bionic/sched_cpualloc.c \
|
bionic/sched_cpualloc.c \
|
||||||
bionic/sched_cpucount.c \
|
bionic/sched_cpucount.c \
|
||||||
bionic/sched_getaffinity.c \
|
bionic/sched_getaffinity.c \
|
||||||
@ -270,6 +268,7 @@ libc_common_src_files := \
|
|||||||
|
|
||||||
libc_bionic_src_files := \
|
libc_bionic_src_files := \
|
||||||
bionic/assert.cpp \
|
bionic/assert.cpp \
|
||||||
|
bionic/brk.cpp \
|
||||||
bionic/debug_format.cpp \
|
bionic/debug_format.cpp \
|
||||||
bionic/dirent.cpp \
|
bionic/dirent.cpp \
|
||||||
bionic/eventfd.cpp \
|
bionic/eventfd.cpp \
|
||||||
@ -282,6 +281,7 @@ libc_bionic_src_files := \
|
|||||||
bionic/__memset_chk.cpp \
|
bionic/__memset_chk.cpp \
|
||||||
bionic/pthread_sigmask.cpp \
|
bionic/pthread_sigmask.cpp \
|
||||||
bionic/raise.cpp \
|
bionic/raise.cpp \
|
||||||
|
bionic/sbrk.cpp \
|
||||||
bionic/__set_errno.cpp \
|
bionic/__set_errno.cpp \
|
||||||
bionic/setlocale.cpp \
|
bionic/setlocale.cpp \
|
||||||
bionic/signalfd.cpp \
|
bionic/signalfd.cpp \
|
||||||
|
@ -25,21 +25,17 @@
|
|||||||
* OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
|
* OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
|
||||||
* SUCH DAMAGE.
|
* SUCH DAMAGE.
|
||||||
*/
|
*/
|
||||||
#include <stddef.h>
|
|
||||||
#include <unistd.h>
|
#include <unistd.h>
|
||||||
#include <sys/types.h>
|
|
||||||
|
|
||||||
/* shared with sbrk.c */
|
/* Shared with sbrk.c. */
|
||||||
char *__bionic_brk;
|
extern "C" void* __bionic_brk; // TODO: should be __LIBC_HIDDEN__ but accidentally exported by NDK :-(
|
||||||
|
|
||||||
int brk(void* end_data)
|
|
||||||
{
|
|
||||||
char* new_brk = __brk( end_data );
|
|
||||||
|
|
||||||
if (new_brk != end_data)
|
|
||||||
return -1;
|
|
||||||
|
|
||||||
__bionic_brk = new_brk;
|
|
||||||
|
|
||||||
|
int brk(void* end_data) {
|
||||||
|
void* new_brk = __brk(end_data);
|
||||||
|
if (new_brk != end_data) {
|
||||||
|
return -1;
|
||||||
|
}
|
||||||
|
__bionic_brk = new_brk;
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
@ -25,36 +25,31 @@
|
|||||||
* OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
|
* OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
|
||||||
* SUCH DAMAGE.
|
* SUCH DAMAGE.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
#include <unistd.h>
|
#include <unistd.h>
|
||||||
#include <errno.h>
|
#include <errno.h>
|
||||||
|
|
||||||
|
/* Shared with brk.c. */
|
||||||
|
extern "C" {
|
||||||
|
void* __bionic_brk; // TODO: should be __LIBC_HIDDEN__ but accidentally exported by NDK :-(
|
||||||
|
}
|
||||||
|
|
||||||
#define SBRK_ALIGN 32
|
void* sbrk(ptrdiff_t increment) {
|
||||||
|
if (__bionic_brk == NULL) {
|
||||||
/* shared with brk() implementation */
|
__bionic_brk = __brk(NULL);
|
||||||
char* __bionic_brk;
|
|
||||||
|
|
||||||
void *sbrk(ptrdiff_t increment)
|
|
||||||
{
|
|
||||||
char* start;
|
|
||||||
char* end;
|
|
||||||
char* new_brk;
|
|
||||||
|
|
||||||
if ( !__bionic_brk)
|
|
||||||
__bionic_brk = __brk((void*)0);
|
|
||||||
|
|
||||||
start = (char*)(((long)__bionic_brk + SBRK_ALIGN-1) & ~(SBRK_ALIGN-1));
|
|
||||||
end = start + increment;
|
|
||||||
|
|
||||||
new_brk = __brk(end);
|
|
||||||
if (new_brk == (void*)-1)
|
|
||||||
return new_brk;
|
|
||||||
else if (new_brk < end)
|
|
||||||
{
|
|
||||||
errno = ENOMEM;
|
|
||||||
return (void*)-1;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
__bionic_brk = new_brk;
|
void* original_brk = __bionic_brk;
|
||||||
return start;
|
void* desired_brk = (void*) ((uintptr_t) original_brk + increment);
|
||||||
|
|
||||||
|
void* new_brk = __brk(desired_brk);
|
||||||
|
if (new_brk == (void*) -1) {
|
||||||
|
return new_brk;
|
||||||
|
} else if (new_brk < desired_brk) {
|
||||||
|
errno = ENOMEM;
|
||||||
|
return (void*) -1;
|
||||||
|
}
|
||||||
|
|
||||||
|
__bionic_brk = new_brk;
|
||||||
|
return original_brk;
|
||||||
}
|
}
|
@ -16,8 +16,19 @@
|
|||||||
|
|
||||||
#include <gtest/gtest.h>
|
#include <gtest/gtest.h>
|
||||||
|
|
||||||
|
#include <stdint.h>
|
||||||
#include <unistd.h>
|
#include <unistd.h>
|
||||||
|
|
||||||
TEST(unistd, sysconf_SC_MONOTONIC_CLOCK) {
|
TEST(unistd, sysconf_SC_MONOTONIC_CLOCK) {
|
||||||
ASSERT_GT(sysconf(_SC_MONOTONIC_CLOCK), 0);
|
ASSERT_GT(sysconf(_SC_MONOTONIC_CLOCK), 0);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
TEST(unistd, sbrk) {
|
||||||
|
void* initial_break = sbrk(0);
|
||||||
|
|
||||||
|
void* new_break = reinterpret_cast<void*>(reinterpret_cast<uintptr_t>(initial_break) + 2000);
|
||||||
|
ASSERT_EQ(0, brk(new_break));
|
||||||
|
|
||||||
|
void* final_break = sbrk(0);
|
||||||
|
ASSERT_EQ(final_break, new_break);
|
||||||
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user