summaryrefslogtreecommitdiffhomepage
path: root/compat
diff options
context:
space:
mode:
Diffstat (limited to 'compat')
-rw-r--r--compat/shm.c150
-rw-r--r--compat/shm.cpp128
-rw-r--r--compat/shm.h87
-rw-r--r--compat/shm.hpp34
4 files changed, 142 insertions, 257 deletions
diff --git a/compat/shm.c b/compat/shm.c
deleted file mode 100644
index 95263a08..00000000
--- a/compat/shm.c
+++ /dev/null
@@ -1,150 +0,0 @@
-#define BUILD_SHM
-#include "shm.h"
-
-#ifdef SHM_WIN32
-
-#include <windows.h>
-
-SHM_FUN(void, init, const char* shm_name, const char* mutex_name, int map_size)
-{
- if (mutex_name != NULL)
- {
- self->mutex = CreateMutexA(NULL, false, mutex_name);
-
- if (!self->mutex)
- goto fail;
- }
-
- self->mapped_file = CreateFileMappingA(
- INVALID_HANDLE_VALUE,
- NULL,
- PAGE_READWRITE,
- 0,
- (unsigned)map_size,
- shm_name);
-
- if (!self->mapped_file)
- goto fail;
-
- self->mem = MapViewOfFile(self->mapped_file,
- FILE_MAP_WRITE,
- 0,
- 0,
- (unsigned) map_size);
-
- if (!self->mem)
- goto fail;
-
- return;
-
-fail:
- SHM_FUN_NAME(free)(self);
-}
-
-SHM_FUN0(void, free)
-{
- if (self->mem)
- (void) UnmapViewOfFile(self->mem);
-
- if (self->mapped_file)
- (void) CloseHandle(self->mapped_file);
-
- if (self->mutex)
- (void) CloseHandle(self->mutex);
-
- self->mem = NULL;
- self->mapped_file = NULL;
- self->mutex = NULL;
-}
-
-SHM_FUN0(void, lock)
-{
- if (self->mutex)
- (void)(WaitForSingleObject(self->mutex, INFINITE) == WAIT_OBJECT_0);
-}
-
-SHM_FUN0(void, unlock)
-{
- (void) ReleaseMutex(self->mutex);
-}
-
-SHM_FUN0(bool, success)
-{
- return self->mem != NULL;
-}
-
-#else
-
-#include <stdio.h>
-#include <string.h>
-#include <sys/file.h>
-#include <sys/mman.h>
-#include <fcntl.h>
-#include <limits.h>
-#include <unistd.h>
-#include <sys/types.h>
-#include <alloca.h>
-
-//#pragma GCC diagnostic ignored "-Wunused-result"
-
-SHM_FUN(void, init, const char *shm_name, const char* mutex_name, int map_size)
-{
- char* filename = alloca(strlen(shm_name)+2);
- (void)mutex_name;
-
- self->mem = (void*)-1;
- self->fd = -1;
- self->size = 0;
-
- if (map_size <= 0)
- goto fail;
-
- self->size = map_size;
- strcpy(filename, "/");
- strcat(filename, shm_name);
- self->fd = shm_open(filename, O_RDWR | O_CREAT, 0600);
- (void)ftruncate(self->fd, (off_t)map_size);
- self->mem = mmap(NULL, (size_t)map_size, PROT_READ|PROT_WRITE, MAP_SHARED, self->fd, (off_t)0);
-
- if (self->mem == (void*)-1)
- goto fail;
-
- return;
-
-fail:
- SHM_FUN_NAME(free)(self);
-}
-
-SHM_FUN0(void, free)
-{
- if (self->mem != (void*)-1)
- (void)munmap(self->mem, self->size);
- if (self->fd != -1)
- (void)close(self->fd);
-
- self->mem = (void*)-1;
- self->fd = -1;
- self->size = 0;
-}
-
-SHM_FUN0(void, lock)
-{
- flock(self->fd, LOCK_EX);
-}
-
-SHM_FUN0(void, unlock)
-{
- flock(self->fd, LOCK_UN);
-}
-
-SHM_FUN0(bool, success)
-{
- return self->mem != (void*) -1;
-}
-
-#endif
-
-SHM_FUN0(void*, ptr)
-{
- return self->mem;
-}
diff --git a/compat/shm.cpp b/compat/shm.cpp
index 265d8ff8..1f863190 100644
--- a/compat/shm.cpp
+++ b/compat/shm.cpp
@@ -5,37 +5,133 @@
* copyright notice and this permission notice appear in all copies.
*/
-#define BUILD_SHM
-#include "shm.hpp"
+#include "shm.h"
-SHMXX_TYPE_NAME& SHMXX_TYPE_NAME::operator=(SHMXX_TYPE_NAME&&) noexcept = default;
+#if defined _WIN32
-// NOLINTNEXTLINE(cppcoreguidelines-pro-type-member-init)
-SHMXX_TYPE_NAME::SHMXX_TYPE_NAME(const char* shm_name, const char* mutex_name, int map_size)
+#include <cstring>
+#include <cstdio>
+
+#include <accctrl.h>
+#include <aclapi.h>
+
+#ifdef QT_CORE_LIB
+# include <QDebug>
+# define warn(str, ...) (qDebug() << "shm:" str ": " << __VA_ARGS__)
+#else
+# define warn(str, ...) (void)0
+#endif
+
+shm_wrapper::shm_wrapper(const char* shm_name, const char* mutex_name, int map_size)
{
- SHM_FUN_NAME(init)(&impl, shm_name, mutex_name, map_size);
+ if (mutex_name == nullptr)
+ mutex = nullptr;
+ else
+ {
+ mutex = CreateMutexA(nullptr, false, mutex_name);
+
+ if (!mutex)
+ {
+ warn("CreateMutexA", (int) GetLastError());
+ return;
+ }
+ }
+
+ mapped_file = CreateFileMappingA(
+ INVALID_HANDLE_VALUE,
+ nullptr,
+ PAGE_READWRITE,
+ 0,
+ map_size,
+ shm_name);
+
+ if (!mapped_file)
+ {
+ warn("CreateFileMappingA", (int) GetLastError());
+
+ return;
+ }
+
+ mem = MapViewOfFile(mapped_file,
+ FILE_MAP_WRITE,
+ 0,
+ 0,
+ map_size);
+
+ if (!mem)
+ warn("MapViewOfFile:", (int) GetLastError());
}
-SHMXX_TYPE_NAME::~SHMXX_TYPE_NAME()
+shm_wrapper::~shm_wrapper()
{
- SHM_FUN_NAME(free)(&impl);
+ if (mem && !UnmapViewOfFile(mem))
+ goto fail;
+
+ if (mapped_file && !CloseHandle(mapped_file))
+ goto fail;
+
+ if (mutex && !CloseHandle(mutex))
+ goto fail;
+
+ return;
+
+fail:
+ warn("failed to close mapping", (int) GetLastError());
}
-bool SHMXX_TYPE_NAME::success() noexcept
+bool shm_wrapper::lock()
{
- return SHM_FUN_NAME(success)(&impl);
+ if (mutex)
+ return WaitForSingleObject(mutex, INFINITE) == WAIT_OBJECT_0;
+ else
+ return false;
}
-void SHMXX_TYPE_NAME::lock() noexcept
+
+bool shm_wrapper::unlock()
+{
+ if (mutex)
+ return ReleaseMutex(mutex);
+ else
+ return false;
+}
+#else
+
+#include <limits.h>
+
+#pragma GCC diagnostic ignored "-Wunused-result"
+shm_wrapper::shm_wrapper(const char *shm_name, const char* /*mutex_name*/, int map_size) : size(map_size)
+{
+ char filename[PATH_MAX+2] {};
+ strcpy(filename, "/");
+ strcat(filename, shm_name);
+ fd = shm_open(filename, O_RDWR | O_CREAT, 0600);
+ (void) ftruncate(fd, map_size);
+ mem = mmap(NULL, map_size, PROT_READ|PROT_WRITE, MAP_SHARED, fd, (off_t)0);
+}
+
+shm_wrapper::~shm_wrapper()
+{
+ (void) munmap(mem, size);
+ (void) close(fd);
+}
+
+bool shm_wrapper::lock()
{
- SHM_FUN_NAME(lock)(&impl);
+ return flock(fd, LOCK_EX) == 0;
}
-void SHMXX_TYPE_NAME::unlock() noexcept
+bool shm_wrapper::unlock()
{
- SHM_FUN_NAME(unlock)(&impl);
+ return flock(fd, LOCK_UN) == 0;
}
+#endif
-void* SHMXX_TYPE_NAME::ptr() noexcept
+bool shm_wrapper::success()
{
- return SHM_FUN_NAME(ptr)(&impl);
+#ifndef _WIN32
+ return mem != (void*) -1;
+#else
+ return mem != nullptr;
+#endif
}
+
diff --git a/compat/shm.h b/compat/shm.h
index 856b9c8c..814ce90c 100644
--- a/compat/shm.h
+++ b/compat/shm.h
@@ -1,68 +1,41 @@
-#ifndef SHM_HEADER_GUARD
-#define SHM_HEADER_GUARD
+/* Copyright (c) 2013 Stanislaw Halik <sthalik@misaki.pl>
-#include "macros1.h"
+ * Permission to use, copy, modify, and/or distribute this software for any
+ * purpose with or without fee is hereby granted, provided that the above
+ * copyright notice and this permission notice appear in all copies.
+ */
+#pragma once
-#ifndef SHM_WIN32_INIT
-# ifdef _WIN32
-# define SHM_WIN32
-# else
-# undef SHM_WIN32
-# endif
+#if defined(_WIN32)
+#include <windows.h>
#else
-# if SHM_WIN32_INIT
-# define SHM_WIN32
-# else
-# undef SHM_WIN32
-# endif
+#include <stdio.h>
+#include <string.h>
+#include <sys/file.h>
+#include <sys/mman.h>
+#include <fcntl.h>
+#include <limits.h>
+#include <unistd.h>
+#include <sys/types.h>
#endif
-#ifndef SHM_TYPE_NAME
-# define SHM_TYPE_NAME shm_mem_impl
-#endif
-
-#ifndef SHM_FUN_PREFIX
-# define SHM_FUN_PREFIX shm_mem_impl_
-#endif
-
-#ifndef SHM_EXPORT
-# define SHM_EXPORT
-#endif
-
-#ifndef __cplusplus
-# define SHM_EXTERN
-# include <stdbool.h>
-struct SHM_TYPE_NAME;
-typedef struct SHM_TYPE_NAME SHM_TYPE_NAME;
-#else
-# define SHM_EXTERN extern "C"
-#endif
+#include "macros.hpp"
+#include "export.hpp"
-struct SHM_TYPE_NAME {
+class OTR_COMPAT_EXPORT shm_wrapper final
+{
void* mem;
-#ifdef SHM_WIN32
- void* mutex;
- void* mapped_file;
+#if defined(_WIN32)
+ HANDLE mutex, mapped_file;
#else
int fd, size;
#endif
-};
-
-#define SHM_FUN_NAME(f) PP_CAT(SHM_FUN_PREFIX, f)
-#define SHM_FUN_(r, f)SHM_EXTERN SHM_EXPORT r SHM_FUN_NAME(f)
-#define SHM_FUN(r, f, ...) SHM_FUN_(r, f)(SHM_TYPE_NAME* self, __VA_ARGS__)
-#define SHM_FUN0(r, f) SHM_FUN_(r, f)(SHM_TYPE_NAME* self)
-
-SHM_FUN(void, init, const char* shm_name, const char* mutex_name, int map_size);
-SHM_FUN0(void, free);
-SHM_FUN0(void, lock);
-SHM_FUN0(void, unlock);
-SHM_FUN0(void*,ptr);
-SHM_FUN0(bool, success);
-#ifndef BUILD_SHM
-# undef SHM_FUN
-# undef SHM_FUN_NAME
-#endif
-
-#endif // SHM_HEADER_GUARD
+public:
+ cc_noinline shm_wrapper(const char *shm_name, const char *mutex_name, int map_size);
+ cc_noinline ~shm_wrapper();
+ cc_noinline bool lock();
+ cc_noinline bool unlock();
+ cc_noinline bool success();
+ inline void* ptr() { return mem; }
+};
diff --git a/compat/shm.hpp b/compat/shm.hpp
deleted file mode 100644
index 428764e4..00000000
--- a/compat/shm.hpp
+++ /dev/null
@@ -1,34 +0,0 @@
-/* Copyright (c) 2013 Stanislaw Halik <sthalik@misaki.pl>
-
- * Permission to use, copy, modify, and/or distribute this software for any
- * purpose with or without fee is hereby granted, provided that the above
- * copyright notice and this permission notice appear in all copies.
- */
-#ifndef SHMXX_HEADER_GUARD
-#define SHMXX_HEADER_GUARD
-
-#include "export.hpp"
-#include "shm.h"
-
-#ifndef SHMXX_TYPE_NAME
-# define SHMXX_TYPE_NAME mem
-#endif
-
-class OTR_COMPAT_EXPORT SHMXX_TYPE_NAME final
-{
- SHM_TYPE_NAME impl;
-
-public:
- SHMXX_TYPE_NAME(const char* shm_name, const char* mutex_name, int map_size);
- ~SHMXX_TYPE_NAME();
-
- bool success() noexcept;
- void* ptr() noexcept;
- void lock() noexcept;
- void unlock() noexcept;
-
- SHMXX_TYPE_NAME& operator=(const SHMXX_TYPE_NAME&) = delete;
- SHMXX_TYPE_NAME& operator=(SHMXX_TYPE_NAME&&) noexcept;
-};
-
-#endif // SHMXX_HEADER_GUARD