3 #include "Arp/System/Core/TypeName.hxx"
4 #include "Arp/System/Core/AppDomainSingleton.hxx"
5 #include "Arp/System/Commons/Logging.h"
6 #include "Arp/System/Commons/Threading/Thread.hpp"
7 #include "boost/interprocess/managed_shared_memory.hpp"
12 namespace Arp {
namespace System {
namespace Commons {
namespace Ipc
20 typedef boost::interprocess::managed_shared_memory SharedMemoryImpl;
21 typedef SharedMemoryImpl::segment_manager SegmentManager;
22 typedef boost::interprocess::permissions SharedMemoryPermission;
26 using Ptr = boost::interprocess::offset_ptr<T>;
87 template<
class T,
typename ...TArgs>
96 template<
class T,
typename ...TArgs>
104 template<
class T,
typename ...TArgs>
111 void Destroy(
const char* name);
182 template<
class T,
typename ...TArgs>
186 Ptr<T> result = Get<T>(name);
190 return Construct<T>(name, args...);
195 template<
class T,
typename ...TArgs>
201 template<
class T,
typename ...TArgs>
207 return new (pResult) T(args...);
213 Ptr<T> pValue = this->Get<T>(name);
214 if(pValue !=
nullptr)
225 (void)boost::interprocess::shared_memory_object::remove(this->
GetName());
API to manage and manipulate memory shared between different processes
Definition: SharedMemory.hpp:17
byte * Allocate(size_t size)
Tries to allocate size amount of bytes in the memory.
Definition: SharedMemory.hpp:166
Arp::String memoryName
Name of memory identifying the shared memory inside the operating system.
Definition: SharedMemory.hpp:138
void ZeroFreeMemory(void)
Writes zero in all bytes not yet allocated.
Definition: SharedMemory.hpp:233
Ptr< T > Get(const char *name)
Tries to find a previously allocated named object.
Definition: SharedMemory.hpp:177
SharedMemoryImpl sharedMemoryImpl
Actual implementation of the shared memory functionality.
Definition: SharedMemory.hpp:141
boost::interprocess::offset_ptr< T > Ptr
Returned pointer types are shared memory based offset pointer.
Definition: SharedMemory.hpp:26
Ptr< T > GetOrConstruct(const char *name, TArgs... args)
Tries to find object identified by name, creates a new one if the object does not exists yet.
Definition: SharedMemory.hpp:183
void Deallocate(byte *pMemory)
Marks the memory pointed to by pMemory available for new allocation requests.
Definition: SharedMemory.hpp:171
bool AllMemoryDeallocated(void)
Checks if all memory has been deallocated.
Definition: SharedMemory.hpp:238
SharedMemory(const char *name)
Opens an existing shared memory.
Definition: SharedMemory.hpp:150
size_t GetSize(void) const
Returns the capacity of the shared memory in bytes.
Definition: SharedMemory.hpp:161
~SharedMemory(void)=default
Deallocates the memory for this management object but not the memory shared between processes.
void Destroy(const char *name)
Deallocates the object in the shared memory, also calling the objects destructor.
Definition: SharedMemory.hpp:211
size_t GetFreeMemory(void) const
Obtain the number of free bytes in the shared memory.
Definition: SharedMemory.hpp:228
SharedMemory(const char *name, size_t memorySize)
Creates an non-existing instance, throws if yet exists.
const Arp::String & GetName(void) const
Returns the name of the memory object.
Definition: SharedMemory.hpp:156
void Remove(void)
Removes the shared memory from the system.
Definition: SharedMemory.hpp:223
Ptr< T > Construct(const char *name, TArgs... args)
Creates a named object in the shared memory.
Definition: SharedMemory.hpp:196
bool CheckSanity(void)
Performs a sanity check over the shared memory.
Definition: SharedMemory.hpp:243
Ptr< T > ConstructUnnamed(TArgs... args)
Creates an unnamed object in the shared memory.
Definition: SharedMemory.hpp:202
@ System
System components used by the System, Device, Plc or Io domains.
Root namespace for the PLCnext API