From bbf9e9debd761b5c5024d8417ad38e1cadc70d5b Mon Sep 17 00:00:00 2001 From: midipix Date: Sat, 21 Nov 2015 21:17:19 -0500 Subject: driver integration 1/9: remove old (ad-hoc) driver, prepare source tree. --- src/logic/pe_map_raw_image.c | 40 ++++++++++++++++++++++++++++++++++++++++ 1 file changed, 40 insertions(+) create mode 100644 src/logic/pe_map_raw_image.c (limited to 'src/logic/pe_map_raw_image.c') diff --git a/src/logic/pe_map_raw_image.c b/src/logic/pe_map_raw_image.c new file mode 100644 index 0000000..caf14b9 --- /dev/null +++ b/src/logic/pe_map_raw_image.c @@ -0,0 +1,40 @@ +#include +#include +#include +#include +#include +#include +#include +#include + +#include + +int pe_map_raw_image (int fd, const char * fname, int prot, struct pe_raw_image * map) +{ + struct stat stat; + int nfd, ret; + + if ((nfd = !fd)) + fd = open(fname,O_RDONLY | O_CLOEXEC); + + if ((fd < 0) || (fstat(fd,&stat) < 0)) + return errno; + + map->size = stat.st_size; + map->addr = mmap(0,map->size,prot,MAP_PRIVATE,fd,0); + + if (map->addr == MAP_FAILED) { + map->addr = 0; + ret = PERK_MAP_ERROR; + } else + ret = 0; + + if (nfd) close(fd); + + return ret; +} + +int pe_unmap_raw_image (struct pe_raw_image * map) +{ + return munmap(map->addr, map->size); +} -- cgit v1.2.3