This class defines a shared-memory region between a master process and one or more child processes Region has three data structures:
More...
#include <tunneldef.h>
|
| TunnelDef (size_t numBuffers, size_t bufferSize, uint32_t expectedChildren) |
| Create a new tunnel. More...
|
|
| TunnelDef (void *sPtr) |
| Access an existing tunnel Child creates the TunnelDef, reads the shmSize, and then resizes its map accordingly. More...
|
|
uint32_t | initialize (void *sPtr) |
| Finish setting up a tunnel once the manager knows the correct size of the tunnel and has mmap'd a large enough region for it. More...
|
|
virtual | ~TunnelDef () |
| Destructor.
|
|
void | shutdown () |
| Clean up a region.
|
|
size_t | getTunnelSize () |
| return size of tunnel
|
|
ShareDataType * | getSharedData () |
| return a pointer to the ShareDataType region
|
|
void | writeMessage (size_t buffer, const MsgType &command) |
| Write data to buffer, blocks until space is available. More...
|
|
MsgType | readMessage (size_t buffer) |
| Read data from buffer, blocks until message received. More...
|
|
bool | readMessageNB (size_t buffer, MsgType *result) |
| Read data from buffer, non-blocking. More...
|
|
void | clearBuffer (size_t buffer) |
| Empty the messages in a buffer. More...
|
|
bool | isMaster () |
| return whether this is a master-side tunnel or a child
|
|
|
ShareDataType * | sharedData |
| Pointer to the Shared Data Region.
|
|
template<typename ShareDataType, typename MsgType>
class SST::Core::Interprocess::TunnelDef< ShareDataType, MsgType >
This class defines a shared-memory region between a master process and one or more child processes Region has three data structures:
- internal bookkeeping (InternalSharedData),
- user defined shared data (ShareDataType)
- multiple circular-buffer queues with entries of type MsgType
- Template Parameters
-
ShareDataType | Type to put in the shared data region |
MsgType | Type of messages being sent in the circular buffers |
◆ TunnelDef() [1/2]
template<typename ShareDataType , typename MsgType >
Create a new tunnel.
- Parameters
-
numBuffers | Number of buffers for which we should tunnel |
bufferSize | How large each buffer should be |
expectedChildren | Number of child processes that will connect to this tunnel |
◆ TunnelDef() [2/2]
template<typename ShareDataType , typename MsgType >
Access an existing tunnel Child creates the TunnelDef, reads the shmSize, and then resizes its map accordingly.
- Parameters
-
sPtr | Location of shared memory region |
◆ clearBuffer()
template<typename ShareDataType , typename MsgType >
Empty the messages in a buffer.
- Parameters
-
buffer | which buffer to empty |
◆ initialize()
template<typename ShareDataType , typename MsgType >
◆ readMessage()
template<typename ShareDataType , typename MsgType >
Read data from buffer, blocks until message received.
- Parameters
-
buffer | which buffer to read from return the message |
◆ readMessageNB()
template<typename ShareDataType , typename MsgType >
Read data from buffer, non-blocking.
- Parameters
-
buffer | which buffer to read from |
result | pointer to return read message at return whether a message was read |
◆ writeMessage()
template<typename ShareDataType , typename MsgType >
Write data to buffer, blocks until space is available.
- Parameters
-
buffer | which buffer index to write to |
command | message to write to buffer |
The documentation for this class was generated from the following file: