X-Git-Url: https://git.lttng.org/?a=blobdiff_plain;f=libustcomm%2Fustcomm.h;h=a8fd6408aa68540fc109dbdeec8e5dc17b4003fc;hb=17bb07b445acdef0034194bdcebe113988a8db60;hp=17bd9c10b084b64b46dfa3ddb513255c5bf83c73;hpb=c39c72ee5890c7727ae2697f321ba1b3d6c862f5;p=ust.git diff --git a/libustcomm/ustcomm.h b/libustcomm/ustcomm.h index 17bd9c1..a8fd640 100644 --- a/libustcomm/ustcomm.h +++ b/libustcomm/ustcomm.h @@ -20,12 +20,21 @@ #include #include +#include -#include "kcompat.h" +#include +#include "multipoll.h" + +#define SOCK_DIR "/tmp/ust-app-socks" +#define UST_SIGNAL SIGIO struct ustcomm_connection { struct list_head list; int fd; + /* Data that has not yet been consumed: */ + char *recv_buf; + int recv_buf_size; + int recv_buf_alloc; }; /* ustcomm_server must be shallow-copyable */ @@ -51,24 +60,36 @@ struct ustcomm_source { void *priv; }; -char *strdup_malloc(const char *s); +struct ustcomm_multipoll_conn_info { + struct ustcomm_connection *conn; + int (*cb)(char *msg, struct ustcomm_source *src); +}; //int send_message_pid(pid_t pid, const char *msg, char **reply); -int ustcomm_request_consumer(pid_t pid, const char *channel); +extern int ustcomm_request_consumer(pid_t pid, const char *channel); + +extern int ustcomm_ustd_recv_message(struct ustcomm_ustd *ustd, char **msg, struct ustcomm_source *src, int timeout); +extern int ustcomm_app_recv_message(struct ustcomm_app *app, char **msg, struct ustcomm_source *src, int timeout); -int ustcomm_ustd_recv_message(struct ustcomm_ustd *ustd, char **msg, struct ustcomm_source *src, int timeout); -int ustcomm_app_recv_message(struct ustcomm_app *app, char **msg, struct ustcomm_source *src, int timeout); +extern int ustcomm_init_app(pid_t pid, struct ustcomm_app *handle); +extern void ustcomm_fini_app(struct ustcomm_app *handle, int keep_socket_file); +extern void ustcomm_fini_ustd(struct ustcomm_ustd *handle); -int ustcomm_init_app(pid_t pid, struct ustcomm_app *handle); +extern int ustcomm_init_ustd(struct ustcomm_ustd *handle, const char *sock_path); -int ustcomm_init_ustd(struct ustcomm_ustd *handle); +extern int ustcomm_connect_app(pid_t pid, struct ustcomm_connection *conn); +extern int ustcomm_close_app(struct ustcomm_connection *conn); +extern int ustcomm_connect_path(const char *path, struct ustcomm_connection *conn, pid_t signalpid); +extern int ustcomm_send_request(struct ustcomm_connection *conn, const char *req, char **reply); +extern int ustcomm_send_reply(struct ustcomm_server *server, char *msg, struct ustcomm_source *src); +extern int ustcomm_disconnect(struct ustcomm_connection *conn); +extern int ustcomm_close_all_connections(struct ustcomm_server *server); +extern void ustcomm_mp_add_app_clients(struct mpentries *ent, struct ustcomm_app *app, int (*cb)(struct ustcomm_connection *conn, char *msg)); -int ustcomm_connect_app(pid_t pid, struct ustcomm_connection *conn); -int ustcomm_send_request(struct ustcomm_connection *conn, char *req, char **reply); -int ustcomm_send_reply(struct ustcomm_server *server, char *msg, struct ustcomm_source *src); +extern int nth_token_is(const char *str, const char *token, int tok_no); -int nth_token_is(char *str, char *token, int tok_no); +extern char *nth_token(const char *str, int tok_no); -char *nth_token(char *str, int tok_no); +extern int pid_is_online(pid_t); #endif /* USTCOMM_H */