fix single threaded peer (aka posix peer) skeleton
[archipelago] / xseg / peers / user / speer.h
1 #include <stddef.h>
2 #include <xseg/xseg.h>
3 /* main mpeer structs */
4 struct peer_req {
5         struct peerd *peer;
6         struct xseg_request *req;
7         ssize_t retval;
8         xport portno;
9         void *priv;
10 };
11
12 struct peerd {
13         struct xseg *xseg;
14         xport portno_start;
15         xport portno_end;
16         long nr_ops;
17         uint32_t defer_portno;
18         struct peer_req *peer_reqs;
19         struct xq free_reqs;
20         void *priv;
21 };
22
23 void fail(struct peerd *peer, struct peer_req *pr);
24 void complete(struct peerd *peer, struct peer_req *pr);
25 void defer_request(struct peerd *peer, struct peer_req *pr);
26 void pending(struct peerd *peer, struct peer_req *req);
27 void log_pr(char *msg, struct peer_req *pr);
28 int canDefer(struct peerd *peer);
29 int submit_peer_req(struct peerd *peer, struct peer_req *pr);
30 struct peer_req *alloc_peer_req(struct peerd *peer);
31 void free_peer_req(struct peerd *peer, struct peer_req *pr);
32 void get_submits_stats();
33 void get_responds_stats();
34
35 static inline struct peerd * __get_peerd(void * custom_peerd)
36 {
37         return (struct peerd *) ((unsigned long) custom_peerd  - offsetof(struct peerd, priv));
38 }
39
40 /********************************
41  *   mandatory peer functions   *
42  ********************************/
43
44 /* peer main function */
45 int custom_peer_init(struct peerd *peer, int argc, char *argv[]);
46
47 /* dispatch function that cannot block
48  * defers blocking calls to helper threads
49  */
50 int dispatch(struct peerd *peer, struct peer_req *pr, struct xseg_request *xseg);
51
52 void usage();