forked from alliedtelesis/apteryx
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathrpc_transport.h
106 lines (89 loc) · 2.74 KB
/
rpc_transport.h
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
93
94
95
96
97
98
99
100
101
102
103
104
105
106
#ifndef _RPC_TRANSPORT_H_
#define _RPC_TRANSPORT_H_
#include <pthread.h>
#include <glib.h>
#include <stdbool.h>
#include <stdio.h>
#include <stdlib.h>
#include <sys/socket.h>
#include <sys/un.h>
#include <string.h>
#include <netinet/in.h>
#include <arpa/inet.h>
typedef uint32_t rpc_id;
typedef struct rpc_socket_s *rpc_socket;
typedef struct rpc_server_s *rpc_server;
typedef struct rpc_service_s *rpc_service;
typedef void (*rpc_callback) (rpc_socket, rpc_id, void *data, size_t len);
typedef struct socket_info_s *socket_info;
struct rpc_socket_s {
pthread_mutex_t lock;
int refcount;
int sock;
void *priv;
rpc_server parent;
pthread_mutex_t out_lock;
rpc_id next_id;
pthread_t thread;
rpc_callback request_cb;
pthread_mutex_t in_lock;
pthread_cond_t in_cond;
GList *in_queue;
int waiting;
bool dead;
uint64_t pid;
uint64_t ns;
};
struct rpc_server_s {
int sock;
rpc_service parent;
pthread_t thread;
pthread_mutex_t lock;
char *url;
char *guid;
socket_info sockinfo;
GList *clients;
rpc_callback request_cb;
};
struct rpc_service_s {
pthread_mutex_t lock;
GList *servers;
rpc_callback request_cb;
void *priv;
};
struct socket_info_s {
int family;
socklen_t address_len;
union
{
struct sockaddr_in addr_in;
struct sockaddr_in6 addr_in6;
struct sockaddr_un addr_un;
} address;
};
struct __attribute__ ((__packed__)) rpc_hdr_s {
uint32_t id;
uint32_t len;
uint32_t mode;
};
#define RPC_SOCKET_HDR_SIZE sizeof (struct rpc_hdr_s)
rpc_service rpc_service_init (rpc_callback request_callback, void *priv);
void *rpc_service_priv_get (rpc_service s);
bool rpc_service_run (rpc_service s, int stopfd);
rpc_server rpc_service_find_server (rpc_service s, const char *url);
bool rpc_service_die (rpc_service s);
bool rpc_service_bind_url (rpc_service s, const char *guid, const char *url);
bool rpc_service_unbind_url (rpc_service s, const char *guid);
rpc_service rpc_server_parent_get (rpc_server s);
rpc_socket rpc_socket_connect_service (const char *url, rpc_callback request_callback);
size_t rpc_socket_hdr_size (void);
rpc_socket rpc_socket_create (int fd, rpc_callback cb, rpc_server parent, int pid, uint64_t ns);
bool rpc_socket_process (rpc_socket sock);
void rpc_socket_ref (rpc_socket sock);
void rpc_socket_deref (rpc_socket sock);
void *rpc_socket_priv_get (rpc_socket s);
rpc_server rpc_socket_parent_get (rpc_socket s);
rpc_id rpc_socket_send_request (rpc_socket sock, void *data, size_t len);
bool rpc_socket_send_response (rpc_socket sock, rpc_id id, void *data, size_t len);
bool rpc_socket_recv (rpc_socket sock, rpc_id id, void **data, size_t *len, uint64_t waitUS);
#endif /* _RPC_TRANSPORT_H_ */