source: mainline/uspace/lib/c/generic/ns.c@ 0dd16778

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

start migrating devman to interfaces

  • Property mode set to 100644
File size: 6.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 libc
30 * @{
31 */
32/** @file
33 */
34
35#include <ns.h>
36#include <ipc/ns.h>
37#include <async.h>
38#include <macros.h>
39#include <errno.h>
40#include "private/ns.h"
41
42int service_register(service_t service)
43{
44 async_exch_t *exch = async_exchange_begin(session_ns);
45 int rc = async_connect_to_me(exch, 0, service, 0, NULL, NULL);
46 async_exchange_end(exch);
47
48 return rc;
49}
50
51async_sess_t *service_connect_iface(exch_mgmt_t mgmt, sysarg_t iface,
52 service_t service, sysarg_t arg3)
53{
54 async_exch_t *exch = async_exchange_begin(session_ns);
55 if (!exch)
56 return NULL;
57
58 async_sess_t *sess =
59 async_connect_me_to(mgmt, exch, iface, service, arg3);
60 async_exchange_end(exch);
61
62 if (!sess)
63 return NULL;
64
65 /*
66 * FIXME Ugly hack to work around limitation of implementing
67 * parallel exchanges using multiple connections. Shift out
68 * first argument for non-initial connections.
69 */
70 async_sess_args_set(sess, iface, arg3, 0);
71
72 return sess;
73}
74
75async_sess_t *service_connect_iface_extended(service_t service, iface_t iface,
76 sysarg_t arg3)
77{
78 async_exch_t *exch = async_exchange_begin(session_ns);
79 if (!exch)
80 return NULL;
81
82 async_sess_t *sess =
83 async_connect_me_to_iface(exch, iface, service, arg3);
84 async_exchange_end(exch);
85
86 if (!sess)
87 return NULL;
88
89 /*
90 * FIXME Ugly hack to work around limitation of implementing
91 * parallel exchanges using multiple connections. Shift out
92 * first argument for non-initial connections.
93 */
94 async_sess_args_set(sess, iface, arg3, 0);
95
96 return sess;
97}
98
99async_sess_t *service_connect(exch_mgmt_t mgmt, service_t service, sysarg_t arg3)
100{
101 async_exch_t *exch = async_exchange_begin(session_ns);
102 if (!exch)
103 return NULL;
104
105 async_sess_t *sess =
106 async_connect_me_to(mgmt, exch, 0, service, arg3);
107 async_exchange_end(exch);
108
109 if (!sess)
110 return NULL;
111
112 /*
113 * FIXME Ugly hack to work around limitation of implementing
114 * parallel exchanges using multiple connections. Shift out
115 * first argument for non-initial connections.
116 */
117 async_sess_args_set(sess, 0, arg3, 0);
118
119 return sess;
120}
121
122async_sess_t *service_connect_blocking_iface(exch_mgmt_t mgmt, sysarg_t iface,
123 service_t service, sysarg_t arg3)
124{
125 async_exch_t *exch = async_exchange_begin(session_ns);
126 if (!exch)
127 return NULL;
128 async_sess_t *sess =
129 async_connect_me_to_blocking(mgmt, exch, iface, service, arg3);
130 async_exchange_end(exch);
131
132 if (!sess)
133 return NULL;
134
135 /*
136 * FIXME Ugly hack to work around limitation of implementing
137 * parallel exchanges using multiple connections. Shift out
138 * first argument for non-initial connections.
139 */
140 async_sess_args_set(sess, iface, arg3, 0);
141
142 return sess;
143}
144
145async_sess_t *service_connect_blocking_iface_extended(service_t service,
146 iface_t iface, sysarg_t arg3)
147{
148 async_exch_t *exch = async_exchange_begin(session_ns);
149 async_sess_t *sess =
150 async_connect_me_to_blocking_iface(exch, iface, service, arg3);
151 async_exchange_end(exch);
152
153 if (!sess)
154 return NULL;
155
156 /*
157 * FIXME Ugly hack to work around limitation of implementing
158 * parallel exchanges using multiple connections. Shift out
159 * first argument for non-initial connections.
160 */
161 async_sess_args_set(sess, iface, arg3, 0);
162
163 return sess;
164}
165
166async_sess_t *service_connect_blocking(exch_mgmt_t mgmt, service_t service,
167 sysarg_t arg3)
168{
169 async_exch_t *exch = async_exchange_begin(session_ns);
170 async_sess_t *sess =
171 async_connect_me_to_blocking(mgmt, exch, 0, service, arg3);
172 async_exchange_end(exch);
173
174 if (!sess)
175 return NULL;
176
177 /*
178 * FIXME Ugly hack to work around limitation of implementing
179 * parallel exchanges using multiple connections. Shift out
180 * first argument for non-initial connections.
181 */
182 async_sess_args_set(sess, 0, arg3, 0);
183
184 return sess;
185}
186
187/** Create bidirectional connection with a service
188 *
189 * @param[in] service Service.
190 * @param[in] arg1 First parameter.
191 * @param[in] arg2 Second parameter.
192 * @param[in] arg3 Third parameter.
193 * @param[in] client_receiver Message receiver.
194 *
195 * @return Session to the service.
196 * @return Other error codes as defined by async_connect_to_me().
197 *
198 */
199async_sess_t *service_bind(service_t service, sysarg_t arg1, sysarg_t arg2,
200 sysarg_t arg3, async_port_handler_t client_receiver)
201{
202 /* Connect to the needed service */
203 async_sess_t *sess =
204 service_connect_blocking(EXCHANGE_SERIALIZE, service, 0);
205 if (sess != NULL) {
206 /* Request callback connection */
207 async_exch_t *exch = async_exchange_begin(sess);
208 int rc = async_connect_to_me(exch, arg1, arg2, arg3,
209 client_receiver, NULL);
210 async_exchange_end(exch);
211
212 if (rc != EOK) {
213 async_hangup(sess);
214 errno = rc;
215 return NULL;
216 }
217 }
218
219 return sess;
220}
221
222int ns_ping(void)
223{
224 async_exch_t *exch = async_exchange_begin(session_ns);
225 int rc = async_req_0_0(exch, NS_PING);
226 async_exchange_end(exch);
227
228 return rc;
229}
230
231int ns_intro(task_id_t id)
232{
233 async_exch_t *exch = async_exchange_begin(session_ns);
234 int rc = async_req_2_0(exch, NS_ID_INTRO, LOWER32(id), UPPER32(id));
235 async_exchange_end(exch);
236
237 return rc;
238}
239
240/** @}
241 */
Note: See TracBrowser for help on using the repository browser.