2010-02-27 23:57:03 -08:00
|
|
|
#ifdef HAVE_CONFIG_H
|
|
|
|
# include "config.h"
|
|
|
|
#endif /* HAVE_CONFIG_H */
|
|
|
|
|
2012-02-17 12:48:11 -08:00
|
|
|
#include <stdlib.h>
|
2008-06-08 14:39:49 -07:00
|
|
|
#include <stdio.h>
|
2008-02-27 13:01:30 -08:00
|
|
|
#include <sys/types.h>
|
2015-11-11 06:04:37 -08:00
|
|
|
#include <unistd.h>
|
2008-02-27 13:01:30 -08:00
|
|
|
|
2012-02-17 12:48:11 -08:00
|
|
|
#ifndef WIN32_LEAN_AND_MEAN
|
|
|
|
# define WIN32_LEAN_AND_MEAN
|
|
|
|
#endif
|
2008-02-27 13:01:30 -08:00
|
|
|
#include <windows.h>
|
|
|
|
#undef WIN32_LEAN_AND_MEAN
|
|
|
|
|
2015-11-11 06:04:37 -08:00
|
|
|
#include <io.h>
|
2008-02-27 13:01:30 -08:00
|
|
|
|
2012-02-17 12:48:11 -08:00
|
|
|
#include "evil_macro.h"
|
2008-04-26 09:27:46 -07:00
|
|
|
#include "sys/mman.h"
|
2012-02-17 12:48:11 -08:00
|
|
|
#include "evil_util.h"
|
|
|
|
#include "evil_private.h"
|
2008-04-26 09:27:46 -07:00
|
|
|
|
2008-02-27 13:01:30 -08:00
|
|
|
|
2008-06-08 14:39:49 -07:00
|
|
|
/***** API *****/
|
|
|
|
|
|
|
|
|
2008-02-27 13:01:30 -08:00
|
|
|
void *
|
2012-10-05 13:09:47 -07:00
|
|
|
mmap(void *addr EVIL_UNUSED,
|
2008-02-27 13:01:30 -08:00
|
|
|
size_t len,
|
|
|
|
int prot,
|
|
|
|
int flags,
|
|
|
|
int fd,
|
|
|
|
off_t offset)
|
|
|
|
{
|
2014-07-13 01:59:40 -07:00
|
|
|
HANDLE fm;
|
|
|
|
DWORD protect = PAGE_NOACCESS;
|
|
|
|
DWORD acs = 0;
|
|
|
|
HANDLE handle;
|
|
|
|
void *data;
|
2008-06-08 14:39:49 -07:00
|
|
|
|
2014-07-13 01:59:40 -07:00
|
|
|
/* support only MAP_SHARED */
|
|
|
|
if (!(flags & MAP_SHARED))
|
|
|
|
return MAP_FAILED;
|
2008-02-27 13:01:30 -08:00
|
|
|
|
2014-07-13 01:59:40 -07:00
|
|
|
if (prot & PROT_EXEC)
|
2008-02-27 13:01:30 -08:00
|
|
|
{
|
2014-07-13 01:59:40 -07:00
|
|
|
if (prot & PROT_READ)
|
2008-02-27 13:01:30 -08:00
|
|
|
{
|
2014-07-13 01:59:40 -07:00
|
|
|
if (prot & PROT_WRITE)
|
|
|
|
protect = PAGE_EXECUTE_READWRITE;
|
|
|
|
else
|
|
|
|
protect = PAGE_EXECUTE_READ;
|
2008-06-08 14:39:49 -07:00
|
|
|
}
|
2014-07-13 01:59:40 -07:00
|
|
|
else
|
2008-06-08 14:39:49 -07:00
|
|
|
{
|
2014-07-13 01:59:40 -07:00
|
|
|
if (prot & PROT_WRITE)
|
|
|
|
protect = PAGE_EXECUTE_WRITECOPY;
|
|
|
|
else
|
|
|
|
protect = PAGE_EXECUTE;
|
2008-02-27 13:01:30 -08:00
|
|
|
}
|
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
2014-07-13 01:59:40 -07:00
|
|
|
if (prot & PROT_READ)
|
2008-02-27 13:01:30 -08:00
|
|
|
{
|
2014-07-13 01:59:40 -07:00
|
|
|
if (prot & PROT_WRITE)
|
|
|
|
protect = PAGE_READWRITE;
|
2008-02-27 13:01:30 -08:00
|
|
|
else
|
2014-07-13 01:59:40 -07:00
|
|
|
protect = PAGE_READONLY;
|
2008-06-08 14:39:49 -07:00
|
|
|
}
|
2014-07-13 01:59:40 -07:00
|
|
|
else if (prot & PROT_WRITE)
|
|
|
|
protect = PAGE_WRITECOPY;
|
|
|
|
}
|
2008-06-08 14:39:49 -07:00
|
|
|
|
2014-07-13 01:59:40 -07:00
|
|
|
handle = (HANDLE)_get_osfhandle(fd);
|
|
|
|
if (handle == INVALID_HANDLE_VALUE)
|
|
|
|
{
|
|
|
|
fprintf(stderr, "[Evil] [mmap] _get_osfhandle failed\n");
|
2008-06-08 14:39:49 -07:00
|
|
|
|
2014-07-13 01:59:40 -07:00
|
|
|
return MAP_FAILED;
|
|
|
|
}
|
2008-06-08 14:39:49 -07:00
|
|
|
|
2014-07-13 01:59:40 -07:00
|
|
|
fm = CreateFileMapping(handle, NULL, protect, 0, 0, NULL);
|
|
|
|
if (!fm)
|
|
|
|
{
|
|
|
|
char *str;
|
2008-06-08 14:39:49 -07:00
|
|
|
|
2014-07-13 01:59:40 -07:00
|
|
|
str = evil_last_error_get();
|
|
|
|
fprintf(stderr, "[Evil] [mmap] CreateFileMapping failed: %s\n", str);
|
|
|
|
free(str);
|
2008-06-08 14:39:49 -07:00
|
|
|
|
2014-07-13 01:59:40 -07:00
|
|
|
return MAP_FAILED;
|
|
|
|
}
|
2008-02-27 13:01:30 -08:00
|
|
|
|
2014-07-13 01:59:40 -07:00
|
|
|
if ((protect & PAGE_READWRITE) == PAGE_READWRITE)
|
|
|
|
acs = FILE_MAP_ALL_ACCESS;
|
|
|
|
else if ((protect & PAGE_WRITECOPY) == PAGE_WRITECOPY)
|
|
|
|
acs = FILE_MAP_COPY;
|
2008-02-27 13:01:30 -08:00
|
|
|
#if 0
|
2014-07-13 01:59:40 -07:00
|
|
|
if (protect & (PAGE_EXECUTE_READWRITE | PAGE_EXECUTE_READ))
|
|
|
|
acs = FILE_MAP_EXECUTE;
|
2008-02-27 13:01:30 -08:00
|
|
|
#endif
|
2015-03-20 00:16:20 -07:00
|
|
|
else if (protect & (PAGE_READWRITE | PAGE_READONLY))
|
2014-07-13 01:59:40 -07:00
|
|
|
acs = FILE_MAP_READ;
|
|
|
|
else
|
|
|
|
{
|
|
|
|
if ((protect & PAGE_WRITECOPY) == PAGE_WRITECOPY)
|
|
|
|
acs = FILE_MAP_WRITE;
|
|
|
|
}
|
2008-02-27 13:01:30 -08:00
|
|
|
|
2014-07-13 01:59:40 -07:00
|
|
|
data = MapViewOfFile(fm,
|
|
|
|
acs,
|
|
|
|
offset & 0xffff0000,
|
|
|
|
offset & 0x0000ffff,
|
|
|
|
len);
|
|
|
|
CloseHandle(fm);
|
2008-06-08 14:39:49 -07:00
|
|
|
|
2014-07-13 01:59:40 -07:00
|
|
|
if (!data)
|
|
|
|
{
|
|
|
|
char *str;
|
2008-06-08 14:39:49 -07:00
|
|
|
|
2014-07-13 01:59:40 -07:00
|
|
|
str = evil_last_error_get();
|
|
|
|
fprintf(stderr, "[Evil] [mmap] MapViewOfFile failed: %s\n", str);
|
|
|
|
free(str);
|
2008-06-08 14:39:49 -07:00
|
|
|
|
2014-07-13 01:59:40 -07:00
|
|
|
return MAP_FAILED;
|
2008-06-09 11:35:49 -07:00
|
|
|
}
|
2014-07-13 01:59:40 -07:00
|
|
|
|
|
|
|
return data;
|
2008-02-27 13:01:30 -08:00
|
|
|
}
|
|
|
|
|
|
|
|
int
|
|
|
|
munmap(void *addr,
|
2012-10-05 13:09:47 -07:00
|
|
|
size_t len EVIL_UNUSED)
|
2008-02-27 13:01:30 -08:00
|
|
|
{
|
2014-07-13 01:59:40 -07:00
|
|
|
BOOL res;
|
2008-02-27 13:01:30 -08:00
|
|
|
|
2014-07-13 01:59:40 -07:00
|
|
|
res = UnmapViewOfFile(addr);
|
|
|
|
if (!res)
|
2008-06-08 14:39:49 -07:00
|
|
|
{
|
|
|
|
char *str;
|
2008-02-27 13:01:30 -08:00
|
|
|
|
2008-06-08 14:39:49 -07:00
|
|
|
str = evil_last_error_get();
|
2014-07-13 01:59:40 -07:00
|
|
|
fprintf(stderr, "[Evil] [munmap] UnmapViewOfFile failed: %s\n", str);
|
2008-06-08 14:39:49 -07:00
|
|
|
free(str);
|
|
|
|
}
|
|
|
|
|
2014-07-13 01:59:40 -07:00
|
|
|
return (res == 0) ? -1 : 0;
|
2008-02-27 13:01:30 -08:00
|
|
|
}
|