summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--mem.c31
1 files changed, 9 insertions, 22 deletions
diff --git a/mem.c b/mem.c
index d019c6f..cb3a047 100644
--- a/mem.c
+++ b/mem.c
@@ -8,33 +8,20 @@
#include <stdint.h>
#include <stdlib.h>
#include <unistd.h>
+
#include "mem.h"
+#ifndef MAP_ANONYMOUS
+#define MAP_ANONYMOUS MAP_ANON
+#endif
-/*
void * alloc_code(size_t *size)
{
+ //start at the 1GB mark to allow plenty of room for sbrk based malloc implementations
+ //while still keeping well within 32-bit displacement range for calling code compiled into the executable
+ static uint8_t *next = (uint8_t *)0x40000000;
*size += PAGE_SIZE - (*size & (PAGE_SIZE - 1));
- return mmap(NULL, *size, PROT_EXEC | PROT_READ | PROT_WRITE, MAP_PRIVATE | MAP_ANONYMOUS, -1, 0);
-}
-*/
-
-/*
-void * alloc_code(size_t *size)
-{
- char * ret = malloc(*size);
- char * base = (char *)(((intptr_t)ret) & (~(PAGE_SIZE-1)));
- mprotect(base, (ret + *size) - base, PROT_EXEC | PROT_READ | PROT_WRITE);
+ uint8_t *ret = mmap(NULL, *size, PROT_EXEC | PROT_READ | PROT_WRITE, MAP_PRIVATE | MAP_ANONYMOUS, -1, 0);
+ next = ret + *size;
return ret;
}
-*/
-void * alloc_code(size_t *size)
-{
- *size += PAGE_SIZE - (*size & (PAGE_SIZE - 1));
- void * ret = sbrk(*size);
- if (ret == ((void *)-1)) {
- return NULL;
- }
- mprotect(ret, *size, PROT_EXEC | PROT_READ | PROT_WRITE);
- return ret;
-}