summaryrefslogtreecommitdiff
path: root/src/logic/pe_image_raw_data.c
diff options
context:
space:
mode:
authormidipix <writeonce@midipix.org>2025-05-30 23:37:19 +0000
committermidipix <writeonce@midipix.org>2025-05-30 23:44:13 +0000
commita7c63916dcd5b63b7965174af87d0edb55bd6194 (patch)
tree3c021a0a151950c30c76c0ebdb9e15487e29d992 /src/logic/pe_image_raw_data.c
parent57ddbe03f41c4fc4686f92734b2aa3a56392815a (diff)
downloadperk-a7c63916dcd5b63b7965174af87d0edb55bd6194.tar.bz2
perk-a7c63916dcd5b63b7965174af87d0edb55bd6194.tar.xz
library api: _raw_ (raw image api) namespace overhaul.
Diffstat (limited to 'src/logic/pe_image_raw_data.c')
-rw-r--r--src/logic/pe_image_raw_data.c66
1 files changed, 66 insertions, 0 deletions
diff --git a/src/logic/pe_image_raw_data.c b/src/logic/pe_image_raw_data.c
new file mode 100644
index 0000000..7ab6da6
--- /dev/null
+++ b/src/logic/pe_image_raw_data.c
@@ -0,0 +1,66 @@
+/***************************************************************/
+/* perk: PE Resource Kit */
+/* Copyright (C) 2015--2021 SysDeer Technologies, LLC */
+/* Released under GPLv2 and GPLv3; see COPYING.PERK. */
+/***************************************************************/
+
+#include <stdint.h>
+#include <stdbool.h>
+#include <unistd.h>
+#include <fcntl.h>
+#include <sys/mman.h>
+#include <sys/types.h>
+#include <sys/stat.h>
+
+#include <perk/perk.h>
+#include "perk_driver_impl.h"
+#include "perk_errinfo_impl.h"
+
+int pe_raw_map_raw_image(
+ const struct pe_driver_ctx * dctx,
+ int fd,
+ const char * path,
+ int prot,
+ struct pe_raw_image * map)
+{
+ int ret;
+ struct stat st;
+ bool fnew;
+ int fdcwd;
+
+ fdcwd = pe_driver_fdcwd(dctx);
+
+ if ((fnew = (fd < 0)))
+ fd = openat(fdcwd,path,O_RDONLY | O_CLOEXEC);
+
+ if (fd < 0)
+ return PERK_SYSTEM_ERROR(dctx);
+
+ if ((ret = fstat(fd,&st) < 0) && fnew)
+ close(fd);
+
+ else if ((st.st_size == 0) && fnew)
+ close(fd);
+
+ if (ret < 0)
+ return PERK_SYSTEM_ERROR(dctx);
+
+ else if (st.st_size == 0)
+ return PERK_CUSTOM_ERROR(
+ dctx,PERK_ERR_IMAGE_SIZE_ZERO);
+
+ map->map_size = st.st_size;
+ map->map_addr = mmap(0,map->map_size,prot,MAP_PRIVATE,fd,0);
+
+ if (fnew)
+ close(fd);
+
+ return (map->map_addr == MAP_FAILED)
+ ? PERK_SYSTEM_ERROR(dctx)
+ : 0;
+}
+
+int pe_raw_unmap_raw_image(struct pe_raw_image * map)
+{
+ return munmap(map->map_addr,map->map_size);
+}