summaryrefslogtreecommitdiff
path: root/src/lib/ipcp.c
diff options
context:
space:
mode:
authordimitri staessens <dimitri.staessens@intec.ugent.be>2016-08-10 12:55:23 +0200
committerdimitri staessens <dimitri.staessens@intec.ugent.be>2016-08-10 12:55:23 +0200
commite5cb8042c9f0c6374c4f14bf7ff3f4fe3cdcd155 (patch)
tree31c27f46ba0a5f4981aa7522b11d133e1288c26d /src/lib/ipcp.c
parent0ec8f7b6d977a9cc469445d4990d432253f979d9 (diff)
parent155fbfb32b9a69705a06a5771bd146c1bed22821 (diff)
downloadouroboros-e5cb8042c9f0c6374c4f14bf7ff3f4fe3cdcd155.tar.gz
ouroboros-e5cb8042c9f0c6374c4f14bf7ff3f4fe3cdcd155.zip
Merged in sandervrijders/ouroboros/be-create-ipcp (pull request #200)
ipcp, irmd, lib: Notify IRMd upon IPCP initialization
Diffstat (limited to 'src/lib/ipcp.c')
-rw-r--r--src/lib/ipcp.c25
1 files changed, 25 insertions, 0 deletions
diff --git a/src/lib/ipcp.c b/src/lib/ipcp.c
index 141db43d..9ff05e7b 100644
--- a/src/lib/ipcp.c
+++ b/src/lib/ipcp.c
@@ -168,6 +168,31 @@ pid_t ipcp_create(enum ipcp_type ipcp_type)
exit(EXIT_FAILURE);
}
+int ipcp_create_r(pid_t api)
+{
+ irm_msg_t msg = IRM_MSG__INIT;
+ irm_msg_t * recv_msg = NULL;
+ int ret = -1;
+
+ msg.code = IRM_MSG_CODE__IPCP_CREATE_R;
+ msg.has_api = true;
+ msg.api = api;
+
+ recv_msg = send_recv_irm_msg(&msg);
+ if (recv_msg == NULL)
+ return -1;
+
+ if (recv_msg->has_result == false) {
+ irm_msg__free_unpacked(recv_msg, NULL);
+ return -1;
+ }
+
+ ret = recv_msg->result;
+ irm_msg__free_unpacked(recv_msg, NULL);
+
+ return ret;
+}
+
int ipcp_destroy(pid_t api)
{
int status;