source: mainline/uspace/lib/net/tl/tl_skel.c@ 0eff68e

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

new async framework with integrated exchange tracking

  • strict isolation between low-level IPC and high-level async framework with integrated exchange tracking
    • each IPC connection is represented by an async_sess_t structure
    • each IPC exchange is represented by an async_exch_t structure
    • exchange management is either based on atomic messages (EXCHANGE_ATOMIC), locking (EXCHANGE_SERIALIZE) or connection cloning (EXCHANGE_CLONE)
  • async_obsolete: temporary compatibility layer to keep old async clients working (several pieces of code are currently broken, but only non-essential functionality)
  • IPC_M_PHONE_HANGUP is now method no. 0 (for elegant boolean evaluation)
  • IPC_M_DEBUG_ALL has been renamed to IPC_M_DEBUG
  • IPC_M_PING has been removed (VFS protocol now has VFS_IN_PING)
  • console routines in libc have been rewritten for better abstraction
  • additional use for libc-private header files (FILE structure opaque to the client)
  • various cstyle changes (typos, indentation, missing externs in header files, improved comments, etc.)
  • Property mode set to 100644
File size: 3.6 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 * Transport layer module skeleton implementation.
35 * @see tl_skel.h
36 */
37
38#include <bool.h>
39#include <errno.h>
40#include <tl_skel.h>
41#include <net_interface.h>
42#include <net/modules.h>
43
44// FIXME: remove this header
45#include <kernel/ipc/ipc_methods.h>
46
47/** Default thread for new connections.
48 *
49 * @param[in] iid The initial message identifier.
50 * @param[in] icall The initial message call structure.
51 *
52 */
53static void tl_client_connection(ipc_callid_t iid, ipc_call_t *icall)
54{
55 /*
56 * Accept the connection by answering
57 * the initial IPC_M_CONNECT_ME_TO call.
58 */
59 async_answer_0(iid, EOK);
60
61 /* Per-connection initialization */
62 tl_connection();
63
64 while (true) {
65 ipc_call_t answer;
66 size_t count;
67
68 /* Clear the answer structure */
69 refresh_answer(&answer, &count);
70
71 /* Fetch the next message */
72 ipc_call_t call;
73 ipc_callid_t callid = async_get_call(&call);
74
75 /* Process the message */
76 int res = tl_message(callid, &call, &answer, &count);
77
78 /*
79 * End if told to either by the message or the processing
80 * result.
81 */
82 if ((!IPC_GET_IMETHOD(call)) || (res == EHANGUP))
83 return;
84
85 /* Answer the message */
86 answer_call(callid, res, &answer, count);
87 }
88}
89
90/** Start the trasport layer module.
91 *
92 * Initialize the client connection serving function, initialize
93 * the module, register the module service and start the async
94 * manager, processing IPC messages in an infinite loop.
95 *
96 * @param[in] service Service identification.
97 *
98 * @return EOK on success.
99 * @return Other error codes as defined for the pm_init() function.
100 * @return Other error codes as defined for the il_initialize()
101 * function.
102 * @return Other error codes as defined for the REGISTER_ME() macro
103 * function.
104 *
105 */
106int tl_module_start(int service)
107{
108 async_set_client_connection(tl_client_connection);
109 int net_phone = net_connect_module();
110 if (net_phone < 0)
111 return net_phone;
112
113 int rc = pm_init();
114 if (rc != EOK)
115 return rc;
116
117 rc = tl_initialize(net_phone);
118 if (rc != EOK)
119 goto out;
120
121 rc = async_connect_to_me(PHONE_NS, service, 0, 0, NULL);
122 if (rc != EOK)
123 goto out;
124
125 async_manager();
126
127out:
128 pm_destroy();
129 return rc;
130}
131
132/** @}
133 */
Note: See TracBrowser for help on using the repository browser.