fujuntang
2021-11-10 c479ef57baaaa28964fc3ec8d80ff99dffa7d49f
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
#ifndef __SHM_SOCKET_H__
#define __SHM_SOCKET_H__
 
#include "usg_common.h"
#include "usg_typedef.h"
#include "shm_queue.h"
#include "proc_def.h"
#include "lock_free_queue.h"
#include <functional>
 
enum shm_socket_type_t
{
    SHM_SOCKET_STREAM = 1,
    SHM_SOCKET_DGRAM = 2
    
};
 
 
#define BUS_ACTION_STOP 1 
 
typedef struct shm_packet_t {
  int key;
 
    size_t size;
    void * buf;
    char uuid[1];
    int action;
 
} shm_packet_t;
 
 
 
 
typedef struct shm_socket_t {
    shm_socket_type_t socket_type;
    int key;
    bool force_bind;
    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; // for uuid
    std::map<int, shm_packet_t> recvbuf2; //for thread local
 
} 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_socket_open(shm_socket_type_t socket_type);
 
 
int shm_socket_close(shm_socket_t * sockt) ;
 
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) ;
 
/**
 * @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 reset = 0, int data_set = 0);
 
int shm_recvfrom(shm_socket_t *socket, void **buf, int *size, int *key,  const struct timespec * timeout = NULL,  int flags=0, int reset = 0, int data_set = 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,  
    const struct timespec * timeout = NULL,  int flags = 0);
 
typedef std::set<int,  std::less<int>, SHM_STL_Allocator<int> > SvrProc;
typedef std::map<SHMString, SvrProc *, std::less<SHMString>, SHM_STL_Allocator<std::pair<const SHMString, SvrProc *> > > SvrTcs;
typedef std::map<int, SHMString, std::less<int>, SHM_STL_Allocator<std::pair<int, const SHMString> > > ProcPartZone;
/**
 * @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_recvandsend(shm_socket_t *sockt,  recvandsend_callback_fn callback,
                    const struct timespec *timeout = NULL, int flag = 0,  void * user_data = NULL);
 
 
void proc_copy(char *dst, void *src, int *count);
 
#endif