2014-01-14 18:23:22 +01:00
|
|
|
/*-------------------------------------------------------------------------
|
|
|
|
*
|
|
|
|
* shm_mq.h
|
|
|
|
* single-reader, single-writer shared memory message queue
|
|
|
|
*
|
2015-01-06 17:43:47 +01:00
|
|
|
* Portions Copyright (c) 1996-2015, PostgreSQL Global Development Group
|
2014-01-14 18:23:22 +01:00
|
|
|
* Portions Copyright (c) 1994, Regents of the University of California
|
|
|
|
*
|
|
|
|
* src/include/storage/shm_mq.h
|
|
|
|
*
|
|
|
|
*-------------------------------------------------------------------------
|
|
|
|
*/
|
|
|
|
#ifndef SHM_MQ_H
|
|
|
|
#define SHM_MQ_H
|
|
|
|
|
|
|
|
#include "postmaster/bgworker.h"
|
|
|
|
#include "storage/dsm.h"
|
|
|
|
#include "storage/proc.h"
|
|
|
|
|
|
|
|
/* The queue itself, in shared memory. */
|
|
|
|
struct shm_mq;
|
|
|
|
typedef struct shm_mq shm_mq;
|
|
|
|
|
|
|
|
/* Backend-private state. */
|
|
|
|
struct shm_mq_handle;
|
|
|
|
typedef struct shm_mq_handle shm_mq_handle;
|
|
|
|
|
2014-10-08 20:35:43 +02:00
|
|
|
/* Descriptors for a single write spanning multiple locations. */
|
|
|
|
typedef struct
|
|
|
|
{
|
|
|
|
const char *data;
|
|
|
|
Size len;
|
|
|
|
} shm_mq_iovec;
|
|
|
|
|
2014-01-14 18:23:22 +01:00
|
|
|
/* Possible results of a send or receive operation. */
|
|
|
|
typedef enum
|
|
|
|
{
|
2014-05-06 18:12:18 +02:00
|
|
|
SHM_MQ_SUCCESS, /* Sent or received a message. */
|
|
|
|
SHM_MQ_WOULD_BLOCK, /* Not completed; retry later. */
|
|
|
|
SHM_MQ_DETACHED /* Other process has detached queue. */
|
2014-01-14 18:23:22 +01:00
|
|
|
} shm_mq_result;
|
|
|
|
|
|
|
|
/*
|
|
|
|
* Primitives to create a queue and set the sender and receiver.
|
|
|
|
*
|
|
|
|
* Both the sender and the receiver must be set before any messages are read
|
|
|
|
* or written, but they need not be set by the same process. Each must be
|
|
|
|
* set exactly once.
|
|
|
|
*/
|
|
|
|
extern shm_mq *shm_mq_create(void *address, Size size);
|
|
|
|
extern void shm_mq_set_receiver(shm_mq *mq, PGPROC *);
|
|
|
|
extern void shm_mq_set_sender(shm_mq *mq, PGPROC *);
|
|
|
|
|
|
|
|
/* Accessor methods for sender and receiver. */
|
|
|
|
extern PGPROC *shm_mq_get_receiver(shm_mq *);
|
|
|
|
extern PGPROC *shm_mq_get_sender(shm_mq *);
|
|
|
|
|
|
|
|
/* Set up backend-local queue state. */
|
|
|
|
extern shm_mq_handle *shm_mq_attach(shm_mq *mq, dsm_segment *seg,
|
|
|
|
BackgroundWorkerHandle *handle);
|
|
|
|
|
2014-10-08 20:35:43 +02:00
|
|
|
/* Associate worker handle with shm_mq. */
|
|
|
|
extern void shm_mq_set_handle(shm_mq_handle *, BackgroundWorkerHandle *);
|
|
|
|
|
2014-01-14 18:23:22 +01:00
|
|
|
/* Break connection. */
|
|
|
|
extern void shm_mq_detach(shm_mq *);
|
|
|
|
|
|
|
|
/* Send or receive messages. */
|
|
|
|
extern shm_mq_result shm_mq_send(shm_mq_handle *mqh,
|
2014-10-08 20:35:43 +02:00
|
|
|
Size nbytes, const void *data, bool nowait);
|
|
|
|
extern shm_mq_result shm_mq_sendv(shm_mq_handle *mqh,
|
|
|
|
shm_mq_iovec *iov, int iovcnt, bool nowait);
|
2014-01-14 18:23:22 +01:00
|
|
|
extern shm_mq_result shm_mq_receive(shm_mq_handle *mqh,
|
2014-03-18 16:19:13 +01:00
|
|
|
Size *nbytesp, void **datap, bool nowait);
|
2014-01-14 18:23:22 +01:00
|
|
|
|
|
|
|
/* Wait for our counterparty to attach to the queue. */
|
|
|
|
extern shm_mq_result shm_mq_wait_for_attach(shm_mq_handle *mqh);
|
|
|
|
|
|
|
|
/* Smallest possible queue. */
|
2014-01-18 21:29:45 +01:00
|
|
|
extern PGDLLIMPORT const Size shm_mq_minimum_size;
|
2014-01-14 18:23:22 +01:00
|
|
|
|
|
|
|
#endif /* SHM_MQ_H */
|