diff options
author | dimitri staessens <dimitri.staessens@intec.ugent.be> | 2016-08-10 12:55:23 +0200 |
---|---|---|
committer | dimitri staessens <dimitri.staessens@intec.ugent.be> | 2016-08-10 12:55:23 +0200 |
commit | e5cb8042c9f0c6374c4f14bf7ff3f4fe3cdcd155 (patch) | |
tree | 31c27f46ba0a5f4981aa7522b11d133e1288c26d /src/lib/ipcp.c | |
parent | 0ec8f7b6d977a9cc469445d4990d432253f979d9 (diff) | |
parent | 155fbfb32b9a69705a06a5771bd146c1bed22821 (diff) | |
download | ouroboros-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.c | 25 |
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; |