source: mainline/uspace/lib/net/nil/nil_skel.c@ 6b82009

lfn serial ticket/834-toolchain-update topic/msim-upgrade topic/simplify-dev-export
Last change on this file since 6b82009 was 6b82009, checked in by Martin Decky <martin@…>, 14 years ago

networking stack: convert to the new async framework

  • Property mode set to 100644
File size: 3.4 KB
Line 
1/*
2 * Copyright (c) 2011 Martin Decky
3 * All rights reserved.
4 *
5 * Redistribution and use in source and binary forms, with or without
6 * modification, are permitted provided that the following conditions
7 * are met:
8 *
9 * - Redistributions of source code must retain the above copyright
10 * notice, this list of conditions and the following disclaimer.
11 * - Redistributions in binary form must reproduce the above copyright
12 * notice, this list of conditions and the following disclaimer in the
13 * documentation and/or other materials provided with the distribution.
14 * - The name of the author may not be used to endorse or promote products
15 * derived from this software without specific prior written permission.
16 *
17 * THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR
18 * IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
19 * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED.
20 * IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT,
21 * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT
22 * NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
23 * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
24 * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
25 * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF
26 * THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
27 */
28
29/** @addtogroup libnet
30 * @{
31 */
32
33/** @file
34 * Network interface layer module skeleton implementation.
35 * @see nil_skel.h
36 */
37
38#include <bool.h>
39#include <errno.h>
40#include <ns.h>
41#include <nil_skel.h>
42#include <net_interface.h>
43#include <net/modules.h>
44
45/** Default thread for new connections.
46 *
47 * @param[in] iid The initial message identifier.
48 * @param[in] icall The initial message call structure.
49 *
50 */
51static void nil_client_connection(ipc_callid_t iid, ipc_call_t *icall,
52 void *arg)
53{
54 /*
55 * Accept the connection by answering
56 * the initial IPC_M_CONNECT_ME_TO call.
57 */
58 async_answer_0(iid, EOK);
59
60 while (true) {
61 ipc_call_t answer;
62 size_t count;
63
64 /* Clear the answer structure */
65 refresh_answer(&answer, &count);
66
67 /* Fetch the next message */
68 ipc_call_t call;
69 ipc_callid_t callid = async_get_call(&call);
70
71 /* Process the message */
72 int res = nil_module_message(callid, &call, &answer,
73 &count);
74
75 /*
76 * End if told to either by the message or the processing
77 * result.
78 */
79 if ((!IPC_GET_IMETHOD(call)) || (res == EHANGUP))
80 return;
81
82 /* Answer the message */
83 answer_call(callid, res, &answer, count);
84 }
85}
86
87/** Start the network interface layer module.
88 *
89 * Initialize the client connection serving function, initialize
90 * the module, register the module service and start the async
91 * manager, processing IPC messages in an infinite loop.
92 *
93 * @param[in] service Service identification.
94 *
95 * @return EOK on success.
96 * @return Other error codes as defined for the pm_init() function.
97 * @return Other error codes as defined for the nil_initialize()
98 * function.
99 *
100 */
101int nil_module_start(sysarg_t service)
102{
103 async_set_client_connection(nil_client_connection);
104 async_sess_t *sess = net_connect_module();
105 if (!sess)
106 return ENOENT;
107
108 int rc = pm_init();
109 if (rc != EOK)
110 return rc;
111
112 rc = nil_initialize(sess);
113 if (rc != EOK)
114 goto out;
115
116 rc = service_register(service);
117 if (rc != EOK)
118 goto out;
119
120 async_manager();
121
122out:
123 pm_destroy();
124 return rc;
125}
126
127/** @}
128 */
Note: See TracBrowser for help on using the repository browser.