From 128724d147a0079952275e1bbce48a7e2a0522ab Mon Sep 17 00:00:00 2001 From: ptitSeb Date: Fri, 2 Apr 2021 13:38:23 +0200 Subject: Implemented a workaround for mmap64 with MAP_32BIT flag --- src/wrapped/wrappedlibc.c | 7 +++++++ 1 file changed, 7 insertions(+) (limited to 'src/wrapped') diff --git a/src/wrapped/wrappedlibc.c b/src/wrapped/wrappedlibc.c index 756a8ee8..fa021802 100755 --- a/src/wrapped/wrappedlibc.c +++ b/src/wrapped/wrappedlibc.c @@ -1887,6 +1887,13 @@ EXPORT void* my_mmap64(x64emu_t* emu, void *addr, unsigned long length, int prot if(prot&PROT_WRITE) prot|=PROT_READ; // PROT_READ is implicit with PROT_WRITE on i386 if(box64_log", addr, length, prot, flags, fd, offset);} + #ifndef NOALIGN + if(!addr && (flags&0x40)) { + // 0x40 is MAP_32BIT, wich only exist on x86_64! + //flags &= ~0x40; // let the flags in? + addr = find32bitBlock(length); + } + #endif void* ret = mmap64(addr, length, prot, flags, fd, offset); if(box64_log