source: mainline/uspace/lib/c/generic/dnsr.c@ 3061bc1

lfn serial ticket/834-toolchain-update topic/msim-upgrade topic/simplify-dev-export
Last change on this file since 3061bc1 was b7fd2a0, checked in by Jiří Zárevúcky <zarevucky.jiri@…>, 7 years ago

Use errno_t in all uspace and kernel code.

Change type of every variable, parameter and return value that holds an
<errno.h> constant to either errno_t (the usual case), or sys_errno_t
(some places in kernel). This is for the purpose of self-documentation,
as well as for type-checking with a bit of type definition hackery.

Although this is a massive commit, it is a simple text replacement, and thus
is very easy to verify. Simply do the following:

`
git checkout <this commit's hash>
git reset HEAD
git add .
tools/srepl '\berrno_t\b' int
git add .
tools/srepl '\bsys_errno_t\b' sysarg_t
git reset
git diff
`

While this doesn't ensure that the replacements are correct, it does ensure
that the commit doesn't do anything except those replacements. Since errno_t
is typedef'd to int in the usual case (and sys_errno_t to sysarg_t), even if
incorrect, this commit cannot change behavior.

  • Property mode set to 100644
File size: 4.6 KB
Line 
1/*
2 * Copyright (c) 2013 Jiri Svoboda
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#include <async.h>
30#include <assert.h>
31#include <errno.h>
32#include <fibril_synch.h>
33#include <inet/dnsr.h>
34#include <ipc/dnsr.h>
35#include <ipc/services.h>
36#include <loc.h>
37#include <stdlib.h>
38#include <str.h>
39
40static FIBRIL_MUTEX_INITIALIZE(dnsr_sess_mutex);
41
42static async_sess_t *dnsr_sess = NULL;
43
44static async_exch_t *dnsr_exchange_begin(void)
45{
46 fibril_mutex_lock(&dnsr_sess_mutex);
47
48 if (dnsr_sess == NULL) {
49 service_id_t dnsr_svc;
50
51 (void) loc_service_get_id(SERVICE_NAME_DNSR, &dnsr_svc,
52 IPC_FLAG_BLOCKING);
53
54 dnsr_sess = loc_service_connect(dnsr_svc, INTERFACE_DNSR,
55 IPC_FLAG_BLOCKING);
56 }
57
58 async_sess_t *sess = dnsr_sess;
59 fibril_mutex_unlock(&dnsr_sess_mutex);
60
61 return async_exchange_begin(sess);
62}
63
64static void dnsr_exchange_end(async_exch_t *exch)
65{
66 async_exchange_end(exch);
67}
68
69errno_t dnsr_name2host(const char *name, dnsr_hostinfo_t **rinfo, ip_ver_t ver)
70{
71 async_exch_t *exch = dnsr_exchange_begin();
72
73 ipc_call_t answer;
74 aid_t req = async_send_1(exch, DNSR_NAME2HOST, (sysarg_t) ver,
75 &answer);
76
77 errno_t rc = async_data_write_start(exch, name, str_size(name));
78 if (rc != EOK) {
79 async_exchange_end(exch);
80 async_forget(req);
81 return rc;
82 }
83
84 dnsr_hostinfo_t *info = calloc(1, sizeof(dnsr_hostinfo_t));
85 if (info == NULL)
86 return ENOMEM;
87
88 ipc_call_t answer_addr;
89 aid_t req_addr = async_data_read(exch, &info->addr,
90 sizeof(inet_addr_t), &answer_addr);
91
92 errno_t retval_addr;
93 async_wait_for(req_addr, &retval_addr);
94
95 if (retval_addr != EOK) {
96 async_exchange_end(exch);
97 async_forget(req);
98 free(info);
99 return retval_addr;
100 }
101
102 ipc_call_t answer_cname;
103 char cname_buf[DNSR_NAME_MAX_SIZE + 1];
104 aid_t req_cname = async_data_read(exch, cname_buf, DNSR_NAME_MAX_SIZE,
105 &answer_cname);
106
107 dnsr_exchange_end(exch);
108
109 errno_t retval_cname;
110 async_wait_for(req_cname, &retval_cname);
111
112 if (retval_cname != EOK) {
113 async_forget(req);
114 free(info);
115 return retval_cname;
116 }
117
118 errno_t retval;
119 async_wait_for(req, &retval);
120
121 if (retval != EOK) {
122 async_forget(req);
123 free(info);
124 return retval;
125 }
126
127 size_t act_size = IPC_GET_ARG2(answer_cname);
128 assert(act_size <= DNSR_NAME_MAX_SIZE);
129
130 cname_buf[act_size] = '\0';
131
132 info->cname = str_dup(cname_buf);
133
134 if (info->cname == NULL) {
135 free(info);
136 return ENOMEM;
137 }
138
139 *rinfo = info;
140 return EOK;
141}
142
143void dnsr_hostinfo_destroy(dnsr_hostinfo_t *info)
144{
145 if (info == NULL)
146 return;
147
148 free(info->cname);
149 free(info);
150}
151
152errno_t dnsr_get_srvaddr(inet_addr_t *srvaddr)
153{
154 async_exch_t *exch = dnsr_exchange_begin();
155
156 ipc_call_t answer;
157 aid_t req = async_send_0(exch, DNSR_GET_SRVADDR, &answer);
158 errno_t rc = async_data_read_start(exch, srvaddr, sizeof(inet_addr_t));
159
160 loc_exchange_end(exch);
161
162 if (rc != EOK) {
163 async_forget(req);
164 return rc;
165 }
166
167 errno_t retval;
168 async_wait_for(req, &retval);
169
170 return retval;
171}
172
173errno_t dnsr_set_srvaddr(inet_addr_t *srvaddr)
174{
175 async_exch_t *exch = dnsr_exchange_begin();
176
177 ipc_call_t answer;
178 aid_t req = async_send_0(exch, DNSR_SET_SRVADDR, &answer);
179 errno_t rc = async_data_write_start(exch, srvaddr, sizeof(inet_addr_t));
180
181 loc_exchange_end(exch);
182
183 if (rc != EOK) {
184 async_forget(req);
185 return rc;
186 }
187
188 errno_t retval;
189 async_wait_for(req, &retval);
190
191 return retval;
192}
193
194/** @}
195 */
Note: See TracBrowser for help on using the repository browser.