#ifndef __SHM_SOCKET_H__
|
#define __SHM_SOCKET_H__
|
|
#include "usg_common.h"
|
#include "usg_typedef.h"
|
#include "shm_queue.h"
|
#include "shm_allocator.h"
|
|
#include "mem_pool.h"
|
#include "hashtable.h"
|
#include "sem_util.h"
|
|
#ifdef __cplusplus
|
extern "C" {
|
#endif
|
|
enum shm_msg_type_t
|
{
|
SHM_SOCKET_OPEN = 1,
|
SHM_SOCKET_OPEN_REPLY = 2,
|
SHM_SOCKET_CLOSE = 3,
|
SHM_COMMON_MSG = 4
|
|
};
|
|
enum shm_connection_status_t {
|
SHM_CONN_CLOSED=1,
|
SHM_CONN_LISTEN=2,
|
SHM_CONN_ESTABLISHED=3
|
};
|
|
typedef struct shm_msg_t {
|
int port;
|
shm_msg_type_t type;
|
size_t size;
|
void * buf;
|
|
} shm_msg_t;
|
|
|
typedef struct shm_socket_t {
|
// 本地port
|
int port;
|
shm_connection_status_t status;
|
SHMQueue<shm_msg_t> *queue;
|
SHMQueue<shm_msg_t> *remoteQueue;
|
LockFreeQueue<shm_msg_t, DM_Allocator> *messageQueue;
|
LockFreeQueue<shm_msg_t, DM_Allocator> *acceptQueue;
|
std::map<int, shm_socket_t* > *clientSocketMap;
|
pthread_t dispatch_thread;
|
|
} shm_socket_t;
|
|
|
/**
|
* 初始化共享内存
|
* @size 共享内存大小, 单位M
|
*
|
*/
|
void shm_init(int size);
|
|
/**
|
* 销毁共享内存
|
* 整个进程退出时需要执行这个方法,该方法首先会检查是否还有其他进程在使用该共享内存,如果还有其他进程在使用就只是detach,如果没有其他进程在使用则销毁整块内存。
|
*/
|
void shm_destroy();
|
|
/**
|
* 释放recv方法分配的buf
|
*/
|
void shm_free(void *buf);
|
|
shm_socket_t *shm_open_socket();
|
|
|
int shm_close_socket(shm_socket_t * socket) ;
|
|
|
int shm_soket_bind(shm_socket_t * socket, int port) ;
|
|
int shm_listen(shm_socket_t * socket) ;
|
|
shm_socket_t* shm_accept(shm_socket_t* socket);
|
|
int shm_connect(shm_socket_t * socket, int port);
|
|
int shm_send(shm_socket_t * socket, const void *buf, const int size) ;
|
|
int shm_recv(shm_socket_t * socket, void **buf, int *size) ;
|
|
|
|
#ifdef __cplusplus
|
}
|
#endif
|
|
#endif
|