From 14c345b38d57fd814f217eb8465963a08ca79f7e Mon Sep 17 00:00:00 2001
From: wangzhengquan <wangzhengquan85@126.com>
Date: 星期五, 05 二月 2021 17:41:09 +0800
Subject: [PATCH] update

---
 src/socket/shm_socket.h |   90 ++++++++++++++++-----------------------------
 1 files changed, 32 insertions(+), 58 deletions(-)

diff --git a/src/socket/shm_socket.h b/src/socket/shm_socket.h
index cf6737f..516a343 100644
--- a/src/socket/shm_socket.h
+++ b/src/socket/shm_socket.h
@@ -4,25 +4,8 @@
 #include "usg_common.h"
 #include "usg_typedef.h"
 #include "shm_queue.h"
-
-enum shm_socket_flag_t
-{
-  SHM_MSG_TIMEOUT = 1,
-  SHM_MSG_NOWAIT = 2
-};
-
-
-
-enum shm_socket_error_type_t {
-	SHM_SOCKET_ECONNFAILED = 1,
-	SHM_SOCKET_ETIMEOUT = 2	
-};
-
-enum shm_connection_status_t {
-	SHM_CONN_CLOSED=1,
-	SHM_CONN_LISTEN=2,
-	SHM_CONN_ESTABLISHED=3
-};
+#include "lock_free_queue.h"
+#include <functional>
 
 enum shm_socket_type_t
 {
@@ -30,23 +13,18 @@
 	SHM_SOCKET_DGRAM = 2
 	
 };
+ 
 
-enum shm_msg_type_t
-{
-	SHM_SOCKET_OPEN = 1,
-	SHM_SOCKET_OPEN_REPLY = 2,
-	SHM_SOCKET_CLOSE = 3,
-	SHM_COMMON_MSG = 4
-	
-};
+#define BUS_ACTION_STOP 1 
 
-typedef struct shm_msg_t {
+typedef struct shm_packet_t {
 	int key;
-	shm_msg_type_t type;
 	size_t size;
 	void * buf;
+	char uuid[64];
+	int action;
 
-} shm_msg_t;
+} shm_packet_t;
 
 
 
@@ -56,58 +34,54 @@
 	// 鏈湴key
 	int key;
 	bool force_bind;
-	int mutex;
-	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;
+	pthread_mutex_t mutex;
+
+	LockFreeQueue<shm_packet_t> *queue;  //self queue
+	LockFreeQueue<shm_packet_t> *remoteQueue; // peer queue
+	std::map<std::string, shm_packet_t> recvbuf;
+	
 
 } shm_socket_t;
 
-
+typedef std::function<void(void *recvbuf, int recvsize, int key, void **sendbuf, int *sendsize, void *user_data)> recvandsend_callback_fn;
 
 size_t shm_socket_remove_keys(int keys[], size_t length);
+size_t shm_socket_remove_keys_exclude(int keys[], size_t length);
 
 shm_socket_t *shm_open_socket(shm_socket_type_t socket_type);
 
 
 int shm_close_socket(shm_socket_t * socket) ;
 
+int shm_socket_stop(shm_socket_t *sockt);
+
 
 int shm_socket_bind(shm_socket_t * socket, int key) ;
 
 int shm_socket_force_bind(shm_socket_t * socket, int key) ;
-
-
-int shm_listen(shm_socket_t * socket) ;
-
-shm_socket_t* shm_accept(shm_socket_t* socket);
-
-int shm_connect(shm_socket_t * socket, int key);
-
-int shm_send(shm_socket_t * socket, const void *buf, const int size) ;
-
-
-int shm_recv(shm_socket_t * socket, void **buf, int *size) ;
-
+ 
 /**
- * @flags : SHM_MSG_NOWAIT
+ * @flags : BUS_NOWAIT_FLAG
  */
 int shm_sendto(shm_socket_t *socket, const void *buf, const int size, const int key, const struct timespec * timeout = NULL, const int flags=0);
 
-int shm_recvfrom(shm_socket_t *socket, void **buf, int *size, int *key,   struct timespec * timeout = NULL,  int flags=0);
+int shm_recvfrom(shm_socket_t *socket, void **buf, int *size, int *key,  const struct timespec * timeout = NULL,  int flags=0);
 
 int shm_sendandrecv(shm_socket_t *socket, const void *send_buf, const int send_size, const int send_key, void **recv_buf, int *recv_size,  
-	struct timespec * timeout = NULL,  int flags=0);
+	const struct timespec * timeout = NULL,  int flags = 0);
 
 /**
- * 鍔熻兘鍚宻hm_sendandrecv, 浣嗘槸涓嶆槸绾跨▼瀹夊叏鐨�
+ * @callback  void (*recvandsend_callback_fn)(void *recvbuf, int recvsize, int key, void **sendbuf, int *sendsize, void * user_data)
+ *                  @recvbuf 鏀跺埌鐨勬暟鎹�
+ *                  @recvsize 鏀跺埌鐨勬暟鎹殑澶у皬
+ *                  @key 鎺ュ彈鏁版嵁骞跺苟鍙戦�佹暟鎹殑瀵硅薄
+ *                  @sendbuf 瀛樺偍杩斿洖鍊肩殑鍦板潃锛岃〃绀鸿繑鍥炵殑鏁版嵁
+ *                  @sendsize 瀛樺偍杩斿洖鍊肩殑鍦板潃锛� 杩斿洖鏁版嵁鐨勯暱搴�
+ *
  */
-int shm_sendandrecv_unsafe(shm_socket_t *socket, const void *send_buf, const int send_size, const int send_key, void **recv_buf, int *recv_size,  
-	struct timespec * timeout = NULL,  int flags=0);
+int shm_recvandsend(shm_socket_t *sockt,  recvandsend_callback_fn callback,
+                    const struct timespec *timeout = NULL, int flag = 0,  void * user_data = NULL);
+
 
 
 

--
Gitblit v1.8.0